/* ============================================================
   CyberSpaceChronicles — Modern Stylesheet 2.0
   Brand: #0A0A0F bg | #00FFB2 accent | #FF6B35 secondary
   Fonts: Playfair Display (headlines) | Inter (body)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,700;0,900;1,700&family=Inter:wght@300;400;500;600;700;800&display=swap');

/* ---- Variables --------------------------------------------- */
:root {
  --bg:           #080810;
  --bg-2:         #0E0E1A;
  --bg-3:         #141420;
  --surface:      #12121C;
  --surface-2:    #1A1A28;
  --border:       rgba(255,255,255,0.07);
  --border-hover: rgba(0,255,178,0.25);
  --accent:       #00FFB2;
  --accent-dim:   #00CC8E;
  --accent-glow:  rgba(0,255,178,0.15);
  --secondary:    #FF6B35;
  --secondary-dim:#CC5529;
  --secondary-glow:rgba(255,107,53,0.15);
  --tertiary:     #7C5CFF;
  --tertiary-glow:rgba(124,92,255,0.18);
  --grad-accent:  linear-gradient(120deg, #00FFB2 0%, #4DD6FF 50%, #7C5CFF 100%);
  --grad-warm:    linear-gradient(120deg, #FF6B35 0%, #FFB547 100%);
  --text:         #F0F0F8;
  --text-muted:   #8B8BA7;
  --text-faint:   #55556A;
  --danger:       #FF4D4D;
  --warning:      #FFB547;
  --info:         #4D9EFF;
  --success:      #00E887;
  --radius:       10px;
  --radius-lg:    16px;
  --radius-xl:    24px;
  --radius-pill:  999px;
  --shadow:       0 4px 32px rgba(0,0,0,0.5);
  --shadow-lg:    0 12px 60px rgba(0,0,0,0.7);
  --shadow-glow:  0 0 40px rgba(0,255,178,0.12);
  --font-head:    'Playfair Display', Georgia, serif;
  --font-body:    'Inter', -apple-system, sans-serif;
  --ease:         cubic-bezier(0.4, 0, 0.2, 1);
  --transition:   0.2s var(--ease);
  --max-w:        1320px;
}

[data-theme="light"] {
  --bg: #F5F5FA; --bg-2: #FFFFFF; --bg-3: #EEEEF6;
  --surface: #FFFFFF; --surface-2: #F8F8FF;
  --border: rgba(0,0,0,0.08); --border-hover: rgba(0,180,120,0.3);
  --accent: #009E70; --accent-dim: #007A56; --accent-glow: rgba(0,158,112,0.12);
  --text: #0D0D1A; --text-muted: #555572; --text-faint: #999AB2;
  --shadow: 0 4px 24px rgba(0,0,0,0.08); --shadow-glow: 0 0 32px rgba(0,158,112,0.08);
}

/* ---- Reset & Base ------------------------------------------ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  line-height: 1.65;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; transition: color var(--transition); }
img { max-width: 100%; height: auto; display: block; }
button { cursor: pointer; font-family: var(--font-body); }
input, textarea, select {
  font-family: var(--font-body);
  background: var(--bg-3);
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: var(--radius);
  padding: 11px 16px;
  font-size: 0.9rem;
  transition: border-color var(--transition), box-shadow var(--transition);
  width: 100%;
}
input:focus, textarea:focus, select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
}

/* ---- Layout ------------------------------------------------ */
.container { max-width: var(--max-w); margin: 0 auto; padding: 0 24px; }

/* ---- Breaking News Ticker ---------------------------------- */
.breaking-ticker {
  background: var(--secondary);
  overflow: hidden;
  position: relative;
  height: 36px;
  display: flex;
  align-items: center;
}
.breaking-ticker__label {
  background: #0A0A0F;
  color: var(--secondary);
  font-weight: 800;
  font-size: 0.68rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0 16px;
  height: 100%;
  display: flex;
  align-items: center;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 2;
  white-space: nowrap;
}
.breaking-ticker__label::after {
  content: '';
  position: absolute;
  right: -12px;
  top: 0; bottom: 0;
  width: 24px;
  background: linear-gradient(to right, #0A0A0F, transparent);
}
.breaking-ticker__track {
  display: flex;
  animation: ticker-scroll 45s linear infinite;
  white-space: nowrap;
  padding-left: 140px;
  font-size: 0.82rem;
  font-weight: 600;
  color: #fff;
}
.breaking-ticker__item { padding-right: 64px; }
.breaking-ticker__item::before { content: '◆'; margin-right: 12px; opacity: 0.6; font-size: 0.6em; }
@keyframes ticker-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ================================================================
   HEADER SYSTEM — Top bar · Masthead · Topics bar
   ================================================================ */

/* ---- Top Utility Bar --------------------------------------- */
.top-bar {
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  height: 38px;
  font-size: 0.74rem;
  color: var(--text-faint);
  overflow: hidden;
}
.top-bar__inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 24px;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.top-bar__left { display: flex; align-items: center; gap: 10px; }
.top-bar__date { font-weight: 500; font-variant-numeric: tabular-nums; }
.top-bar__sep { color: var(--text-faint); opacity: 0.4; }
.top-bar__edition { font-style: italic; color: var(--text-faint); }
.top-bar__right { display: flex; align-items: center; gap: 14px; }
.top-bar__social {
  color: var(--text-faint);
  display: flex; align-items: center;
  transition: color var(--transition);
}
.top-bar__social:hover { color: var(--text-muted); }
.top-bar__divider { width: 1px; height: 14px; background: var(--border); }
.top-bar__subscribe {
  background: var(--accent);
  color: #080810;
  font-weight: 700;
  font-size: 0.7rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: var(--radius-pill);
  transition: background var(--transition);
}
.top-bar__subscribe:hover { background: var(--accent-dim); }

/* ---- Masthead --------------------------------------------- */
.masthead {
  background: rgba(8,8,16,0.97);
  backdrop-filter: blur(28px);
  -webkit-backdrop-filter: blur(28px);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 100;
  height: 70px;
}
.masthead__inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 20px;
  height: 100%;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
}
.masthead__left  { display: flex; align-items: center; gap: 4px; }
.masthead__center { display: flex; justify-content: center; }
.masthead__right { display: flex; align-items: center; justify-content: flex-end; gap: 4px; }

/* Publication name */
.masthead__logo { display: block; text-align: center; line-height: 1; }
.masthead__name {
  display: block;
  font-family: var(--font-head);
  font-size: 1.6rem;
  font-weight: 900;
  color: var(--text);
  letter-spacing: -0.035em;
  line-height: 1;
  transition: color var(--transition);
}
.masthead__logo:hover .masthead__name { color: var(--accent); }
.masthead__tagline {
  display: block;
  font-family: var(--font-body);
  font-size: 0.595rem;
  font-weight: 700;
  color: var(--text-faint);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin-top: 5px;
}

/* Hamburger button */
.hamburger {
  background: none; border: none; cursor: pointer;
  padding: 9px; border-radius: var(--radius);
  display: flex; flex-direction: column; gap: 5px;
  transition: background var(--transition);
  flex-shrink: 0;
}
.hamburger:hover { background: var(--surface); }
.hamburger span {
  display: block; width: 22px; height: 2px;
  background: var(--text-muted); border-radius: 2px;
  transition: transform 0.28s var(--ease), opacity 0.18s, width 0.18s;
  transform-origin: center;
}
.hamburger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); background: var(--text); }
.hamburger.is-open span:nth-child(2) { opacity: 0; width: 0; }
.hamburger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); background: var(--text); }

/* Masthead icon buttons */
.masthead__icon-btn,
.nav__search-btn,
.nav__theme-toggle,
.nav__icon-btn {
  background: none; border: none; color: var(--text-muted);
  width: 40px; height: 40px; border-radius: var(--radius-pill);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: 0.78rem; font-weight: 700;
  letter-spacing: 0.02em;
  transition: color var(--transition), background var(--transition);
}
.masthead__icon-btn:hover,
.nav__search-btn:hover,
.nav__theme-toggle:hover,
.nav__icon-btn:hover { color: var(--text); background: var(--surface); }

/* Auth injected by Clerk */
.nav__auth-btn {
  background: var(--accent); color: #080810;
  border: none; padding: 8px 18px; border-radius: var(--radius-pill);
  font-weight: 700; font-size: 0.82rem;
  letter-spacing: 0.01em; cursor: pointer;
  transition: background var(--transition);
  white-space: nowrap;
}
.nav__auth-btn:hover { background: var(--accent-dim); }
.nav__user {
  display: flex; align-items: center; gap: 8px; cursor: pointer;
  padding: 4px 10px 4px 4px; border-radius: var(--radius-pill);
  border: 1px solid var(--border); transition: all var(--transition);
}
.nav__user:hover { border-color: var(--border-hover); background: var(--surface); }
.nav__user img { width: 30px; height: 30px; border-radius: 50%; object-fit: cover; }
.nav__user-name { font-size: 0.82rem; font-weight: 600; }

/* ---- Topics Bar ------------------------------------------- */
.topics-bar {
  background: var(--bg-2);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 70px;
  z-index: 90;
  /* Soft edge fade — indicates scroll */
  -webkit-mask-image: linear-gradient(to right, transparent 0, #000 20px, #000 calc(100% - 20px), transparent 100%);
  mask-image: linear-gradient(to right, transparent 0, #000 20px, #000 calc(100% - 20px), transparent 100%);
}
.topics-bar__inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  overflow-x: auto;
  scrollbar-width: none;
}
.topics-bar__inner::-webkit-scrollbar { display: none; }

/* Tabs — both .category-tab (JS-injected) and any static ones */
.category-tab {
  padding: 11px 18px;
  font-size: 0.83rem;
  font-weight: 600;
  color: var(--text-faint);
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  border-top: 2px solid transparent;
  transition: color 0.15s, border-color 0.15s;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
  flex-shrink: 0;
  letter-spacing: 0.01em;
}
.category-tab:hover { color: var(--text-muted); border-bottom-color: var(--border-hover); }
.category-tab.active { color: var(--text); border-bottom-color: var(--accent); }

/* Hide the old category-tabs wrapper (replaced by topics-bar) */
.category-tabs { display: none; }

/* ---- Reading Progress Bar --------------------------------- */
.reading-progress {
  position: fixed;
  top: 0; left: 0;
  height: 3px;
  width: var(--rp, 0%);
  background: var(--accent);
  z-index: 999;
  transition: width 80ms linear;
  pointer-events: none;
  border-radius: 0 2px 2px 0;
  display: none;          /* shown only on article pages via JS */
}
.reading-progress.is-active { display: block; }

/* ---- Mobile Menu Overlay ---------------------------------- */
.mobile-menu {
  position: fixed; inset: 0;
  z-index: 200;
  visibility: hidden; pointer-events: none;
}
.mobile-menu.is-open { visibility: visible; pointer-events: all; }
.mobile-menu__backdrop {
  position: absolute; inset: 0;
  background: rgba(4,4,10,0.75);
  backdrop-filter: blur(6px);
  opacity: 0; transition: opacity 0.3s var(--ease);
}
.mobile-menu.is-open .mobile-menu__backdrop { opacity: 1; }
.mobile-menu__panel {
  position: absolute; left: 0; top: 0; bottom: 0;
  width: min(320px, 82vw);
  background: var(--bg-2);
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  transform: translateX(-100%);
  transition: transform 0.32s var(--ease);
  overflow-y: auto; overflow-x: hidden;
  box-shadow: 12px 0 48px rgba(0,0,0,0.5);
}
.mobile-menu.is-open .mobile-menu__panel { transform: none; }

.mobile-menu__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 20px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.mobile-menu__brand {
  font-family: var(--font-head);
  font-size: 1.15rem; font-weight: 900;
  color: var(--text); letter-spacing: -0.02em;
}
.mobile-menu__close-btn {
  background: var(--surface); border: 1px solid var(--border);
  color: var(--text-muted); width: 34px; height: 34px;
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: 1.1rem; line-height: 1;
  transition: all var(--transition);
}
.mobile-menu__close-btn:hover { color: var(--text); border-color: var(--border-hover); }

.mobile-menu__search-wrap {
  padding: 14px 20px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.mobile-menu__search-wrap input {
  background: var(--surface); border-color: var(--border);
  border-radius: var(--radius-pill);
  font-size: 0.88rem;
}

.mobile-menu__section-label {
  font-size: 0.65rem; font-weight: 800;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-faint);
  padding: 18px 20px 6px;
}
.mobile-menu__links { flex: 1; padding-bottom: 8px; }
.mobile-menu__links a {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 20px;
  color: var(--text-muted); font-weight: 500; font-size: 0.93rem;
  border-left: 3px solid transparent;
  transition: all var(--transition);
}
.mobile-menu__links a:hover {
  color: var(--text); background: var(--surface);
  border-left-color: var(--accent);
}
.mobile-menu__links a.active {
  color: var(--accent); background: var(--accent-glow);
  border-left-color: var(--accent);
}

.mobile-menu__foot {
  padding: 18px 20px; border-top: 1px solid var(--border);
  display: flex; flex-direction: column; gap: 14px; flex-shrink: 0;
}
.mobile-menu__socials { display: flex; gap: 12px; }
.mobile-menu__socials a {
  color: var(--text-faint); transition: color var(--transition);
  display: flex; align-items: center;
}
.mobile-menu__socials a:hover { color: var(--text-muted); }
.mobile-menu__cta {
  display: block; text-align: center;
  padding: 11px 16px; background: var(--accent); color: #080810;
  font-weight: 700; font-size: 0.88rem; border-radius: var(--radius-pill);
  transition: background var(--transition);
}
.mobile-menu__cta:hover { background: var(--accent-dim); }

/* ---- Back-to-top button ----------------------------------- */
.back-to-top {
  position: fixed; bottom: 28px; right: 24px;
  width: 42px; height: 42px; border-radius: 50%;
  background: var(--surface-2); border: 1px solid var(--border);
  color: var(--text-muted);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; z-index: 80;
  opacity: 0; transform: translateY(12px);
  transition: opacity 0.3s, transform 0.3s, background var(--transition), color var(--transition);
  box-shadow: var(--shadow); pointer-events: none;
}
.back-to-top.is-visible { opacity: 1; transform: none; pointer-events: all; }
.back-to-top:hover { background: var(--accent); color: #080810; border-color: var(--accent); }

/* ---- Nav responsive --------------------------------------- */
/* Default: left-cluster search visible, right-cluster search hidden (desktop) */
#mobileSearchBtn { display: none; }

@media (max-width: 860px) {
  .top-bar__edition, .top-bar__sep { display: none; }
  .masthead__name { font-size: 1.3rem; }
}
@media (max-width: 768px) {
  /* On small screens: show right-cluster search, hide left-cluster one */
  .masthead__search-hint { display: none; }
  #mobileSearchBtn { display: flex; }
}
@media (max-width: 560px) {
  .top-bar { display: none; }
  .masthead { height: 60px; }
  .topics-bar { top: 60px; }
  .masthead__name { font-size: 1.1rem; }
  .masthead__tagline { display: none; }
}

/* ---- Hero — Full-bleed magazine split ---------------------- */
.hero {
  position: relative;
  overflow: hidden;
  min-height: 580px;
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.hero__image-pane {
  position: relative;
  overflow: hidden;
  min-height: 480px;
}
.hero__image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 8s ease;
}
.hero:hover .hero__image { transform: scale(1.04); }
.hero__image-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, var(--bg) 0%, transparent 40%),
              linear-gradient(to top, var(--bg) 0%, transparent 50%);
}
.hero__content-pane {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 60px 56px 60px 64px;
  background: linear-gradient(135deg, var(--bg-2) 0%, var(--bg) 100%);
  position: relative;
}
.hero__content-pane::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 2px;
  height: 60%;
  background: linear-gradient(to bottom, var(--accent), transparent);
}
.hero__eyebrow {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 20px;
}
.hero__badge {
  display: inline-flex; align-items: center;
  background: var(--accent); color: #080810;
  font-size: 0.68rem; font-weight: 800; letter-spacing: 0.12em;
  text-transform: uppercase; padding: 5px 12px; border-radius: var(--radius-pill);
}
.hero__featured-label {
  font-size: 0.75rem; font-weight: 600; color: var(--text-faint);
  letter-spacing: 0.1em; text-transform: uppercase;
}
.hero__title {
  font-family: var(--font-head);
  font-size: clamp(1.7rem, 3vw, 2.6rem);
  font-weight: 900;
  line-height: 1.12;
  margin-bottom: 16px;
  letter-spacing: -0.02em;
}
.hero__title a { color: var(--text); transition: color var(--transition); }
.hero__title a:hover { color: var(--accent); }
.hero__subtitle {
  color: var(--text-muted);
  font-size: 1rem;
  max-width: 460px;
  margin-bottom: 28px;
  line-height: 1.6;
}
.hero__meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.hero__author { display: flex; align-items: center; gap: 9px; }
.hero__author img { width: 34px; height: 34px; border-radius: 50%; object-fit: cover; border: 2px solid var(--border); }
.hero__author-name { font-size: 0.85rem; font-weight: 600; }
.hero__date, .hero__read-time {
  font-size: 0.78rem; color: var(--text-faint);
  display: flex; align-items: center; gap: 5px;
}
.hero__cta {
  margin-top: 28px;
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--accent); font-weight: 700; font-size: 0.9rem;
  transition: gap var(--transition);
}
.hero__cta:hover { gap: 12px; color: var(--accent); }

/* Mobile hero fallback */
@media (max-width: 900px) {
  .hero { grid-template-columns: 1fr; min-height: 0; }
  .hero__image-pane { min-height: 320px; }
  .hero__image-overlay { background: linear-gradient(to top, var(--bg) 0%, transparent 60%); }
  .hero__content-pane { padding: 36px 24px; }
  .hero__content-pane::before { display: none; }
}

/* ---- Bento Grid -------------------------------------------- */
.bento {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 200px;
  gap: 16px;
}
.bento__item {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  position: relative;
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}
.bento__item:hover {
  border-color: var(--border-hover);
  box-shadow: 0 8px 40px rgba(0,0,0,0.4), 0 0 0 1px var(--border-hover);
  transform: translateY(-2px);
  z-index: 2;
}
.bento__item--wide  { grid-column: span 8; grid-row: span 2; }
.bento__item--tall  { grid-column: span 4; grid-row: span 2; }
.bento__item--half  { grid-column: span 6; grid-row: span 1; }
.bento__item--third { grid-column: span 4; grid-row: span 1; }
.bento__item--small { grid-column: span 3; grid-row: span 1; }

.bento__image {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.5s var(--ease);
}
.bento__item:hover .bento__image { transform: scale(1.05); }
.bento__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(8,8,16,0.95) 0%, rgba(8,8,16,0.4) 60%, transparent 100%);
}
.bento__body {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 20px;
}
.bento__category {
  font-size: 0.68rem; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--accent);
  margin-bottom: 6px; display: block;
}
.bento__title {
  font-family: var(--font-head);
  color: #fff;
  line-height: 1.25;
  font-weight: 700;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.bento__item--wide  .bento__title { font-size: 1.5rem; -webkit-line-clamp: 3; }
.bento__item--tall  .bento__title { font-size: 1.1rem; -webkit-line-clamp: 3; }
.bento__item--half  .bento__title { font-size: 1rem;   -webkit-line-clamp: 2; }
.bento__item--third .bento__title { font-size: 0.95rem; -webkit-line-clamp: 2; }
.bento__item--small .bento__title { font-size: 0.88rem; -webkit-line-clamp: 2; }
.bento__title a { color: inherit; }
.bento__meta {
  display: flex; align-items: center; gap: 10px; margin-top: 8px;
  font-size: 0.75rem; color: rgba(255,255,255,0.5);
}

/* Bento no-image fallback */
.bento__item--noimage .bento__body { position: static; padding: 24px; }
.bento__item--noimage .bento__title { color: var(--text); }
.bento__item--noimage .bento__category { color: var(--accent); }

/* ---- Article Card (list / grid) ---------------------------- */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all var(--transition);
  display: flex;
  flex-direction: column;
  position: relative;
}
.card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(to right, var(--accent), var(--secondary));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition);
  z-index: 1;
}
.card:hover::before { transform: scaleX(1); }
.card:hover {
  border-color: var(--border-hover);
  box-shadow: var(--shadow), 0 0 0 1px var(--border-hover);
  transform: translateY(-3px);
}
.card__image {
  aspect-ratio: 16/9;
  overflow: hidden;
  background: var(--bg-3);
  position: relative;
}
.card__image img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.5s var(--ease);
}
.card:hover .card__image img { transform: scale(1.06); }
.card__image-placeholder {
  width: 100%; height: 100%; display: flex; align-items: center; justify-content: center;
  color: var(--text-faint); font-size: 2rem;
  background: linear-gradient(135deg, var(--bg-3), var(--surface-2));
}
.card__body { padding: 20px; display: flex; flex-direction: column; flex: 1; }
.card__category {
  font-size: 0.68rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 9px; display: inline-block;
}
.card__title {
  font-family: var(--font-head);
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: 8px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  letter-spacing: -0.01em;
}
.card__title a { color: var(--text); transition: color var(--transition); }
.card__title a:hover { color: var(--accent); }
.card__excerpt {
  font-size: 0.86rem;
  color: var(--text-muted);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: 16px;
  flex: 1;
  line-height: 1.55;
}
.card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}
.card__author { display: flex; align-items: center; gap: 7px; }
.card__author img { width: 26px; height: 26px; border-radius: 50%; object-fit: cover; }
.card__author-name { font-size: 0.8rem; color: var(--text-muted); font-weight: 500; }
.card__date { font-size: 0.74rem; color: var(--text-faint); }
.card__read-time { font-size: 0.74rem; color: var(--text-faint); white-space: nowrap; }

/* Horizontal card variant */
.card--horizontal {
  flex-direction: row;
  align-items: stretch;
}
.card--horizontal .card__image {
  width: 120px;
  min-width: 120px;
  aspect-ratio: unset;
  border-radius: 0;
}
.card--horizontal .card__body { padding: 16px; }
.card--horizontal .card__title { font-size: 0.9rem; -webkit-line-clamp: 2; }
.card--horizontal .card__excerpt { display: none; }

/* ---- Type Badge -------------------------------------------- */
.type-badge {
  display: inline-block;
  font-size: 0.63rem;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  padding: 3px 9px;
  border-radius: var(--radius-pill);
}
/* Focus (category kicker) + format type badge on one row */
.kicker-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 6px; }
.kicker-row .kicker { margin-bottom: 0; }

.type-badge--intelligence_brief { background: rgba(77,158,255,0.12);  color: #6DB8FF; }
.type-badge--policy_brief        { background: rgba(167,139,250,0.14); color: #C4B5FD; }
.type-badge--policy_analysis     { background: rgba(94,234,212,0.12);  color: #5EEAD4; }
.type-badge--commentary          { background: rgba(255,181,71,0.12);  color: #FFD080; }
.type-badge--opinion             { background: var(--accent-glow);     color: var(--accent); }
.type-badge--sponsored           { background: var(--secondary-glow);  color: var(--secondary); }

/* ---- Section Heading --------------------------------------- */
.section-heading {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 28px;
}
.section-heading__title {
  font-family: var(--font-head);
  font-size: 1.35rem;
  font-weight: 900;
  display: flex; align-items: center; gap: 12px;
  letter-spacing: -0.02em;
}
.section-heading__title::before {
  content: '';
  display: block; width: 4px; height: 22px;
  background: linear-gradient(to bottom, var(--accent), var(--secondary));
  border-radius: 2px;
}
.section-heading__link {
  font-size: 0.84rem; color: var(--text-faint);
  display: flex; align-items: center; gap: 4px;
  transition: color var(--transition);
  font-weight: 500;
}
.section-heading__link:hover { color: var(--accent); }

/* ---- Ad Slot ----------------------------------------------- */
.ad-slot {
  background: var(--bg-3);
  border: 1px dashed var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  text-align: center;
  position: relative;
}
.ad-slot__label {
  font-size: 0.6rem;
  color: var(--text-faint);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 4px 0;
  background: var(--bg-2);
}
.ad-slot--header  { width: 100%; max-height: 90px; }
.ad-slot--sidebar { width: 100%; aspect-ratio: 300/250; }
.ad-slot--inline  { width: 100%; max-height: 60px; }
.ad-slot--footer  { width: 100%; max-height: 90px; }
.ad-slot img { max-width: 100%; max-height: 100%; object-fit: contain; margin: auto; }

/* ---- Sidebar ----------------------------------------------- */
.sidebar { display: flex; flex-direction: column; gap: 28px; }
.sidebar-widget {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 24px;
}
.sidebar-widget__title {
  font-family: var(--font-head);
  font-size: 0.95rem;
  font-weight: 700;
  margin-bottom: 18px;
  display: flex; align-items: center; gap: 8px;
  letter-spacing: -0.01em;
}
.sidebar-widget__title::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
}

/* Trending list */
.trending-list { list-style: none; display: flex; flex-direction: column; gap: 14px; }
.trending-item { display: flex; gap: 14px; align-items: flex-start; }
.trending-item__number {
  font-size: 1.1rem; font-weight: 900;
  color: var(--border); min-width: 26px; line-height: 1.2;
  font-family: var(--font-head);
}
.trending-item:first-child .trending-item__number { color: var(--accent); }
.trending-item:nth-child(2) .trending-item__number { color: var(--secondary); }
.trending-item__title {
  font-size: 0.875rem; font-weight: 600; line-height: 1.35;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
  letter-spacing: -0.01em;
}
.trending-item__title a { color: var(--text); transition: color var(--transition); }
.trending-item__title a:hover { color: var(--accent); }
.trending-item__meta { font-size: 0.72rem; color: var(--text-faint); margin-top: 3px; }

/* ---- Related Articles Sidebar ------------------------------ */
.related-list { list-style: none; display: flex; flex-direction: column; gap: 0; }
.related-item {
  display: flex;
  gap: 12px;
  padding: 14px 0;
  border-bottom: 1px solid var(--border);
  transition: background var(--transition);
  border-radius: var(--radius);
  cursor: pointer;
}
.related-item:last-child { border-bottom: none; }
.related-item:hover { background: var(--accent-glow); padding-left: 8px; padding-right: 8px; }
.related-item__img {
  width: 72px;
  min-width: 72px;
  height: 54px;
  object-fit: cover;
  border-radius: 8px;
  background: var(--bg-3);
  flex-shrink: 0;
}
.related-item__img-placeholder {
  width: 72px; min-width: 72px; height: 54px;
  background: linear-gradient(135deg, var(--bg-3), var(--surface-2));
  border-radius: 8px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-faint); font-size: 1.2rem;
}
.related-item__body { flex: 1; min-width: 0; }
.related-item__category {
  font-size: 0.64rem; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--accent); margin-bottom: 4px; display: block;
}
.related-item__title {
  font-size: 0.84rem; font-weight: 600; line-height: 1.35;
  color: var(--text); display: -webkit-box;
  -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
  letter-spacing: -0.01em;
  transition: color var(--transition);
}
.related-item:hover .related-item__title { color: var(--accent); }
.related-item__meta { font-size: 0.71rem; color: var(--text-faint); margin-top: 5px; }

/* ---- Newsletter CTA ---------------------------------------- */
.newsletter-cta {
  background: linear-gradient(135deg, var(--surface) 0%, var(--surface-2) 50%, rgba(0,255,178,0.04) 100%);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 72px 40px;
  text-align: center;
  margin: 72px 0;
  position: relative;
  overflow: hidden;
}
.newsletter-cta::before {
  content: '';
  position: absolute;
  top: -80px; left: 50%; transform: translateX(-50%);
  width: 400px; height: 400px;
  background: radial-gradient(circle, var(--accent-glow) 0%, transparent 70%);
  pointer-events: none;
}
.newsletter-cta__label {
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--accent);
  margin-bottom: 14px; display: block;
}
.newsletter-cta__title {
  font-family: var(--font-head);
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 900;
  margin-bottom: 12px;
  letter-spacing: -0.02em;
}
.newsletter-cta__sub {
  color: var(--text-muted);
  margin-bottom: 36px;
  max-width: 480px;
  margin-left: auto; margin-right: auto;
  font-size: 0.95rem;
}
.newsletter-cta__form {
  display: flex; gap: 10px; max-width: 460px; margin: 0 auto;
}
.newsletter-cta__form input {
  flex: 1; background: var(--bg-3); border-color: var(--border);
  border-radius: var(--radius-pill);
  padding: 12px 20px;
}
.newsletter-cta__form button {
  background: var(--accent); color: #080810;
  border: none; padding: 12px 28px; border-radius: var(--radius-pill);
  font-weight: 800; font-size: 0.88rem; white-space: nowrap;
  transition: all var(--transition);
}
.newsletter-cta__form button:hover {
  background: var(--accent-dim);
  transform: translateY(-1px);
  box-shadow: 0 4px 20px var(--accent-glow);
}

/* ---- Article Page ------------------------------------------ */
.article-layout {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 48px 24px 96px;
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 56px;
  align-items: start;
}
.article-main { min-width: 0; }
.article-sidebar {
  position: sticky;
  top: 88px;
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.article__header { margin-bottom: 32px; }
.article__eyebrow {
  display: flex; align-items: center; gap: 10px; margin-bottom: 16px;
}
.article__category {
  color: var(--accent); font-weight: 700; font-size: 0.78rem;
  letter-spacing: 0.09em; text-transform: uppercase;
}
.article__title {
  font-family: var(--font-head);
  font-size: clamp(1.75rem, 3.5vw, 2.5rem);
  font-weight: 900;
  line-height: 1.15;
  margin: 14px 0;
  letter-spacing: -0.025em;
}
.article__subtitle {
  font-size: 1.1rem; color: var(--text-muted);
  line-height: 1.6; margin-bottom: 24px;
  font-weight: 400;
}
.article__meta {
  display: flex; align-items: center; gap: 20px; flex-wrap: wrap;
  padding: 18px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.article__author { display: flex; align-items: center; gap: 10px; }
.article__author img {
  width: 40px; height: 40px; border-radius: 50%; object-fit: cover;
  border: 2px solid var(--border);
}
.article__author-name { font-weight: 700; font-size: 0.9rem; }
.article__author-role { font-size: 0.73rem; color: var(--text-faint); }
.article__date, .article__views, .article__read-time {
  font-size: 0.8rem; color: var(--text-muted);
  display: flex; align-items: center; gap: 5px;
}

/* Cover image */
.article__cover {
  width: 100%; aspect-ratio: 16/9; object-fit: cover;
  border-radius: var(--radius-xl); margin-bottom: 36px;
  box-shadow: var(--shadow);
}

/* Rich text body */
.article__body { font-size: 1.05rem; line-height: 1.85; }
.article__body h2 {
  font-family: var(--font-head); font-size: 1.55rem; font-weight: 900;
  margin: 42px 0 16px; letter-spacing: -0.02em;
  color: var(--text);
}
.article__body h3 {
  font-family: var(--font-head); font-size: 1.2rem; font-weight: 700;
  margin: 32px 0 12px; letter-spacing: -0.01em;
}
.article__body p { margin-bottom: 22px; }
.article__body a {
  color: var(--accent);
  text-decoration: underline;
  text-decoration-color: rgba(0,255,178,0.35);
  text-underline-offset: 3px;
  transition: text-decoration-color var(--transition);
}
.article__body a:hover { text-decoration-color: var(--accent); }
.article__body blockquote {
  border-left: 3px solid var(--accent);
  background: var(--accent-glow);
  padding: 22px 28px;
  margin: 32px 0;
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
  font-style: italic;
  color: var(--text-muted);
  font-size: 1.08rem;
}
.article__body code {
  background: var(--bg-3); color: var(--accent);
  padding: 2px 7px; border-radius: 5px; font-size: 0.88em;
  border: 1px solid var(--border);
}
.article__body pre {
  background: var(--bg-3); padding: 22px; border-radius: var(--radius-lg);
  overflow-x: auto; margin-bottom: 22px;
  border: 1px solid var(--border);
}
.article__body pre code { background: none; padding: 0; color: var(--text); border: none; }
.article__body ul, .article__body ol { padding-left: 26px; margin-bottom: 22px; }
.article__body li { margin-bottom: 7px; }
.article__body img { border-radius: var(--radius-lg); margin: 28px auto; box-shadow: var(--shadow); }

/* Reading progress bar */
.reading-progress {
  position: fixed; top: 0; left: 0; z-index: 200;
  height: 3px;
  background: linear-gradient(to right, var(--accent), var(--secondary));
  transform-origin: left;
  transition: transform 0.1s linear;
  width: 100%;
  box-shadow: 0 0 10px var(--accent-glow);
}

/* Share buttons */
.share-buttons {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin: 36px 0;
  padding: 24px;
  background: var(--surface);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
}
.share-label { font-size: 0.8rem; font-weight: 600; color: var(--text-faint); margin-right: 4px; }
.share-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 16px; border-radius: var(--radius-pill); border: 1px solid var(--border);
  font-size: 0.8rem; font-weight: 600; color: var(--text-muted);
  background: var(--bg-3); transition: all var(--transition); cursor: pointer;
}
.share-btn:hover { transform: translateY(-2px); box-shadow: 0 4px 14px rgba(0,0,0,0.3); }
.share-btn--twitter:hover  { border-color: #1DA1F2; color: #1DA1F2; background: rgba(29,161,242,0.1); }
.share-btn--linkedin:hover { border-color: #0A66C2; color: #0A66C2; background: rgba(10,102,194,0.1); }
.share-btn--whatsapp:hover { border-color: #25D366; color: #25D366; background: rgba(37,211,102,0.1); }
.share-btn--copy:hover     { border-color: var(--accent); color: var(--accent); background: var(--accent-glow); }

/* Author card */
.author-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-xl); padding: 28px; margin: 36px 0;
}
.author-card__inner { display: flex; gap: 20px; align-items: flex-start; }
.author-card img { width: 68px; height: 68px; border-radius: 50%; object-fit: cover; flex-shrink: 0; border: 2px solid var(--border); }
.author-card__name { font-family: var(--font-head); font-size: 1.1rem; font-weight: 900; margin-bottom: 6px; letter-spacing: -0.01em; }
.author-card__bio { font-size: 0.875rem; color: var(--text-muted); margin-bottom: 12px; line-height: 1.6; }
.social-links { display: flex; gap: 8px; flex-wrap: wrap; }
.social-link {
  display: flex; align-items: center; gap: 5px;
  padding: 5px 12px; border-radius: var(--radius-pill);
  background: var(--bg-3); border: 1px solid var(--border);
  font-size: 0.78rem; color: var(--text-muted);
  transition: all var(--transition);
}
.social-link:hover { background: var(--accent-glow); border-color: var(--border-hover); color: var(--accent); }

/* Source citations */
.sources {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 22px; margin-top: 36px;
}
.sources__title {
  font-weight: 700; font-size: 0.78rem; margin-bottom: 14px;
  color: var(--text-faint); text-transform: uppercase; letter-spacing: 0.09em;
  display: flex; align-items: center; gap: 6px;
}
.sources__list { list-style: none; display: flex; flex-direction: column; gap: 6px; }
.sources__list li { font-size: 0.85rem; }
.sources__list a { color: var(--accent); display: flex; align-items: center; gap: 5px; }

/* Comments */
.comments-section { margin-top: 56px; }
.comment {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 20px; margin-bottom: 14px;
}
.comment--reply { margin-left: 44px; border-left: 3px solid var(--border); }
.comment__header { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.comment__avatar { width: 36px; height: 36px; border-radius: 50%; object-fit: cover; }
.comment__author { font-weight: 700; font-size: 0.875rem; }
.comment__date   { font-size: 0.73rem; color: var(--text-faint); }
.comment__body   { font-size: 0.92rem; line-height: 1.65; color: var(--text-muted); }
.comment__actions { margin-top: 10px; display: flex; gap: 12px; }
.comment__action-btn {
  background: none; border: none; font-size: 0.78rem; color: var(--text-faint);
  display: flex; align-items: center; gap: 4px;
  transition: color var(--transition); padding: 4px 8px; border-radius: var(--radius-pill);
}
.comment__action-btn:hover { color: var(--accent); background: var(--accent-glow); }
.comment-form textarea { min-height: 100px; resize: vertical; }
.comment-form__submit {
  background: var(--accent); color: #080810;
  border: none; padding: 10px 26px; border-radius: var(--radius-pill);
  font-weight: 800; margin-top: 12px; transition: all var(--transition);
}
.comment-form__submit:hover { background: var(--accent-dim); transform: translateY(-1px); }

/* ---- Buttons ----------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 11px 22px; border-radius: var(--radius-pill);
  font-weight: 700; font-size: 0.88rem; border: none;
  transition: all var(--transition); cursor: pointer;
  text-decoration: none; letter-spacing: 0.01em;
}
.btn--primary { background: var(--accent); color: #080810; }
.btn--primary:hover { background: var(--accent-dim); transform: translateY(-1px); box-shadow: 0 4px 20px var(--accent-glow); }
.btn--secondary { background: var(--secondary); color: #fff; }
.btn--secondary:hover { background: var(--secondary-dim); transform: translateY(-1px); box-shadow: 0 4px 20px var(--secondary-glow); }
.btn--outline { background: transparent; border: 1px solid var(--border); color: var(--text); }
.btn--outline:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-glow); }
.btn--ghost { background: var(--surface); border: 1px solid var(--border); color: var(--text-muted); }
.btn--ghost:hover { border-color: var(--border-hover); color: var(--text); }
.btn--sm  { padding: 7px 16px; font-size: 0.8rem; }
.btn--lg  { padding: 15px 36px; font-size: 1rem; }

/* ---- Badges ------------------------------------------------ */
.badge {
  display: inline-block; padding: 3px 10px; border-radius: var(--radius-pill);
  font-size: 0.68rem; font-weight: 700; letter-spacing: 0.06em;
}
.badge--accent   { background: var(--accent-glow);      color: var(--accent); }
.badge--orange   { background: var(--secondary-glow);   color: var(--secondary); }
.badge--danger   { background: rgba(255,77,77,0.12);    color: var(--danger); }
.badge--success  { background: rgba(0,232,135,0.12);    color: var(--success); }
.badge--warning  { background: rgba(255,181,71,0.12);   color: var(--warning); }

/* ---- Pagination -------------------------------------------- */
.pagination {
  display: flex; align-items: center; justify-content: center; gap: 6px; margin-top: 56px;
}
.pagination__btn {
  padding: 9px 16px; border-radius: var(--radius-pill);
  background: var(--surface); border: 1px solid var(--border);
  color: var(--text-muted); font-size: 0.86rem; font-weight: 600;
  cursor: pointer; transition: all var(--transition); text-decoration: none; display: inline-block;
}
.pagination__btn:hover, .pagination__btn.active {
  background: var(--accent); border-color: var(--accent); color: #080810;
  box-shadow: 0 0 20px var(--accent-glow);
}
.pagination__btn:disabled { opacity: 0.35; cursor: not-allowed; }

/* ---- Skeleton loaders -------------------------------------- */
.skeleton {
  background: linear-gradient(90deg, var(--surface) 25%, var(--surface-2) 50%, var(--surface) 75%);
  background-size: 300% 100%;
  animation: skeleton-shimmer 1.6s infinite;
  border-radius: var(--radius);
}
@keyframes skeleton-shimmer {
  0%   { background-position: 300% 0; }
  100% { background-position: -300% 0; }
}
.skeleton-text  { height: 13px; width: 100%; margin-bottom: 8px; }
.skeleton-title { height: 20px; width: 75%; margin-bottom: 12px; }
.skeleton-image { aspect-ratio: 16/9; width: 100%; }

/* ---- Toast notifications ----------------------------------- */
.toast-container {
  position: fixed; bottom: 28px; right: 28px; z-index: 9999;
  display: flex; flex-direction: column; gap: 8px;
}
.toast {
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 14px 18px;
  display: flex; align-items: center; gap: 10px;
  min-width: 280px; max-width: 400px;
  box-shadow: var(--shadow-lg);
  animation: toast-in 0.25s var(--ease);
}
@keyframes toast-in {
  from { opacity: 0; transform: translateX(24px) scale(0.96); }
  to   { opacity: 1; transform: translateX(0)    scale(1); }
}
.toast--success { border-left: 3px solid var(--success); }
.toast--error   { border-left: 3px solid var(--danger); }
.toast--info    { border-left: 3px solid var(--info); }
.toast__text { flex: 1; font-size: 0.875rem; }

/* ---- Search overlay ---------------------------------------- */
.search-overlay {
  position: fixed; inset: 0; z-index: 999;
  background: rgba(4,4,10,0.88);
  backdrop-filter: blur(20px);
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: 88px;
  opacity: 0; pointer-events: none;
  transition: opacity 0.2s var(--ease);
}
.search-overlay.open { opacity: 1; pointer-events: all; }
.search-box {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  width: 100%; max-width: 640px;
  padding: 20px;
  margin: 0 20px;
  box-shadow: 0 24px 80px rgba(0,0,0,0.6);
}
.search-box__input-row {
  display: flex; gap: 10px; align-items: center;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 10px 14px;
}
.search-box__input {
  flex: 1; background: none; border: none;
  font-size: 1rem; padding: 0; box-shadow: none;
  color: var(--text);
}
.search-box__input:focus { outline: none; box-shadow: none; border: none; }
.search-box__kbd {
  font-size: 0.65rem; font-weight: 700; color: var(--text-faint);
  border: 1px solid var(--border); border-radius: 5px;
  padding: 2px 6px; font-family: var(--font-body);
  background: var(--bg-3); letter-spacing: 0.04em;
  flex-shrink: 0;
}
.search-box__close {
  background: none; border: none;
  color: var(--text-faint); width: 28px; height: 28px;
  border-radius: var(--radius-pill); display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all var(--transition); flex-shrink: 0;
}
.search-box__close:hover { color: var(--text); background: var(--border); }
.search-box__results { margin-top: 12px; }
.search-box__hint {
  margin-top: 12px; padding-top: 12px;
  border-top: 1px solid var(--border);
  font-size: 0.7rem; color: var(--text-faint);
  display: flex; align-items: center;
}
.search-box__hint kbd {
  display: inline-block;
  border: 1px solid var(--border); border-radius: 4px;
  padding: 1px 5px; font-size: 0.65rem; font-family: var(--font-body);
  background: var(--bg-3); margin: 0 2px; color: var(--text-faint);
}
.search-result-item {
  display: flex; gap: 12px; align-items: center;
  padding: 10px 12px; border-radius: var(--radius-lg);
  transition: background var(--transition); cursor: pointer;
  text-decoration: none; color: inherit;
}
.search-result-item:hover { background: var(--surface); }
.search-result-item.is-focused { background: var(--surface); }
.search-result-item img { width: 54px; height: 40px; object-fit: cover; border-radius: 8px; flex-shrink: 0; }
.search-result-item__title { font-size: 0.9rem; font-weight: 600; letter-spacing: -0.01em; line-height: 1.3; }
.search-result-item__meta  { font-size: 0.72rem; color: var(--text-faint); margin-top: 3px; }

/* ---- Tag cloud --------------------------------------------- */
.tag-cloud { display: flex; flex-wrap: wrap; gap: 8px; }
.tag-pill {
  padding: 5px 14px; border-radius: var(--radius-pill);
  background: var(--surface); border: 1px solid var(--border);
  font-size: 0.78rem; color: var(--text-muted); font-weight: 500;
  transition: all var(--transition);
}
.tag-pill:hover { background: var(--accent-glow); border-color: var(--border-hover); color: var(--accent); }

/* ---- Footer ------------------------------------------------ */
.footer {
  background: var(--bg-2);
  border-top: 1px solid var(--border);
  padding: 72px 0 28px;
  margin-top: 96px;
}
.footer__grid {
  display: grid; grid-template-columns: 2.2fr 1fr 1fr 1fr;
  gap: 48px; margin-bottom: 56px;
}
.footer__brand-name {
  font-family: var(--font-head); font-size: 1.25rem; font-weight: 900;
  color: var(--accent); margin-bottom: 8px; letter-spacing: -0.02em;
}
.footer__tagline { font-size: 0.84rem; color: var(--text-muted); margin-bottom: 24px; line-height: 1.55; }
.footer__social { display: flex; gap: 8px; }
.footer__social a {
  width: 38px; height: 38px; border-radius: var(--radius-pill);
  background: var(--surface); border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-muted); font-size: 0.9rem; transition: all var(--transition);
}
.footer__social a:hover { background: var(--accent-glow); border-color: var(--border-hover); color: var(--accent); transform: translateY(-2px); }
.footer__col-title {
  font-weight: 700; font-size: 0.8rem; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--text-faint); margin-bottom: 18px;
}
.footer__links { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.footer__links a { font-size: 0.875rem; color: var(--text-muted); transition: color var(--transition); }
.footer__links a:hover { color: var(--accent); }
.footer__bottom {
  border-top: 1px solid var(--border); padding-top: 24px;
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px;
}
.footer__copyright { font-size: 0.78rem; color: var(--text-faint); }
.footer__legal { display: flex; gap: 20px; }
.footer__legal a { font-size: 0.78rem; color: var(--text-faint); transition: color var(--transition); }
.footer__legal a:hover { color: var(--accent); }

/* ---- Bookmark button --------------------------------------- */
.bookmark-btn {
  background: var(--surface); border: 1px solid var(--border);
  color: var(--text-muted); padding: 9px 14px; border-radius: var(--radius-pill);
  transition: all var(--transition); cursor: pointer; display: flex; align-items: center; gap: 6px;
  font-size: 0.82rem; font-weight: 600;
}
.bookmark-btn.active { border-color: var(--accent); color: var(--accent); background: var(--accent-glow); }
.bookmark-btn:hover  { border-color: var(--accent); color: var(--accent); }

/* ---- PWA Install Banner ------------------------------------ */
.pwa-banner {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 500;
  background: var(--surface-2); border-top: 1px solid var(--border);
  padding: 18px 24px; display: flex; align-items: center; gap: 16px;
  box-shadow: 0 -8px 32px rgba(0,0,0,0.4);
  transform: translateY(100%); transition: transform 0.35s var(--ease);
}
.pwa-banner.show { transform: translateY(0); }
.pwa-banner__text { flex: 1; font-size: 0.875rem; }
.pwa-banner__text strong { color: var(--accent); }

/* ---- Divider ----------------------------------------------- */
.divider {
  height: 1px;
  background: linear-gradient(to right, transparent, var(--border), transparent);
  margin: 48px 0;
}

/* ---- Glow pulse on accent elements ------------------------- */
@keyframes glow-pulse {
  0%, 100% { box-shadow: 0 0 12px var(--accent-glow); }
  50%       { box-shadow: 0 0 28px var(--accent-glow), 0 0 48px var(--accent-glow); }
}

/* ---- Responsive -------------------------------------------- */
@media (max-width: 1100px) {
  .article-layout { grid-template-columns: 1fr 300px; gap: 40px; }
  .bento__item--wide  { grid-column: span 12; }
  .bento__item--tall  { grid-column: span 6; }
  .bento__item--half  { grid-column: span 6; }
  .bento__item--third { grid-column: span 6; }
  .bento__item--small { grid-column: span 6; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  .article-layout { grid-template-columns: 1fr; padding: 24px 16px 64px; }
  .article-sidebar { position: static; }
  .hero { grid-template-columns: 1fr; }
  .newsletter-cta__form { flex-direction: column; }
  .footer__grid { grid-template-columns: 1fr; gap: 32px; }
  .footer__bottom { flex-direction: column; text-align: center; }
  .bento { grid-auto-rows: 160px; gap: 12px; }
  .bento__item--wide,
  .bento__item--tall,
  .bento__item--half,
  .bento__item--third,
  .bento__item--small { grid-column: span 12; grid-row: span 1; }
  .bento__item--wide  { grid-row: span 2; }
  .container { padding: 0 16px; }
}

/* ============================================================
   POLISH PASS — ambient depth, gradient text, scrollbar,
   selection, scroll-reveal, micro-interactions
   ============================================================ */

/* Ambient gradient mesh behind everything */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(60vw 50vh at 12% -5%, var(--accent-glow), transparent 60%),
    radial-gradient(55vw 45vh at 95% 8%, var(--tertiary-glow), transparent 60%),
    radial-gradient(50vw 50vh at 50% 110%, var(--secondary-glow), transparent 60%);
  opacity: 0.7;
  animation: meshDrift 24s ease-in-out infinite alternate;
}
@keyframes meshDrift {
  0%   { transform: translate3d(0,0,0) scale(1); }
  100% { transform: translate3d(0,-2%,0) scale(1.06); }
}
@media (prefers-reduced-motion: reduce) {
  body::before { animation: none; }
  html { scroll-behavior: auto; }
}

/* Gradient headlines */
.hero__content-pane h1,
.section-heading__title,
.newsletter-cta__title {
  background: var(--grad-accent);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Custom scrollbar */
* { scrollbar-width: thin; scrollbar-color: var(--accent-dim) transparent; }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--bg-2); }
::-webkit-scrollbar-thumb {
  background: linear-gradient(var(--accent-dim), var(--tertiary));
  border-radius: var(--radius-pill);
  border: 2px solid var(--bg-2);
}
::-webkit-scrollbar-thumb:hover { background: var(--accent); }

/* Selection */
::selection { background: var(--accent); color: #080810; }

/* Scroll-reveal */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.7s var(--ease), transform 0.7s var(--ease);
  will-change: opacity, transform;
}
.reveal.is-visible { opacity: 1; transform: none; }

/* Slight lift + glow on interactive cards */
.card, .bento__item, .related-item {
  transition: transform var(--transition), box-shadow var(--transition),
              border-color var(--transition);
}
.card:hover, .bento__item:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg), var(--shadow-glow);
}

/* Focus-visible accessibility ring */
a:focus-visible, button:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: var(--radius);
}

/* ================================================================
   HOMEPAGE — Magazine layout (lead · top stories · rows · opinion)
   ================================================================ */

.home-lead   { padding-top: 36px; }
.section-block { margin-top: 56px; }

/* Shared editorial typography ---------------------------------- */
.kicker {
  display: inline-block;
  font-size: 0.7rem; font-weight: 800;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--kicker, var(--accent));
  margin-bottom: 10px;
}
.kicker--xs { font-size: 0.64rem; margin-bottom: 6px; }

.byline {
  display: flex; flex-wrap: wrap; align-items: center; gap: 7px;
  font-size: 0.82rem; color: var(--text-muted); margin-top: 14px;
}
.byline--sm { font-size: 0.75rem; margin-top: 8px; }
.byline__dot { color: var(--text-faint); opacity: 0.5; }
.muted-note { color: var(--text-faint); font-size: 0.86rem; }

/* Lead grid ---------------------------------------------------- */
.lead-grid {
  display: grid;
  grid-template-columns: 1.7fr 1fr;
  gap: 44px;
  align-items: start;
}

.lead-story__media {
  display: block; position: relative;
  aspect-ratio: 16 / 10;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--surface);
}
.lead-story__media img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.6s var(--ease);
}
.lead-story__media:hover img { transform: scale(1.03); }
.lead-story__media-fallback {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-head); font-size: 1.4rem; font-weight: 900;
  color: var(--text-faint);
  background: linear-gradient(135deg, var(--surface), var(--surface-2));
}
.lead-story__flag {
  position: absolute; top: 14px; left: 14px;
  background: var(--accent); color: #080810;
  font-size: 0.66rem; font-weight: 800; letter-spacing: 0.08em;
  text-transform: uppercase; padding: 5px 11px;
  border-radius: var(--radius-pill);
}
.lead-story__body { padding-top: 22px; }
.lead-story__title {
  font-family: var(--font-head);
  font-size: clamp(1.7rem, 3.4vw, 2.5rem);
  font-weight: 900; line-height: 1.08;
  letter-spacing: -0.025em; margin-bottom: 14px;
}
.lead-story__title a { color: var(--text); transition: color var(--transition); }
.lead-story__title a:hover { color: var(--accent); }
.lead-story__dek {
  font-size: 1.05rem; color: var(--text-muted); line-height: 1.6;
  max-width: 62ch;
}

/* Top stories (numbered text list) ----------------------------- */
.rail-heading {
  font-size: 0.74rem; font-weight: 800;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-faint);
  padding-bottom: 12px; margin-bottom: 4px;
  border-bottom: 2px solid var(--border);
}
.top-stories__list { list-style: none; }
.top-story {
  display: flex; gap: 14px; align-items: flex-start;
  padding: 16px 0;
  border-bottom: 1px solid var(--border);
}
.top-story:last-child { border-bottom: none; }
.top-story__num {
  font-family: var(--font-head);
  font-size: 1.15rem; font-weight: 900;
  color: var(--text-faint); line-height: 1.2;
  min-width: 22px; flex-shrink: 0;
}
.top-story:nth-child(1) .top-story__num { color: var(--accent); }
.top-story__title {
  display: block;
  font-family: var(--font-head);
  font-size: 1.02rem; font-weight: 700; line-height: 1.3;
  color: var(--text); letter-spacing: -0.01em;
  transition: color var(--transition);
}
.top-story__title:hover { color: var(--accent); }
.top-story__meta { font-size: 0.72rem; color: var(--text-faint); margin-top: 6px; }
.top-story__empty { color: var(--text-faint); font-size: 0.86rem; padding: 16px 0; }

/* Latest — thumbnail + text rows ------------------------------- */
.story-rows {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px 40px;
}
.story-row { display: flex; gap: 18px; align-items: flex-start; }
.story-row__media {
  flex-shrink: 0;
  width: 150px; aspect-ratio: 4 / 3;
  border-radius: var(--radius); overflow: hidden;
  background: var(--surface);
}
.story-row__media img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.5s var(--ease);
}
.story-row__media:hover img { transform: scale(1.05); }
.story-row__media-fallback {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-head); font-weight: 900; font-size: 0.95rem;
  color: var(--text-faint); text-transform: uppercase;
  background: linear-gradient(135deg, var(--surface), var(--surface-2));
}
.story-row__body { flex: 1; min-width: 0; }
.story-row__title {
  font-family: var(--font-head);
  font-size: 1.12rem; font-weight: 700; line-height: 1.25;
  letter-spacing: -0.01em; margin-bottom: 7px;
}
.story-row__title a { color: var(--text); transition: color var(--transition); }
.story-row__title a:hover { color: var(--accent); }
.story-row__dek {
  font-size: 0.86rem; color: var(--text-muted); line-height: 1.5;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Opinion + rail layout ---------------------------------------- */
.opinion-layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 44px; align-items: start;
}
.opinion-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px;
}
.opinion-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--secondary);
  border-radius: var(--radius-lg);
  padding: 22px 22px 20px;
  transition: border-color var(--transition), transform var(--transition);
}
.opinion-card:hover { transform: translateY(-3px); border-left-color: var(--accent); }
.opinion-card__tag {
  font-size: 0.64rem; font-weight: 800; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--secondary);
}
.opinion-card__title {
  display: block;
  font-family: var(--font-head);
  font-size: 1.18rem; font-weight: 700; line-height: 1.3;
  letter-spacing: -0.01em; color: var(--text);
  margin: 10px 0 8px; transition: color var(--transition);
}
.opinion-card__title:hover { color: var(--accent); }
.opinion-card__dek {
  font-size: 0.85rem; color: var(--text-muted); line-height: 1.5;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.opinion-card__by {
  font-size: 0.78rem; font-weight: 600; color: var(--text-faint);
  margin-top: 14px;
}

/* Home rail cards ---------------------------------------------- */
.home-rail { display: flex; flex-direction: column; gap: 22px; }
.rail-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 22px;
}
.rail-card--accent { border-color: var(--border-hover); }
.rail-card__title {
  display: flex; align-items: center; gap: 9px;
  font-size: 0.78rem; font-weight: 800;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--text); margin-bottom: 16px;
}
.rail-card__text { font-size: 0.85rem; color: var(--text-muted); line-height: 1.55; margin-bottom: 16px; }

/* Auto-link (linkify plugin output) ---------------------------- */
.auto-link {
  color: var(--accent);
  text-decoration: none;
  border-bottom: 1px solid rgba(0,255,178,0.3);
  word-break: break-word;
  transition: border-color var(--transition), color var(--transition);
}
.auto-link:hover { border-bottom-color: var(--accent); }

/* ---- Homepage responsive ------------------------------------- */
@media (max-width: 1100px) {
  .lead-grid      { grid-template-columns: 1fr; gap: 32px; }
  .opinion-layout { grid-template-columns: 1fr; gap: 36px; }
  .home-rail      { display: grid; grid-template-columns: repeat(2, 1fr); align-items: start; }
  .home-rail .ad-slot { grid-column: 1 / -1; }
}
@media (max-width: 760px) {
  .section-block { margin-top: 44px; }
  .story-rows    { grid-template-columns: 1fr; gap: 24px; }
  .opinion-grid  { grid-template-columns: 1fr; }
  .home-rail     { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .story-row__media { width: 108px; }
  .story-row { gap: 14px; }
  .lead-story__dek { font-size: 0.96rem; }
}

/* ============================================================
   Static pages (About / Contact), Author profile, Category
   ============================================================ */

.page-narrow { max-width: 860px; }

/* Shared page hero */
.page-hero { margin-bottom: 32px; }
.page-hero__title {
  font-family: var(--font-head, inherit);
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 900; line-height: 1.05; margin: 6px 0 14px;
}
.page-hero__lead {
  font-size: 1.12rem; line-height: 1.6; color: var(--text-muted);
  max-width: 62ch;
}

/* About: stat strip */
.about-stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
  margin: 28px 0 40px; padding: 24px 0; border-block: 1px solid var(--border);
}
.about-stat { text-align: center; }
.about-stat__num {
  display: block; font-size: 2rem; font-weight: 800; color: var(--accent);
}
.about-stat__label { font-size: 0.82rem; color: var(--text-faint); }

/* Prose */
.prose { font-size: 1.05rem; line-height: 1.75; color: var(--text); }
.prose h2 { font-size: 1.4rem; font-weight: 800; margin: 32px 0 12px; }
.prose p, .prose ul { margin-bottom: 16px; color: var(--text-muted); }
.prose ul { padding-left: 22px; }
.prose li { margin-bottom: 8px; }
.prose strong { color: var(--text); }

/* About: team grid */
.about-team { margin-top: 48px; }
.team-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 18px;
}
.team-card {
  background: var(--surface, rgba(255,255,255,0.02));
  border: 1px solid var(--border); border-radius: 14px; padding: 20px; text-align: center;
}
.team-card__avatar {
  width: 64px; height: 64px; border-radius: 50%; margin: 0 auto 12px;
  overflow: hidden; display: flex; align-items: center; justify-content: center;
  background: var(--accent); color: #04110d; font-weight: 800; font-size: 1.4rem;
}
.team-card__avatar img { width: 100%; height: 100%; object-fit: cover; }
.team-card__name { font-weight: 700; }
.team-card__role { font-size: 0.78rem; color: var(--accent); margin-bottom: 8px; }
.team-card__bio { font-size: 0.85rem; color: var(--text-muted); line-height: 1.5; }

/* About CTA */
.about-cta {
  margin-top: 48px; padding: 32px; text-align: center;
  border: 1px solid var(--border); border-radius: 16px;
  background: linear-gradient(135deg, rgba(124,92,255,0.08), rgba(0,255,178,0.06));
}
.about-cta h2 { font-size: 1.5rem; font-weight: 800; margin-bottom: 8px; }
.about-cta p { color: var(--text-muted); margin-bottom: 18px; }

/* Contact layout */
.contact-layout { display: grid; grid-template-columns: 1.6fr 1fr; gap: 36px; }
.contact-form { display: flex; flex-direction: column; gap: 16px; position: relative; }
.form-field { display: flex; flex-direction: column; gap: 6px; }
.form-field label { font-size: 0.85rem; font-weight: 600; color: var(--text-muted); }
.form-field input,
.form-field textarea {
  width: 100%; padding: 12px 14px; font: inherit; color: var(--text);
  background: var(--bg-2, rgba(255,255,255,0.03));
  border: 1px solid var(--border); border-radius: 10px; outline: none;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.form-field input:focus,
.form-field textarea:focus {
  border-color: var(--accent); box-shadow: 0 0 0 3px rgba(0,255,178,0.12);
}
.form-field textarea { resize: vertical; }

/* Alerts */
.alert { padding: 14px 16px; border-radius: 10px; margin-bottom: 20px; font-size: 0.92rem; }
.alert--success { background: rgba(16,185,129,0.12); border: 1px solid rgba(16,185,129,0.4); color: #34d399; }
.alert--error   { background: rgba(239,68,68,0.10);  border: 1px solid rgba(239,68,68,0.4);  color: #f87171; }

/* Contact sidebar */
.contact-aside { display: flex; flex-direction: column; gap: 14px; }
.contact-card {
  border: 1px solid var(--border); border-radius: 12px; padding: 16px 18px;
  background: var(--surface, rgba(255,255,255,0.02));
}
.contact-card h3 { font-size: 0.95rem; font-weight: 700; margin-bottom: 2px; }
.contact-card p { font-size: 0.8rem; color: var(--text-faint); margin-bottom: 8px; }
.contact-card a { color: var(--accent); font-size: 0.9rem; word-break: break-word; }

/* Author hero */
.author-hero {
  display: flex; gap: 24px; align-items: center; flex-wrap: wrap;
  padding-bottom: 28px; border-bottom: 1px solid var(--border);
}
.author-hero__avatar {
  width: 96px; height: 96px; border-radius: 50%; flex-shrink: 0; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  background: var(--accent); color: #04110d; font-weight: 800; font-size: 2.4rem;
}
.author-hero__avatar img { width: 100%; height: 100%; object-fit: cover; }
.author-hero__name { font-size: clamp(1.6rem, 4vw, 2.4rem); font-weight: 900; margin: 4px 0 10px; }
.author-hero__bio { color: var(--text-muted); max-width: 60ch; line-height: 1.6; }
.author-hero__meta {
  display: flex; gap: 16px; flex-wrap: wrap; margin-top: 12px;
  font-size: 0.85rem; color: var(--text-faint);
}
.author-hero__meta a { color: var(--accent); }

/* Category hero (compact, smaller footprint) */
.cat-hero {
  margin-bottom: 28px; padding-bottom: 18px;
  border-bottom: 3px solid var(--cat-color, var(--accent));
}
.cat-hero__title { font-size: clamp(1.8rem, 4vw, 2.6rem); font-weight: 900; margin: 4px 0 8px; }
.cat-hero__desc { color: var(--text-muted); max-width: 60ch; line-height: 1.55; }
.cat-hero__count { margin-top: 10px; font-size: 0.82rem; color: var(--text-faint); }

/* Category lead story — deliberately smaller image */
.cat-lead {
  display: grid; grid-template-columns: 300px 1fr; gap: 22px;
  padding-bottom: 26px; margin-bottom: 26px; border-bottom: 1px solid var(--border);
}
.cat-lead__media {
  display: block; aspect-ratio: 16/10; border-radius: 12px; overflow: hidden;
  background: var(--bg-3, rgba(255,255,255,0.04));
}
.cat-lead__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cat-lead__title {
  display: block; font-family: var(--font-head, inherit);
  font-size: 1.5rem; font-weight: 800; line-height: 1.2; margin: 10px 0 8px; color: var(--text);
}
.cat-lead__title:hover { color: var(--accent); }
.cat-lead__dek { color: var(--text-muted); line-height: 1.55; margin-bottom: 10px; }

/* type-badge spacing within new layouts */
.story-row .type-badge,
.cat-lead .type-badge { display: inline-block; margin-bottom: 6px; }

@media (max-width: 760px) {
  .contact-layout { grid-template-columns: 1fr; }
  .cat-lead { grid-template-columns: 1fr; }
  .cat-lead__media { aspect-ratio: 16/9; max-height: 220px; }
  .about-stats { grid-template-columns: 1fr; gap: 20px; }
}

/* ============================================================
   Sign-in page
   ============================================================ */
.auth-page { max-width: 460px; margin: 0 auto; text-align: center; }
.auth-page__head { margin-bottom: 26px; }
.auth-page__title { font-size: clamp(1.6rem, 4vw, 2.2rem); font-weight: 900; margin: 6px 0 8px; }
.auth-page__sub { color: var(--text-muted); }
.auth-page__widget { display: flex; justify-content: center; min-height: 120px; }
.auth-page__alt { margin-top: 24px; font-size: 0.9rem; color: var(--text-faint); }
.auth-page__alt a { color: var(--accent); }

.auth-fallback {
  text-align: left; border: 1px solid var(--border); border-radius: 14px;
  padding: 22px 24px; background: var(--surface, rgba(255,255,255,0.02));
}
.auth-fallback p { margin-bottom: 10px; color: var(--text-muted); line-height: 1.55; }
.auth-fallback code {
  background: var(--bg-3, rgba(255,255,255,0.06)); padding: 1px 6px;
  border-radius: 5px; font-size: 0.85em; color: var(--text);
}
.auth-fallback__dev {
  margin-top: 6px; padding-top: 12px; border-top: 1px solid var(--border);
}
.auth-fallback__dev a { color: var(--accent); }

/* ---- Custom auth: OAuth buttons, form, divider --------------- */
.auth-oauth { display: flex; flex-direction: column; gap: 10px; margin-bottom: 6px; }
.oauth-btn {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  width: 100%; padding: 12px 16px; border-radius: 10px;
  border: 1px solid var(--border); background: var(--surface, rgba(255,255,255,0.03));
  color: var(--text); font-weight: 600; font-size: 0.95rem;
  text-decoration: none; cursor: pointer; transition: background .15s, border-color .15s;
}
.oauth-btn:hover { background: var(--bg-3, rgba(255,255,255,0.07)); border-color: var(--accent); }
.oauth-btn svg { flex-shrink: 0; }

.auth-divider {
  display: flex; align-items: center; gap: 12px;
  color: var(--text-faint); font-size: 0.8rem; margin: 18px 0;
}
.auth-divider::before, .auth-divider::after {
  content: ""; flex: 1; height: 1px; background: var(--border);
}

.auth-form { text-align: left; display: flex; flex-direction: column; gap: 14px; }
.auth-form .form-field { display: flex; flex-direction: column; gap: 6px; }
.auth-form label { font-size: 0.85rem; color: var(--text-muted); font-weight: 600; }
.auth-form input[type="email"],
.auth-form input[type="password"],
.auth-form input[type="text"] {
  width: 100%; padding: 12px 14px; border-radius: 10px;
  border: 1px solid var(--border); background: var(--bg-2, rgba(255,255,255,0.02));
  color: var(--text); font-size: 0.95rem;
}
.auth-form input:focus { outline: none; border-color: var(--accent); }
.auth-remember {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.85rem; color: var(--text-muted); cursor: pointer;
}
.auth-remember input { width: 15px; height: 15px; accent-color: var(--accent); }
.auth-page__hint {
  margin-top: 18px; font-size: 0.82rem; color: var(--text-faint); line-height: 1.5;
}
.auth-page__hint code {
  background: var(--bg-3, rgba(255,255,255,0.06)); padding: 1px 6px;
  border-radius: 5px; font-size: 0.9em;
}

/* ---- Nav user menu (server-rendered auth state) ------------- */
.nav-auth { position: relative; }
.nav-user {
  display: flex; align-items: center; gap: 8px; cursor: pointer;
  padding: 4px 6px; border-radius: 999px; outline: none;
}
.nav-user__avatar {
  width: 30px; height: 30px; border-radius: 50%; object-fit: cover; flex-shrink: 0;
}
.nav-user__avatar--initial {
  display: flex; align-items: center; justify-content: center;
  background: var(--accent-dim, rgba(0,255,178,0.15)); color: var(--accent);
  font-weight: 700; font-size: 0.85rem;
}
.nav-user__name {
  font-size: 0.85rem; font-weight: 600; color: var(--text);
  max-width: 120px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.nav-user__menu {
  position: absolute; right: 0; top: calc(100% + 8px);
  min-width: 180px; background: var(--bg-2, #14141c);
  border: 1px solid var(--border); border-radius: 12px; padding: 6px;
  box-shadow: 0 12px 30px rgba(0,0,0,0.4); z-index: 300;
  opacity: 0; visibility: hidden; transform: translateY(-4px);
  transition: opacity .15s, transform .15s, visibility .15s;
}
.nav-user:hover .nav-user__menu,
.nav-user:focus-within .nav-user__menu {
  opacity: 1; visibility: visible; transform: translateY(0);
}
.nav-user__menu a {
  display: block; padding: 9px 12px; border-radius: 8px;
  font-size: 0.875rem; color: var(--text); text-decoration: none;
}
.nav-user__menu a:hover { background: var(--bg-3, rgba(255,255,255,0.06)); }
@media (max-width: 600px) { .nav-user__name { display: none; } }

/* ============================================================
   Article right-rail: author box + interactive comments
   ============================================================ */
.author-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;margin-bottom:20px}
.author-box__top{display:flex;align-items:center;gap:12px}
.author-box__avatar{width:54px;height:54px;border-radius:50%;object-fit:cover;flex-shrink:0}
.author-box__avatar--initial{display:flex;align-items:center;justify-content:center;background:var(--bg-3);color:var(--accent);font-weight:800;font-size:1.3rem}
.author-box__kicker{display:block;font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint)}
.author-box__name{font-weight:700;font-size:1.02rem;color:var(--text);text-decoration:none}
.author-box__name:hover{color:var(--accent)}
.author-box__bio{margin:12px 0 0;font-size:.86rem;line-height:1.55;color:var(--text-muted)}
.author-box__links{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px}
.author-box__links a{font-size:.8rem;color:var(--accent);text-decoration:none}
.author-box__links a:hover{text-decoration:underline}

.comments-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;margin-bottom:20px}
.comments-box__head h2{font-size:1.05rem;margin:0 0 14px}
.comments-box__head span{color:var(--text-faint);font-weight:500}
.comment-signin{text-align:center;background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:14px}
.comment-signin p{margin:0 0 12px;font-size:.86rem;color:var(--text-muted)}
.comment-signin__note{font-size:.74rem;color:var(--text-faint)}
.fb-btn{display:inline-flex;align-items:center;gap:9px;background:#1877F2;color:#fff;font-weight:600;font-size:.88rem;padding:10px 18px;border-radius:8px;text-decoration:none}
.fb-btn:hover{background:#166fe0}
.comment-form textarea{width:100%;min-height:84px;padding:11px 13px;background:var(--bg-2);border:1px solid var(--border);border-radius:10px;color:var(--text);font:inherit;resize:vertical}
.comment-form__actions{display:flex;gap:8px;margin-top:10px}
.comment-form__reply{padding:8px 12px;background:var(--bg-3);border-radius:8px;margin-bottom:10px;font-size:.82rem;color:var(--text-muted)}
.comments-list{margin-top:18px;display:flex;flex-direction:column;gap:16px}
.comments-empty{color:var(--text-faint);text-align:center;padding:18px;font-size:.88rem}
.comment{border-bottom:1px solid var(--border);padding-bottom:14px}
.comment:last-child{border-bottom:none;padding-bottom:0}
.comment--reply{margin-left:22px;padding-left:14px;border-left:2px solid var(--border);border-bottom:none}
.comment__header{display:flex;align-items:center;gap:9px;margin-bottom:7px}
.comment__avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;flex-shrink:0}
.comment__avatar--initial{display:flex;align-items:center;justify-content:center;background:var(--bg-3);color:var(--accent);font-weight:700;font-size:.85rem}
.comment__author{font-weight:600;font-size:.88rem}
.comment__date{font-size:.74rem;color:var(--text-faint);margin-left:auto}
.comment__body{font-size:.9rem;line-height:1.55;color:var(--text);word-wrap:break-word}
.comment__actions{display:flex;align-items:center;gap:14px;margin-top:8px}
.comment__like,.comment__action-btn{display:inline-flex;align-items:center;gap:5px;background:none;border:none;color:var(--text-faint);font-size:.8rem;cursor:pointer;padding:2px 0;transition:color .15s}
.comment__like:hover,.comment__action-btn:hover{color:var(--accent)}
.comment__like.is-liked{color:#ff5a78}
.comment__like-count{font-weight:600}
