/* ==========================================================
   THEMES CHARACTER v1 — stronger personality for
   MONOCHROME INK (editorial) & NEON STREAM (glow/cyber)
   ========================================================== */

/* =========================================================
   MONOCHROME INK — editorial magazine
   - rule lines under section heads
   - drop-cap on hero lead
   - serif numerals w/ dotted underlines
   - magazine-style byline bar
   ========================================================= */
.theme-monochrome-ink .sec-head {
  border-bottom: 1px solid var(--ink);
  padding-bottom: 12px;
}
.theme-monochrome-ink .sec-head-en {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0;
  font-size: 15px;
  color: var(--primary);
  position: relative;
  padding-left: 22px;
}
.theme-monochrome-ink .sec-head-en::before {
  content: '§';
  position: absolute; left: 0; top: 50%; transform: translateY(-50%);
  font-size: 18px; font-style: normal;
  color: var(--primary);
}
.theme-monochrome-ink .sec-head-jp {
  font-family: var(--font-jp-display);
  font-weight: 900;
  letter-spacing: -0.03em;
}
.theme-monochrome-ink .sec-head-r {
  font-family: var(--font-display);
  font-style: italic; font-weight: 500;
  letter-spacing: 0; font-size: 13px;
  color: var(--fg-soft);
}

/* hero lead drop-cap */
.theme-monochrome-ink .hero-sub::first-letter,
.theme-monochrome-ink .hero-im-sub::first-letter {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 3.4em;
  float: left;
  line-height: 0.85;
  margin: 8px 10px 0 0;
  color: var(--primary);
  font-weight: 700;
}

/* numbered stats w/ dotted underline */
.theme-monochrome-ink .hero-stat-num,
.theme-monochrome-ink .artist-hero-stat-num {
  font-family: var(--font-display);
  font-style: italic;
  border-bottom: 2px dotted var(--ink);
  padding-bottom: 4px;
  display: inline-block;
}
.theme-monochrome-ink .artist-hero-stat-label,
.theme-monochrome-ink .hero-stat-label {
  font-family: var(--font-display);
  font-style: italic;
  letter-spacing: 0;
  font-weight: 500;
  text-transform: none;
  font-size: 13px;
}

/* magazine-style byline on product & series cards */
.theme-monochrome-ink .p-card-artist,
.theme-monochrome-ink .series-card-artist {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  letter-spacing: 0;
  font-size: 13px;
}

/* rule separator between series */
.theme-monochrome-ink .series-card {
  box-shadow: none;
  border-radius: 2px;
}
.theme-monochrome-ink .series-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 1px 0 var(--ink);
}

/* pull quotes from about items */
.theme-monochrome-ink .about-num {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  color: var(--primary);
  border-bottom: 1px solid var(--ink);
  padding-bottom: 4px;
}

/* news-row get a magazine-index look */
.theme-monochrome-ink .news-row {
  border-bottom: 1px solid var(--line-soft);
  padding: 18px 0;
  display: grid;
  grid-template-columns: auto auto 1fr;
  gap: 20px;
  align-items: baseline;
}
.theme-monochrome-ink .news-date {
  font-family: var(--font-display);
  font-style: italic; font-weight: 500;
  letter-spacing: 0;
  color: var(--fg-muted);
}

/* footer: editorial masthead */
.theme-monochrome-ink .site-ftr {
  background: #0f0e0d;
  color: #F2EEE4;
}
.theme-monochrome-ink .ftr-logo-big {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  letter-spacing: -0.03em;
}

/* manga-fx tape & issue stamps — neutralize */
.theme-monochrome-ink .series-wrap::before,
.theme-monochrome-ink .series-wrap::after,
.theme-monochrome-ink .hero-sc-issue { display: none; }

/* marquee: thin rule */
.theme-monochrome-ink .marquee {
  background: var(--ink); color: var(--ink-fg);
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  letter-spacing: 0.05em;
  font-size: 16px;
  padding: 10px 0;
  border-top: 1px solid var(--ink); border-bottom: 1px solid var(--ink);
}

/* =========================================================
   NEON STREAM — streaming / cyber glow
   - neon underline on links & active states
   - card glow on hover
   - glass header w/ gradient bottom border
   - gradient chip for CAMPFIRE banner
   ========================================================= */
.theme-neon-stream .site-hdr {
  border-bottom: 1px solid transparent;
  position: sticky;
}
.theme-neon-stream .site-hdr::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -1px;
  height: 1px;
  background: var(--brand-gradient);
  opacity: 0.7;
}

/* hdr nav — active gets gradient underline */
.theme-neon-stream .hdr-nav-link {
  position: relative;
}
.theme-neon-stream .hdr-nav-link::after {
  content: ''; position: absolute; left: 14px; right: 14px; bottom: 2px;
  height: 2px; background: var(--brand-gradient);
  transform: scaleX(0); transform-origin: left;
  transition: transform .28s cubic-bezier(.2,.9,.2,1);
}
.theme-neon-stream .hdr-nav-link:hover::after,
.theme-neon-stream .hdr-nav-link.active::after { transform: scaleX(1); }
.theme-neon-stream .hdr-nav-link:hover,
.theme-neon-stream .hdr-nav-link.active { background: transparent; color: #fff; }

/* product cards glow */
.theme-neon-stream .p-card,
.theme-neon-stream .pickup-hero,
.theme-neon-stream .pickup-small,
.theme-neon-stream .series-card,
.theme-neon-stream .artist-card {
  transition: transform .3s cubic-bezier(.2,.9,.2,1), box-shadow .3s ease, border-color .3s ease;
  border: 1px solid var(--line);
}
.theme-neon-stream .p-card:hover,
.theme-neon-stream .pickup-hero:hover,
.theme-neon-stream .pickup-small:hover,
.theme-neon-stream .series-card:hover,
.theme-neon-stream .artist-card:hover {
  transform: translateY(-4px);
  border-color: transparent;
  box-shadow:
    0 20px 40px rgba(0,0,0,.55),
    0 0 0 1.5px rgba(212,53,126,.45),
    0 0 40px -4px rgba(212,53,126,.35);
}

/* neon underline on interactive text */
.theme-neon-stream .hero-sc-artist strong,
.theme-neon-stream .pd-artist-mini strong {
  border-bottom: 1.5px solid transparent;
  background-image: linear-gradient(90deg, #5B5EDB, #8A4FD1, #D4357E);
  background-position: 0 100%;
  background-repeat: no-repeat;
  background-size: 100% 2px;
  padding-bottom: 2px;
}

/* badges — gradient pill */
.theme-neon-stream .p-badge-new,
.theme-neon-stream .series-card-badge,
.theme-neon-stream .news-tag.new {
  background: var(--brand-gradient);
  color: #fff;
  border: none;
  box-shadow: 0 4px 16px rgba(212,53,126,.35);
}

/* CTA primary — always glow */
.theme-neon-stream .btn-primary {
  background: var(--brand-gradient);
  color: #fff;
  border: none;
  box-shadow: 0 8px 28px rgba(212,53,126,.35);
}
.theme-neon-stream .btn-primary:hover {
  box-shadow: 0 12px 40px rgba(212,53,126,.5);
  transform: translateY(-2px);
}
.theme-neon-stream .btn-ghost {
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.18);
  color: #fff;
}
.theme-neon-stream .btn-ghost:hover {
  background: rgba(255,255,255,.12);
  color: #fff;
  border-color: var(--primary);
}

/* section-head accent */
.theme-neon-stream .sec-head {
  border-bottom: 1px solid var(--line-soft);
}
.theme-neon-stream .sec-head-en {
  position: relative;
  padding-left: 14px;
}
.theme-neon-stream .sec-head-en::before {
  content: ''; position: absolute; left: 0; top: 50%; transform: translateY(-50%);
  width: 4px; height: 18px;
  background: var(--brand-gradient);
  border-radius: 2px;
  box-shadow: 0 0 14px rgba(212,53,126,.5);
}

/* hero kicker — glassy pill */
.theme-neon-stream .kicker {
  background: rgba(255,255,255,.08);
  backdrop-filter: blur(10px);
  padding: 6px 14px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  color: #fff;
}

/* marquee */
.theme-neon-stream .marquee {
  background: linear-gradient(90deg, #1B1828 0%, #2a1c3d 50%, #1B1828 100%);
  color: #fff;
  border-top: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
}
.theme-neon-stream .marquee-item::after { color: var(--primary); }

/* campfire banner */
.theme-neon-stream .camp-banner {
  background: linear-gradient(90deg, rgba(91,94,219,.25), rgba(212,53,126,.25));
  border-bottom: 1px solid var(--line);
  color: #fff;
}
.theme-neon-stream .camp-banner a {
  color: #fff; font-weight: 800;
  text-shadow: 0 0 12px rgba(212,53,126,.6);
}

/* filter bar */
.theme-neon-stream .filter-chip.active {
  background: var(--brand-gradient);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 4px 20px rgba(212,53,126,.4);
}

/* price text in product detail */
.theme-neon-stream .pd-price {
  background: var(--brand-gradient);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

/* flow page — neon trail */
.theme-neon-stream .flow-num {
  background: var(--brand-gradient);
  color: #fff;
  box-shadow: 0 0 24px rgba(212,53,126,.45);
}
.theme-neon-stream .flow-grid::before {
  background: linear-gradient(to right, transparent, var(--primary), transparent);
  height: 1px;
  box-shadow: 0 0 12px rgba(212,53,126,.6);
}

/* about cards */
.theme-neon-stream .about-card {
  border: 1px solid var(--line);
}
.theme-neon-stream .about-num {
  background: var(--brand-gradient);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  font-weight: 900;
}

/* footer: full-width gradient top edge */
.theme-neon-stream .site-ftr {
  border-top: 1px solid transparent;
  position: relative;
}
.theme-neon-stream .site-ftr::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0;
  height: 1px;
  background: var(--brand-gradient);
  opacity: 0.6;
}