:root {
  /* Palette */
  --bg: #000;
  --bg-2: #050505;
  --text: #fff;
  --muted: #cfd2d8;
  --muted-2: #dfe3ea;
  --gold: #FFD700;
  --gold-2: #ffec8b;
  --border: #1a1a1a;

  /* Layout & rhythm */
  --wrap: 1200px;
  --gutter: clamp(.9rem, 1.2vw, 1.25rem);
  --radius: .95rem;
  --radius-lg: 1.1rem;

  /* Effects */
  --ring: 0 0 0 3px color-mix(in oklab, var(--gold) 40%, transparent);
  --card-bg: linear-gradient(180deg, rgba(255, 255, 255, .06), rgba(255, 255, 255, .03));
  --glass: blur(6px) saturate(120%);
  --shadow-1: 0 12px 32px -18px color-mix(in oklab, var(--gold) 55%, transparent);
  --shadow-2: 0 18px 48px -12px color-mix(in oklab, var(--gold) 26%, transparent);
  --shadow-soft: 0 26px 80px -32px rgba(0, 0, 0, .75);
  --accent-line: linear-gradient(90deg, transparent, color-mix(in oklab, var(--gold) 60%, transparent), transparent);
  --gold-wash: radial-gradient(44% 40% at 78% 12%, color-mix(in oklab, var(--gold) 18%, transparent) 0, transparent 70%);

  /* Fluid type scale */
  --fs-0: clamp(.88rem, .25vw + .82rem, .98rem);
  --fs-1: clamp(1rem, .45vw + .92rem, 1.15rem);
  --fs-2: clamp(1.15rem, .65vw + 1rem, 1.35rem);
  --fs-3: clamp(1.35rem, 1vw + 1.1rem, 1.6rem);
  --fs-4: clamp(1.6rem, 1.4vw + 1.2rem, 2rem);
}

.wrap {
  max-width: var(--wrap);
  margin-inline: auto;
  padding-inline: clamp(.9rem, 2vw, 1.25rem);
}

/* Selection for readability */
::selection {
  background: color-mix(in oklab, var(--gold) 35%, #333);
  color: #111;
}

/* ---------- Buttons ---------- */
a.btn,
.btn:link,
.btn:visited {
  color: inherit;
  text-decoration: none;
}

.btn {
  --btn-bg: #0e0e0e;
  --btn-fg: #fff;
  --btn-bd: #232323;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .55rem;
  padding: .9rem 1.1rem;
  border-radius: var(--radius);
  border: 1px solid var(--btn-bd);
  color: var(--btn-fg);
  font-weight: 800;
  letter-spacing: .2px;
  cursor: pointer;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease, color .2s ease;
  min-height: 44px;
  /* mobile touch target */
  -webkit-tap-highlight-color: transparent;
}

.btn:focus-visible {
  outline: none;
  box-shadow: var(--ring);
  transform: translateY(-1px);
}

.btn-primary {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, var(--gold), var(--gold-2));
  color: #111 !important;
  border-color: transparent;
  box-shadow: 0 14px 40px -14px color-mix(in oklab, var(--gold) 60%, transparent);
}

@media (hover:hover) {
  .btn-primary:hover {
    transform: translateY(-1px) scale(1.01);
  }
}

.btn-primary::after {
  content: "";
  position: absolute;
  inset: -20% -60%;
  background: linear-gradient(100deg, transparent 45%, rgba(255, 255, 255, .6) 50%, transparent 55%);
  mix-blend-mode: screen;
  transform: translateX(-120%);
  pointer-events: none;
  animation: shineSweep 3.4s ease-in-out infinite;
}

.btn-ghost {
  background: #0e0e0e;
  color: #fff;
  border-color: #232323;
}

.btn-ghost:hover {
  border-color: color-mix(in oklab, var(--gold) 40%, #232323);
  box-shadow: var(--ring);
}

/* ---------- Eyebrow ---------- */
.eyebrow {
  display: inline-block;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: var(--fs-0);
  padding: .35rem .6rem;
  border-radius: .6rem;
  color: #111;
  background: linear-gradient(135deg, var(--gold), var(--gold-2));
  box-shadow: var(--shadow-1);
}

/* =========================
   HERO
   ========================= */
.b-hero {
  position: relative;
  background: var(--bg);
  color: var(--text);
  border-block-end: 1px solid var(--border);
  padding-block: clamp(2rem, 5vw, 3rem) 1.2rem;
  padding-top: max(150px, env(safe-area-inset-top));
  isolation: isolate;
}

.b-hero .bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

.b-hero .bg::before {
  content: "";
  position: absolute;
  inset: -30%;
  background:
    radial-gradient(42% 36% at 18% 28%, color-mix(in oklab, var(--gold) 18%, transparent) 0, transparent 60%),
    radial-gradient(46% 40% at 82% 72%, color-mix(in oklab, var(--gold-2) 16%, transparent) 0, transparent 70%);
  filter: blur(64px);
  opacity: .24;
}

.b-hero .bg::after {
  content: "";
  position: absolute;
  inset: -35%;
  background:
    linear-gradient(transparent 97%, rgba(255, 255, 255, .07) 98%) 0 0/24px 24px,
    linear-gradient(90deg, transparent 97%, rgba(255, 255, 255, .07) 98%) 0 0/24px 24px;
  mask-image: radial-gradient(60% 60% at 50% 40%, #000 30%, transparent 70%);
  opacity: .18;
  animation: gridDrift 36s linear infinite;
}

.b-hero .wrap {
  position: relative;
  z-index: 1;
}

.b-hero h1 {
  margin: .6rem 0 .45rem;
  font-size: var(--fs-4);
  letter-spacing: -.01em;
  background: linear-gradient(135deg, #fff 40%, color-mix(in oklab, var(--gold) 22%, #fff));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: goldFlow 10s ease-in-out infinite alternate;
}

.b-hero .lead {
  color: var(--muted);
  max-width: 72ch;
  margin: 0;
  line-height: 1.6;
  font-size: var(--fs-1);
}

/* Search — mobile sticky + bigger tap */
.search {
  margin-top: 1rem;
  position: relative;
  width: 100%;
  max-width: min(560px, 100%);
  position: sticky;
  top: .5rem;
  z-index: 5;
}

.search::before {
  content: "";
  position: absolute;
  left: .9rem;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  opacity: .75;
  background:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23cfd2d8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='8'/><line x1='21' y1='21' x2='16.65' y2='16.65'/></svg>") no-repeat center/contain;
  pointer-events: none;
}

.search input {
  width: 100%;
  background: #080808;
  border: 1px solid #232323;
  border-radius: var(--radius);
  padding: 1rem 1rem 1rem 2.6rem;
  color: #fff;
  font-size: var(--fs-1);
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease, transform .2s ease;
}

.search input::placeholder {
  color: #9aa1ad;
}

.search input:focus {
  outline: none;
  border-color: color-mix(in oklab, var(--gold) 42%, #232323);
  box-shadow: var(--ring);
  background: #0b0b0b;
  transform: translateY(-1px);
}

/* =========================
   GRID
   ========================= */
.b-grid {
  background: var(--bg);
  color: var(--text);
  padding: 1.15rem 0 2.2rem;
}

.grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--gutter);
  grid-template-columns: repeat(auto-fill, minmax(clamp(260px, 28vw, 1fr), 1fr));
  align-items: start;
  container-type: inline-size;
  /* enables container queries below */
}

@media (width <=700px) {
  .grid {
    grid-template-columns: 1fr;
  }
}

/* Cards */
.card {
  position: relative;
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  gap: .65rem;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) + .1rem);
  overflow: hidden;
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease, background .25s ease, outline-color .25s ease;
  box-shadow: var(--shadow-soft);
  content-visibility: auto;
  contain-intrinsic-size: 420px;
  /* perf: faster list paint */
}

.card::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 2px;
  background: var(--accent-line);
  opacity: .7;
}

.card::before {
  content: "";
  position: absolute;
  inset: auto 10% -2px 10%;
  height: 22px;
  border-radius: 999px;
  background: radial-gradient(60% 90% at 50% 0%, color-mix(in oklab, var(--gold) 40%, transparent), transparent 70%);
  opacity: .4;
  filter: blur(10px);
}

@media (hover:hover) {
  .card:hover {
    transform: translateY(-6px) scale(1.006);
    border-color: color-mix(in oklab, var(--gold) 44%, var(--border));
    box-shadow: var(--shadow-2);
  }
}

.card:focus-within {
  outline: 2px solid color-mix(in oklab, var(--gold) 45%, transparent);
  outline-offset: 2px;
}

/* Cover */
.cover {
  aspect-ratio: 16/9;
  background: #0a0a0a;
  border-bottom: 1px solid var(--border);
  overflow: hidden;
  position: relative;
}

.cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  inline-size: 100%;
  transform: scale(1.02);
  transition: transform .55s ease, filter .35s ease;
  image-rendering: auto;
  -webkit-user-drag: none;
  user-select: none;
}

.cover::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, .22), transparent 30%, transparent 70%, rgba(0, 0, 0, .18));
  pointer-events: none;
}

@media (hover:hover) {
  .card:hover .cover img {
    transform: scale(1.06);
    filter: saturate(1.05) contrast(1.02);
  }
}

/* Meta & chip */
.meta {
  display: flex;
  align-items: center;
  gap: .55rem;
  padding: .8rem 1rem 0;
}

.meta .chip {
  position: relative;
  overflow: hidden;
  font-size: calc(var(--fs-0) * .95);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #111;
  padding: .34rem .64rem;
  border-radius: .6rem;
  background: linear-gradient(135deg, var(--gold), var(--gold-2));
  box-shadow: 0 10px 26px -14px color-mix(in oklab, var(--gold) 60%, transparent);
}

.meta .chip::after {
  content: "";
  position: absolute;
  inset: -60% -80%;
  background: linear-gradient(115deg, transparent 45%, rgba(255, 255, 255, .65) 50%, transparent 55%);
  mix-blend-mode: screen;
  transform: translateX(-120%);
  pointer-events: none;
  animation: shineSweep 4.2s ease-in-out infinite .5s;
}

/* Title */
.title {
  padding: 0 1rem;
}

.title h2 {
  font-size: var(--fs-2);
  letter-spacing: .1px;
  margin: .15rem 0 0;
  line-height: 1.28;
}

.title h2 a {
  color: #fff;
  text-decoration: none;
  background:
    linear-gradient(currentColor 0 0) 0 100%/0 2px no-repeat;
  transition: background-size .22s ease, color .22s ease;
}

.title h2 a:hover {
  color: var(--gold);
  background-size: 100% 2px;
}

/* Excerpt (line clamp) */
.excerpt {
  padding: 0 1rem;
  color: var(--muted-2);
  line-height: 1.6;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 3.9em;
  font-size: var(--fs-1);
}

/* Actions */
.actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .6rem;
  padding: 0 1rem 1rem;
  flex-wrap: wrap;
}

.actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .64rem .95rem;
  border-radius: .85rem;
  border: 1px solid #232323;
  text-decoration: none;
  font-weight: 800;
  letter-spacing: .2px;
  color: #fff;
  background: #0e0e0e;
  min-height: 42px;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease, color .2s ease, background .2s ease;
}

.actions a:hover {
  border-color: color-mix(in oklab, var(--gold) 38%, #232323);
  box-shadow: var(--ring);
}

.actions a:first-child {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, var(--gold), var(--gold-2));
  color: #111;
  border-color: transparent;
  box-shadow: 0 12px 36px -12px color-mix(in oklab, var(--gold) 60%, transparent);
}

.actions a:first-child::after {
  content: "";
  position: absolute;
  inset: -20% -60%;
  background: linear-gradient(100deg, transparent 45%, rgba(255, 255, 255, .6) 50%, transparent 55%);
  mix-blend-mode: screen;
  transform: translateX(-120%);
  pointer-events: none;
  animation: shineSweep 3.6s ease-in-out infinite .2s;
}

@media (hover:hover) {
  .actions a:first-child:hover {
    transform: translateY(-1px) scale(1.01);
  }
}

/* Empty state */
.empty {
  color: #cfd2d8;
  text-align: center;
  padding: 1.2rem 0;
  border: 1px dashed #232323;
  border-radius: .9rem;
  background: linear-gradient(180deg, rgba(255, 255, 255, .03), rgba(255, 255, 255, .02));
  font-size: var(--fs-1);
}

/* =========================
   CTA BAND
   ========================= */
.b-band {
  border-top: 1px solid var(--border);
  background: var(--bg-2);
  color: #fff;
  padding: 1.55rem 0 1.8rem;
}

.band {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: clamp(1rem, 1.7vw, 1.5rem);
  box-shadow: var(--shadow-soft);
  position: relative;
  overflow: hidden;
}

.band::before {
  content: "";
  position: absolute;
  inset: -10% -20% auto -20%;
  height: 60%;
  background: var(--gold-wash);
  filter: blur(38px);
  opacity: .24;
  pointer-events: none;
}

.band h2 {
  margin: 0 0 .2rem;
  font-size: var(--fs-3);
}

.band p {
  margin: 0;
  color: #cfd2d8;
  font-size: var(--fs-1);
}

.band-cta {
  display: flex;
  gap: .8rem;
  flex-wrap: wrap;
}

@media (max-width:860px) {
  .band {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* =========================
   Progressive enhancement
   ========================= */

/* Backdrop for capable browsers */
@supports(backdrop-filter: blur(4px)) {

  .card,
  .band {
    backdrop-filter: var(--glass);
  }
}

/* Container query: tighten text when columns are narrow */
@container (max-width: 320px) {
  .title h2 {
    font-size: clamp(1.05rem, 2.5vw, 1.14rem);
  }

  .excerpt {
    -webkit-line-clamp: 4;
  }
}

/* Scrollbar (subtle) */
* {
  scrollbar-width: thin;
  scrollbar-color: #333 #0b0b0b;
}

*::-webkit-scrollbar {
  height: 10px;
  width: 10px;
}

*::-webkit-scrollbar-thumb {
  background: #333;
  border-radius: 10px;
}

*::-webkit-scrollbar-track {
  background: #0b0b0b;
}

/* Respect motion/contrast/forced-colors */
@media (prefers-reduced-motion:reduce) {

  .reveal,
  .card,
  .cover img,
  .btn,
  .actions a,
  .meta .chip::after,
  .btn-primary::after,
  .actions a:first-child::after,
  .b-hero .bg::after,
  .b-hero h1 {
    transition: none !important;
    animation: none !important;
  }
}

@media (prefers-contrast: more) {

  .btn,
  .actions a {
    border-color: #444;
  }

  .card {
    border-color: #2a2a2a;
  }

  .search input {
    border-color: #3a3a3a;
  }
}

@media (forced-colors: active) {

  .btn,
  .actions a,
  .card,
  .band,
  .search input {
    border: 1px solid CanvasText;
  }

  .title h2 a {
    text-decoration: underline;
    background: none;
  }
}

/* Touch/keyboard affordances */
@media (pointer:coarse) {

  .actions a,
  .btn {
    min-height: 48px;
    padding: .75rem 1rem;
  }
}

/* =========================
   Keyframes
   ========================= */
@keyframes shineSweep {
  0% {
    transform: translateX(-120%);
  }

  45% {
    transform: translateX(120%);
  }

  100% {
    transform: translateX(120%);
  }
}

@keyframes gridDrift {
  from {
    transform: translateY(0);
  }

  to {
    transform: translateY(-24px);
  }
}

@keyframes goldFlow {
  0% {
    background-position: 0% 50%;
  }

  100% {
    background-position: 100% 50%;
  }
}