: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;
  background-attachment: fixed;
}

/* ============ Body Patterns (per personality) =================== */
body.pattern-grid {
  background-image:
    linear-gradient(var(--bg-elev) 1px, transparent 1px),
    linear-gradient(90deg, var(--bg-elev) 1px, transparent 1px);
  background-size: 48px 48px;
}
body.pattern-dots {
  background-image: radial-gradient(circle, var(--bg-elev) 1.4px, transparent 1.4px);
  background-size: 22px 22px;
}
body.pattern-scanlines {
  background-image: repeating-linear-gradient(0deg, rgba(255,255,255,0.025) 0 1px, transparent 1px 3px);
}
body.pattern-hatch {
  background-image: repeating-linear-gradient(45deg, rgba(255,255,255,0.03) 0 1px, transparent 1px 12px);
}
body.pattern-blueprint {
  background-image:
    linear-gradient(rgba(57,255,20,0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(57,255,20,0.08) 1px, transparent 1px),
    linear-gradient(rgba(57,255,20,0.18) 1px, transparent 1px),
    linear-gradient(90deg, rgba(57,255,20,0.18) 1px, transparent 1px);
  background-size: 16px 16px, 16px 16px, 80px 80px, 80px 80px;
}
body.pattern-noise {
  position: relative;
}
body.pattern-noise::before {
  content: ''; position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/></svg>");
  opacity: 0.06; mix-blend-mode: overlay;
}
body.pattern-stripes {
  background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 14px, transparent 14px 28px);
}
body.pattern-wave {
  background-image: radial-gradient(ellipse 800px 300px at 30% 20%, rgba(255,255,255,0.05), transparent 60%),
                    radial-gradient(ellipse 600px 250px at 80% 60%, rgba(255,255,255,0.04), transparent 60%);
}
body.pattern-halftone {
  background-image: radial-gradient(circle, rgba(255,255,255,0.06) 2.4px, transparent 2.5px);
  background-size: 18px 18px;
  background-position: 0 0, 9px 9px;
}
body > * { position: relative; z-index: 1; }
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: 1700px; margin: 0 auto; padding: 0 28px; }
@media (max-width: 640px) { .container { padding: 0 14px; } }

/* 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); }

/* ============ Card Style: overlay (cinema/magazine/noir/luxury) ============ */
.vc-overlay { position: relative; }
.vc-overlay .thumb-wrap { aspect-ratio: 16/9; }
.vc-overlay .vc-overlay-grad { position: absolute; inset: auto 0 0 0; height: 70%;
  background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.3) 40%, rgba(0,0,0,0.92) 100%);
  pointer-events: none; }
.vc-overlay .vc-overlay-info { position: absolute; left: 0; right: 0; bottom: 0;
  padding: 14px 16px 12px; color: #fff; pointer-events: none; }
.vc-overlay .vc-overlay-info h3 { font-size: 15px; line-height: 1.25; margin: 0 0 6px; color: #fff;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.vc-overlay .vc-overlay-info .meta { display: flex; gap: 10px; font-size: 11px; color: rgba(255,255,255,0.75);
  letter-spacing: 0.05em; text-transform: uppercase; }
.vc-overlay .cat-chip { background: var(--primary); color: var(--bg-base); padding: 2px 6px; border-radius: 3px; }
.vc-overlay:hover .vc-overlay-grad { background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.4) 30%, rgba(0,0,0,0.95) 100%); }

/* ============ Card Style: polaroid (vintage/gallery/retro-80s) ============ */
.vc-polaroid { background: #FAF7EC; padding: 10px 10px 36px; border-radius: 0;
  box-shadow: 0 8px 24px -8px rgba(0,0,0,0.55); transform: rotate(-0.5deg); transition: transform .25s; }
.vc-polaroid:nth-child(2n) { transform: rotate(0.6deg); }
.vc-polaroid:nth-child(3n) { transform: rotate(-1.1deg); }
.vc-polaroid:hover { transform: rotate(0deg) scale(1.02); }
.vc-polaroid .thumb-wrap { aspect-ratio: 4/3; background: #1a1a1a; }
.vc-polaroid .thumb-wrap img { filter: saturate(0.8) contrast(1.05); }
.vc-polaroid .info-wrap { padding: 12px 4px 0; color: #2a2a2a; }
.vc-polaroid .info-wrap h3 { font-family: 'Special Elite', 'Fraunces', serif; font-size: 14px; color: #2a2a2a;
  font-weight: 400; line-height: 1.3; margin: 0 0 4px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.vc-polaroid .meta { font-family: 'Special Elite', monospace; font-size: 11px; color: #777; display: flex; gap: 6px; }
.vc-polaroid .duration-pill { background: rgba(0,0,0,0.85); color: #fff; }

/* ============ Card Style: brutal (brutalist/club/festival/bold-grid) ============ */
.vc-brutal { border: 3px solid var(--text-primary); border-radius: 0; background: var(--bg-elev);
  box-shadow: 6px 6px 0 var(--primary); transition: transform .15s, box-shadow .15s; }
.vc-brutal:hover { transform: translate(-3px, -3px); box-shadow: 9px 9px 0 var(--primary); }
.vc-brutal .thumb-wrap { aspect-ratio: 16/9; }
.vc-brutal .info-wrap { padding: 12px 14px; border-top: 3px solid var(--text-primary); }
.vc-brutal .info-wrap h3 { font-size: 14px; text-transform: uppercase; letter-spacing: -0.01em;
  font-weight: 800; color: var(--text-primary); margin: 0 0 6px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.vc-brutal .meta { font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase;
  display: flex; gap: 10px; color: var(--text-secondary); }
.vc-brutal .cat-chip { background: var(--text-primary); color: var(--bg-base); padding: 1px 6px; }

/* ============ Card Style: list (terminal/hacker/arcade) ============ */
.card-style-list { display: flex; flex-direction: column; gap: 0; }
.vc-list { display: grid; grid-template-columns: 280px 1fr; gap: 0; align-items: stretch;
  border-top: 1px solid var(--bg-elev); padding: 0; transition: background .2s; background: transparent; }
.vc-list:hover { background: rgba(57,255,20,0.04); }
.vc-list:last-child { border-bottom: 1px solid var(--bg-elev); }
.vc-list .thumb-wrap { aspect-ratio: 16/10; min-height: 160px; }
.vc-list .info-wrap { padding: 18px 24px; display: flex; flex-direction: column; justify-content: center;
  font-family: 'JetBrains Mono', monospace; }
.vc-list .vc-list-prompt { color: var(--accent); font-size: 11px; margin-bottom: 6px; }
.vc-list .info-wrap h3 { font-family: 'JetBrains Mono', monospace; font-size: 16px; line-height: 1.4;
  color: var(--text-primary); font-weight: 500; margin: 0 0 10px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.vc-list .meta { font-size: 11px; color: var(--text-secondary); display: flex; gap: 16px; flex-wrap: wrap; }
.vc-list .cat-chip { color: var(--accent); }
@media (max-width: 720px) { .vc-list { grid-template-columns: 1fr; } .vc-list .thumb-wrap { min-height: auto; } }

/* ============ Card Style: tabloid (tabloid/zine) ============ */
.vc-tabloid { background: #1a1a1a; border: 2px solid #FFCC00; transform: rotate(-0.4deg);
  box-shadow: 4px 4px 0 rgba(255,204,0,0.4); transition: transform .2s; position: relative; }
.vc-tabloid:nth-child(2n) { transform: rotate(0.7deg); }
.vc-tabloid:hover { transform: rotate(0deg) scale(1.02); }
.vc-tabloid .thumb-wrap { aspect-ratio: 16/9; }
.vc-tabloid .vc-tabloid-stamp { position: absolute; top: 8px; left: -6px; background: #FFCC00; color: #000;
  font-family: 'Anton', sans-serif; font-size: 11px; padding: 3px 10px; transform: rotate(-6deg);
  letter-spacing: 0.1em; box-shadow: 2px 2px 0 #000; z-index: 2; }
.vc-tabloid .info-wrap { padding: 10px 14px 14px; }
.vc-tabloid .info-wrap h3 { font-family: 'Anton', 'Archivo Black', sans-serif; font-size: 17px; color: #FFCC00;
  text-transform: uppercase; line-height: 1.1; margin: 0 0 6px; letter-spacing: -0.01em;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.vc-tabloid .meta { font-size: 10px; color: rgba(255,204,0,0.7); display: flex; gap: 10px; text-transform: uppercase; letter-spacing: 0.1em; }
.vc-tabloid .cat-chip { color: #fff; }

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

.grid-masonry-3-col { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
@media (min-width: 768px) { .grid-masonry-3-col { grid-template-columns: repeat(3, 1fr); gap: 16px; } }
@media (min-width: 1100px) { .grid-masonry-3-col { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 1500px) { .grid-masonry-3-col { grid-template-columns: repeat(5, 1fr); } }

.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 (premium tube-site default — compact 1-row hero, then dense grid) --- */
.hero-strip {
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px;
  padding: 24px 0 16px; margin-bottom: 8px;
  border-bottom: 1px solid var(--bg-elev);
}
.hero-strip-left { display: flex; align-items: baseline; gap: 14px; }
.hero-strip-name { font-size: 22px; color: var(--text-primary); letter-spacing: -0.01em; line-height: 1; }
@media (min-width: 900px) { .hero-strip-name { font-size: 28px; } }
.hero-strip-chip { font-size: 10px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--accent); padding: 3px 10px; background: var(--bg-elev); border-radius: 999px; }
.hero-strip-tag { font-size: 12px; color: var(--text-secondary); letter-spacing: 0.05em; flex: 1; min-width: 200px; }
.hero-strip-cta { font-size: 12px; color: var(--text-primary); letter-spacing: 0.1em; text-transform: uppercase;
  border-bottom: 1px solid var(--primary); padding-bottom: 2px; transition: color .2s; white-space: nowrap; }
.hero-strip-cta:hover { color: var(--primary); }

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

/* --- Personality: bold (huge banner title) --- */
.hero-bold { display: block; padding: 56px 0 32px; border-bottom: 1px solid var(--bg-elev); }
.hero-bold .bold-title { font-size: 48px; line-height: 1; letter-spacing: -0.03em;
  text-transform: uppercase; color: var(--primary); margin-bottom: 16px; }
@media (min-width: 768px) { .hero-bold .bold-title { font-size: 64px; } }
@media (min-width: 1100px) { .hero-bold .bold-title { font-size: 84px; } }
.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: 88px 0 64px; }
.hero-minimal .minimal-title { font-size: 56px; line-height: 0.95; letter-spacing: -0.04em; color: var(--primary); }
@media (min-width: 900px) { .hero-minimal .minimal-title { font-size: 80px; } }
@media (min-width: 1200px) { .hero-minimal .minimal-title { font-size: 104px; } }
.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: 56px 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: 56px; letter-spacing: -0.02em;
  text-transform: uppercase; color: var(--text-primary); line-height: 0.95; }
@media (min-width: 900px) { .hero-noir .noir-title { font-size: 80px; } }
@media (min-width: 1200px) { .hero-noir .noir-title { font-size: 96px; } }
.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: 40px 0 24px; 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: 56px; letter-spacing: -0.03em; line-height: 1; margin: 14px 0; color: var(--text-primary); text-transform: none; }
@media (min-width: 900px) { .hero-masthead .masthead-title { font-size: 80px; } }
@media (min-width: 1200px) { .hero-masthead .masthead-title { font-size: 104px; } }
.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: 32px; }
.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; }
.ad-slot .ad-frame-embed { border: 0; padding: 0; background: transparent; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.ad-slot .ad-frame-embed > * { max-width: 100%; max-height: 100%; }
.ad-slot .ad-frame-embed iframe { width: 300px; height: 250px; border: 0; }

/* ============ 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; position: relative; }
.video-player iframe, .video-player video { width: 100%; height: 100%; border: 0; display: block; }
.vast-overlay { position: absolute; top: 12px; left: 12px; right: 12px; display: none; align-items: center; justify-content: space-between; pointer-events: none; z-index: 5; }
.vast-overlay .vast-label { background: rgba(0,0,0,0.7); color: #fff; padding: 6px 12px; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; border-radius: 4px; }
.vast-overlay .vast-skip { background: rgba(0,0,0,0.85); color: #fff; padding: 8px 14px; font-size: 13px; cursor: pointer; pointer-events: auto; border-radius: 4px; user-select: none; transition: background .2s; }
.vast-overlay .vast-skip:hover { background: var(--primary); }
.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: 38px; color: var(--primary); letter-spacing: -0.02em; line-height: 1; margin-bottom: 8px; }
@media (min-width: 768px) { .footer-loud .loud-shout { font-size: 52px; } }
@media (min-width: 1100px) { .footer-loud .loud-shout { font-size: 72px; } }
.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; }

/* ============ ADULT TUBE THEMES — additional grid/header styles ============ */

/* High-density tube grids */
.grid-tight-5-col { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
@media (min-width: 700px) { .grid-tight-5-col { grid-template-columns: repeat(3, 1fr); gap: 12px; } }
@media (min-width: 1024px) { .grid-tight-5-col { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 1300px) { .grid-tight-5-col { grid-template-columns: repeat(5, 1fr); } }
@media (min-width: 1600px) { .grid-tight-5-col { grid-template-columns: repeat(6, 1fr); } }

.grid-tight-6-col { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; }
@media (min-width: 600px) { .grid-tight-6-col { grid-template-columns: repeat(3, 1fr); gap: 10px; } }
@media (min-width: 900px)  { .grid-tight-6-col { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 1200px) { .grid-tight-6-col { grid-template-columns: repeat(5, 1fr); } }
@media (min-width: 1500px) { .grid-tight-6-col { grid-template-columns: repeat(6, 1fr); } }
@media (min-width: 1800px) { .grid-tight-6-col { grid-template-columns: repeat(7, 1fr); } }

/* Tube-card tightening — kill rounding & airy spacing for the tube feel */
body.tube-tight .video-card,
body.tube-tight .video-card .thumb { border-radius: 0; }
body.tube-tight .video-card .info { padding: 6px 0 0; }
body.tube-tight .video-card .title { font-size: 13px; line-height: 1.3; font-weight: 600; }
body.tube-tight .video-card .meta  { font-size: 11px; opacity: 0.85; }

/* ===== Tube header — BANNER (Pornhub-classic / YouPorn / PornGo) ===== */
.tube-banner-bar {
  background: linear-gradient(180deg, var(--bg-elev) 0%, var(--bg-base) 100%);
  border-bottom: 2px solid var(--primary);
  padding: 0;
}
.tube-banner-top { display: flex; align-items: center; gap: 14px; padding: 14px 0; flex-wrap: wrap; }
.tube-banner-logo { display: inline-flex; align-items: center; gap: 0; font-weight: 800; font-size: 22px; letter-spacing: -0.01em; }
.tube-banner-logo .logo-pre  { color: var(--text-primary); }
.tube-banner-logo .logo-pill { color: #000; background: var(--primary); padding: 2px 10px; border-radius: 4px; margin-left: 4px; }
.tube-banner-search { flex: 1; min-width: 200px; }
.tube-banner-search input {
  width: 100%; padding: 10px 14px; background: var(--bg-base); color: var(--text-primary);
  border: 1px solid rgba(255,255,255,0.08); border-radius: var(--card-radius);
  font-size: 14px; outline: none;
}
.tube-banner-search input:focus { border-color: var(--primary); }
.tube-banner-cats { background: var(--bg-base); border-bottom: 1px solid rgba(255,255,255,0.05); }
.tube-banner-cats-row { display: flex; gap: 0; overflow-x: auto; padding: 0; }
.tube-banner-cats-row a {
  padding: 12px 16px; color: var(--text-secondary); font-size: 13px; font-weight: 500;
  letter-spacing: 0.02em; white-space: nowrap; transition: all .15s;
  border-bottom: 3px solid transparent;
}
.tube-banner-cats-row a:hover { color: var(--text-primary); border-bottom-color: var(--accent); }
.tube-banner-cats-row a.active { color: var(--primary); border-bottom-color: var(--primary); }

/* ===== Tube header — TABS (xHamster / TNAFlix / Beeg / XNXX) ===== */
.tube-tabs-bar { background: var(--bg-elev); border-bottom: 1px solid rgba(0,0,0,0.4); }
.tube-tabs-row { display: flex; align-items: center; gap: 16px; padding: 0; flex-wrap: wrap; }
.tube-tabs-logo {
  font-weight: 900; font-size: 22px; padding: 14px 0; color: var(--primary);
  letter-spacing: -0.02em; text-transform: lowercase;
}
.tube-tabs-nav { display: flex; align-items: stretch; flex: 1; flex-wrap: wrap; }
.tube-tabs-nav a {
  padding: 18px 18px; color: var(--text-secondary); font-size: 13px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.04em; transition: all .15s; position: relative;
}
.tube-tabs-nav a:hover { color: var(--text-primary); background: rgba(255,255,255,0.03); }
.tube-tabs-nav a.active { color: var(--primary); }
.tube-tabs-nav a.active::after {
  content:''; position:absolute; left:0; right:0; bottom:0; height:3px; background: var(--primary);
}
.tube-tabs-search input {
  padding: 8px 14px; background: var(--bg-base); color: var(--text-primary);
  border: 1px solid rgba(255,255,255,0.1); border-radius: 999px; min-width: 200px;
}

/* ===== Tube header — SIDEBAR (TXXX) — left rail of categories ===== */
body.tube-sidebar-layout main.container { display: grid; grid-template-columns: 1fr; gap: 24px; }
@media (min-width: 1100px) {
  body.tube-sidebar-layout main.container { grid-template-columns: 220px 1fr; }
}
.tube-sidebar-rail {
  background: var(--bg-elev); border-radius: var(--card-radius); padding: 16px 0;
  align-self: start; position: sticky; top: 12px;
}
.tube-sidebar-rail h4 { font-size: 11px; text-transform: uppercase; letter-spacing: 0.15em;
  color: var(--text-secondary); padding: 0 16px 10px; }
.tube-sidebar-rail a {
  display: block; padding: 9px 16px; color: var(--text-secondary); font-size: 13px;
  border-left: 3px solid transparent; transition: all .15s;
}
.tube-sidebar-rail a:hover, .tube-sidebar-rail a.active {
  color: var(--text-primary); background: rgba(255,255,255,0.03); border-left-color: var(--primary);
}

/* ===== Sticky chip bar (above grid, used by themes with chip_bar=true) ===== */
.tube-chip-bar {
  display: flex; gap: 8px; padding: 12px 0; overflow-x: auto;
  border-bottom: 1px solid var(--bg-elev); margin-bottom: 16px;
  scrollbar-width: none;
}
.tube-chip-bar::-webkit-scrollbar { display: none; }
.tube-chip-bar a {
  flex-shrink: 0; padding: 6px 14px; font-size: 12px; font-weight: 600; color: var(--text-secondary);
  background: var(--bg-elev); border-radius: 999px; transition: all .15s;
  text-transform: capitalize; letter-spacing: 0.01em;
}
.tube-chip-bar a:hover { background: var(--primary); color: #000; }

/* ===== Featured-row hero (RedTube / DrTuber / PornGo / Hclips) ===== */
.tube-featured-row {
  display: grid; grid-template-columns: 1fr; gap: 12px;
  margin: 16px 0 28px;
}
@media (min-width: 900px) { .tube-featured-row { grid-template-columns: 2fr 1fr 1fr; grid-template-rows: 1fr 1fr; } }
.tube-featured-row > a:first-child { grid-row: span 2; }
.tube-featured-row a { display: block; position: relative; aspect-ratio: 16/9; overflow: hidden; border-radius: var(--card-radius); }
.tube-featured-row img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.tube-featured-row a:hover img { transform: scale(1.04); }
.tube-featured-row .fr-meta {
  position: absolute; left: 0; right: 0; bottom: 0; padding: 16px;
  background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.85) 100%);
  color: #fff; font-size: 14px; font-weight: 600; line-height: 1.3;
}
.tube-featured-row .fr-tag {
  position: absolute; top: 10px; left: 10px;
  padding: 2px 8px; background: var(--primary); color: #000; font-size: 10px; font-weight: 800;
  text-transform: uppercase; letter-spacing: 0.1em; border-radius: 2px;
}

/* ===== Light-theme tweaks (xVideos-Minimal / XNXX-Tabs) ===== */
body.theme-xvideos-minimal,
body.theme-xnxx-tabs {
  background: #fff; color: #111;
}
body.theme-xvideos-minimal .video-card .title,
body.theme-xnxx-tabs .video-card .title { color: #111; }
body.theme-xvideos-minimal .video-card .meta,
body.theme-xnxx-tabs .video-card .meta { color: #666; }
body.theme-xvideos-minimal .site-footer,
body.theme-xnxx-tabs .site-footer { background: #f2f2f2; color: #555; border-top: 1px solid #e0e0e0; }
body.theme-xvideos-minimal .site-footer a,
body.theme-xnxx-tabs .site-footer a { color: #333; }

/* ===== HTML5 video player + VAST overlay ===== */
.video-player-wrap {
  position: relative; aspect-ratio: 16/9; background: #000; border-radius: var(--card-radius); overflow: hidden;
}
.video-player-wrap video {
  width: 100%; height: 100%; display: block; background: #000;
}
.video-player-wrap iframe {
  width: 100%; height: 100%; border: 0; display: block;
}
.vast-overlay {
  position: absolute; top: 12px; right: 12px; z-index: 5;
  display: flex; align-items: center; gap: 10px;
  padding: 6px 12px; background: rgba(0,0,0,0.75); color: #fff;
  font-size: 11px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase;
  border-radius: 4px; backdrop-filter: blur(4px);
}
.vast-skip {
  cursor: pointer; padding: 4px 10px; background: rgba(255,255,255,0.15);
  border-radius: 3px; transition: background .15s;
}
.vast-skip:hover { background: rgba(255,255,255,0.3); }
.vast-skip[disabled] { opacity: 0.4; cursor: not-allowed; pointer-events: none; }
