/* ============ TOKENS ============ */
:root{
  --blue:#3B82F6;        /* primary action */
  --blue-700:#2563EB;    /* hover/depth */
  --blue-50:#EEF4FF;     /* tint */
  --red:#E63946;         /* second accent */
  --red-700:#CC2936;     /* darker red — AA-safe for small text on light + white text on red */
  --red-50:#FDECEE;      /* tint */
  --ink:#0B0D10;         /* footer bg + darkest */
  --ink-2:#12161D;       /* lifted dark surface */
  --bg:#F4F6FA;          /* page */
  --surface:#FFFFFF;     /* cards */
  --text:#11151B;        /* main text */
  --muted:#5C6675;       /* secondary text */
  --muted-2:#6B7280;     /* tertiary (AA on white) */
  --line:#E7EAF0;        /* hairline */
  --scrim:linear-gradient(180deg, rgba(11,13,16,0) 16%, rgba(18,24,38,.5) 56%, rgba(11,13,16,.92) 100%); /* unified photo overlay */
  --line-dk:rgba(255,255,255,.10);
  --foot-text:#AEB6C2;
  --foot-head:#FFFFFF;

  --radius:20px;         /* previews / cards */
  --radius-sm:14px;
  --radius-pill:999px;

  --shadow-1:0 1px 2px rgba(11,13,16,.05), 0 1px 1px rgba(11,13,16,.04);
  --shadow-2:0 18px 40px -22px rgba(11,13,16,.30);

  --display:"Oswald", "Arial Narrow", system-ui, sans-serif;  /* condensed sports headlines */
  --label:"Oswald", "Arial Narrow", system-ui, sans-serif;    /* small uppercase labels/scores */
  --body:"Inter", system-ui, -apple-system, sans-serif;       /* reading text + UI */
  --mono:ui-monospace, "SF Mono", "Cascadia Code", "Roboto Mono", Menlo, monospace; /* code only */

  --wrap:1200px;
  --gap:clamp(16px,3.2vw,24px);
  --sec-pad:clamp(44px,6.5vw,76px);

  /* Heading type scale — one source for sizes across all templates */
  --fs-display:clamp(2rem,4.8vw,3rem);   /* hero + single-post title */
  --fs-h1:clamp(1.8rem,4.2vw,2.6rem);    /* archive / page H1 */
  --fs-h2:clamp(1.5rem,3.6vw,2.15rem);   /* section heads, article H2 */
  --fs-h3:clamp(1.2rem,2.2vw,1.45rem);   /* sub-headings */
  --fs-card:1.12rem;                      /* card + video titles */
}

/* ============ RESET / BASE ============ */
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%; overflow-x:hidden; overflow-x:clip}
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:var(--body); font-size:16px; line-height:1.65;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-wrap:break-word;
}
img{display:block; max-width:100%; height:auto}
a{color:inherit; text-decoration:none}
button{font:inherit}
h1,h2,h3,h4{font-family:var(--display); margin:0; line-height:1.1; letter-spacing:.01em}
:focus-visible{outline:3px solid var(--blue); outline-offset:2px; border-radius:6px}
.vh{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0}
.wrap{max-width:var(--wrap); margin-inline:auto; padding-inline:20px}
@media(min-width:760px){ .wrap{padding-inline:32px} }

.ico{width:1em; height:1em; fill:currentColor; flex:none; stroke-linecap:round; stroke-linejoin:round}
.bolt{fill:var(--red)}

/* ============ BUTTONS / TAGS ============ */
.btn{
  display:inline-flex; align-items:center; gap:8px; cursor:pointer;
  font-family:var(--display); font-weight:600; font-size:.95rem;
  padding:11px 18px; border-radius:12px; border:1px solid transparent;
  transition:transform .15s ease, background .15s ease, box-shadow .15s ease;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--blue-700); color:#fff; box-shadow:0 8px 18px -8px rgba(37,99,235,.7)}
.btn-primary:hover{background:#1d4ed8}
.btn-ghost{background:#fff; color:var(--text); border-color:var(--line)}
.btn-ghost:hover{border-color:#cfd6e2; box-shadow:var(--shadow-1)}
.btn-dark{background:var(--ink); color:#fff}
.btn-dark:hover{background:#1c222c}

/* "Visit RallyFuel" — animated iridescent gradient + periodic gloss sweep. */
.visit.btn-primary,
.visit.btn-primary:hover{
  position:relative; overflow:hidden; color:#fff; text-shadow:0 1px 2px rgba(11,13,16,.45);
  background:linear-gradient(110deg, var(--blue-700), var(--blue), var(--red), var(--blue), var(--blue-700));
  background-size:200% 100%;
  animation:rfb-sheen 7s linear infinite;
  box-shadow:0 8px 20px -8px rgba(59,130,246,.7);
}
.visit.btn-primary:hover{filter:saturate(1.08) brightness(1.04)}
.visit.btn-primary > *{position:relative; z-index:1}
.visit.btn-primary::after{
  content:""; position:absolute; top:0; bottom:0; left:-65%; width:42%;
  background:linear-gradient(100deg, transparent, rgba(255,255,255,.55), transparent);
  transform:skewX(-18deg); z-index:0; animation:rfb-glint 5.5s ease-in-out infinite;
}
@keyframes rfb-sheen{0%{background-position:0 0} 100%{background-position:-200% 0}}
@keyframes rfb-glint{0%,8%{left:-65%} 42%,100%{left:135%}}
@media(prefers-reduced-motion:reduce){
  .visit.btn-primary{animation:none; background:var(--blue-700)}
  .visit.btn-primary::after{display:none}
}

span.tag{
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--label); font-size:.66rem; font-weight:500;
  letter-spacing:.08em; text-transform:uppercase;
  padding:5px 10px; border-radius:var(--radius-pill);
  background:var(--red-700); color:#fff; white-space:nowrap;
}
span.tag-soft{background:var(--blue-50); color:var(--blue-700)}

.eyebrow{
  display:inline-flex; align-items:center; gap:7px; margin:0 0 12px;
  font-family:var(--label); font-size:.72rem; font-weight:500;
  letter-spacing:.16em; text-transform:uppercase; color:var(--red-700);
}
.eyebrow .ico{width:.95em; height:.95em}

.meta{
  font-family:var(--label); font-size:.72rem; color:var(--muted-2);
  letter-spacing:.02em; text-transform:uppercase;
}

/* ============ HEADER ============ */
/* Slim top utility bar */
.utility-bar{background:var(--ink); color:var(--foot-text); border-bottom:1px solid rgba(255,255,255,.08)}
.utility-bar .wrap{display:flex; align-items:center; justify-content:space-between; gap:14px; min-height:38px; padding-block:6px}
.utility-msg{display:inline-flex; align-items:center; gap:8px; margin:0; font-family:var(--label); letter-spacing:.06em; text-transform:uppercase; font-size:.7rem; color:#fff}
.utility-msg .ico{width:1em; height:1em; fill:var(--red)}
.utility-social{display:flex; gap:4px}
.utility-social a{display:inline-grid; place-items:center; width:30px; height:30px; border-radius:8px; color:var(--foot-text); transition:color .15s ease, background .15s ease}
.utility-social a:hover{color:#fff; background:rgba(255,255,255,.08)}
.utility-social svg{width:15px; height:15px; fill:currentColor}
@media(max-width:640px){
  .utility-bar .wrap{justify-content:center}
  .utility-social{display:none}
}

.site-header{
  position:sticky; top:0; z-index:60; background:rgba(11,13,16,.85);
  backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid rgba(255,255,255,.08); transition:box-shadow .25s ease;
}
.site-header.scrolled{box-shadow:0 6px 24px -16px rgba(11,13,16,.4)}

/* Condense the header on deeper scroll */
.bar{transition:padding-block .25s ease}
.brand .mark{transition:width .25s ease, height .25s ease}
.brand .word{transition:font-size .25s ease}
.site-header.is-compact .bar{padding-block:7px}
.site-header.is-compact .brand .mark{width:30px; height:30px}
.site-header.is-compact .brand .mark svg{width:17px; height:17px}
.site-header.is-compact .brand .word{font-size:1.04rem}
.site-header.is-compact .chips{max-height:0; opacity:0; padding-block:0; border-top-color:transparent; pointer-events:none}

/* Reading progress bar (single posts) */
.reading-progress{position:fixed; top:0; left:0; right:0; height:3px; z-index:100; pointer-events:none; background:transparent}
.reading-progress span{display:block; height:100%; width:0; background:linear-gradient(90deg,var(--blue),var(--red))}
.bar{display:flex; align-items:center; gap:10px; padding-block:12px}

.menu-btn{
  display:inline-flex; align-items:center; gap:8px; cursor:pointer; height:42px;
  background:#fff; border:1px solid var(--line); border-radius:12px;
  padding:0 14px; font-family:var(--label); font-size:.7rem; letter-spacing:.1em;
  text-transform:uppercase; color:var(--text);
}
.menu-btn:hover{border-color:#cfd6e2}
.menu-btn .lbl{display:none}
@media(min-width:560px){ .menu-btn .lbl{display:inline} }
.menu-btn svg{width:16px;height:16px}

.brand{display:inline-flex; align-items:center; gap:10px; margin-right:auto}
.brand .mark{width:34px; height:34px; border-radius:11px; background:var(--ink); display:grid; place-items:center; flex:none}
.brand .mark svg{width:19px; height:19px}
.brand .word{font-family:var(--display); font-weight:700; font-size:1.18rem; letter-spacing:.01em; line-height:1}
.brand .word .fl{color:var(--blue)}
.brand .sub{display:none; font-family:var(--label); font-size:.6rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted-2); margin-top:3px}
@media(min-width:560px){ .brand .sub{display:block} }

form.search{display:flex; align-items:center; gap:8px; background:#fff; border:1px solid var(--line);
  border-radius:12px; padding:8px 12px; min-width:0}
form.search svg{width:17px; height:17px; color:var(--muted-2); flex:none}
form.search input{border:0; outline:0; background:transparent; font:inherit; font-size:.92rem; width:100%; min-width:0; color:var(--text)}
form.search input::placeholder{color:var(--muted-2)}

.search-icon{display:inline-grid; place-items:center; width:42px; height:42px; flex:none;
  background:#fff; border:1px solid var(--line); border-radius:12px; cursor:pointer; color:var(--text); transition:border-color .15s ease, background .15s ease}
.search-icon:hover{border-color:#cfd6e2; background:#fff}
.search-icon svg{width:18px; height:18px}

.visit{flex:none; height:42px; padding-block:0}
.visit .lbl{display:none}
@media(min-width:560px){ .visit .lbl{display:inline} }
.visit svg{width:15px; height:15px}
.menu-btn:focus-visible,.search-icon:focus-visible,.drawer-close:focus-visible,.search-modal-close:focus-visible,.visit:focus-visible{outline:2px solid var(--blue-700); outline-offset:2px}

/* Uploaded custom logo (replaces the text wordmark). */
.bar .custom-logo-link{display:inline-flex; align-items:center; margin-right:auto}
.bar .custom-logo{height:38px; width:auto; max-width:210px; display:block}
.drawer-top .custom-logo-link,.site-footer .custom-logo-link{display:inline-flex; align-items:center}
.drawer-top .custom-logo,.site-footer .custom-logo{height:34px; width:auto; max-width:190px; display:block}

/* category chips */
.chips{display:flex; gap:8px; overflow-x:auto; overflow-y:hidden; max-height:80px; padding-block:10px; scrollbar-width:none;
  border-top:1px solid var(--line); -webkit-overflow-scrolling:touch;
  transition:max-height .3s ease, opacity .2s ease, padding-block .25s ease, border-color .2s ease}
.chips::-webkit-scrollbar{display:none}
.chip{flex:none; padding:7px 14px; border-radius:var(--radius-pill); border:1px solid var(--line);
  background:#fff; font-size:.83rem; font-weight:500; color:var(--muted); transition:.15s; white-space:nowrap}
.chip:hover{color:var(--text); border-color:#cfd6e2}
.chip.is-active{background:var(--ink); color:#fff; border-color:var(--ink)}

/* ============ DARK MASTHEAD (black logo bar) ============
   All scoped to .site-header so the drawer, search modal, footer and cards
   keep their light styling. The uploaded logo image (if any) is shown as-is —
   use a logo that reads on a dark background. */
.site-header .menu-btn{background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.18); color:#fff}
.site-header .menu-btn:hover{background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.4)}
.site-header .search-icon{background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.18); color:#fff}
.site-header .search-icon:hover{background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.4)}
.site-header .brand .mark{background:#fff}
.site-header .brand .word{color:#fff}
.site-header .brand .sub{color:var(--foot-text)}
.site-header .chips{border-top-color:rgba(255,255,255,.08)}
.site-header .chip{background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.16); color:var(--foot-text)}
.site-header .chip:hover{background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.4); color:#fff}
.site-header .chip.is-active{background:#fff; border-color:#fff; color:var(--ink)}

/* ============ DRAWER (full nav) ============ */
.rfb-toggle{position:absolute; width:1px; height:1px; opacity:0; pointer-events:none; clip:rect(0 0 0 0)}
/* Lock background scroll while the drawer or search modal is open. */
html:has(#nav-toggle:checked),
html:has(#search-toggle:checked){overflow:hidden}
.scrim{position:fixed; inset:0; background:rgba(11,13,16,.5); opacity:0; visibility:hidden;
  transition:.25s; z-index:70}
.drawer{position:fixed; top:0; left:0; height:100dvh; width:min(420px,90vw); background:#fff;
  z-index:80; transform:translateX(-100%); transition:transform .3s cubic-bezier(.4,0,.2,1);
  display:flex; flex-direction:column; box-shadow:0 0 60px rgba(11,13,16,.3)}
#nav-toggle:checked ~ .scrim{opacity:1; visibility:visible}
#nav-toggle:checked ~ .drawer{transform:translateX(0)}
.drawer-top{display:flex; align-items:center; justify-content:space-between; padding:18px 20px; border-bottom:1px solid var(--line)}
.drawer-close{cursor:pointer; background:var(--bg); border:1px solid var(--line); border-radius:12px; width:38px; height:38px; display:grid; place-items:center}
.drawer-close svg{width:18px; height:18px}
.drawer-nav{overflow-y:auto; padding:16px 20px 8px; flex:1}
.drawer-nav .grp{margin-bottom:18px}
.drawer-nav .grp > a{display:block; font-family:var(--display); font-weight:700; font-size:1.05rem; padding:6px 0}
.drawer-nav .sub{display:flex; flex-wrap:wrap; gap:6px 8px; margin:6px 0 2px}
.drawer-nav .sub a{font-size:.83rem; color:var(--muted); background:var(--bg); border:1px solid var(--line);
  padding:5px 11px; border-radius:var(--radius-pill)}
.drawer-nav .sub a:hover{color:var(--blue-700); border-color:#cfd6e2}
.drawer-foot{padding:16px 20px; border-top:1px solid var(--line); background:var(--bg)}
.drawer-social{display:flex; gap:10px; margin-bottom:14px}
.drawer-social a{width:38px; height:38px; border-radius:12px; background:#fff; border:1px solid var(--line);
  display:grid; place-items:center; color:var(--text)}
.drawer-social a:hover{color:var(--blue-700)}
.drawer-social svg{width:17px; height:17px}

/* ============ SEARCH MODAL ============ */
.search-modal{position:fixed; inset:0; z-index:90; display:flex; align-items:flex-start; justify-content:center;
  padding:clamp(64px,14vh,160px) 20px 20px; opacity:0; visibility:hidden; transition:opacity .2s ease, visibility .2s ease}
#search-toggle:checked ~ .search-modal{opacity:1; visibility:visible}
.search-modal-scrim{position:absolute; inset:0; background:rgba(11,13,16,.62); backdrop-filter:blur(4px); cursor:pointer}
.search-modal-card{position:relative; z-index:2; width:min(640px,100%); max-height:calc(100dvh - 120px); overflow:hidden auto; background:#fff; border-radius:var(--radius);
  border:1px solid var(--line); box-shadow:0 40px 80px -30px rgba(11,13,16,.55);
  padding:clamp(20px,3vw,28px); transform:translateY(-14px) scale(.98); transition:transform .22s cubic-bezier(.2,.7,.2,1)}
#search-toggle:checked ~ .search-modal .search-modal-card{transform:translateY(0) scale(1)}
.search-modal-head{display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:16px}
.search-modal-head h2{font-size:1.12rem; font-weight:700}
.search-modal-close{cursor:pointer; background:var(--bg); border:1px solid var(--line); border-radius:12px;
  width:38px; height:38px; display:grid; place-items:center; flex:none; color:var(--text); transition:border-color .15s ease}
.search-modal-close:hover{border-color:#cfd6e2}
.search-modal-close svg{width:18px; height:18px}
.search-modal .search{padding:14px 16px; border-radius:14px; border-width:1.5px; gap:12px}
.search-modal .search svg{width:20px; height:20px}
.search-modal .search input{font-size:1.08rem}
.search-modal .search:focus-within{border-color:var(--blue); box-shadow:0 0 0 4px rgba(59,130,246,.14)}
.search-modal-hint{margin:14px 2px 0; font-family:var(--label); font-size:.72rem; letter-spacing:.04em;
  color:var(--muted-2); text-transform:uppercase}
.search-modal-hint kbd{font-family:var(--mono); background:var(--bg); border:1px solid var(--line);
  border-bottom-width:2px; border-radius:6px; padding:2px 6px; font-size:.72rem; color:var(--text)}
@media(min-width:560px){ .search-modal-head h2{font-size:1.25rem} }
.search-suggest{margin-top:20px; padding-top:18px; border-top:1px solid var(--line); display:grid; grid-template-columns:minmax(0,1fr); gap:18px}
.search-suggest-label{font-family:var(--label); font-size:.64rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted-2); margin:0 0 10px}
.search-chips{display:flex; flex-wrap:wrap; gap:8px}
.search-chip{padding:7px 13px; border-radius:var(--radius-pill); border:1px solid var(--line); background:#fff; font-size:.84rem; font-weight:500; color:var(--muted); transition:color .15s ease, border-color .15s ease}
.search-chip:hover{color:var(--blue-700); border-color:#cfd6e2}
.search-popular{list-style:none; margin:0; padding:0; display:grid; grid-template-columns:minmax(0,1fr); gap:2px}
.search-popular a{display:block; padding:8px 10px; margin:0 -10px; border-radius:9px; font-weight:600; font-size:.95rem; color:var(--text); line-height:1.3; transition:background .15s ease, color .15s ease}
.search-popular a:hover{background:var(--bg); color:var(--blue-700)}

/* ============ SECTION HEADER ============ */
.section{padding-block:var(--sec-pad)}

/* Full-bleed dark section (Watch & learn) for editorial rhythm */
.section-dark{background:var(--ink); color:#fff; border-block:1px solid rgba(255,255,255,.08)}
.section-dark .eyebrow{color:var(--foot-text)}
.section-dark .sec-head h2{color:#fff}
.section-dark .sec-head .lead{color:rgba(255,255,255,.7)}
.section-dark .sec-link{color:#fff}
.section-dark .video-card{border:1px solid rgba(255,255,255,.1)}
.section-dark .video-meta{background:var(--ink-2)}
.section-dark .video-meta h3{color:#fff}
.section-dark .video-card:hover .video-meta h3{color:#9DC3FF}

/* Stats / promise band */
.stats-band{position:relative; overflow:hidden; color:#fff; padding-block:clamp(38px,5vw,62px);
  background:linear-gradient(120deg,var(--ink),var(--ink-2)); border-block:1px solid rgba(255,255,255,.08)}
.stats-bolt{position:absolute; right:-26px; top:50%; transform:translateY(-50%) rotate(8deg);
  width:clamp(180px,26vw,280px); height:clamp(180px,26vw,280px); fill:rgba(255,255,255,.04); pointer-events:none}
.stats-eyebrow{display:inline-flex; align-items:center; gap:8px; margin:0 0 22px; font-family:var(--label);
  font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--red)}
.stats-eyebrow .ico{width:1em; height:1em; fill:var(--red)}
.stats-grid{display:flex; flex-wrap:wrap; gap:26px clamp(32px,6vw,68px); position:relative; z-index:1}
.stat{min-width:120px}
.stat-num{display:block; font-family:var(--display); font-weight:700; font-size:clamp(2.4rem,5vw,3.4rem);
  line-height:1; letter-spacing:.01em; font-variant-numeric:tabular-nums;
  background:linear-gradient(135deg,#ffffff,#c9d6ee); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent}
.stat-label{display:block; margin-top:10px; color:rgba(255,255,255,.72); font-size:.92rem; line-height:1.4; max-width:24ch}
.sec-head{display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:clamp(20px,3vw,32px)}
.sec-head h2{font-size:var(--fs-h2); font-weight:700}
.sec-head .lead{color:var(--muted); margin:8px 0 0; max-width:46ch; font-size:.98rem}
.sec-link{font-family:var(--label); font-size:.74rem; letter-spacing:.08em; text-transform:uppercase;
  color:var(--blue-700); display:inline-flex; align-items:center; gap:6px; flex:none; white-space:nowrap}
.sec-link svg{width:14px; height:14px; transition:transform .15s}
.sec-link:hover svg{transform:translateX(3px)}
.title-accent{display:inline-block; height:4px; width:54px; border-radius:4px;
  background:linear-gradient(90deg,var(--blue),var(--red)); margin-top:14px}

/* ============ HERO ============ */
.hero{padding-top:clamp(24px,4vw,40px); padding-bottom:clamp(28px,4.5vw,48px)}
.hero-grid{display:grid; gap:16px; align-items:start}
@media(min-width:980px){ .hero-grid{grid-template-columns:minmax(0,1.6fr) minmax(0,1fr); gap:20px} }

.feature{position:relative; display:flex; border-radius:var(--radius); overflow:hidden;
  min-height:clamp(440px,48vw,540px); background:linear-gradient(135deg,#1b2330,#0b0d10);
  box-shadow:var(--shadow-2); isolation:isolate}
.feature::before{content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  border-radius:inherit; box-shadow:inset 0 0 0 1px rgba(255,255,255,.07)}
.feature img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-1}
.feature::after{content:""; position:absolute; inset:0; background:var(--scrim)}
.feature-body{position:relative; align-self:flex-end; width:100%; padding:clamp(22px,3.4vw,38px); z-index:2}
.feature-ph{position:absolute; inset:0; z-index:-1; display:grid; place-items:center}
.feature-ph svg{width:38%; max-width:210px; fill:rgba(255,255,255,.06)}
.feature .dek{color:rgba(255,255,255,.86); margin:14px 0 0; font-size:1.02rem; max-width:52ch; line-height:1.5;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden}
.feature .row{display:flex; gap:8px; flex-wrap:wrap; margin-bottom:16px}
.feature h1{color:#fff; font-size:var(--fs-display); font-weight:700; max-width:18ch; line-height:1.05;
  text-shadow:0 2px 30px rgba(0,0,0,.45)}
.feature .fmeta{color:rgba(255,255,255,.82); margin-top:16px; display:flex; align-items:center; gap:10px; flex-wrap:wrap}
.feature .read{display:inline-flex; align-items:center; gap:7px; color:#fff; font-family:var(--display);
  font-weight:600; font-size:.95rem; margin-top:18px}
.feature .read svg{width:15px; height:15px; transition:transform .2s}
.feature:hover .read svg{transform:translateX(4px)}
.feature:hover img{transform:scale(1.04)}
.feature img{transition:transform .6s cubic-bezier(.2,.6,.2,1)}

/* trending rail */
.trending{display:flex; flex-direction:column; background:#fff; border:1px solid var(--line);
  border-radius:var(--radius); padding:20px; box-shadow:var(--shadow-1)}
.trend-head{margin-bottom:4px}
.trending .cap{font-family:var(--label); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted-2); margin-bottom:6px}
.trending h2{font-size:1.05rem; display:flex; align-items:center; gap:8px}
.trending h2 .ico{width:17px; height:17px; color:var(--red)}
.trend-list{display:flex; flex-direction:column}
.trend-item{display:grid; grid-template-columns:auto 52px minmax(0,1fr); gap:13px; align-items:center;
  padding:13px 8px 13px 0; margin-right:-8px; border-top:1px solid var(--line); border-radius:12px;
  transition:background .15s ease}
.trend-list .trend-item:first-child{border-top:0}
.trend-item:hover{background:var(--bg)}
.trend-rank{font-family:var(--display); font-weight:700; font-size:1.15rem; font-variant-numeric:tabular-nums;
  width:1.7em; text-align:center; padding-left:6px;
  background:linear-gradient(135deg,var(--blue),var(--red)); -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent}
.trend-thumb{width:52px; height:52px; border-radius:11px; object-fit:cover; background:var(--bg); border:1px solid var(--line)}
.trend-thumb--ph{display:grid; place-items:center; background:linear-gradient(135deg,var(--blue-700),var(--red)); border:0}
.trend-thumb--ph svg{width:22px; height:22px; fill:#fff}
.trend-item h3{font-size:.92rem; font-weight:600; font-family:var(--body); line-height:1.32; letter-spacing:0;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden}
.trend-item:hover h3{color:var(--blue-700)}
.trend-item .tm{font-family:var(--label); font-size:.62rem; color:var(--muted-2); text-transform:uppercase; letter-spacing:.06em; margin-top:4px}
.trend-foot{display:inline-flex; align-items:center; gap:7px; margin-top:14px; padding-top:16px;
  border-top:1px solid var(--line); font-family:var(--display); font-weight:600; font-size:.88rem; color:var(--blue-700)}
.trend-foot svg{width:14px; height:14px; transition:transform .15s ease}
.trend-foot:hover svg{transform:translateX(3px)}

/* ============ CARD GRID ============ */
.grid{display:grid; gap:var(--gap)}
@media(min-width:620px){ .grid-2{grid-template-columns:repeat(2,minmax(0,1fr))} }
@media(min-width:980px){ .grid-3{grid-template-columns:repeat(3,minmax(0,1fr))} }

.card{background:#fff; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  display:flex; flex-direction:column; box-shadow:var(--shadow-1);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease}
.card:hover{transform:translateY(-4px); box-shadow:var(--shadow-2); border-color:#dde3ec}
.thumb{position:relative; aspect-ratio:16/10; overflow:hidden;
  background:linear-gradient(135deg,#dbe3f0,#eef1f6)}
.thumb img{width:100%; height:100%; object-fit:cover; transition:transform .5s ease}
.card:hover .thumb img{transform:scale(1.05)}
.thumb .tag{position:absolute; left:12px; top:12px}
.card-body{padding:18px; display:flex; flex-direction:column; gap:10px; flex:1}
.card-body h3{font-size:var(--fs-card); font-weight:700; line-height:1.25}
.card:hover .card-body h3{color:var(--blue-700)}
.card-body p{margin:0; color:var(--muted); font-size:.92rem; line-height:1.55}
.card-foot{margin-top:auto; padding-top:12px; border-top:1px solid var(--line); display:flex; align-items:center; gap:8px; font-family:var(--body); font-size:.78rem; color:var(--muted)}
.card-foot .cf-av{width:24px; height:24px; border-radius:50%; object-fit:cover; background:var(--bg); flex:none}
.card-foot .cf-author{font-weight:600; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.card-foot .cf-date{white-space:nowrap}
.card-foot .dot{width:3px; height:3px; border-radius:50%; background:var(--muted-2); flex:none}
.thumb-fallback{position:absolute; inset:0; display:grid; place-items:center; background:linear-gradient(135deg,var(--blue-700),var(--red))}
.thumb-fallback svg{width:32%; height:32%; fill:rgba(255,255,255,.92)}

/* span helper for featured-in-grid */
@media(min-width:620px){ .card.wide{grid-column:1/-1; flex-direction:row} .card.wide .thumb{aspect-ratio:auto; width:46%; min-height:240px} .card.wide .card-body{width:54%; justify-content:center; padding:clamp(20px,3vw,34px)} }

/* ============ AD / CTA BLOCK ============ */
.promo{grid-column:1/-1; position:relative; overflow:hidden; border-radius:var(--radius);
  background:linear-gradient(120deg,var(--blue-700),var(--blue)); color:#fff;
  padding:clamp(26px,4.5vw,44px); box-shadow:0 22px 50px -26px rgba(37,99,235,.85)}
.promo::before{content:""; position:absolute; right:-40px; top:-60px; width:320px; height:320px;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.18), transparent 60%); pointer-events:none}
.promo .pbolt{position:absolute; right:clamp(-20px,2vw,30px); bottom:-30px; width:200px; height:200px; opacity:.16; transform:rotate(8deg)}
.promo .pbolt svg{width:100%; height:100%; fill:#fff}
.promo-inner{position:relative; z-index:2; max-width:640px}
.promo .ek{font-family:var(--label); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.85)}
.promo h3{font-size:var(--fs-h2); font-weight:700; margin:10px 0 8px; color:#fff; max-width:18ch}
.promo p{margin:0 0 20px; color:rgba(255,255,255,.92); font-size:.98rem; max-width:52ch}
.promo-actions{display:flex; flex-wrap:wrap; gap:12px 14px; align-items:center}
.store-row{display:flex; gap:10px; flex-wrap:wrap}
.store-badge{display:inline-flex; align-items:center; gap:10px; height:48px; background:var(--ink); color:#fff;
  border:1px solid rgba(255,255,255,.22); border-radius:12px; padding:0 16px 0 14px; transition:.15s}
.store-badge:hover{background:#000; transform:translateY(-2px)}
.store-badge .glyph{width:22px; height:22px; flex:none}
.store-badge .st{display:flex; flex-direction:column; line-height:1.05}
.store-badge .st small{font-size:.58rem; letter-spacing:.04em; opacity:.85; font-family:var(--body)}
.store-badge .st b{font-family:var(--display); font-weight:700; font-size:.95rem}
.promo .btn-light{background:#fff; color:var(--blue-700); height:48px; padding:0 20px}
.promo .btn-light:hover{background:#eef4ff}
@media(max-width:540px){
  .promo-actions{align-items:stretch}
  .promo .btn-light{width:100%; justify-content:center}
  .store-row{width:100%}
  .store-badge{flex:1}
}

/* ============ VIDEOS ============ */
.video-card{display:block; border-radius:var(--radius); overflow:hidden; background:var(--ink);
  border:1px solid var(--line); box-shadow:var(--shadow-1); transition:transform .18s, box-shadow .18s}
.video-card:hover{transform:translateY(-4px); box-shadow:var(--shadow-2)}
.video-thumb{position:relative; aspect-ratio:16/9; background:#0b0d10}
.video-thumb img{width:100%; height:100%; object-fit:cover; opacity:.92}
.video-thumb::after{content:""; position:absolute; inset:0; background:var(--scrim)}
.play{position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); z-index:2;
  width:62px; height:62px; border-radius:50%; background:var(--red); display:grid; place-items:center;
  box-shadow:0 10px 30px rgba(230,57,70,.55); transition:transform .2s}
.video-card:hover .play{transform:translate(-50%,-50%) scale(1.08)}
.play svg{width:22px; height:22px; fill:#fff; margin-left:3px}
.video-dur{position:absolute; right:10px; bottom:10px; z-index:2; font-family:var(--label); font-size:.66rem;
  background:rgba(11,13,16,.8); color:#fff; padding:3px 7px; border-radius:6px}
.video-meta{padding:15px 16px; background:#fff}
.video-meta .vk{font-family:var(--label); font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; color:var(--red)}
.video-meta h3{font-size:var(--fs-card); font-weight:700; margin-top:5px; line-height:1.25}
.video-card:hover .video-meta h3{color:var(--blue-700)}
.video-thumb iframe{position:absolute; inset:0; width:100%; height:100%; border:0}

/* ============ TOPIC TILES ============ */
.topics{display:grid; gap:12px; grid-template-columns:repeat(2,minmax(0,1fr))}
@media(min-width:760px){ .topics{grid-template-columns:repeat(3,minmax(0,1fr))} }
@media(min-width:1000px){ .topics{grid-template-columns:repeat(6,minmax(0,1fr))} }
.topic{position:relative; border:1px solid var(--line); background:#fff; border-radius:var(--radius-sm);
  padding:18px 16px; display:flex; flex-direction:column; gap:10px; min-height:118px; transition:.18s; overflow:hidden}
.topic:hover{border-color:#cfd6e2; transform:translateY(-3px); box-shadow:var(--shadow-1)}
.topic .ti{width:38px; height:38px; border-radius:11px; display:grid; place-items:center; background:var(--blue-50); color:var(--blue-700)}
.topic:nth-child(2n) .ti{background:var(--red-50); color:var(--red)}
.topic .ti svg{width:19px; height:19px}
.topic h3{font-size:1rem; font-weight:700; letter-spacing:.01em}
.topic span{font-family:var(--label); font-size:.64rem; letter-spacing:.06em; text-transform:uppercase; color:var(--muted-2)}

/* ============ HOW IT WORKS + TRUST BADGES ============ */
.sec-head-center{justify-content:center; text-align:center}
.sec-head-center .title-accent{margin-inline:auto}
.hiw-steps{list-style:none; margin:clamp(10px,2vw,20px) 0 0; padding:0; display:grid; gap:18px; grid-template-columns:repeat(3,minmax(0,1fr))}
@media(max-width:760px){ .hiw-steps{grid-template-columns:minmax(0,1fr)} }
.hiw-step{position:relative; background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:clamp(22px,2.6vw,28px); box-shadow:var(--shadow-1); overflow:hidden}
.hiw-ico{display:grid; place-items:center; width:46px; height:46px; border-radius:13px;
  background:var(--blue-50); color:var(--blue-700); margin-bottom:14px}
.hiw-ico svg{width:23px; height:23px; fill:currentColor}
.hiw-num{position:absolute; top:18px; right:20px; font-family:var(--display); font-weight:700; font-size:1.5rem; line-height:1;
  background:linear-gradient(180deg,var(--blue),var(--red)); -webkit-background-clip:text; background-clip:text; color:transparent; opacity:.28}
.hiw-step h3{font-family:var(--display); font-size:1.18rem; font-weight:700; margin:0 0 6px}
.hiw-step p{margin:0; color:var(--muted); font-size:.95rem; line-height:1.6}
.trust-badges{list-style:none; margin:clamp(20px,3vw,30px) 0 0; padding:0; display:flex; flex-wrap:wrap; justify-content:center; gap:10px 12px}
.trust-badges li{display:inline-flex; align-items:center; gap:7px; padding:9px 15px; border-radius:var(--radius-pill);
  background:#fff; border:1px solid var(--line); font-family:var(--label); font-size:.72rem; font-weight:500;
  letter-spacing:.06em; text-transform:uppercase; color:var(--text); box-shadow:var(--shadow-1)}
.trust-badges svg{width:15px; height:15px; fill:var(--blue-700)}

/* ============ STYLE GUIDE / ARTICLE PREVIEW ============ */
.guide-wrap{background:#fff; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-1)}
.guide-bar{display:flex; align-items:center; gap:8px; padding:14px 20px; border-bottom:1px solid var(--line); background:var(--bg)}
.guide-bar .dots{display:flex; gap:6px}
.guide-bar .dots i{width:11px; height:11px; border-radius:50%; background:#d6dce6}
.guide-bar .dots i:nth-child(1){background:#ff6058} .guide-bar .dots i:nth-child(2){background:#ffbd2e} .guide-bar .dots i:nth-child(3){background:#28c840}
.guide-bar .url{font-family:var(--label); font-size:.72rem; color:var(--muted-2)}
.prose{padding:clamp(22px,4vw,44px); max-width:760px; margin-inline:auto}
.prose .kicker{font-family:var(--label); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--red-700); margin-bottom:10px}
.prose h2{font-size:var(--fs-h2); font-weight:700; margin:0 0 6px}
.prose .byline{font-family:var(--label); font-size:.72rem; color:var(--muted-2); text-transform:uppercase; letter-spacing:.04em; margin-bottom:22px}
.prose h3{font-size:var(--fs-h3); font-weight:700; margin:30px 0 10px; letter-spacing:.01em}
.prose p{margin:0 0 16px; color:#283041; font-size:1.02rem; line-height:1.7}
.prose a{color:var(--blue-700); font-weight:600; text-decoration:underline; text-decoration-color:#bcd2ff; text-underline-offset:3px}
.prose a:hover{text-decoration-color:var(--blue)}
.prose strong{font-weight:700; color:var(--text)}
.prose code{font-family:var(--mono); font-size:.86em; background:var(--blue-50); color:var(--blue-700);
  padding:2px 6px; border-radius:6px}
.prose ul{margin:0 0 18px; padding-left:0; list-style:none}
.prose ul li{position:relative; padding-left:26px; margin-bottom:9px; color:#283041; line-height:1.6}
.prose ul li::before{content:""; position:absolute; left:4px; top:.62em; width:8px; height:8px; border-radius:3px;
  background:linear-gradient(135deg,var(--blue),var(--red))}

blockquote{margin:30px 0; padding:8px 0 8px 28px; border-left:4px solid var(--red);
  position:relative}
blockquote p{font-family:var(--display); font-weight:600; font-size:clamp(1.2rem,2.8vw,1.55rem);
  line-height:1.35; color:var(--ink); letter-spacing:.01em; margin:0 0 8px}
blockquote cite{font-family:var(--label); font-size:.74rem; font-style:normal; color:var(--muted);
  text-transform:uppercase; letter-spacing:.08em}

.table-cap{font-family:var(--label); font-size:.7rem; letter-spacing:.06em; text-transform:uppercase; color:var(--muted-2); margin:28px 0 10px}
.t-scroll{overflow-x:auto; border:1px solid var(--line); border-radius:var(--radius-sm); -webkit-overflow-scrolling:touch}
table.data{width:100%; border-collapse:collapse; font-size:.92rem; min-width:480px}
table.data caption{text-align:left; font-family:var(--label); font-size:.68rem; letter-spacing:.08em;
  text-transform:uppercase; color:var(--muted-2); padding:12px 16px; border-bottom:1px solid var(--line)}
table.data thead th{background:var(--ink); color:#fff; font-family:var(--display); font-weight:600;
  text-align:left; padding:12px 16px; font-size:.82rem; letter-spacing:.01em; white-space:nowrap}
table.data thead th.num{text-align:right}
table.data tbody td{padding:12px 16px; border-top:1px solid var(--line); color:#283041}
table.data tbody td.num{text-align:right; font-family:var(--label); font-variant-numeric:tabular-nums; color:var(--text)}
table.data tbody tr:nth-child(even){background:#fafbfd}
table.data tbody td .pill{display:inline-block; font-family:var(--label); font-size:.66rem; padding:3px 8px;
  border-radius:var(--radius-pill); background:var(--blue-50); color:var(--blue-700)}
table.data tbody td .pill.hot{background:var(--red-50); color:var(--red)}

.callout{display:flex; gap:14px; align-items:flex-start; margin:28px 0 4px; padding:18px 20px;
  background:var(--blue-50); border:1px solid #d8e6ff; border-radius:var(--radius-sm)}
.callout .ci{width:30px; height:30px; border-radius:9px; background:var(--blue); color:#fff; display:grid; place-items:center; flex:none}
.callout .ci svg{width:17px; height:17px; fill:#fff}
.callout p{margin:0; font-size:.95rem; color:#1f2a3d}
.callout strong{font-family:var(--display)}

/* ============ FOOTER ============ */
.site-footer{background:var(--ink); color:var(--foot-text)}
.foot-grid{display:grid; gap:36px 32px; padding-block:clamp(48px,7vw,72px)}
@media(min-width:680px){ .foot-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr)} .foot-brand{grid-column:1/-1} }
@media(min-width:1000px){ .foot-grid{grid-template-columns:minmax(0,1.5fr) minmax(0,1fr) minmax(0,1fr)} .foot-brand{grid-column:auto} }

.foot-brand .fb-word{display:flex; align-items:center; gap:11px; margin-bottom:14px}
.foot-brand .mark{width:38px; height:38px; border-radius:11px; background:#fff; display:grid; place-items:center}
.foot-brand .mark svg{width:21px; height:21px}
.foot-brand .word{font-family:var(--display); font-weight:700; font-size:1.3rem; color:#fff; letter-spacing:.01em}
.foot-brand .word .fl{color:var(--blue)}
.foot-brand p{margin:0 0 20px; font-size:.92rem; line-height:1.6; max-width:34ch; color:var(--foot-text)}
.foot-store{display:flex; gap:10px; flex-wrap:wrap; margin-bottom:20px}
.foot-social{display:flex; gap:10px}
.foot-social a{width:38px; height:38px; border-radius:12px; background:var(--ink-2); border:1px solid var(--line-dk);
  display:grid; place-items:center; color:#fff; transition:.15s}
.foot-social a:hover{background:var(--blue); border-color:var(--blue)}
.foot-social svg{width:17px; height:17px}

.foot-col h4{font-family:var(--label); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase;
  color:#fff; margin:0 0 16px; display:flex; align-items:center; gap:7px}
.foot-col h4 .ico{width:13px; height:13px; fill:var(--red)}
.foot-col ul{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px}
.foot-col a{font-size:.92rem; color:var(--foot-text); transition:.15s; display:flex; align-items:baseline; gap:8px}
.foot-col a:hover{color:#fff; transform:translateX(3px)}
.foot-pop a{line-height:1.4}
.foot-pop .n{font-family:var(--label); font-size:.7rem; color:var(--blue); flex:none}
.foot-pop .t{min-width:0; overflow-wrap:break-word}

.foot-bottom{border-top:1px solid var(--line-dk); padding-block:22px;
  display:flex; flex-wrap:wrap; gap:12px 20px; align-items:center; justify-content:space-between}
.foot-bottom p{margin:0; font-size:.8rem; color:var(--foot-text)}
.foot-badges{display:flex; gap:10px; flex-wrap:wrap}
.foot-badges span{display:inline-flex; align-items:center; gap:6px; font-family:var(--label); font-size:.66rem;
  letter-spacing:.04em; text-transform:uppercase; color:var(--foot-text);
  border:1px solid var(--line-dk); padding:5px 10px; border-radius:var(--radius-pill)}
.foot-badges svg{width:13px; height:13px; fill:#3ddc84}
.foot-legal{display:flex; flex-wrap:wrap; gap:6px 16px; font-size:.78rem}
.foot-legal a{color:var(--foot-text)} .foot-legal a:hover{color:#fff}

/* ============ MOTION ============ */
/* Tabular figures for sport-style numbers (reading time, counts, dates) */
.meta, .fmeta, .card-foot, .topic span, .video-meta, .trend-item .tm, .comment-metadata, .page-head .crumbs{font-variant-numeric:tabular-nums}
.topic-n{font-family:var(--display); font-weight:700; font-size:1.06rem; line-height:1; color:var(--text); font-variant-numeric:tabular-nums}

/* Scroll reveal — added by JS only, and only when motion is allowed */
.reveal{opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s cubic-bezier(.2,.7,.2,1)}
.reveal.reveal-in{opacity:1; transform:none}
@media(prefers-reduced-motion:reduce){ .reveal{opacity:1; transform:none; transition:none} }

@media(prefers-reduced-motion:reduce){
  *{animation:none !important; transition:none !important; scroll-behavior:auto !important}
}
.reveal{opacity:0; transform:translateY(16px); animation:rise .7s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes rise{to{opacity:1; transform:none}}

/* ====================================================================
   WORDPRESS INTEGRATION — additions beyond the static design system.
   Pagination, comments, post content (WP blocks), widgets, page header.
   ==================================================================== */

/* ---- Generic page / archive header ---- */
.page-head{padding-top:clamp(28px,5vw,52px); padding-bottom:clamp(8px,2vw,16px)}
.page-head .eyebrow{margin-bottom:10px}
.page-head h1{font-size:var(--fs-h1); font-weight:700; letter-spacing:.01em}
.page-head .lead{color:var(--muted); margin:12px 0 0; max-width:62ch; font-size:1.02rem}
.page-head .crumbs{font-family:var(--label); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase; color:var(--muted-2); margin-bottom:14px; display:flex; flex-wrap:wrap; gap:6px; align-items:center}
.page-head .crumbs a{color:var(--blue-700)} .page-head .crumbs a:hover{text-decoration:underline}
.page-head .crumbs .sep{opacity:.5}

/* ---- Pagination ---- */
.pagination{display:flex; justify-content:center; margin-top:clamp(34px,5vw,52px)}
.pagination .nav-links{display:flex; flex-wrap:wrap; gap:8px; align-items:center}
.pagination .page-numbers{display:inline-grid; place-items:center; min-width:44px; height:44px; padding:0 12px;
  border:1px solid var(--line); border-radius:12px; background:#fff; font-family:var(--display); font-weight:600;
  font-size:.95rem; color:var(--text); transition:.15s}
.pagination a.page-numbers:hover{border-color:#cfd6e2; box-shadow:var(--shadow-1)}
.pagination .page-numbers.current{background:var(--ink); color:#fff; border-color:var(--ink)}
.pagination .page-numbers.dots{border-color:transparent; background:transparent}

/* post-to-post nav (single) */
.post-nav{display:grid; gap:12px; margin:clamp(32px,5vw,48px) 0; grid-template-columns:minmax(0,1fr)}
@media(min-width:680px){ .post-nav{grid-template-columns:minmax(0,1fr) minmax(0,1fr)} }
.post-nav a{display:block; padding:18px 20px; border:1px solid var(--line); border-radius:var(--radius-sm);
  background:#fff; transition:.18s; box-shadow:var(--shadow-1)}
.post-nav a:hover{border-color:#cfd6e2; transform:translateY(-3px); box-shadow:var(--shadow-2)}
.post-nav .dir{font-family:var(--label); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted-2)}
.post-nav .ttl{font-family:var(--display); font-weight:700; font-size:1.02rem; margin-top:6px; display:block; line-height:1.3}
.post-nav .next{text-align:right}

/* Related "Read next" grid on single posts */
.related{margin-top:clamp(40px,6vw,64px); padding-top:clamp(30px,4vw,44px); border-top:1px solid var(--line)}

/* ---- Single post layout ---- */
.single-wrap{padding-top:clamp(24px,4vw,40px); padding-bottom:var(--sec-pad)}

/* Article share controls — inline row on mobile, gutter rail on desktop */
.entry-wrap{position:relative}
.article-share{max-width:760px; margin:0 auto clamp(20px,3vw,28px); padding-bottom:18px; border-bottom:1px solid var(--line)}
.article-share-inner{display:flex; align-items:center; gap:9px}
.article-share .share-label{font-family:var(--label); font-size:.64rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted-2); margin-right:2px}
.share-btn{position:relative; display:inline-grid; place-items:center; width:40px; height:40px; border-radius:11px;
  border:1px solid var(--line); background:#fff; color:var(--text); cursor:pointer; transition:border-color .15s ease, color .15s ease}
.share-btn:hover{border-color:#cfd6e2; color:var(--blue-700)}
.share-btn svg{width:17px; height:17px; fill:currentColor}
.share-btn.share-copy svg{fill:none; stroke:currentColor}
.share-done{position:absolute; bottom:calc(100% + 8px); left:50%; transform:translateX(-50%) translateY(4px);
  background:var(--ink); color:#fff; font-family:var(--label); font-size:.58rem; letter-spacing:.08em; text-transform:uppercase;
  padding:4px 8px; border-radius:6px; white-space:nowrap; opacity:0; pointer-events:none; transition:opacity .15s ease, transform .15s ease}
.share-copy.is-copied .share-done{opacity:1; transform:translateX(-50%) translateY(0)}
@media(min-width:1120px){
  .article-share{position:absolute; top:0; bottom:0; left:calc(50% - 380px - 56px); width:42px; max-width:none; margin:0; padding:0; border:0}
  .article-share-inner{position:sticky; top:100px; flex-direction:column; gap:10px}
  .article-share .share-label{writing-mode:vertical-rl; transform:rotate(180deg); margin:0 0 4px}
}
.single-hero{max-width:820px; margin-inline:auto; text-align:center; margin-bottom:clamp(22px,3.5vw,34px)}
.single-hero h1{font-size:var(--fs-display); font-weight:700; margin:14px 0 0; letter-spacing:.01em}
.single-dek{max-width:660px; margin:14px auto 0; color:var(--muted); font-size:clamp(1.05rem,2vw,1.22rem); line-height:1.5}
.single-hero .post-meta{display:flex; flex-wrap:wrap; gap:8px 14px; justify-content:center; align-items:center;
  margin-top:18px; font-family:var(--label); font-size:.74rem; text-transform:uppercase; letter-spacing:.04em; color:var(--muted)}
.single-hero .post-meta .av{width:26px; height:26px; border-radius:50%; object-fit:cover}
.single-figure{max-width:1000px; margin:0 auto clamp(26px,4vw,40px); border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow-2); aspect-ratio:16/9; background:linear-gradient(135deg,#dbe3f0,#eef1f6)}
.single-figure img{width:100%; height:100%; object-fit:cover}
.entry{max-width:760px; margin-inline:auto}

/* The post content uses the .prose styles (h2/h3/blockquote/table/code from the
   design system). These extra rules cover native WordPress blocks. */
.entry > *{max-width:760px; margin-left:auto; margin-right:auto}
/* Comfortable reading measure — body text sits narrower than figures/media. */
.entry > p, .entry > ul, .entry > ol, .entry > h2, .entry > h3, .entry > h4, .entry > blockquote{max-width:70ch}
.entry .alignwide{max-width:1000px}
.entry .alignfull{max-width:none; width:100vw; margin-left:calc(50% - 50vw); margin-right:calc(50% - 50vw); border-radius:0}
.entry figure{margin:26px auto}
.entry figure img{border-radius:var(--radius-sm)}
.entry figcaption{font-family:var(--label); font-size:.72rem; color:var(--muted-2); text-align:center; margin-top:8px; letter-spacing:.02em}
.entry .wp-block-image{margin:26px auto}
.entry .wp-block-pullquote{border:0; border-block:2px solid var(--red); padding:26px 0; margin:36px auto; text-align:center}
.entry .wp-block-pullquote p{font-family:var(--display); font-weight:700; font-size:clamp(1.45rem,3.2vw,1.95rem); line-height:1.22; color:var(--ink); letter-spacing:.01em}
.entry .wp-block-pullquote cite{display:block; margin-top:12px; font-family:var(--label); font-size:.72rem; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); font-style:normal}

/* HTML sitemap shortcode ([rfb_sitemap]) */
.rfb-sitemap{display:grid; gap:30px}
.rfb-sitemap-group h2{margin:0 0 12px; font-family:var(--display); font-size:1.2rem; font-weight:700}
.rfb-sitemap-group ul{list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:6px 28px}
.rfb-sitemap-group ul ul{display:block; margin:4px 0 0 14px}
.rfb-sitemap-group a{text-decoration:none}
.rfb-sitemap-group a:hover{text-decoration:underline}
.entry .wp-block-table table{width:100%; border-collapse:collapse; font-size:.92rem}
.entry .wp-block-table th{background:var(--ink); color:#fff; font-family:var(--display); padding:12px 16px; text-align:left}
.entry .wp-block-table td{padding:12px 16px; border-top:1px solid var(--line)}
.entry .wp-block-table tr:nth-child(even) td{background:#fafbfd}
.entry pre{background:var(--ink); color:#e8edf5; border-radius:var(--radius-sm); padding:18px 20px; overflow:auto;
  font-family:var(--mono); font-size:.86rem; line-height:1.55}
.entry .wp-block-button__link{display:inline-flex; align-items:center; gap:8px; background:var(--blue); color:#fff;
  font-family:var(--display); font-weight:600; padding:11px 20px; border-radius:12px; text-decoration:none}
.entry .wp-block-button__link:hover{background:var(--blue-700)}
.entry hr{border:0; height:1px; background:var(--line); margin:34px auto}
.entry h2{font-family:var(--display); font-size:var(--fs-h2); font-weight:700; margin:34px auto 12px; letter-spacing:.01em}
.entry h3{font-family:var(--display); font-size:var(--fs-h3); font-weight:700; margin:28px auto 10px}
.entry p{margin:0 auto 16px; color:#283041; font-size:1.04rem; line-height:1.72}

/* Drop cap on the first paragraph */
.entry > p:first-of-type::first-letter{float:left; font-family:var(--display); font-weight:700; font-size:3.3em;
  line-height:.78; padding:8px 12px 0 0; color:var(--blue-700)}

/* In-article CTA (inserted mid-content) */
.inline-cta{position:relative; overflow:hidden; margin:34px auto; padding:clamp(22px,3vw,28px) clamp(22px,3vw,30px);
  border-radius:var(--radius); color:#fff; background:linear-gradient(120deg,var(--blue-700),var(--blue));
  box-shadow:0 18px 40px -24px rgba(37,99,235,.8); display:flex; align-items:center; gap:18px; flex-wrap:wrap}
.entry .inline-cta p{margin:0; flex:1 1 240px; font-family:var(--body); font-size:1.02rem; line-height:1.45; color:#fff}
.inline-cta .btn-light{background:#fff; color:var(--blue-700); flex:none}
.inline-cta .btn-light:hover{background:#eef4ff}
.inline-cta-bolt{position:absolute; right:-18px; bottom:-28px; width:150px; height:150px; opacity:.16; transform:rotate(8deg); pointer-events:none}
.inline-cta-bolt svg{width:100%; height:100%; fill:#fff}
.entry a{color:var(--blue-700); font-weight:600; text-decoration:underline; text-decoration-color:#bcd2ff; text-underline-offset:3px}
.entry ul,.entry ol{margin:0 auto 18px; padding-left:24px; color:#283041; line-height:1.7}
.entry li{margin-bottom:8px}
.entry img{border-radius:var(--radius-sm)}

/* tag list under post */
.entry-tags{display:flex; flex-wrap:wrap; gap:8px; max-width:760px; margin:clamp(28px,4vw,40px) auto 0}
.entry-tags a{font-family:var(--label); font-size:.72rem; text-transform:uppercase; letter-spacing:.04em;
  background:var(--bg); border:1px solid var(--line); padding:6px 12px; border-radius:var(--radius-pill); color:var(--muted)}
.entry-tags a:hover{color:var(--blue-700); border-color:#cfd6e2}

/* author box */
.author-box{display:flex; gap:16px; align-items:flex-start; max-width:760px; margin:clamp(30px,4vw,44px) auto 0;
  padding:22px 24px; background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-1)}
.author-box .av{width:56px; height:56px; border-radius:50%; object-fit:cover; flex:none; background:var(--bg)}
.author-box h4{font-family:var(--display); font-size:1.1rem; font-weight:700}
.author-box .role{font-family:var(--label); font-size:.66rem; text-transform:uppercase; letter-spacing:.12em; color:var(--red); margin:0 0 4px}
.author-box h4{font-family:var(--display); font-size:1.2rem; font-weight:700}
.author-box .author-bio{margin:8px 0 0; font-size:.94rem; color:var(--muted); line-height:1.6}
.author-box p{margin:0; font-size:.94rem; color:var(--muted); line-height:1.6}
.author-links{display:flex; flex-wrap:wrap; align-items:center; gap:12px 16px; margin-top:14px}
.author-social{display:flex; gap:8px}
.author-social a{display:inline-grid; place-items:center; width:34px; height:34px; border-radius:9px; border:1px solid var(--line); color:var(--muted); transition:border-color .15s ease, color .15s ease}
.author-social a:hover{color:var(--blue-700); border-color:#cfd6e2}
.author-social svg{width:16px; height:16px; fill:currentColor}
.author-more{display:inline-flex; align-items:center; gap:6px; font-family:var(--display); font-weight:600; font-size:.86rem; color:var(--blue-700)}
.author-more svg{width:14px; height:14px; transition:transform .15s ease}
.author-more:hover svg{transform:translateX(3px)}

/* ---- Comments ---- */
.comments{max-width:760px; margin:clamp(40px,6vw,64px) auto 0}
.comments-title{font-family:var(--display); font-size:1.4rem; font-weight:700; margin-bottom:24px}
.comment-list{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:20px}
.comment-list ul.children{list-style:none; margin:16px 0 0; padding-left:clamp(14px,3vw,34px); display:flex; flex-direction:column; gap:18px}
.comment-body{padding:18px 20px; background:#fff; border:1px solid var(--line); border-radius:var(--radius-sm); box-shadow:var(--shadow-1)}
.comment-meta{display:flex; align-items:center; gap:10px; margin-bottom:8px}
.comment-meta .avatar{border-radius:50%}
.comment-author{font-family:var(--display); font-weight:700; font-size:.96rem}
.comment-metadata{font-family:var(--label); font-size:.68rem; text-transform:uppercase; letter-spacing:.04em; color:var(--muted-2)}
.comment-content{font-size:.96rem; color:#283041; line-height:1.6}
.comment-content p{margin:0 0 10px}
.reply a{font-family:var(--label); font-size:.7rem; text-transform:uppercase; letter-spacing:.06em; color:var(--blue-700)}
#respond.is-collapsed{display:none}
.comment-toggle{display:inline-flex; align-items:center; gap:8px; margin-top:24px;
  font-family:var(--display); font-weight:600; font-size:.95rem; padding:11px 20px; border-radius:12px;
  border:1px solid var(--line); background:#fff; color:var(--text); cursor:pointer;
  transition:border-color .15s ease, color .15s ease}
.comment-toggle:hover{border-color:#cfd6e2; color:var(--blue-700)}
.comment-toggle[hidden]{display:none}
.comment-respond{margin-top:28px; padding:24px; background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-1)}
.comment-reply-title{font-family:var(--display); font-size:1.2rem; font-weight:700; margin-bottom:8px}
.comment-form label{display:block; font-family:var(--label); font-size:.7rem; text-transform:uppercase; letter-spacing:.06em; color:var(--muted); margin:14px 0 6px}
.comment-form input[type=text],.comment-form input[type=email],.comment-form input[type=url],.comment-form textarea{
  width:100%; border:1px solid var(--line); border-radius:11px; padding:11px 14px; font:inherit; font-size:.95rem;
  background:#fff; color:var(--text)}
.comment-form input:focus,.comment-form textarea:focus{outline:none; border-color:var(--blue); box-shadow:0 0 0 3px rgba(59,130,246,.15)}
.comment-form .form-submit{margin-top:18px}
.comment-form .submit{display:inline-flex; align-items:center; gap:8px; cursor:pointer; background:var(--blue); color:#fff;
  font-family:var(--display); font-weight:600; font-size:.95rem; padding:12px 22px; border-radius:12px; border:0}
.comment-form .submit:hover{background:var(--blue-700)}

/* ---- Widgets (footer + sidebar) ---- */
.widget{margin-bottom:24px}
.widget-title{font-family:var(--label); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:#fff; margin:0 0 16px}
.site-footer .widget ul{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px}
.site-footer .widget a{font-size:.92rem; color:var(--foot-text)}
.site-footer .widget a:hover{color:#fff}
.site-footer .widget select{width:100%; padding:10px; border-radius:10px; border:1px solid var(--line-dk); background:var(--ink-2); color:#fff}

/* sidebar (optional, used on default page template if a sidebar is active) */
.has-sidebar{display:grid; gap:clamp(28px,4vw,48px); grid-template-columns:minmax(0,1fr)}
@media(min-width:1000px){ .has-sidebar{grid-template-columns:minmax(0,1fr) 320px} }
.sidebar .widget{background:#fff; border:1px solid var(--line); border-radius:var(--radius-sm); padding:20px; box-shadow:var(--shadow-1)}
.sidebar .widget-title{color:var(--text); font-size:.7rem; margin-bottom:14px}
.sidebar .widget ul{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px}
.sidebar .widget a{color:var(--muted); font-size:.92rem} .sidebar .widget a:hover{color:var(--blue-700)}

/* ---- Empty-state (no posts / 404) ---- */
.empty-state{max-width:620px; margin-inline:auto; text-align:center; padding:clamp(40px,8vw,90px) 0}
.empty-state .big{font-family:var(--display); font-weight:700; font-size:clamp(3rem,16vw,7rem);
  background:linear-gradient(120deg,var(--blue),var(--red)); -webkit-background-clip:text; background-clip:text; color:transparent; line-height:1}
.empty-state h1{font-size:clamp(1.5rem,4.4vw,2.2rem); font-weight:700; margin:14px 0 10px}
.empty-state p{color:var(--muted); margin:0 auto 24px; max-width:48ch}
.empty-state .search{max-width:380px; margin:0 auto 18px}

/* skip link target offset for sticky header */
#main{scroll-margin-top:80px}

/* drawer nav when rendered from an assigned WordPress menu */
.drawer-nav .menu{list-style:none; margin:0; padding:0}
.drawer-nav .menu > li{margin-bottom:18px}
.drawer-nav .menu > li > a{display:block; font-family:var(--display); font-weight:700; font-size:1.05rem; padding:6px 0}
.drawer-nav .menu .sub-menu{list-style:none; margin:6px 0 2px; padding:0; display:flex; flex-wrap:wrap; gap:6px 8px}
.drawer-nav .menu .sub-menu a{font-size:.83rem; color:var(--muted); background:var(--bg); border:1px solid var(--line);
  padding:5px 11px; border-radius:var(--radius-pill)}
.drawer-nav .menu .sub-menu a:hover{color:var(--blue-700); border-color:#cfd6e2}

/* footer legal menu rendered from a WP menu */
.foot-legal .legal-menu{display:flex; flex-wrap:wrap; gap:6px 16px; list-style:none; margin:0; padding:0}
.foot-legal .legal-menu li{margin:0}
