/* ============================================================
   The Equestrian Editorial — Design Tokens
   ============================================================ */
:root {
  --ete-primary: #00113a;
  --ete-primary-container: #002366;
  --ete-primary-fixed: #dbe1ff;
  --ete-primary-fixed-dim: #b3c5ff;
  --ete-on-primary: #ffffff;
  --ete-on-primary-container: #758dd5;

  --ete-secondary: #775a19;
  --ete-secondary-container: #fed488;
  --ete-secondary-fixed: #ffdea5;
  --ete-secondary-fixed-dim: #e9c176;
  --ete-on-secondary: #ffffff;
  --ete-on-secondary-container: #785a1a;

  --ete-tertiary: #011334;
  --ete-tertiary-container: #172849;
  --ete-on-tertiary: #ffffff;

  --ete-surface: #f8f9fa;
  --ete-surface-bright: #f8f9fa;
  --ete-surface-dim: #d9dadb;
  --ete-surface-container-lowest: #ffffff;
  --ete-surface-container-low: #f3f4f5;
  --ete-surface-container: #edeeef;
  --ete-surface-container-high: #e7e8e9;
  --ete-surface-container-highest: #e1e3e4;
  --ete-surface-variant: #e1e3e4;
  --ete-on-surface: #191c1d;
  --ete-on-surface-variant: #444650;
  --ete-outline: #757682;
  --ete-outline-variant: #c5c6d2;
  --ete-inverse-surface: #2e3132;

  --ete-error: #ba1a1a;
  --ete-error-container: #ffdad6;

  --ete-font-headline: "Newsreader", Georgia, "Times New Roman", serif;
  --ete-font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --ete-r-sm: 0.125rem;
  --ete-r-md: 0.375rem;
  --ete-r-lg: 0.75rem;
  --ete-r-xl: 1rem;

  --ete-wrap: min(72rem, 100% - 2rem);
  --ete-wrap-narrow: min(48rem, 100% - 2rem);
}

/* ============================================================
   Reset
   ============================================================ */
*,*::before,*::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--ete-font-body);
  font-size: 16px;
  line-height: 1.6;
  color: var(--ete-on-surface);
  background: var(--ete-surface);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img,svg,video { max-width: 100%; height: auto; display: block; }
a { color: var(--ete-primary); text-decoration: none; }
a:hover { color: var(--ete-primary-container); }
button { font-family: inherit; cursor: pointer; }
ul,ol { padding-left: 1.25rem; }

/* ============================================================
   Typography — Editorial Serif + Inter UI
   ============================================================ */
h1,h2,h3,h4,h5,h6 {
  font-family: var(--ete-font-headline);
  color: var(--ete-primary);
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1.15;
  margin: 0 0 0.6em;
}
h1 { font-size: clamp(2rem, 3.6vw + 1rem, 3.5rem); font-weight: 800; }
h2 { font-size: clamp(1.6rem, 2vw + 1rem, 2.25rem); }
h3 { font-size: clamp(1.25rem, 1vw + 1rem, 1.5rem); }
h4 { font-size: 1.125rem; }
p { margin: 0 0 1.1em; }
strong { font-weight: 600; color: var(--ete-primary); }

.ete-eyebrow {
  font-family: var(--ete-font-body);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ete-secondary);
}

.ete-italic-headline { font-style: italic; }

/* ============================================================
   Layout
   ============================================================ */
.ete-wrap { width: var(--ete-wrap); margin-inline: auto; }
.ete-wrap-narrow { width: var(--ete-wrap-narrow); margin-inline: auto; }

.ete-section { padding-block: clamp(2.5rem, 5vw, 4.5rem); }
.ete-section--alt { background: var(--ete-surface-container-low); }
.ete-section--primary { background: linear-gradient(135deg, var(--ete-primary) 0%, var(--ete-primary-container) 100%); color: var(--ete-on-primary); }
.ete-section--primary h1,.ete-section--primary h2,.ete-section--primary h3 { color: var(--ete-on-primary); }

/* ============================================================
   Header — Sticky Glassmorphism
   ============================================================ */
.ete-site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,0.82);
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
  box-shadow: 0 8px 30px rgba(0,35,102,0.05);
}
.ete-header-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding-block: 0.9rem;
}
.ete-brand { display: inline-flex; align-items: center; }
.ete-brand__logo {
  display: block;
  width: auto;
  height: 46px;
  max-width: 180px;
  object-fit: contain;
}
@media (max-width: 640px) {
  .ete-brand__logo { height: 38px; }
}

/* Primary Nav */
.ete-nav { display: flex; align-items: center; gap: 1.5rem; }
.ete-nav__list { display: none; gap: 1.4rem; list-style: none; margin: 0; padding: 0; }
.ete-nav__list > li { position: relative; }
.ete-nav__list a {
  font-size: 0.82rem; font-weight: 700; letter-spacing: 0.06em;
  color: var(--ete-primary); text-transform: uppercase;
  padding: 0.6rem 0; display: inline-block; line-height: 1;
  transition: color .15s;
}
.ete-nav__list > li > a:hover { color: var(--ete-secondary); }
.ete-nav__list > li.menu-item-has-children > a::after {
  content: "";
  display: inline-block; width: 0; height: 0; margin-left: 0.35rem;
  border-left: 4px solid transparent; border-right: 4px solid transparent;
  border-top: 5px solid currentColor; vertical-align: middle;
  transform: translateY(-1px); opacity: .7;
}
/* Desktop dropdown */
.ete-nav__list .sub-menu {
  display: none;
  position: absolute; top: 100%; left: -1rem; z-index: 60;
  min-width: 240px; margin: 0; padding: 0.5rem;
  list-style: none;
  background: var(--ete-surface-container-lowest);
  border-radius: var(--ete-r-md);
  box-shadow: 0 18px 40px rgba(0,17,58,.14), 0 4px 10px rgba(0,17,58,.06);
}
.ete-nav__list > li:hover > .sub-menu,
.ete-nav__list > li:focus-within > .sub-menu { display: block; }
.ete-nav__list .sub-menu li { list-style: none; }
.ete-nav__list .sub-menu a {
  display: block;
  padding: 0.6rem 0.8rem;
  font-size: 0.78rem; letter-spacing: 0.04em;
  color: var(--ete-primary); text-transform: none;
  font-weight: 600;
  border-radius: var(--ete-r-sm);
}
.ete-nav__list .sub-menu a:hover {
  background: var(--ete-surface-container-low);
  color: var(--ete-primary-container);
}
.ete-nav__toggle {
  background: none; border: 0; padding: 0.35rem;
  color: var(--ete-primary); display: grid; place-items: center;
}
@media (min-width: 840px) {
  .ete-nav__list { display: flex; }
  .ete-nav__toggle { display: none; }
}

/* Kill focus-outline hop-over on dropdown click targets */
.ete-nav__list > li.menu-item-has-children > a[href="#"] { cursor: default; }

/* Mobile drawer */
.ete-mobile-nav {
  display: none; position: fixed; inset: 64px 0 0; z-index: 40;
  background: var(--ete-surface-container-lowest);
  padding: 1.25rem; overflow-y: auto;
}
.ete-mobile-nav.is-open { display: block; }
.ete-mobile-nav ul { list-style: none; margin: 0; padding: 0; }
.ete-mobile-nav li a {
  display: block; padding: 0.9rem 0.5rem;
  font-family: var(--ete-font-headline); font-size: 1.25rem; font-weight: 700;
  color: var(--ete-primary);
  border-bottom: 1px solid var(--ete-outline-variant);
}

/* ============================================================
   Hero / Editorial Page Header
   ============================================================ */
.ete-page-hero {
  background: linear-gradient(135deg, var(--ete-primary) 0%, var(--ete-primary-container) 100%);
  color: var(--ete-on-primary);
  padding-block: clamp(3rem, 6vw, 5rem);
  position: relative; overflow: hidden;
}
.ete-page-hero::after {
  content: ""; position: absolute; right: -40px; bottom: -40px;
  width: 280px; height: 280px; border-radius: 50%;
  background: radial-gradient(circle, rgba(254,212,136,0.14) 0%, transparent 70%);
  pointer-events: none;
}
.ete-page-hero h1 { color: var(--ete-on-primary); margin-bottom: 0.3em; }
.ete-page-hero .ete-eyebrow { color: var(--ete-secondary-container); }
.ete-page-hero__meta { opacity: 0.85; font-size: 0.9rem; }

/* ============================================================
   Cards — No-Line Rule (Surface tiers for separation)
   ============================================================ */
.ete-card {
  background: var(--ete-surface-container-lowest);
  border-radius: var(--ete-r-md);
  padding: 1.25rem;
  box-shadow: 0 2px 12px rgba(0,17,58,0.04);
}
.ete-card--accent { border-left: 4px solid var(--ete-secondary); }
.ete-card--navy { border-left: 4px solid var(--ete-primary); }

/* Horizontal scroll rail */
.ete-rail {
  display: flex; gap: 0.9rem; overflow-x: auto;
  padding-bottom: 0.5rem; scroll-snap-type: x mandatory;
  -ms-overflow-style: none; scrollbar-width: none;
}
.ete-rail::-webkit-scrollbar { display: none; }
.ete-rail > * { scroll-snap-align: start; flex: 0 0 auto; }

/* ============================================================
   Buttons
   ============================================================ */
.ete-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 0.5rem; padding: 0.8rem 1.4rem;
  font-weight: 700; font-size: 0.78rem; letter-spacing: 0.15em;
  text-transform: uppercase; border-radius: var(--ete-r-md);
  border: 0; cursor: pointer; transition: transform .15s, box-shadow .15s;
}
.ete-btn--primary {
  background: linear-gradient(135deg, var(--ete-primary) 0%, var(--ete-primary-container) 100%);
  color: var(--ete-on-primary);
  box-shadow: 0 6px 18px rgba(0,35,102,0.2);
}
.ete-btn--primary:hover { transform: translateY(-1px); color: var(--ete-on-primary); }
.ete-btn--gold {
  background: var(--ete-secondary-container);
  color: var(--ete-on-secondary-container);
}
.ete-btn--gold:hover { background: var(--ete-secondary-fixed-dim); }
.ete-btn--ghost {
  background: transparent; color: var(--ete-primary);
  box-shadow: inset 0 0 0 1.5px var(--ete-outline-variant);
}
.ete-btn--ghost:hover { background: var(--ete-surface-container); }
.ete-btn--block { display: flex; width: 100%; }

/* ============================================================
   Grids
   ============================================================ */
.ete-grid { display: grid; gap: 1.25rem; }
.ete-grid--2 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.ete-grid--3 { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.ete-grid--news { grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 1.8rem; }

/* ============================================================
   News card (editorial)
   ============================================================ */
.ete-news { display: flex; gap: 1rem; }
.ete-news__thumb {
  flex: 0 0 112px; height: 112px;
  border-radius: var(--ete-r-md); overflow: hidden;
  background: var(--ete-surface-container-highest);
}
.ete-news__thumb img { width: 100%; height: 100%; object-fit: cover; }
.ete-news__body { display: flex; flex-direction: column; justify-content: center; }
.ete-news__cat {
  font-size: 0.65rem; font-weight: 700; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--ete-secondary); margin-bottom: 0.25rem;
}
.ete-news__title {
  font-family: var(--ete-font-headline); font-weight: 700; font-size: 1.05rem;
  line-height: 1.25; color: var(--ete-primary); margin: 0 0 0.3rem;
}
.ete-news__meta { font-size: 0.78rem; color: var(--ete-on-surface-variant); margin: 0; }

/* ============================================================
   Affiliate / Operator row
   ============================================================ */
.ete-op-row {
  display: flex; align-items: center; gap: 1rem; padding: 1rem;
  background: var(--ete-surface-container-lowest);
  border-radius: var(--ete-r-lg);
  box-shadow: 0 2px 10px rgba(0,17,58,0.05);
}
.ete-op-row__logo {
  width: 56px; height: 56px; border-radius: var(--ete-r-md);
  background: var(--ete-surface-container-highest);
  display: grid; place-items: center; font-weight: 900;
  color: var(--ete-primary); font-size: 1.25rem; flex: 0 0 56px;
}
.ete-op-row__body { flex-grow: 1; min-width: 0; }
.ete-op-row__stars { color: var(--ete-secondary-container); font-size: 0.95rem; }
.ete-op-row__bonus {
  font-size: 0.78rem; font-weight: 700; letter-spacing: 0.02em;
  color: var(--ete-secondary); text-transform: uppercase;
}

/* ============================================================
   Betting-event content (1:1 migration wrapper)
   ============================================================ */
.ete-entry {
  font-family: var(--ete-font-body);
  color: var(--ete-on-surface);
  font-size: 1rem; line-height: 1.75;
}
.ete-entry h2 { font-size: clamp(1.5rem, 1.6vw + 1rem, 2rem); margin-top: 2em; }
.ete-entry h3 { margin-top: 1.8em; }
.ete-entry table {
  width: 100%; border-collapse: collapse; margin: 1.5em 0;
  background: var(--ete-surface-container-lowest); border-radius: var(--ete-r-md);
  overflow: hidden; box-shadow: 0 2px 10px rgba(0,17,58,0.04);
}
.ete-entry table th, .ete-entry table td {
  padding: 0.75rem 1rem; text-align: left; vertical-align: middle;
}
.ete-entry table thead th {
  background: var(--ete-primary); color: var(--ete-on-primary);
  font-size: 0.8rem; letter-spacing: 0.08em; text-transform: uppercase;
}
.ete-entry table tbody tr + tr td { border-top: 1px solid var(--ete-surface-container); }
.ete-entry a { color: var(--ete-primary-container); text-decoration: underline; text-underline-offset: 3px; }
.ete-entry blockquote {
  border-left: 4px solid var(--ete-secondary);
  padding: 0.25rem 0 0.25rem 1.25rem;
  margin: 1.5em 0; font-style: italic; color: var(--ete-on-surface-variant);
}
.ete-entry ul li, .ete-entry ol li { margin-bottom: 0.5em; }
.ete-entry img { border-radius: var(--ete-r-md); margin: 1em 0; }

/* ============================================================
   Sidebar (betting pages)
   ============================================================ */
.ete-layout { display: grid; grid-template-columns: 1fr; gap: 2rem; }
@media (min-width: 960px) { .ete-layout { grid-template-columns: minmax(0, 1fr) 320px; } }
.ete-side { display: flex; flex-direction: column; gap: 1.5rem; }
.ete-side__title {
  font-size: 0.75rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ete-on-surface-variant); margin-bottom: 0.75rem;
}

/* ============================================================
   Footer
   ============================================================ */
.ete-footer {
  background: var(--ete-primary);
  color: var(--ete-on-primary);
  padding-block: 3rem 1.5rem;
}
.ete-footer h4 {
  font-size: 0.75rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ete-secondary-container); font-family: var(--ete-font-body);
  font-weight: 700; margin-bottom: 0.8rem;
}
.ete-footer ul { list-style: none; margin: 0; padding: 0; }
.ete-footer li { margin-bottom: 0.5rem; }
.ete-footer a { color: rgba(255,255,255,0.78); font-size: 0.9rem; }
.ete-footer a:hover { color: var(--ete-secondary-container); }
.ete-footer__cols { display: grid; gap: 2rem; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); margin-bottom: 2.5rem; }
.ete-footer__brand { max-width: 22rem; }
.ete-footer__brand p { font-size: 0.85rem; color: rgba(255,255,255,0.72); line-height: 1.6; }
.ete-footer__legal {
  border-top: 1px solid rgba(255,255,255,0.12);
  padding-top: 1.25rem; font-size: 0.78rem; color: rgba(255,255,255,0.55);
  display: flex; flex-wrap: wrap; gap: 1rem; justify-content: space-between;
}
.ete-footer__legal a { color: rgba(255,255,255,0.55); }

/* ============================================================
   Fan-Zone signup
   ============================================================ */
.ete-fanzone {
  background: var(--ete-primary-container);
  color: var(--ete-on-primary);
  border-radius: var(--ete-r-xl);
  padding: 2rem; position: relative; overflow: hidden;
}
.ete-fanzone h2 { color: var(--ete-on-primary); }
.ete-fanzone input[type=email] {
  width: 100%; padding: 0.85rem 1rem;
  border: 0; border-radius: var(--ete-r-md);
  background: rgba(255,255,255,0.1); color: #fff;
  font-family: inherit; font-size: 0.9rem;
}
.ete-fanzone input[type=email]::placeholder { color: rgba(255,255,255,0.55); }

/* ============================================================
   Breadcrumbs
   ============================================================ */
.ete-breadcrumbs {
  font-size: 0.78rem; color: var(--ete-on-surface-variant);
  margin-bottom: 1rem;
}
.ete-breadcrumbs a { color: var(--ete-on-surface-variant); }
.ete-breadcrumbs a:hover { color: var(--ete-primary); }
.ete-breadcrumbs span[aria-current] { color: var(--ete-primary); font-weight: 600; }

/* ============================================================
   Utilities
   ============================================================ */
.ete-mb-0 { margin-bottom: 0 !important; }
.ete-mt-lg { margin-top: 2.5rem; }
.ete-text-center { text-align: center; }
.ete-visually-hidden {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ============================================================
   LEGACY CONTENT-CLASSES (ctable / _logo / rating / btn / tnc)
   Ported from corpus theme and re-themed to our Navy + Gold tokens.
   Required because migrated DB content uses these class names.
   ============================================================ */

/* --- Operator logos (sprite-style, using background-image) --- */
._logo:before,
._logo:after,
._logo > span {
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    display: inline-block;
    vertical-align: middle;
    width: 150px;
    height: 60px;
    color: transparent;
    font-size: 0;
    max-width: 100%;
}
._logo > span > a { display: block; width: 100%; height: 100%; }
._logo.l:before, ._logo.l:after, ._logo.l > span { width: 123px; height: 54px; }
._logo.m:before, ._logo.m:after, ._logo.m > span { width: 82px; height: 36px; }
._logo.s:before, ._logo.s:after, ._logo.s > span { width: 62px; height: 27px; }

._logo.bet10      > span,  ._logo.bet10:before,      ._logo.bet10:after       { background-image: url(../images/operators/10bet.png); }
._logo.bet365     > span,  ._logo.bet365:before,     ._logo.bet365:after      { background-image: url(../images/operators/bet365.png); }
._logo.betfred    > span,  ._logo.betfred:before,    ._logo.betfred:after     { background-image: url(../images/operators/betfred.png); }
._logo.betmgm     > span,  ._logo.betmgm:before,     ._logo.betmgm:after      { background-image: url(../images/operators/betmgm.png); }
._logo.betvictor  > span,  ._logo.betvictor:before,  ._logo.betvictor:after   { background-image: url(../images/operators/betvictor.png); }
._logo.betway     > span,  ._logo.betway:before,     ._logo.betway:after      { background-image: url(../images/operators/betway.png); }
._logo.coral      > span,  ._logo.coral:before,      ._logo.coral:after       { background-image: url(../images/operators/coral.png); }
._logo.ladbrokes  > span,  ._logo.ladbrokes:before,  ._logo.ladbrokes:after   { background-image: url(../images/operators/ladbrokes.png); }
._logo.midnite    > span,  ._logo.midnite:before,    ._logo.midnite:after     { background-image: url(../images/operators/midnite.png); }
._logo.quinnbet   > span,  ._logo.quinnbet:before,   ._logo.quinnbet:after    { background-image: url(../images/operators/quinnbet.png); }
._logo.william-hill > span, ._logo.william-hill:before, ._logo.william-hill:after { background-image: url(../images/operators/william-hill.png); }
._logo.spreadex   > span,  ._logo.spreadex:before,   ._logo.spreadex:after    { background-image: url(../images/operators/spreadex.png); }
._logo.thepools   > span,  ._logo.thepools:before,   ._logo.thepools:after    { background-image: url(../images/operators/thepools.png); }
._logo.vulkan-vegas > span,._logo.vulkan-vegas:before,._logo.vulkan-vegas:after{ background-image: url(../images/operators/vulkan-vegas.png); }
._logo.lucky-days > span,  ._logo.lucky-days:before, ._logo.lucky-days:after  { background-image: url(../images/operators/luckydays.png); }
._logo.n1casino   > span,  ._logo.n1casino:before,   ._logo.n1casino:after    { background-image: url(../images/operators/n1casino.png); }

/* --- .ctable comparison table — re-themed to Navy + Gold --- */
.ctable { width: 100%; margin: 2rem 0; }
.ctable table {
    display: block;
    border: 0;
    background: var(--ete-surface-container-lowest);
    border-radius: var(--ete-r-lg);
    overflow: hidden;
    box-shadow: 0 8px 24px rgba(0,17,58,.06);
}
.ctable table caption {
    display: block;
    text-align: center;
    font-family: var(--ete-font-headline);
    font-weight: 700;
    font-size: 1.35rem;
    color: var(--ete-primary);
    padding: 1.25rem 1rem 0.75rem;
    caption-side: top;
}
.ctable tbody { display: block; }
.ctable tr {
    display: flex;
    flex-flow: row wrap;
    align-items: center;
    padding: 1rem 0.75rem;
    border-top: 1px solid var(--ete-surface-container);
}
.ctable tr:first-child { border-top: 0; }
.ctable td {
    display: block;
    flex-basis: 25%;
    max-width: 25%;
    border: 0;
    box-sizing: border-box;
    font-size: 0.95rem;
    color: var(--ete-on-surface);
    padding: 0.4rem 0.6rem;
    text-align: center;
}
.ctable td[data-label]:before {
    content: attr(data-label);
    display: block;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--ete-on-surface-variant);
    margin-bottom: 0.25rem;
}
.ctable td > strong {
    font-family: var(--ete-font-headline);
    font-size: 1.5rem;
    color: var(--ete-primary);
    display: block;
    line-height: 1.1;
}
.ctable td > strong + span { font-size: 0.78rem; color: var(--ete-on-surface-variant); text-transform: uppercase; letter-spacing: 0.08em; }
.ctable ._logo { display: block; margin: 0 auto; }

/* 5-star rating with sprite (star.png: 2×15px sprite — gold filled / grey empty) */
.ctable .rating {
    display: block;
    position: relative;
    width: 90px;
    margin: 0 auto;
    padding-top: 22px;
    font-size: 0.85rem;
    color: var(--ete-on-surface-variant);
    font-weight: 600;
}
.ctable .rating:before,
.ctable .rating:after {
    content: "";
    position: absolute;
    display: block;
    width: 100%;
    height: 14px;
    top: 3px;
    left: 0;
    background: url(../images/operators/star.png) repeat-x 0 0;
}
.ctable .rating:after { background-position: 0 -15px; }
.ctable .rating.r50:after { width: 100%; }
.ctable .rating.r49:after { width: 98%; }
.ctable .rating.r48:after { width: 97%; }
.ctable .rating.r47:after { width: 96%; }
.ctable .rating.r46:after { width: 95%; }
.ctable .rating.r45:after { width: 90%; }
.ctable .rating.r40:after { width: 80%; }
.ctable .rating.r35:after { width: 70%; }
.ctable .rating.r30:after { width: 60%; }
.ctable .rating.r25:after { width: 50%; }
.ctable .rating strong { color: var(--ete-primary); }

/* CTA button inside ctable — gold gradient, prominent */
.ctable table td a.btn,
.ctable .btn {
    display: block;
    padding: 0.75rem 1rem;
    margin: 0 auto;
    max-width: 140px;
    font-weight: 800;
    font-size: 0.75rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ete-on-secondary-container);
    background: var(--ete-secondary-container);
    border-radius: var(--ete-r-md);
    text-decoration: none;
    box-shadow: 0 2px 6px rgba(119,90,25,.22);
    transition: transform .15s, box-shadow .15s, background .2s;
    text-align: center;
}
.ctable table td a.btn:hover,
.ctable .btn:hover {
    background: var(--ete-secondary-fixed-dim);
    transform: translateY(-1px);
    box-shadow: 0 6px 14px rgba(119,90,25,.28);
    color: var(--ete-on-secondary-container);
}

/* T&Cs small-print row (full-width beneath the data cells) */
.ctable .tnc {
    flex-basis: 100%;
    max-width: none;
    margin: 0.6rem 0.5rem 0;
    padding-top: 0.6rem;
    font-size: 0.72rem;
    line-height: 1.45;
    color: var(--ete-on-surface-variant);
    border-top: 1px solid var(--ete-surface-container);
    text-align: left;
}
.ctable .tnc a { color: var(--ete-primary); text-decoration: underline; text-underline-offset: 2px; }
.ctable .tnc span { cursor: pointer; text-decoration: underline; }
.ctable .tnc span:hover { text-decoration: none; }

/* data-d-20 / data-d-30 column-width overrides */
.ctable[data-d-20*="1"] td:first-child,
.ctable[data-d-20*="2"] td:nth-child(2),
.ctable[data-d-20*="3"] td:nth-child(3),
.ctable[data-d-20*="4"] td:nth-child(4),
.ctable[data-d-20*="5"] td:nth-child(5){flex-basis:20%;max-width:20%;}
.ctable[data-d-30*="1"] td:first-child,
.ctable[data-d-30*="2"] td:nth-child(2),
.ctable[data-d-30*="3"] td:nth-child(3),
.ctable[data-d-30*="4"] td:nth-child(4),
.ctable[data-d-30*="5"] td:nth-child(5){flex-basis:30%;max-width:30%;}

@media only screen and (max-width: 1024px) {
    .ctable td { flex-basis: 50%; max-width: 50%; }
    .ctable[data-m-33*="1"] td:first-child,
    .ctable[data-m-33*="2"] td:nth-child(2),
    .ctable[data-m-33*="3"] td:nth-child(3),
    .ctable[data-m-33*="4"] td:nth-child(4),
    .ctable[data-m-33*="5"] td:nth-child(5){flex-basis:33%;max-width:33%;}
    .ctable[data-m-40*="1"] td:first-child,
    .ctable[data-m-40*="2"] td:nth-child(2),
    .ctable[data-m-40*="3"] td:nth-child(3),
    .ctable[data-m-40*="4"] td:nth-child(4),
    .ctable[data-m-40*="5"] td:nth-child(5){flex-basis:40%;max-width:40%;}
    .ctable[data-m-60*="1"] td:first-child,
    .ctable[data-m-60*="2"] td:nth-child(2),
    .ctable[data-m-60*="3"] td:nth-child(3),
    .ctable[data-m-60*="4"] td:nth-child(4),
    .ctable[data-m-60*="5"] td:nth-child(5){flex-basis:60%;max-width:60%;}
}

@media only screen and (max-width: 600px) {
    .ctable td { flex-basis: 50%; max-width: 50%; padding: 0.3rem 0.4rem; }
    .ctable td > strong { font-size: 1.2rem; }
    ._logo > span, ._logo:before, ._logo:after { width: 100px; height: 40px; }
}

/* WP alignments (fallback) */
.alignleft  { float: left; margin: 0.5rem 1.25rem 1rem 0; }
.alignright { float: right; margin: 0.5rem 0 1rem 1.25rem; }
.aligncenter{ display: block; margin: 1.25rem auto; clear: both; max-width: 100%; }
.size-full img, img.size-full, img.aligncenter { max-width: 100%; height: auto; border-radius: var(--ete-r-md); }

/* list-faq — migrated FAQ blocks */
.list-faq { margin: 1.5em 0; display: flex; flex-direction: column; gap: 0.75rem; }
.list-faq > div,
.list-faq .faq-item {
    background: var(--ete-surface-container-lowest);
    border-radius: var(--ete-r-md);
    padding: 1rem 1.25rem;
    box-shadow: 0 2px 8px rgba(0,17,58,.04);
}
.list-faq h3, .list-faq h4, .list-faq strong {
    font-family: var(--ete-font-headline);
    color: var(--ete-primary);
    margin: 0 0 0.4rem;
    font-size: 1.05rem;
    font-weight: 700;
}
