:root {
  --primary: #FF00FF; --accent: #00FFFF;
  --bg-base: #050510; --bg-elev: #0F0F1A; --bg-overlay: rgba(5,5,16,0.8);
  --text-primary: #FFFFFF; --text-secondary: #A0A0B0;
  --card-radius: 8px;
  --title-font: 'Chakra Petch', sans-serif;
  --body-font: 'JetBrains Mono', monospace;
}

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bg-base);
  color: var(--text-primary);
  font-family: var(--body-font);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  min-height: 100vh;
  overflow-x: hidden;
  line-height: 1.5;
}
h1, h2, h3, h4, h5, h6, .font-title {
  font-family: var(--title-font);
  letter-spacing: -0.01em;
  margin: 0;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { font: inherit; cursor: pointer; }
input, textarea, select { font: inherit; color: inherit; }
::selection { background: var(--primary); color: var(--bg-base); }

/* Scrollbar */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--bg-base); }
::-webkit-scrollbar-thumb { background: var(--bg-elev); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--primary); }

/* Layout container */
.container { max-width: 1600px; margin: 0 auto; padding: 0 24px; }
@media (max-width: 640px) { .container { padding: 0 16px; } }

/* Utility */
.bg-elev { background: var(--bg-elev); }
.bg-base { background: var(--bg-base); }
.text-primary-ink { color: var(--text-primary); }
.text-secondary-ink { color: var(--text-secondary); }
.primary-ink { color: var(--primary); }
.accent-ink { color: var(--accent); }
.border-elev { border: 1px solid var(--bg-elev); }
.hover-primary:hover { color: var(--primary); }
.mt-4 { margin-top: 16px; } .mt-6 { margin-top: 24px; } .mt-8 { margin-top: 32px; }
.mt-10 { margin-top: 40px; } .mt-14 { margin-top: 56px; } .mt-16 { margin-top: 64px; }
.mb-2 { margin-bottom: 8px; } .mb-3 { margin-bottom: 12px; } .mb-4 { margin-bottom: 16px; }
.mb-5 { margin-bottom: 20px; } .mb-6 { margin-bottom: 24px; } .mb-8 { margin-bottom: 32px; }
.p-4 { padding: 16px; } .p-6 { padding: 24px; } .p-8 { padding: 32px; }
.py-6 { padding-top: 24px; padding-bottom: 24px; } .py-10 { padding: 40px 0; } .py-14 { padding: 56px 0; }
.text-xs { font-size: 11px; } .text-sm { font-size: 13px; } .text-base { font-size: 15px; }
.text-lg { font-size: 18px; } .text-xl { font-size: 20px; } .text-2xl { font-size: 24px; }
.text-3xl { font-size: 30px; } .text-4xl { font-size: 36px; } .text-5xl { font-size: 48px; }
.uppercase { text-transform: uppercase; }
.tracking-wider { letter-spacing: 0.1em; }
.tracking-widest { letter-spacing: 0.2em; }
.font-bold { font-weight: 700; } .font-semibold { font-weight: 600; }
.flex { display: flex; } .inline-flex { display: inline-flex; }
.items-center { align-items: center; } .justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.gap-2 { gap: 8px; } .gap-3 { gap: 12px; } .gap-4 { gap: 16px; } .gap-6 { gap: 24px; }
.flex-wrap { flex-wrap: wrap; } .flex-1 { flex: 1 1 0; }
.grid { display: grid; }
.hidden { display: none; }
.block { display: block; }
.w-full { width: 100%; } .max-w-2xl { max-width: 672px; margin: 0 auto; } .max-w-3xl { max-width: 768px; margin: 0 auto; }
.line-clamp-2 { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.text-center { text-align: center; }
.text-red { color: #ff6464; }

/* Fade in animation */
@keyframes fadeInUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.fade-in-up { animation: fadeInUp 0.5s cubic-bezier(0.4, 0, 0.2, 1) both; }

/* ============ Header ============ */
.site-header { border-bottom: 1px solid var(--bg-elev); z-index: 40; }
.header-sticky-solid { position: sticky; top: 0; background: var(--bg-base); }
.header-transparent-on-scroll { position: sticky; top: 0; background: transparent; transition: background 0.3s; }
.header-transparent-on-scroll.scrolled { background: var(--bg-overlay); backdrop-filter: blur(18px); }
.header-split-two-row { position: sticky; top: 0; background: var(--bg-base); }
.header-centered-logo { position: sticky; top: 0; background: var(--bg-base); }
.site-header .inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 16px 0; }
.site-logo { display: flex; align-items: center; gap: 8px; font-family: var(--title-font); font-size: 22px; color: var(--text-primary); }
.site-logo .dot { width: 10px; height: 10px; background: var(--primary); border-radius: 50%; }
.search-box { display: flex; align-items: center; flex: 1; max-width: 560px;
  background: var(--bg-elev); border-radius: var(--card-radius); padding: 8px 14px; gap: 10px; }
.search-box input { background: transparent; border: 0; outline: 0; flex: 1; font-size: 14px; }
.nav-cats { display: flex; gap: 20px; font-size: 14px; }
.nav-cats a { color: var(--text-secondary); transition: color .2s; }
.nav-cats a:hover { color: var(--primary); }
.mobile-menu-btn { display: none; background: transparent; border: 0; color: var(--text-primary); font-size: 22px; padding: 8px 10px; }
.mobile-menu { display: none; flex-direction: column; border-top: 1px solid var(--bg-elev); background: var(--bg-base); }
.mobile-menu.open { display: flex; }
.mobile-menu a { padding: 12px 20px; color: var(--text-secondary); border-bottom: 1px solid var(--bg-elev); font-size: 14px; }
.mobile-menu a:hover { color: var(--primary); background: var(--bg-elev); }
@media (max-width: 960px) {
  .search-box { display: none; }
  .nav-cats { display: none; }
  .mobile-menu-btn { display: inline-flex; }
}

/* --- Header: prompt (terminal bar) --- */
.header-prompt { background: #060a0a; border-bottom: 1px solid rgba(57,255,20,0.2); font-family: 'JetBrains Mono', monospace; padding: 8px 0; }
.header-prompt .prompt-line { display: flex; align-items: center; gap: 14px; font-size: 13px; flex-wrap: wrap; color: #d6ffcc; }
.header-prompt .prompt-user { color: var(--accent); font-weight: 700; white-space: nowrap; }
.header-prompt .prompt-cmd { color: var(--text-primary); }
.header-prompt .prompt-cmd:hover { color: var(--accent); }
.header-prompt .prompt-sep { color: rgba(255,255,255,0.2); }
.header-prompt .prompt-cat { color: rgba(255,255,255,0.55); }
.header-prompt .prompt-cat:hover { color: var(--accent); }
.header-prompt .prompt-search { margin-left: auto; display: flex; align-items: center; gap: 8px; color: var(--text-secondary); }
.header-prompt .prompt-search input { background: transparent; border: 0; outline: 0; color: #d6ffcc; font-family: inherit; }
@media (max-width: 960px) { .header-prompt .prompt-cat, .header-prompt .prompt-search, .header-prompt .prompt-sep { display: none; } }

/* --- Header: strip (newspaper) --- */
.header-strip { background: var(--bg-base); border-bottom: 1px solid var(--bg-elev); }
.header-strip .strip-top { display: flex; justify-content: space-between; font-family: 'Special Elite', 'Playfair Display', serif; font-size: 11px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--text-secondary); padding: 6px 24px; border-bottom: 1px solid var(--bg-elev); }
.header-strip .strip-bar { display: flex; align-items: center; gap: 24px; padding: 12px 24px; flex-wrap: wrap; }
.header-strip .strip-name { font-family: 'Playfair Display', 'Cormorant Garamond', serif; font-weight: 900; font-size: 28px; letter-spacing: -0.02em; color: var(--text-primary); }
.header-strip .strip-nav { display: flex; gap: 20px; font-size: 13px; flex: 1; justify-content: center; }
.header-strip .strip-nav a { color: var(--text-secondary); font-family: 'Playfair Display', serif; font-style: italic; }
.header-strip .strip-nav a:hover { color: var(--primary); }
.header-strip .search-box { max-width: 220px; }
@media (max-width: 960px) { .header-strip .strip-nav, .header-strip .search-box { display: none; } }

/* --- Header: wordmark (editorial/gallery/luxury) --- */
.header-wordmark { background: var(--bg-base); border-bottom: 1px solid var(--bg-elev); }
.header-wordmark .wordmark-top { display: flex; align-items: center; justify-content: space-between; padding: 24px; gap: 16px; }
.header-wordmark .wordmark-brand { display: flex; flex-direction: column; align-items: flex-start; gap: 2px; }
.header-wordmark .wordmark-name { font-size: 28px; color: var(--primary); letter-spacing: -0.01em; line-height: 1; }
@media (min-width: 900px) { .header-wordmark .wordmark-name { font-size: 34px; } }
.header-wordmark .wordmark-tag { font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--text-secondary); font-style: italic; }
.header-wordmark .wordmark-search input { background: var(--bg-elev); padding: 8px 14px; }
.header-wordmark .wordmark-nav-row { border-top: 1px solid var(--bg-elev); }
.header-wordmark .wordmark-nav { display: flex; gap: 24px; padding: 10px 0; justify-content: center; font-size: 12px; letter-spacing: 0.15em; text-transform: uppercase; flex-wrap: wrap; }
.header-wordmark .wordmark-nav a { color: var(--text-secondary); }
.header-wordmark .wordmark-nav a:hover { color: var(--primary); }
@media (max-width: 960px) { .header-wordmark .wordmark-search, .header-wordmark .wordmark-nav-row { display: none; } }

/* --- Header: centered (logo between split nav) --- */
.header-centered2 { background: var(--bg-base); border-bottom: 1px solid var(--bg-elev); padding: 16px 0; }
.header-centered2 .centered-row { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 24px; }
.header-centered2 .centered-left-cats { display: flex; gap: 18px; justify-content: flex-end; font-size: 12px; letter-spacing: 0.15em; text-transform: uppercase; }
.header-centered2 .centered-right-cats { display: flex; gap: 18px; font-size: 12px; letter-spacing: 0.15em; text-transform: uppercase; align-items: center; }
.header-centered2 .centered-left-cats a, .header-centered2 .centered-right-cats a { color: var(--text-secondary); }
.header-centered2 .centered-left-cats a:hover, .header-centered2 .centered-right-cats a:hover { color: var(--primary); }
.header-centered2 .centered-logo { font-family: var(--title-font); font-size: 32px; color: var(--primary); letter-spacing: -0.01em; justify-content: center; }
.header-centered2 .centered-search-icon { font-size: 18px; color: var(--text-primary); }
@media (max-width: 960px) { .header-centered2 .centered-left-cats, .header-centered2 .centered-right-cats { display: none; } .header-centered2 .centered-row { grid-template-columns: 1fr auto; } }

/* --- Header: minimal2 (logo + nav only, no search box) --- */
.header-minimal2 { padding: 16px 0; border-bottom: 1px solid var(--bg-elev); }
.header-minimal2 .minimal-row { display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.header-minimal2 .minimal-nav { gap: 18px; font-size: 12px; letter-spacing: 0.15em; text-transform: uppercase; }
.header-minimal2 .minimal-search-link { font-size: 18px; color: var(--text-primary); margin-left: 12px; }
.header-minimal2 .minimal-search-link:hover { color: var(--primary); }

/* ============ Video Card ============ */
.video-card {
  position: relative;
  overflow: hidden;
  border-radius: var(--card-radius);
  background: var(--bg-elev);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.3s;
  cursor: pointer;
  display: block;
}
.video-card:hover { transform: translateY(-4px) scale(1.02); box-shadow: 0 20px 60px -20px var(--primary); }
.video-card .thumb-wrap { position: relative; aspect-ratio: 16/9; overflow: hidden; background: var(--bg-base); }
.video-card .thumb-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s; }
.video-card:hover .thumb-wrap img { transform: scale(1.08); }
.video-card .play-overlay {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,0.6) 100%);
  opacity: 0; transition: opacity 0.3s;
}
.video-card:hover .play-overlay { opacity: 1; }
.video-card .play-overlay .pin { width: 56px; height: 56px; background: var(--primary); color: var(--bg-base);
  display: flex; align-items: center; justify-content: center; border-radius: 50%; font-size: 24px; }
.duration-pill { position: absolute; bottom: 8px; right: 8px; background: rgba(0,0,0,0.85); color: #fff;
  padding: 2px 8px; font-size: 11px; font-weight: 600; border-radius: 3px; }
.hd-badge { position: absolute; top: 8px; left: 8px; background: var(--primary); color: var(--bg-base);
  padding: 2px 8px; font-size: 10px; font-weight: 700; letter-spacing: 0.05em; }
.info-wrap { padding: 12px; }
.info-wrap h3 { font-size: 15px; line-height: 1.3; margin-bottom: 8px; color: var(--text-primary);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.info-wrap .meta { display: flex; align-items: center; gap: 12px; font-size: 11px; color: var(--text-secondary); }
.info-wrap .meta .cat-chip { padding: 2px 8px; background: var(--bg-base); color: var(--accent);
  border-radius: var(--card-radius); font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; }

/* Buttons */
.btn { padding: 12px 28px; font-weight: 600; border-radius: var(--card-radius); border: 0; transition: all 0.25s;
  font-family: var(--body-font); letter-spacing: 0.02em; text-align: center; display: inline-block; }
.btn-primary { background: var(--primary); color: var(--bg-base); }
.btn-primary:hover { filter: brightness(1.15); box-shadow: 0 10px 30px -10px var(--primary); transform: translateY(-1px); }
.btn-ghost { background: transparent; color: var(--text-primary); border: 1px solid var(--text-secondary); }
.btn-ghost:hover { border-color: var(--primary); color: var(--primary); }

/* Variant button overrides */
.variant-button-pill .btn { border-radius: 999px; }
.variant-button-sharp .btn { border-radius: 0; }
.variant-button-filled-gradient .btn-primary { background: linear-gradient(135deg, var(--primary), var(--accent)); }
.variant-button-ghost-underline .btn-primary { background: transparent; color: var(--primary);
  border-bottom: 2px solid var(--primary); border-radius: 0; padding-left: 0; padding-right: 0; }

/* Card variants */
.variant-card-glass .video-card { background: rgba(255,255,255,0.04); backdrop-filter: blur(18px);
  border: 1px solid rgba(255,255,255,0.06); }
.variant-card-bordered .video-card { border: 1px solid var(--text-secondary); background: transparent; }
.variant-card-elevated-shadow .video-card { box-shadow: 0 12px 40px -12px rgba(0,0,0,0.5); }
.variant-card-flat-glow .video-card:hover { box-shadow: 0 0 0 1px var(--accent), 0 20px 60px -20px var(--accent); }

/* ============ Grids ============ */
.grid-tight-4-col { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
@media (min-width: 768px) { .grid-tight-4-col { grid-template-columns: repeat(3, 1fr); gap: 20px; } }
@media (min-width: 1200px) { .grid-tight-4-col { grid-template-columns: repeat(4, 1fr); } }

.grid-masonry-3-col { columns: 1; column-gap: 20px; }
@media (min-width: 768px) { .grid-masonry-3-col { columns: 2; } }
@media (min-width: 1100px) { .grid-masonry-3-col { columns: 3; } }
.grid-masonry-3-col > * { break-inside: avoid; margin-bottom: 20px; }

.grid-wide-2-col-featured { display: grid; grid-template-columns: 1fr; gap: 24px; }
@media (min-width: 1000px) {
  .grid-wide-2-col-featured { grid-template-columns: 2fr 1fr; }
  .grid-wide-2-col-featured > *:first-child { grid-row: span 2; }
}

.grid-magazine-editorial { display: grid; grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: minmax(180px, auto); gap: 20px; }
.grid-magazine-editorial > *:nth-child(5n+1) { grid-column: span 2; grid-row: span 2; }
@media (max-width: 900px) {
  .grid-magazine-editorial { grid-template-columns: repeat(2, 1fr); }
  .grid-magazine-editorial > *:nth-child(5n+1) { grid-column: span 2; grid-row: span 1; }
}

.grid-carousel-hybrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 24px; }

.grid-list-large-thumbnails { display: flex; flex-direction: column; gap: 20px; }
.grid-list-large-thumbnails .video-card { display: grid; grid-template-columns: 260px 1fr; gap: 20px; align-items: stretch; }
@media (max-width: 720px) { .grid-list-large-thumbnails .video-card { grid-template-columns: 1fr; } }

/* ============ Hero / Sections ============ */
.hero { padding: 40px 0; display: grid; grid-template-columns: 2fr 1fr; gap: 32px; align-items: center; }
@media (max-width: 960px) { .hero { grid-template-columns: 1fr; } .hero .ad-wrap { display: none; } }
.hero .chip { display: inline-block; padding: 4px 12px; font-size: 10px; text-transform: uppercase;
  letter-spacing: 0.2em; background: var(--bg-elev); color: var(--accent);
  border-radius: var(--card-radius); margin-bottom: 16px; }
.hero h1 { font-size: 40px; line-height: 1.05; margin-bottom: 12px; }
@media (min-width: 768px) { .hero h1 { font-size: 52px; } }
@media (min-width: 1100px) { .hero h1 { font-size: 64px; } }
.hero .tagline { font-size: 17px; color: var(--text-secondary); max-width: 540px; }
.hero .ctas { margin-top: 24px; display: flex; gap: 12px; flex-wrap: wrap; }

/* --- Personality: strip (no hero) --- */
.hero-strip { display: flex; align-items: baseline; justify-content: space-between; gap: 20px;
  padding: 20px 0 8px; border-bottom: 1px solid var(--bg-elev); margin-bottom: 24px; flex-wrap: wrap; }
.hero-strip .site-mini { font-family: var(--title-font); font-size: 22px; color: var(--text-primary); letter-spacing: -0.01em; }
.hero-strip .tagline-mini { font-size: 12px; color: var(--text-secondary); text-transform: uppercase; letter-spacing: 0.2em; }

/* --- Personality: split (default premium hero) --- */
.hero-split { /* inherits .hero */ }

/* --- Personality: bold (huge banner title) --- */
.hero-bold { display: block; padding: 64px 0 32px; border-bottom: 1px solid var(--bg-elev); }
.hero-bold .bold-title { font-size: 72px; line-height: 0.95; letter-spacing: -0.03em;
  text-transform: uppercase; color: var(--primary); margin-bottom: 16px; }
@media (min-width: 768px) { .hero-bold .bold-title { font-size: 112px; } }
@media (min-width: 1100px) { .hero-bold .bold-title { font-size: 160px; } }
.hero-bold .bold-bar { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.hero-bold .bold-tag { color: var(--text-secondary); font-size: 14px; letter-spacing: 0.1em; text-transform: uppercase; max-width: 640px; }

/* --- Personality: magazine (asymmetric with big cover card) --- */
.hero-magazine { display: grid; grid-template-columns: 1fr; gap: 32px; padding: 56px 0 24px;
  border-bottom: 1px dashed var(--bg-elev); }
@media (min-width: 1000px) { .hero-magazine { grid-template-columns: 1fr 1.3fr; } }
.hero-magazine .chip-serif { background: transparent; color: var(--primary);
  border: 1px solid var(--primary); border-radius: 0; padding: 4px 14px; font-size: 11px; }
.hero-magazine .mag-title { font-size: 56px; line-height: 1; }
@media (min-width: 1100px) { .hero-magazine .mag-title { font-size: 84px; } }
.hero-magazine .mag-tag { font-style: italic; font-size: 18px; max-width: 520px; }
.hero-magazine .mag-cover { position: relative; display: block; overflow: hidden;
  aspect-ratio: 16/10; border-radius: var(--card-radius); background: var(--bg-elev); }
.hero-magazine .mag-cover img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s; }
.hero-magazine .mag-cover:hover img { transform: scale(1.04); }
.hero-magazine .mag-cover-meta { position: absolute; inset: auto 0 0 0; padding: 32px 24px 20px;
  background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.85) 100%); }
.hero-magazine .mag-issue { font-size: 10px; letter-spacing: 0.3em; color: var(--accent); text-transform: uppercase; }
.hero-magazine .mag-cover-meta h3 { color: #fff; font-size: 22px; margin-top: 8px; line-height: 1.2; }

/* --- Personality: minimal --- */
.hero-minimal { display: block; padding: 112px 0 80px; }
.hero-minimal .minimal-title { font-size: 80px; line-height: 0.95; letter-spacing: -0.04em; color: var(--primary); }
@media (min-width: 1100px) { .hero-minimal .minimal-title { font-size: 160px; } }
.hero-minimal .minimal-tag { margin-top: 24px; font-size: 16px; color: var(--text-secondary); max-width: 420px; line-height: 1.5; }
.hero-minimal .minimal-cta { display: inline-block; margin-top: 40px; font-size: 15px; color: var(--text-primary);
  border-bottom: 1px solid var(--primary); padding-bottom: 4px; transition: color .2s; }
.hero-minimal .minimal-cta:hover { color: var(--primary); }

/* --- Personality: terminal --- */
.hero-terminal { display: block; padding: 56px 0; }
.term-window { max-width: 820px; margin: 0 auto; border-radius: var(--card-radius);
  overflow: hidden; background: #060a0a; border: 1px solid rgba(57,255,20,0.25);
  box-shadow: 0 20px 60px -20px rgba(0, 255, 120, 0.15); }
.term-bar { background: #0b1010; padding: 10px 14px; font-size: 11px;
  color: var(--text-secondary); display: flex; align-items: center; gap: 8px; font-family: 'JetBrains Mono', monospace; }
.term-bar span { display: inline-block; width: 10px; height: 10px; border-radius: 50%; background: #444; }
.term-bar span:nth-child(1) { background: #ff6464; }
.term-bar span:nth-child(2) { background: #ffb838; }
.term-bar span:nth-child(3) { background: #39c74e; }
.term-body { padding: 32px 28px; font-family: 'JetBrains Mono', monospace; font-size: 14px; line-height: 1.8; color: #d6ffcc; }
.term-line { white-space: pre-wrap; }
.term-prompt { color: var(--accent); font-weight: 700; margin-right: 8px; }
.term-muted { color: rgba(255,255,255,0.38); }
.term-cursor { display: inline-block; margin-left: 4px; animation: blink 1s steps(1) infinite; color: var(--accent); }
@keyframes blink { 50% { opacity: 0; } }
.term-actions { margin-top: 18px; display: flex; gap: 10px; flex-wrap: wrap; }

/* --- Personality: centered --- */
.hero-centered { display: block; text-align: center; padding: 72px 0 40px; }
.hero-centered .chip { margin-bottom: 20px; }
.hero-centered .centered-title { font-size: 48px; line-height: 1.1; max-width: 880px; margin: 0 auto; }
@media (min-width: 1100px) { .hero-centered .centered-title { font-size: 72px; } }
.hero-centered .tagline { margin: 16px auto 0; max-width: 560px; }
.hero-centered .ctas { justify-content: center; }

/* --- Personality: noir --- */
.hero-noir { display: block; text-align: center; padding: 64px 0 32px;
  border-top: 2px solid var(--primary); border-bottom: 2px solid var(--primary); margin: 24px 0 40px; }
.hero-noir .noir-chip { font-size: 10px; letter-spacing: 0.5em; color: var(--accent);
  text-transform: uppercase; margin-bottom: 16px; }
.hero-noir .noir-title { font-family: var(--title-font); font-size: 80px; letter-spacing: -0.02em;
  text-transform: uppercase; color: var(--text-primary); line-height: 0.9; }
@media (min-width: 1100px) { .hero-noir .noir-title { font-size: 144px; } }
.hero-noir .noir-tag { margin-top: 12px; color: var(--text-secondary); font-size: 14px; letter-spacing: 0.2em; text-transform: uppercase; }
.hero-noir .ctas { justify-content: center; margin-top: 28px; }

/* --- Personality: poetic --- */
.hero-poetic { display: block; padding: 96px 0 56px; text-align: left; max-width: 980px; }
.hero-poetic .poetic-chip { font-style: italic; font-size: 13px; color: var(--text-secondary); letter-spacing: 0.2em; margin-bottom: 40px; }
.hero-poetic .poetic-quote { font-family: 'Playfair Display', 'Cormorant Garamond', serif; font-style: italic;
  font-weight: 400; font-size: 44px; line-height: 1.2; color: var(--text-primary);
  margin: 0; padding: 0; border: 0; }
@media (min-width: 900px) { .hero-poetic .poetic-quote { font-size: 64px; } }
@media (min-width: 1200px) { .hero-poetic .poetic-quote { font-size: 80px; } }
.hero-poetic .quote-mark { color: var(--primary); font-family: serif; font-size: 1.2em; padding: 0 4px; }
.hero-poetic .poetic-attrib { margin-top: 24px; color: var(--text-secondary); font-style: italic; font-size: 16px; }
.hero-poetic .ctas { margin-top: 48px; }

/* --- Personality: masthead (newspaper flag) --- */
.hero-masthead { display: block; text-align: center; padding: 48px 0 28px; border-bottom: 4px double var(--text-primary); }
.hero-masthead .masthead-rule { height: 3px; background: var(--text-primary); margin: 6px 0; }
.hero-masthead .masthead-meta { display: flex; justify-content: space-between; font-family: 'Special Elite', 'Playfair Display', serif; font-size: 12px; text-transform: uppercase; letter-spacing: 0.2em; color: var(--text-secondary); padding: 4px 8px; }
.hero-masthead .masthead-title { font-family: 'Playfair Display', 'Cormorant Garamond', serif; font-weight: 900;
  font-size: 72px; letter-spacing: -0.03em; line-height: 0.95; margin: 18px 0; color: var(--text-primary); text-transform: none; }
@media (min-width: 900px) { .hero-masthead .masthead-title { font-size: 120px; } }
@media (min-width: 1200px) { .hero-masthead .masthead-title { font-size: 160px; } }
.hero-masthead .masthead-chip { font-style: italic; color: var(--primary); margin: 16px 0 8px; letter-spacing: 0.1em; font-size: 13px; }
.hero-masthead .masthead-tag { font-family: 'Playfair Display', serif; font-size: 16px; color: var(--text-secondary); margin: 8px 0; }
.hero-masthead .ctas { justify-content: center; margin-top: 20px; padding-bottom: 8px; }

/* --- Personality: gallery (museum) --- */
.hero-gallery { display: grid; grid-template-columns: 1fr; gap: 48px; padding: 72px 0 40px; }
@media (min-width: 900px) { .hero-gallery { grid-template-columns: 1.3fr 1fr; gap: 80px; align-items: center; } }
.hero-gallery .gallery-frame { display: block; aspect-ratio: 3/4; overflow: hidden; background: var(--bg-elev);
  border: 1px solid var(--text-secondary); max-height: 560px; }
.hero-gallery .gallery-frame img { width: 100%; height: 100%; object-fit: cover; filter: saturate(0.85); transition: transform .8s, filter .6s; }
.hero-gallery .gallery-frame:hover img { transform: scale(1.03); filter: saturate(1); }
.hero-gallery .gallery-chip { font-family: 'Playfair Display', serif; font-style: italic; font-size: 12px; letter-spacing: 0.4em; text-transform: uppercase; color: var(--accent); margin-bottom: 24px; }
.hero-gallery .gallery-title { font-size: 48px; line-height: 1; margin-bottom: 12px; color: var(--text-primary); }
@media (min-width: 1100px) { .hero-gallery .gallery-title { font-size: 72px; } }
.hero-gallery .gallery-tag { font-size: 14px; color: var(--text-secondary); max-width: 360px; letter-spacing: 0.05em; margin-bottom: 24px; }

.section { margin-top: 48px; }
.section-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
.section-head h2 { font-size: 26px; display: flex; align-items: center; gap: 10px; }
.section-head h2 .icon { color: var(--primary); }
.section-head .view-all { font-size: 13px; color: var(--text-secondary); }
.section-head .view-all:hover { color: var(--primary); }

/* Personality-specific section-title tweaks */
.home-personality-bold-grid .section-head h2, .home-personality-club .section-head h2 { font-size: 20px; letter-spacing: 0.2em; text-transform: uppercase; }
.home-personality-minimal .section-head h2, .home-personality-japanese .section-head h2 { font-size: 14px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--text-secondary); }
.home-personality-minimal .section-head h2 .icon, .home-personality-japanese .section-head h2 .icon { display: none; }
.home-personality-terminal .section-head h2, .home-personality-hacker .section-head h2, .home-personality-arcade .section-head h2 { font-family: 'JetBrains Mono', monospace; font-size: 16px; color: var(--accent); text-transform: lowercase; }
.home-personality-arcade .section-head h2 { font-family: 'Press Start 2P', 'JetBrains Mono', monospace; font-size: 13px; text-transform: uppercase; letter-spacing: 0.15em; }
.home-personality-noir .section-head h2, .home-personality-spotlight .section-head h2, .home-personality-underground .section-head h2 { font-size: 22px; letter-spacing: 0.15em; text-transform: uppercase; }
.home-personality-editorial .section-head h2, .home-personality-vintage .section-head h2 { font-style: italic; font-weight: 400; }
.home-personality-straight .section-head h2 { font-size: 16px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-secondary); }
.home-personality-magazine .section-head h2, .home-personality-masthead .section-head h2 { font-family: 'Playfair Display', 'Cormorant Garamond', serif; font-weight: 400; font-style: italic; font-size: 28px; }
.home-personality-tabloid .section-head h2 { font-family: 'Anton', sans-serif; font-size: 30px; text-transform: uppercase; color: #FFCC00; background: #000; padding: 4px 12px; transform: rotate(-1deg); display: inline-flex; }
.home-personality-zine .section-head h2 { font-family: 'Special Elite', monospace; text-transform: lowercase; font-size: 22px; transform: rotate(-1.5deg); }
.home-personality-poetic .section-head h2 { font-family: 'Playfair Display', serif; font-style: italic; font-weight: 400; font-size: 32px; letter-spacing: -0.01em; }
.home-personality-gallery .section-head h2 { font-family: 'Playfair Display', serif; font-weight: 400; font-size: 14px; letter-spacing: 0.4em; text-transform: uppercase; color: var(--text-secondary); }
.home-personality-luxury .section-head h2 { font-family: 'Cormorant Garamond', 'Playfair Display', serif; font-style: italic; font-size: 30px; color: var(--primary); }
.home-personality-retro-80s .section-head h2 { font-family: 'Chakra Petch', 'Bebas Neue', sans-serif; text-transform: uppercase; letter-spacing: 0.2em; text-shadow: 2px 2px 0 var(--primary); font-size: 22px; }
.home-personality-cinema .section-head h2 { font-family: 'Playfair Display', serif; font-weight: 400; font-size: 28px; text-transform: none; font-style: italic; }
.home-personality-festival .section-head h2 { font-weight: 700; letter-spacing: 0.05em; font-size: 24px; }
.home-personality-brutalist .section-head h2 { font-family: 'JetBrains Mono', monospace; text-transform: uppercase; font-size: 32px; letter-spacing: -0.02em; border-bottom: 4px solid var(--text-primary); padding-bottom: 6px; }

/* ============ 300x250 Ad Slot ============ */
.ad-slot { display: inline-flex; flex-direction: column; align-items: center; gap: 6px; text-align: center; }
.ad-slot .ad-label { font-size: 10px; letter-spacing: 0.2em; color: var(--text-secondary); text-transform: uppercase; }
.ad-slot .ad-frame { width: 300px; height: 250px; border: 1px dashed var(--text-secondary);
  overflow: hidden; background: var(--bg-elev); display: flex; align-items: center; justify-content: center; }
.ad-slot .ad-frame img { width: 100%; height: 100%; object-fit: cover; }

/* ============ Age gate ============ */
.age-gate-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,0.85);
  backdrop-filter: blur(24px); display: flex; align-items: center; justify-content: center;
  z-index: 100; padding: 20px; }
.age-gate-card { max-width: 520px; width: 100%; background: var(--bg-elev);
  border: 1px solid var(--primary); border-radius: var(--card-radius); padding: 40px 32px; text-align: center; }
.age-gate-card .icon-wrap { display: flex; justify-content: center; margin-bottom: 20px; }
.age-gate-card .icon-wrap .icon { width: 56px; height: 56px; border-radius: 50%;
  background: var(--primary); color: var(--bg-base); display: flex; align-items: center;
  justify-content: center; font-size: 28px; }
.age-gate-card h2 { font-size: 32px; color: var(--primary); margin-bottom: 12px; }
.age-gate-card p { color: var(--text-secondary); font-size: 14px; margin-bottom: 8px; }
.age-gate-card .ctas { margin-top: 24px; display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* ============ Video detail ============ */
.video-detail { display: grid; grid-template-columns: 1fr 320px; gap: 32px; padding: 24px 0; }
@media (max-width: 1000px) { .video-detail { grid-template-columns: 1fr; } }
.video-player { width: 100%; background: #000; border-radius: var(--card-radius); overflow: hidden; aspect-ratio: 16/9; }
.video-player iframe { width: 100%; height: 100%; border: 0; }
.video-title { font-size: 28px; margin-top: 20px; color: var(--text-primary); }

/* Video caption — personality-specific small banner above the player */
.video-caption { display: inline-block; margin-bottom: 14px; padding: 6px 14px; font-size: 11px; letter-spacing: 0.1em; }
.video-caption.chip-serif { font-family: 'Playfair Display', serif; font-style: italic; color: var(--primary); background: transparent; border: 0; padding: 0; font-size: 15px; text-transform: none; letter-spacing: 0; }
.video-caption.chip-serif-italic { font-family: 'Playfair Display', serif; font-style: italic; color: var(--text-secondary); background: transparent; padding: 0; font-size: 14px; letter-spacing: 0; text-transform: none; }
.video-caption.chip-bold { font-weight: 700; background: var(--primary); color: var(--bg-base); text-transform: uppercase; letter-spacing: 0.3em; }
.video-caption.chip-mini { color: var(--text-secondary); text-transform: uppercase; letter-spacing: 0.3em; padding-left: 0; padding-right: 0; font-size: 10px; }
.video-caption.chip-term { font-family: 'JetBrains Mono', monospace; color: var(--accent); background: rgba(57,255,20,0.1); border: 1px solid rgba(57,255,20,0.3); border-radius: 4px; text-transform: none; letter-spacing: 0; }
.video-caption.chip-loud { background: linear-gradient(135deg, var(--primary), var(--accent)); color: #fff; font-weight: 700; text-transform: uppercase; letter-spacing: 0.2em; }
.video-caption.chip-noir { color: var(--accent); letter-spacing: 0.4em; text-transform: uppercase; background: transparent; border-top: 1px solid var(--primary); border-bottom: 1px solid var(--primary); padding: 8px 16px; font-size: 11px; }
.video-caption.chip-cinema { font-family: 'Playfair Display', serif; color: var(--primary); background: transparent; border-bottom: 1px solid var(--primary); padding: 4px 0; border-radius: 0; font-size: 13px; letter-spacing: 0.2em; text-transform: uppercase; }
.video-caption.chip-gallery { font-family: 'Playfair Display', serif; color: var(--text-secondary); font-style: italic; font-size: 11px; letter-spacing: 0.4em; text-transform: uppercase; padding: 0; }
.video-caption.chip-tabloid { background: #FFCC00; color: #000; font-family: 'Anton', sans-serif; font-size: 16px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.05em; transform: rotate(-1.5deg); padding: 4px 12px; }
.video-caption.chip-zine { font-family: 'Special Elite', monospace; text-transform: lowercase; transform: rotate(-1deg); background: var(--bg-elev); padding: 2px 10px; font-size: 13px; }
.video-caption.chip-arcade { font-family: 'Press Start 2P', 'JetBrains Mono', monospace; background: var(--primary); color: var(--bg-base); padding: 6px 10px; font-size: 10px; text-transform: uppercase; }
.video-caption.chip-brutal { font-family: 'JetBrains Mono', monospace; text-transform: uppercase; color: var(--text-primary); border: 2px solid var(--text-primary); padding: 4px 12px; font-weight: 700; letter-spacing: 0.2em; }

.video-meta-row { display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 12px; margin-top: 16px; font-size: 13px; color: var(--text-secondary); }
.video-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 20px; }
.video-tags .tag { font-size: 11px; padding: 4px 10px; background: var(--bg-elev); color: var(--text-secondary);
  border-radius: var(--card-radius); }
.related-card { display: grid; grid-template-columns: 110px 1fr; gap: 12px; padding: 8px;
  border-radius: var(--card-radius); background: var(--bg-elev); }
.related-card img { width: 110px; height: 62px; object-fit: cover; border-radius: var(--card-radius); }

/* ============ Forms ============ */
.form-field { display: block; margin-bottom: 16px; }
.form-field label { display: block; font-size: 10px; text-transform: uppercase; letter-spacing: 0.15em;
  color: var(--text-secondary); margin-bottom: 6px; }
.form-field input, .form-field textarea, .form-field select {
  width: 100%; padding: 12px 16px; background: var(--bg-elev); color: var(--text-primary);
  border: 1px solid transparent; border-radius: var(--card-radius); outline: 0; transition: border-color .2s; }
.form-field input:focus, .form-field textarea:focus, .form-field select:focus { border-color: var(--primary); }

/* ============ Admin panel ============ */
.admin-page { padding: 32px 0; }
.admin-tabs { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 24px; }
.admin-tabs .tab { padding: 8px 16px; font-size: 13px; background: var(--bg-elev); color: var(--text-secondary);
  border-radius: var(--card-radius); border: 0; display: inline-flex; align-items: center; gap: 8px; }
.admin-tabs .tab.active { background: var(--primary); color: var(--bg-base); }
.admin-section { background: var(--bg-elev); padding: 24px; border-radius: var(--card-radius); margin-bottom: 20px; }
.admin-section h3 { font-size: 18px; margin-bottom: 16px; }
.admin-section table { width: 100%; border-collapse: collapse; font-size: 13px; }
.admin-section th { text-align: left; color: var(--text-secondary); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.1em; padding-bottom: 8px; }
.admin-section td { padding: 8px 0; border-top: 1px solid var(--bg-base); }
.admin-section td .danger { color: #ff6464; background: none; border: 0; }
.stat-box { padding: 16px; background: var(--bg-base); border-radius: var(--card-radius); }
.stat-box .label { font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-secondary); }
.stat-box .value { font-family: var(--title-font); font-size: 26px; color: var(--primary); margin-top: 4px; }
.grid-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
@media (min-width: 700px) { .grid-stats { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1000px) { .grid-stats { grid-template-columns: repeat(6, 1fr); } }
.admin-section textarea { min-height: 120px; }

/* ============ Footer (personality-driven) ============ */
.site-footer { margin-top: 80px; border-top: 1px solid var(--bg-elev); }

/* -- formal (default) -- */
.footer-formal .footer-grid { display: grid; grid-template-columns: 1fr; gap: 40px; padding: 56px 0; }
@media (min-width: 768px) { .footer-formal .footer-grid { grid-template-columns: 2fr 1fr 1fr 1fr; } }
.footer-formal h4 { font-size: 10px; text-transform: uppercase; letter-spacing: 0.2em;
  color: var(--text-secondary); margin-bottom: 16px; }
.footer-formal ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.footer-formal a:hover { color: var(--primary); }
.footer-formal .footer-copy { border-top: 1px solid var(--bg-elev); padding: 20px 0; text-align: center; font-size: 11px; color: var(--text-secondary); }

/* -- minimal -- */
.footer-minimal { border-top: 1px solid var(--bg-elev); }
.footer-minimal .minimal-footer-inner { display: flex; align-items: center; justify-content: space-between; padding: 32px 24px; gap: 24px; flex-wrap: wrap; font-size: 12px; }
.footer-minimal .minimal-left { font-family: var(--title-font); font-size: 14px; color: var(--text-primary); letter-spacing: -0.01em; }
.footer-minimal .minimal-links { display: flex; gap: 18px; flex-wrap: wrap; }
.footer-minimal .minimal-links a { color: var(--text-secondary); transition: color .2s; }
.footer-minimal .minimal-links a:hover { color: var(--primary); }
.footer-minimal .minimal-right { color: var(--text-secondary); font-size: 11px; letter-spacing: 0.1em; }

/* -- loud -- */
.footer-loud { background: var(--bg-elev); padding: 64px 0 32px; border-top: 4px solid var(--primary); }
.footer-loud .loud-shout { font-size: 48px; color: var(--primary); letter-spacing: -0.02em; line-height: 1; margin-bottom: 8px; }
@media (min-width: 768px) { .footer-loud .loud-shout { font-size: 80px; } }
@media (min-width: 1100px) { .footer-loud .loud-shout { font-size: 120px; } }
.footer-loud .loud-sub { font-size: 14px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--text-secondary); margin-bottom: 40px; }
.footer-loud .loud-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 24px; padding: 24px 0; border-top: 2px solid var(--bg-base); border-bottom: 2px solid var(--bg-base); }
.footer-loud .loud-col h4 { font-size: 12px; letter-spacing: 0.3em; color: var(--accent); margin-bottom: 12px; font-weight: 900; }
.footer-loud .loud-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; font-size: 13px; }
.footer-loud .loud-col a:hover { color: var(--primary); }
.footer-loud .loud-copy { margin-top: 24px; font-size: 10px; letter-spacing: 0.2em; color: var(--text-secondary); }

/* -- dark-theater -- */
.footer-theater { background: var(--bg-base); padding: 64px 0; border-top: 2px solid var(--primary); }
.footer-theater .theater-inner { display: grid; grid-template-columns: 60px 1fr 60px; gap: 32px; align-items: stretch; }
@media (max-width: 720px) { .footer-theater .theater-inner { grid-template-columns: 20px 1fr 20px; } }
.footer-theater .theater-curtain { background: linear-gradient(90deg, var(--primary) 0%, transparent 60%, var(--primary) 100%); opacity: 0.3; }
.footer-theater .theater-center { text-align: center; padding: 24px 0; }
.footer-theater .theater-chip { font-size: 11px; letter-spacing: 0.5em; color: var(--accent); text-transform: uppercase; margin-bottom: 16px; }
.footer-theater .theater-name { font-size: 40px; color: var(--primary); letter-spacing: 0.1em; text-transform: uppercase; }
@media (min-width: 900px) { .footer-theater .theater-name { font-size: 64px; } }
.footer-theater .theater-tag { font-style: italic; color: var(--text-secondary); margin: 12px 0 24px; font-size: 14px; }
.footer-theater .theater-links { display: flex; justify-content: center; gap: 10px; flex-wrap: wrap; font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-secondary); }
.footer-theater .theater-links a { color: var(--text-primary); }
.footer-theater .theater-links a:hover { color: var(--primary); }
.footer-theater .theater-links span { color: var(--primary); opacity: 0.6; }
.footer-theater .theater-copy { margin-top: 24px; font-size: 10px; color: var(--text-secondary); letter-spacing: 0.1em; }

/* -- tech (terminal) -- */
.footer-tech { background: #050a05; border-top: 1px solid rgba(57,255,20,0.3); padding: 40px 0; font-family: 'JetBrains Mono', monospace; }
.footer-tech .tech-line { color: var(--accent); font-size: 13px; margin-bottom: 16px; }
.footer-tech .tech-block { background: rgba(0,0,0,0.4); border: 1px solid rgba(57,255,20,0.15); padding: 20px 24px; border-radius: var(--card-radius); font-size: 13px; line-height: 1.9; }
.footer-tech .tech-row { display: flex; gap: 12px; flex-wrap: wrap; }
.footer-tech .tech-key { color: #6cffb0; min-width: 110px; }
.footer-tech .tech-eq { color: var(--text-secondary); }
.footer-tech .tech-val { color: #d6ffcc; }
.footer-tech .tech-val a { color: var(--accent); }
.footer-tech .tech-val a:hover { text-decoration: underline; }
.footer-tech .tech-copy { margin-top: 16px; color: var(--text-secondary); font-size: 12px; }
