:root {

  --max: 1480px;

  /* ==================================================
     SURFACE SYSTEM
  ================================================== */

  --surface-1:
    rgba(255,255,255,0.025);

  --surface-2:
    rgba(255,255,255,0.04);

  --surface-3:
    rgba(255,255,255,0.06);

  /* ==================================================
     BORDER SYSTEM
  ================================================== */

  --border-soft:
    rgba(255,255,255,0.05);

  --border-mid:
    rgba(255,255,255,0.08);

  --border-strong:
    rgba(255,255,255,0.12);

  /* ==================================================
     ELEVATION
  ================================================== */

  --shadow-1:
    0 6px 18px rgba(0,0,0,0.22);

  --shadow-2:
    0 14px 40px rgba(0,0,0,0.34);

  --shadow-3:
    0 24px 70px rgba(0,0,0,0.46);

  /* ==================================================
     MOTION
  ================================================== */

  --motion-fast:
    0.18s ease;

  --motion-mid:
    0.26s ease;

  --motion-slow:
    0.4s cubic-bezier(.2,.8,.2,1);
}

* {
  box-sizing: border-box;
}

html,
body {

  margin: 0;
  padding: 0;

  background:

    var(--glow-orb),

    var(--glow-orb-alt),

    var(--bg);

  color: var(--text);

  font-family:
    Inter,
    system-ui,
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    sans-serif;

  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;

  overflow-x: hidden;
}

a {
  color: inherit;
  text-decoration: none;

  transition:
    color var(--motion-fast);
}

img {
  display: block;
  width: 100%;
}

.page {
  max-width: var(--max);
  margin: 0 auto;
  padding: 24px;
}

/* ==================================================
   HEADER
================================================== */

.topbar {

  position: sticky;
  top: 0;

  z-index: 50;

  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);

  background: var(--glass-bg);

  border-bottom:
    1px solid var(--border);

  box-shadow:
    var(--glow-soft);
}

.topbar-inner {

  max-width: var(--max);

  margin: 0 auto;

  padding: 14px 24px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  gap: 18px;
}

/* ==================================================
   BRAND
================================================== */

.brand {

  display: flex;
  align-items: center;

  gap: 12px;

  min-width: 0;

  font-weight: 700;

  letter-spacing: 0.01em;
}

.brand-badge {

  width: 42px;
  height: 42px;

  border-radius: 16px;

  display: grid;
  place-items: center;

  background: var(--grad-primary);

  border:
    1px solid var(--border);

  box-shadow:
    var(--glow-soft);

  font-size: 1.05rem;

  position: relative;

  overflow: hidden;
}

.brand-badge::after {

  content: "";

  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.14),
      transparent 60%
    );

  opacity: 0.38;

  pointer-events: none;
}

.brand-copy {

  min-width: 0;

  display: inline-flex;
  flex-direction: column;

  color: inherit;
}

.brand-copy small {

  display: block;

  margin-top: 3px;

  color: var(--muted);

  font-size: 0.72rem;

  font-weight: 500;

  letter-spacing: 0.04em;
}

/* ==================================================
   ACTIONS
================================================== */

.top-actions {

  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;

  gap: 10px;
}

/* ==================================================
   GLOBAL INTERACTIVES
================================================== */

.pill,
.ghost-btn,
.solid-btn,
.chip {

  border: 0;

  color: var(--text);

  cursor: pointer;

  transition:
    transform var(--motion-fast),
    border-color var(--motion-fast),
    background var(--motion-fast),
    box-shadow var(--motion-fast),
    opacity var(--motion-fast);
}

/* ==================================================
   PILL
================================================== */

.pill {

  display: inline-flex;
  align-items: center;

  gap: 8px;

  white-space: nowrap;

  padding: 10px 14px;

  border-radius: 999px;

  font-size: 0.88rem;

  font-weight: 600;

  background:
    linear-gradient(
      180deg,
      var(--surface-2),
      var(--surface-1)
    );

  border:
    1px solid var(--border);

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  box-shadow:
    var(--glow-soft);
}
/* ==================================================
   HOVERS
================================================== */

.pill:hover,
.ghost-btn:hover,
.chip:hover,
.tag-card:hover,
.model-card:hover,
.hero-card:hover,
.insight-stat:hover,
.mini-panel:hover,
.accordion-item:hover {

  transform: translateY(-2px);

  border-color:
    color-mix(
      in srgb,
      var(--accent) 22%,
      var(--border)
    );

  box-shadow:
    var(--glow-mid);
}

/* ==================================================
   BUTTONS
================================================== */

.ghost-btn,
.solid-btn {

  display: inline-flex;
  align-items: center;
  justify-content: center;

  gap: 8px;

  padding: 12px 16px;

  border-radius: 16px;

  font-size: 0.92rem;
  font-weight: 600;

  letter-spacing: 0.01em;

  position: relative;

  overflow: hidden;

  isolation: isolate;
}

/* ==================================================
   GHOST BUTTON
================================================== */

.ghost-btn {

  background:
    linear-gradient(
      180deg,
      var(--surface-2),
      var(--surface-1)
    );

  border:
    1px solid var(--border);

  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);

  box-shadow:
    var(--glow-soft);
}

.ghost-btn:hover {

  background:
    var(--grad-soft);

  box-shadow:
    var(--glow-mid);
}

/* ==================================================
   SOLID BUTTON
================================================== */

.solid-btn {

  background: var(--grad-primary);

  border:
    1px solid var(--border);

  box-shadow:
    var(--glow-soft);
}

.solid-btn::before {

  content: "";

  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.18),
      transparent 60%
    );

  opacity: 0.55;

  pointer-events: none;

  z-index: -1;
}

.solid-btn:hover {

  transform: translateY(-2px);

  box-shadow:
    var(--glow-mid);
}

/* ==================================================
   HERO
================================================== */

.hero {

  display: grid;

  grid-template-columns:
    minmax(0, 1.18fr)
    minmax(340px, 0.82fr);

  gap: 16px;

  margin-top: 16px;

  align-items: stretch;
}

/* ==================================================
   GLOBAL SURFACES
================================================== */

.hero-card,
.side-hero-card,
.section-card,
.accordion-item,
.mini-panel,
.tag-card,
.model-card,
.insight-stat {

  background:
    color-mix(
      in srgb,
      var(--card) 92%,
      transparent
    );

  border:
    1px solid var(--border-soft);

  box-shadow:
    var(--panel-depth);
}

/* ==================================================
   HERO CARD
================================================== */

.hero-card {

  position: relative;

  isolation: isolate;

  overflow: clip;

  display: grid;

  align-items: end;

  min-height: 230px;

  border-radius: 22px;

  background:
    color-mix(
      in srgb,
      var(--card) 94%,
      transparent
    );

  border:
    1px solid rgba(255,255,255,0.06);

  box-shadow:
    0 8px 24px rgba(0,0,0,0.18);
}

/* ==================================================
   HERO OVERLAY
================================================== */

.hero-card::before {

  content: "";

  position: absolute;

  inset: 0;

  z-index: 1;

  background:
    linear-gradient(
      180deg,
      rgba(0,0,0,0.04) 0%,
      rgba(0,0,0,0.24) 52%,
      rgba(0,0,0,0.64) 100%
    );
}

/* ==================================================
   HERO ATMOSPHERE
================================================== */

.hero-card::after {

  content: "";

  position: absolute;

  inset: 0;

  border-radius: inherit;

  background:
    radial-gradient(
      circle at top right,
      rgba(255,255,255,0.045),
      transparent 52%
    );

  opacity: 0.12;

  pointer-events: none;

  z-index: 2;
}

/* ==================================================
   HERO BG
================================================== */

.hero-bg {

  position: absolute;

  inset: 0;

  overflow: hidden;

  border-radius: inherit;
}

.hero-bg img {

  width: 100%;
  height: 100%;

  object-fit: cover;

  object-position: center center;

  transform: scale(1);

  transition:
    transform 0.35s ease;
}

.hero-card:hover .hero-bg img {

  transform: scale(1.012);
}

/* ==================================================
   HERO CONTENT
================================================== */

.hero-content {

  position: relative;

  z-index: 3;

  padding: 16px;
}

/* ==================================================
   KICKER
================================================== */

.kicker {

  display: inline-flex;
  align-items: center;

  gap: 7px;

  margin-bottom: 8px;

  padding: 5px 10px;

  border-radius: 999px;

  background:
    rgba(255,255,255,0.06);

  border:
    1px solid rgba(255,255,255,0.08);

  font-size: 0.68rem;
  font-weight: 600;

  letter-spacing: 0.07em;

  text-transform: uppercase;

  color: var(--highlight_color);

  backdrop-filter: blur(6px);
}

/* ==================================================
   HERO TITLE
================================================== */

.hero-title {

  margin: 0 0 8px;

  max-width: 14ch;

  font-size:
    clamp(1.55rem, 2.35vw, 2.25rem);

  line-height: 0.98;

  font-weight: 780;

  letter-spacing: -0.028em;

  text-wrap: balance;
}

/* ==================================================
   HERO SUB
================================================== */

.hero-sub {

  margin: 0 0 10px;

  max-width: 46ch;

  color: var(--muted);

  font-size: 0.86rem;

  line-height: 1.42;

  font-weight: 400;
}

/* ==================================================
   FLEX GROUPS
================================================== */

.hero-meta,
.card-meta,
.tag-meta,
.stats-grid,
.mini-panel-grid,
.metric-row,
.chip-row,
.button-row,
.section-head,
.accordion-head {

  display: flex;

  align-items: center;
  flex-wrap: wrap;

  gap: 10px;
}

/* ==================================================
   HERO META PILL
================================================== */

.hero-meta .pill {

  background:
    rgba(255,255,255,0.055);

  border:
    1px solid rgba(255,255,255,0.07);
}

/* ==================================================
   BUTTON ROW
================================================== */

.button-row {
  margin-top: 8px;
}

/* ==================================================
   SIDE HERO
================================================== */

.side-hero {

  display: grid;

  gap: 9px;
}

/* ==================================================
   SIDE HERO CARD
================================================== */

.side-hero-card {

  position: relative;

  overflow: hidden;

  min-height: 88px;

  padding: 12px 14px;

  border-radius: 16px;

  background:
    color-mix(
      in srgb,
      var(--card) 92%,
      transparent
    );

  border:
    1px solid rgba(255,255,255,0.06);

  box-shadow:
    0 3px 10px rgba(0,0,0,0.12);

  transition:
    transform 0.18s ease,
    border-color 0.18s ease,
    background 0.18s ease;
}

/* ==================================================
   SIDE HERO HOVER
================================================== */

.side-hero-card:hover {

  transform: translateY(-1px);

  border-color:
    rgba(255,255,255,0.10);

  background:
    color-mix(
      in srgb,
      var(--card) 96%,
      transparent
    );
}

/* ==================================================
   SIDE HERO ATMOSPHERE
================================================== */

.side-hero-card::after {

  content: "";

  position: absolute;

  top: -60px;
  right: -60px;

  width: 130px;
  height: 130px;

  border-radius: 50%;

  background:
    radial-gradient(
      circle,
      rgba(255,255,255,0.035),
      transparent 68%
    );

  opacity: 0.08;

  pointer-events: none;
}

/* ==================================================
   HEADINGS
================================================== */

.side-hero-card h3,
.mini-panel h3,
.section-head h2,
.accordion-head h3,
.tag-card h3,
.model-card h3 {

  margin: 0;

  font-weight: 680;

  letter-spacing: -0.018em;

  line-height: 1.08;
}

/* ==================================================
   SIDE HERO TEXT TIGHTENING
================================================== */

.side-hero-card h3 {

  font-size: 0.95rem;
}

.side-hero-card p {

  margin-bottom: 0;

  font-size: 0.84rem;

  line-height: 1.38;
}

/* ==================================================
   TEXT SYSTEM
================================================== */

.side-hero-card p,
.mini-panel p,
.tag-card p,
.model-card p,
.section-head p,
.accordion-body p,
.helper-copy,
.eyebrow,
.tiny,
.muted {

  color: var(--muted);
}

/* ==================================================
   EYEBROW
================================================== */

.eyebrow {

  display: inline-flex;
  align-items: center;

  gap: 7px;

  margin-bottom: 5px;

  font-size: 0.66rem;

  font-weight: 600;

  text-transform: uppercase;

  letter-spacing: 0.11em;

  color: var(--highlight_color);

  opacity: 0.76;
}

/* ==================================================
   SMALL TEXT
================================================== */

.tiny {

  font-size: 0.81rem;

  line-height: 1.4;

  color:
    color-mix(
      in srgb,
      var(--text) 76%,
      transparent
    );
}

.muted {
  color: var(--muted);
}

.helper-copy {

  margin-top: 20px;

  font-size: 0.92rem;

  line-height: 1.62;
}

/* ==================================================
   MOBILE HERO
================================================== */

@media (max-width: 768px) {

  .hero {
    display: block;
    margin-top: 12px;
  }

  .side-hero {
    display: none;
  }

  .hero-card {
    min-height: 210px;
    border-radius: 18px;
  }

  .hero-content {
    padding: 15px;
  }

  .hero-title {
    max-width: 13ch;

    font-size:
      clamp(1.5rem, 7.5vw, 2rem);

    line-height: 1;
  }

  .hero-sub {
    font-size: 0.86rem;
    line-height: 1.4;
  }

  .kicker {
    font-size: 0.65rem;
    padding: 5px 9px;
    margin-bottom: 7px;
  }

}

/* ==================================================
   SMALL PHONE HERO
================================================== */

@media (max-width: 520px) {

  .hero-card {
    min-height: 185px;
  }

  .hero-sub {
    display: none;
  }

}
/* ==================================================
   SECTION
================================================== */

.section {
  margin-top: 28px;
}

/* ==================================================
   SECTION HEAD
================================================== */

.section-head {

  display: flex;
  align-items: flex-end;
  justify-content: space-between;

  gap: 14px;

  margin-bottom: 12px;

  padding-bottom: 12px;

  position: relative;
}

.section-head::after {

  content: "";

  position: absolute;
  bottom: 0;
  left: 0;

  width: 100%;
  height: 1px;

  background:
    linear-gradient(
      to right,
      rgba(255,255,255,0.12),
      rgba(255,255,255,0.05) 38%,
      transparent
    );
}

.section-head > div:first-child {
  min-width: 0;
}

/* ==================================================
   SECTION TITLE
================================================== */

.section-head h2 {

  position: relative;

  display: flex;
  align-items: center;

  gap: 8px;

  margin: 0 0 4px;

  padding-left: 14px;

  font-size:
    clamp(1.22rem, 1.8vw, 1.68rem);

  font-weight: 720;

  line-height: 1.08;

  letter-spacing: -0.028em;
}

.section-head h2::before {

  content: "";

  position: absolute;
  left: 0;
  top: 50%;

  width: 3px;
  height: 68%;

  transform: translateY(-50%);

  border-radius: 999px;

  background:
    linear-gradient(
      180deg,
      var(--accent),
      var(--highlight)
    );

  box-shadow:
    0 0 10px rgba(255,255,255,0.06);
}
/* ==================================================
   SECTION COPY
================================================== */

.section-head p {

  max-width: 500px;

  margin: 0;

  color: var(--muted);

  font-size: 0.86rem;

  line-height: 1.45;
}

/* ==================================================
   SECTION ACTIONS
================================================== */

.section-actions {

  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;

  gap: 8px;

  flex-shrink: 0;
}
/* ==================================================
   RAIL
================================================== */

.rail-wrap {
  position: relative;
}

/* ==================================================
   RAIL CONTROLS
================================================== */

.rail-controls {

  position: absolute;

  top: -52px;
  right: 0;

  display: flex;

  gap: 8px;

  z-index: 5;
}

/* ==================================================
   RAIL BUTTONS
================================================== */

.rail-btn {

  width: 42px;
  height: 42px;

  display: inline-grid;
  place-items: center;

  border-radius: 15px;

  border:
    1px solid var(--border);

  background:
    linear-gradient(
      180deg,
      var(--surface-2),
      var(--surface-1)
    );

  color: var(--text);

  cursor: pointer;

  font-size: 1.05rem;
  line-height: 1;

  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);

  box-shadow:
    var(--glow-soft);

  transition:
    transform var(--motion-fast),
    border-color var(--motion-fast),
    box-shadow var(--motion-fast),
    background var(--motion-fast),
    opacity var(--motion-fast);
}

.rail-btn:hover {

  transform: translateY(-2px);

  border-color:
    color-mix(
      in srgb,
      var(--accent) 24%,
      var(--border)
    );

  background:
    var(--grad-soft);

  box-shadow:
    var(--glow-mid);
}

.rail-btn:active {
  transform: translateY(0);
}

/* ==================================================
   RAIL GRID
================================================== */

.rail {

  display: grid;

  grid-auto-flow: column;

  grid-auto-columns:
    minmax(260px, 1fr);

  gap: 16px;

  overflow-x: auto;
  overflow-y: hidden;

  padding-bottom: 10px;

  scroll-snap-type: x proximity;
  scroll-behavior: smooth;

  scrollbar-width: none;

  -webkit-overflow-scrolling: touch;

  overscroll-behavior-inline: contain;
}

.rail::-webkit-scrollbar {
  display: none;
}
/* ==================================================
   MODEL CARD
================================================== */

.model-card {

  position: relative;

  overflow: hidden;

  min-height: 370px;

  border-radius: 26px;

  display: grid;

  grid-template-rows:
    230px auto;

  scroll-snap-align: start;

  contain: layout paint;

  isolation: isolate;

  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  box-shadow:
    var(--glow-soft);

  transition:
    transform var(--motion-mid),
    border-color var(--motion-fast),
    box-shadow var(--motion-mid);
}

/* subtle surface glow */
.model-card::before {

  content: "";

  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.025),
      transparent 24%
    );

  pointer-events: none;

  opacity: 0.7;

  z-index: 1;
}

/* ==================================================
   THUMB
================================================== */

.model-thumb {

  position: relative;

  overflow: hidden;

  height: 100%;

  line-height: 0;

  background:
    color-mix(
      in srgb,
      var(--bg) 88%,
      black
    );
}

.model-thumb::after {

  content: "";

  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      180deg,
      rgba(0,0,0,0.00),
      rgba(0,0,0,0.10)
    );

  pointer-events: none;

  z-index: 1;
}

.model-thumb img {

  width: 100%;
  height: 100%;

  display: block;

  object-fit: cover;

  transform: scale(1.01);

  filter:
    contrast(1.03)
    saturate(1.02)
    brightness(0.95);

  transition:
    transform var(--motion-slow),
    filter var(--motion-slow);
}

/* ==================================================
   IMAGE HOVER
================================================== */

.model-card:hover .model-thumb img {

  transform: scale(1.04);

  filter:
    contrast(1.05)
    saturate(1.04)
    brightness(0.98);
}

/* ==================================================
   BADGE STACK
================================================== */

.badge-stack {

  position: absolute;

  top: 12px;
  left: 12px;

  z-index: 5;

  display: flex;
  align-items: center;
  flex-wrap: wrap;

  gap: 6px;

  max-width:
    calc(100% - 24px);
}

/* ==================================================
   BADGES
================================================== */

.badge {

  display: inline-flex;
  align-items: center;
  justify-content: center;

  height: 24px;

  padding: 0 10px;

  border-radius: 999px;

  border:
    1px solid var(--border);

  background:
    var(--glass-bg);

  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);

  color: var(--text);

  font-size: 0.68rem;
  font-weight: 600;

  letter-spacing: 0.03em;

  line-height: 1;

  white-space: nowrap;

  box-shadow:
    var(--glow-soft);

  transition:
    border-color var(--motion-fast),
    background var(--motion-fast),
    transform var(--motion-fast);
}

.badge:hover {

  transform: translateY(-1px);

  border-color:
    color-mix(
      in srgb,
      var(--accent) 22%,
      var(--border)
    );
}

/* ==================================================
   MOBILE PERFORMANCE
================================================== */

@media (max-width: 820px) {

  .model-card:hover .model-thumb img {
    transform: none;
  }

  .badge {
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
  }
}

/* ==================================================
   LIVE DOT
================================================== */

.live-dot {

  position: relative;

  top: -1px;

  width: 8px;
  height: 8px;

  flex-shrink: 0;

  border-radius: 50%;

  background:
    var(--highlight);

  margin-right: 7px;

  box-shadow:
    0 0 10px color-mix(
      in srgb,
      var(--highlight) 45%,
      transparent
    );
}

/* ==================================================
   LIVE PULSE
================================================== */

.live-dot::after {

  content: "";

  position: absolute;

  inset: -3px;

  border-radius: 50%;

  border:
    1.5px solid color-mix(
      in srgb,
      var(--highlight) 55%,
      transparent
    );

  opacity: 0.7;

  transform: scale(0.9);

  animation:
    livePulse 2.2s infinite ease-out;
}

/* ==================================================
   LIVE PULSE
================================================== */

@keyframes livePulse {

  0% {

    opacity: 0.7;

    transform: scale(0.9);
  }

  75% {

    opacity: 0;

    transform: scale(1.9);
  }

  100% {

    opacity: 0;

    transform: scale(1.9);
  }
}

/* ==================================================
   CARD BODY
================================================== */

.card-body {

  display: flex;
  flex-direction: column;

  gap: 8px;

  padding: 14px;

  min-width: 0;

  position: relative;

  z-index: 2;
}

/* ==================================================
   TOPLINE
================================================== */

.card-topline {

  display: flex;
  align-items: center;

  gap: 8px;

  width: 100%;

  min-width: 0;
}

/* ==================================================
   TITLE
================================================== */

.card-topline h3 {

  flex: 1 1 auto;

  min-width: 0;

  margin: 0;

  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;

  font-size: 1rem;

  font-weight: 700;

  line-height: 1.25;

  letter-spacing: -0.02em;
}

/* ==================================================
   VIEWERS
================================================== */

.viewer-number {

  flex: 0 0 auto;

  white-space: nowrap;

  color: var(--text);

  font-weight: 700;

  font-variant-numeric:
    tabular-nums;
}

/* ==================================================
   META
================================================== */

.card-meta {

  display: flex;
  align-items: flex-start;

  min-height: 34px;
  min-width: 0;

  color: var(--muted);

  font-size: 0.8rem;

  line-height: 1.45;
}

/* ==================================================
   SUBJECT
================================================== */

.model-subject {

  width: 100%;
  min-width: 0;

  overflow: hidden;

  display: -webkit-box;

  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;

  word-break: break-word;
}

/* ==================================================
   TAGS
================================================== */

.chip-row {

  display: flex;
  flex-wrap: wrap;
  align-content: flex-start;

  gap: 6px;

  min-height: 32px;
  max-height: 42px;

  overflow: hidden;

  min-width: 0;
}

.chip {

  display: inline-flex;
  align-items: center;

  max-width: 100%;

  margin: 0;

  padding: 4px 8px;

  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;

  border-radius: 999px;

  border:
    1px solid var(--border);

  background:
    var(--grad-soft);

  color: var(--text);

  font-size: 0.66rem;
  font-weight: 600;

  letter-spacing: 0.02em;

  line-height: 1.1;

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  transition:
    border-color var(--motion-fast),
    background var(--motion-fast),
    transform var(--motion-fast);
}

.chip:hover {

  transform: translateY(-1px);

  border-color:
    color-mix(
      in srgb,
      var(--accent) 20%,
      var(--border)
    );

  background:
    var(--grad-mix);
}

/* ==================================================
   FOOTER
================================================== */

.card-footer {

  display: flex;
  align-items: center;
  justify-content: space-between;

  gap: 10px;

  margin-top: auto;

  min-width: 0;

  color: var(--muted);

  font-size: 0.8rem;
}

.card-footer > * {
  min-width: 0;
}

/* ==================================================
   CTA
================================================== */

.card-cta {

  color: var(--text);

  font-weight: 600;

  white-space: nowrap;

  transition:
    color var(--motion-fast),
    opacity var(--motion-fast);
}

.card-cta:hover {

  color: var(--highlight_color);
}
/* ==================================================
   GRID SYSTEM
================================================== */

.grid-3,
.grid-4,
.stats-grid,
.mini-panel-grid,
.accordion-grid {

  display: grid;

  gap: 18px;
}

/* ==================================================
   GRID LAYOUTS
================================================== */

.grid-3 {

  grid-template-columns:
    repeat(3, minmax(0, 1fr));
}

.grid-4,
.stats-grid {

  grid-template-columns:
    repeat(4, minmax(0, 1fr));
}

.mini-panel-grid {

  grid-template-columns:
    repeat(3, minmax(0, 1fr));
}

.accordion-grid {

  grid-template-columns:
    repeat(2, minmax(0, 1fr));
}

/* ==================================================
   PANEL SYSTEM
================================================== */

.insight-stat,
.mini-panel,
.tag-card,
.accordion-item {

  position: relative;

  overflow: hidden;

  padding: 18px;

  border-radius: 24px;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);

  box-shadow:
    var(--glow-soft);

  transition:
    transform var(--motion-mid),
    border-color var(--motion-fast),
    box-shadow var(--motion-mid),
    background var(--motion-mid);
}

/* ==================================================
   PANEL ATMOSPHERE
================================================== */

.insight-stat::before,
.mini-panel::before,
.tag-card::before,
.accordion-item::before {

  content: "";

  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.025),
      transparent 28%
    );

  pointer-events: none;

  opacity: 0.8;
}

/* ==================================================
   TAG CARD
================================================== */

.tag-card {

  position: relative;

  min-height: 165px;
}

/* ==================================================
   ATMOSPHERIC ORB
================================================== */

.tag-card::after {

  content: "";

  position: absolute;

  right: -30px;
  bottom: -70px;

  width: 170px;
  height: 170px;

  border-radius: 50%;

  background: var(--glow-orb);

  opacity: 0.85;

  pointer-events: none;

  transition:
    transform var(--motion-slow),
    opacity var(--motion-mid),
    background var(--motion-mid);
}

/* ==================================================
   TAG CARD HOVER
================================================== */

.tag-card:hover::after {

  background: var(--glow-orb-alt);

  transform: scale(1.08);

  opacity: 1;
}

/* ==================================================
   TAG COUNT
================================================== */

.tag-card .count {

  margin: 12px 0 8px;

  font-size: 2.2rem;

  font-weight: 800;

  line-height: 1;

  letter-spacing: -0.05em;

  color: var(--text);
}

/* ==================================================
   TAG META
================================================== */

.tag-meta {

  font-size: 0.92rem;

  line-height: 1.7;

  color: var(--muted);
}

/* ==================================================
   MINI PANEL
================================================== */

.mini-panel {
  min-height: 100%;
}

/* ==================================================
   METRIC ROW
================================================== */

.metric-row {

  display: flex;
  align-items: center;
  justify-content: space-between;

  gap: 16px;

  padding: 12px 0;

  border-bottom:
    1px solid var(--border);

  font-size: 0.92rem;

  line-height: 1.4;
}

.metric-row:last-child {

  border-bottom: 0;

  padding-bottom: 0;
}

/* ==================================================
   ACCORDION
================================================== */

.accordion-wrap {

  display: none;

  margin-top: 30px;
}

/* ==================================================
   ACCORDION ITEM
================================================== */

.accordion-item {

  overflow: hidden;

  border-radius: 24px;

  transition:
    transform var(--motion-mid),
    border-color var(--motion-fast),
    box-shadow var(--motion-mid),
    background var(--motion-mid);
}

/* ==================================================
   ACCORDION HOVER
================================================== */

.accordion-item:hover {

  border-color:
    color-mix(
      in srgb,
      var(--accent) 20%,
      var(--border)
    );

  box-shadow:
    var(--glow-mid);
}

/* ==================================================
   ACCORDION HEAD
================================================== */

.accordion-head {

  width: 100%;

  display: flex;
  align-items: center;
  justify-content: space-between;

  gap: 14px;

  padding: 0;

  background: transparent;

  border: 0;

  color: inherit;

  cursor: pointer;

  text-align: left;
}

/* ==================================================
   ACCORDION ICON
================================================== */

.accordion-icon {

  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: 34px;
  height: 34px;

  border-radius: 12px;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  font-size: 1rem;

  flex-shrink: 0;

  transition:
    transform var(--motion-mid),
    background var(--motion-fast),
    border-color var(--motion-fast);
}

/* ==================================================
   OPEN STATE
================================================== */

.accordion-item.open .accordion-icon {

  transform: rotate(45deg);

  border-color:
    color-mix(
      in srgb,
      var(--accent) 22%,
      var(--border)
    );

  background:
    var(--grad-mix);
}

/* ==================================================
   ACCORDION BODY
================================================== */

.accordion-body {

  max-height: 0;

  overflow: hidden;

  opacity: 0;

  transition:
    max-height 0.42s cubic-bezier(.2,.8,.2,1),
    opacity 0.28s ease,
    padding-top 0.28s ease;

  padding-top: 0;
}

/* ==================================================
   OPEN BODY
================================================== */

.accordion-item.open .accordion-body {

  max-height: 700px;

  opacity: 1;

  padding-top: 18px;
}

/* ==================================================
   FOOTER NOTE
================================================== */

.footer-note {

  margin: 36px 0 14px;

  color: var(--muted);

  font-size: 0.9rem;

  line-height: 1.6;

  text-align: center;

  opacity: 0.9;
}

/* ==================================================
   PAGINATION
================================================== */

.pagination {

  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;

  gap: 14px;

  margin-top: 34px;
}
/* ==================================================
   FOOTER
================================================== */

.site-footer {

  position: relative;

  overflow: hidden;

  margin-top: 60px;

  padding: 48px 24px;

  border-top:
    1px solid var(--border);

  background:

    var(--glow-orb),

    linear-gradient(
      180deg,
      rgba(255,255,255,0.015),
      transparent
    ),

    color-mix(
      in srgb,
      var(--bg) 94%,
      black
    );
}

/* subtle footer atmosphere */
.site-footer::before {

  content: "";

  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.02),
      transparent 18%
    );

  pointer-events: none;

  opacity: 0.8;
}

.footer-inner {

  position: relative;

  z-index: 2;

  max-width: 1480px;

  margin: 0 auto;
}

/* ==================================================
   FOOTER GRID
================================================== */

.footer-grid {

  display: grid;

  grid-template-columns:
    repeat(4, minmax(0,1fr));

  gap: 36px;
}

/* ==================================================
   FOOTER HEADINGS
================================================== */

.footer-col h4 {

  margin: 0 0 12px;

  font-weight: 700;

  font-size: 0.95rem;

  letter-spacing: -0.01em;

  color: var(--text);
}

.footer-col ul {

  list-style: none;

  padding: 0;
  margin: 0;
}

.footer-col li {
  margin: 8px 0;
}

/* ==================================================
   FOOTER LINKS
================================================== */

.footer-col a {

  color: var(--muted);

  font-size: 0.9rem;

  transition:
    color var(--motion-fast),
    opacity var(--motion-fast);
}

.footer-col a:hover {

  color: var(--text);

  opacity: 1;
}

/* ==================================================
   FOOTER BRAND
================================================== */

.footer-brand {

  display: flex;
  align-items: center;

  gap: 10px;

  margin-bottom: 10px;

  font-size: 1.05rem;

  font-weight: 700;
}

/* ==================================================
   FOOTER ICON
================================================== */

.footer-icon {

  color: var(--accent);

  font-size: 1.2rem;

  text-shadow:
    var(--glow-soft);
}

.footer-text {

  color: var(--muted);

  font-size: 0.9rem;

  line-height: 1.7;
}

/* ==================================================
   FOOTER BOTTOM
================================================== */

.footer-bottom {

  margin-top: 36px;

  padding-top: 18px;

  border-top:
    1px solid var(--border);

  text-align: center;

  color: var(--muted);

  font-size: 0.82rem;

  line-height: 1.6;
}

/* ==================================================
   TRENDING BADGE
================================================== */

.model-card.top-trending .badge.hot {

  background: var(--grad-primary);

  border:
    1px solid var(--border);

  color: var(--text);

  box-shadow:
    var(--glow-mid);
}

/* ==================================================
   URGENCY BAR
================================================== */

.urgency-bar {

  position: absolute;

  left: 0;
  bottom: 0;

  width: 100%;
  height: 3px;

  z-index: 4;

  overflow: hidden;

  opacity: 0.9;

  background:
    linear-gradient(
      90deg,
      transparent,
      color-mix(
        in srgb,
        var(--accent) 22%,
        transparent
      ),
      transparent
    );
}

/* moving signal */
.urgency-bar::before {

  content: "";

  position: absolute;

  inset: 0;

  background: var(--grad-primary);

  animation:
    urgencyMove 2.8s linear infinite;
}

/* ==================================================
   SIGNAL MOTION
================================================== */

@keyframes urgencyMove {

  0% {
    transform: translateX(-100%);
  }

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

/* ==================================================
   VIEWERS
================================================== */

.model-card:not(.top-card) .thumb-viewers {
  opacity: 0.72;
}

.model-card.top-card .thumb-viewers {
  opacity: 1;
}

/* ==================================================
   TREND UP
================================================== */

.trend-up {

  font-size: 0.74rem;

  font-weight: 700;

  color: var(--ok);

  letter-spacing: 0.01em;
}
/* ==================================================
   HOMEPAGE INTRO
================================================== */

.homepage-intro {

  position: relative;

  overflow: hidden;

  isolation: isolate;

  width: 100%;
  max-width: 100%;

  margin: 24px 0 32px;

  padding: 24px 26px;

  border-radius: 24px;

  background:
    color-mix(
      in srgb,
      var(--card) 92%,
      transparent
    );

  border:
    1px solid var(--border-soft);

  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);

  box-shadow:
    var(--glow-mid);
}

/* ==================================================
   ATMOSPHERE
================================================== */

.homepage-intro::before {

  content: "";

  position: absolute;

  top: -120px;
  right: -120px;

  width: 260px;
  height: 260px;

  border-radius: 50%;

  background:
    var(--glow-orb);

  opacity: 0.30;

  pointer-events: none;

  z-index: 0;
}

/* ==================================================
   SURFACE SHEEN
================================================== */

.homepage-intro::after {

  content: "";

  position: absolute;
  inset: 0;

  background:
    var(--surface-sheen);

  opacity: 0.85;

  pointer-events: none;

  z-index: 1;
}

/* ==================================================
   CONTENT LAYER
================================================== */

.homepage-intro > * {

  position: relative;

  z-index: 2;
}

/* ==================================================
   HOMEPAGE TITLE
================================================== */

.homepage-title {

  margin: 0 0 12px;

  font-size: 1.2rem;

  font-weight: 750;

  letter-spacing: -0.02em;

  color: var(--text);
}

/* ==================================================
   HOMEPAGE TEXT
================================================== */

.homepage-text {

  font-size: 0.95rem;

  line-height: 1.8;

  color: var(--muted);
}

/* ==================================================
   HEADINGS
================================================== */

.card-heading {

  margin-bottom: 6px;

  font-size: 1.05rem;

  font-weight: 700;

  letter-spacing: -0.02em;
}

.stat-heading {

  font-size: 1.15rem;

  font-weight: 700;

  letter-spacing: -0.02em;

  color: var(--text);
}

/* ==================================================
   RESPONSIVE
================================================== */

@media (max-width: 1180px) {

  .hero {
    grid-template-columns: 1fr;
  }

  .stats-grid,
  .grid-4 {
    grid-template-columns:
      repeat(2, minmax(0, 1fr));
  }

  .mini-panel-grid,
  .grid-3 {
    grid-template-columns: 1fr;
  }
}

/* ==================================================
   MOBILE
================================================== */

@media (max-width: 820px) {

  .page,
  .topbar-inner {

    padding-left: 14px;
    padding-right: 14px;
  }

  .topbar-inner {

    flex-direction: column;

    align-items: flex-start;

    gap: 12px;
  }

  .top-actions {

    width: 100%;

    justify-content: flex-start;

    gap: 8px;
  }

  .rail-controls {
    display: none;
  }

  .grid-4,
  .stats-grid,
  .accordion-grid {
    grid-template-columns: 1fr;
  }

  .desktop-only {
    display: none !important;
  }

  .accordion-wrap {
    display: block;
  }

    .hero-title {
    max-width: none;
  }

  /* smoother mobile rail */
  .rail {

    grid-auto-columns: 82%;

    gap: 14px;
  }
}

/* ==================================================
   DEVICE TOGGLES
================================================== */

@media (min-width: 821px) {

  .mobile-only {
    display: none !important;
  }
}

/* ==================================================
   FOOTER RESPONSIVE
================================================== */

@media (max-width: 900px) {

  .footer-grid {

    grid-template-columns:
      1fr 1fr;

    gap: 28px;
  }
}

@media (max-width: 600px) {

  .footer-grid {

    grid-template-columns: 1fr;

    gap: 22px;
  }
}

/* ==================================================
   FOOTER PARTNERS
================================================== */

.footer-partners {

  margin-top: 40px;

  padding-top: 22px;

  border-top:
    1px solid var(--border);
}

.footer-partners-title {

  margin-bottom: 12px;

  font-size: 0.88rem;

  font-weight: 600;

  color: var(--muted);

  letter-spacing: 0.01em;
}

.footer-partner-links {

  display: flex;
  flex-wrap: wrap;

  gap: 10px;
}

/* ==================================================
   STATS
================================================== */

.stat-row {

  display: flex;

  gap: 12px;

  margin: 14px 0;
}

.stat-box {

  flex: 1;

  position: relative;

  overflow: hidden;

  padding: 14px;

  border-radius: 16px;

  text-align: center;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  box-shadow:
    var(--glow-soft);

  transition:
    transform var(--motion-fast),
    border-color var(--motion-fast),
    box-shadow var(--motion-fast);
}

/* subtle atmosphere */
.stat-box::before {

  content: "";

  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.03),
      transparent 28%
    );

  pointer-events: none;

  opacity: 0.8;
}

.stat-box:hover {

  transform: translateY(-2px);

  border-color:
    color-mix(
      in srgb,
      var(--accent) 22%,
      var(--border)
    );

  box-shadow:
    var(--glow-mid);
}

.stat-value {

  font-size: 1.25rem;

  font-weight: 800;

  letter-spacing: -0.03em;

  color: var(--text);
}

.stat-label {

  margin-top: 4px;

  font-size: 0.68rem;

  font-weight: 600;

  letter-spacing: 0.08em;

  text-transform: uppercase;

  color: var(--muted);
}

/* ==================================================
   SIGNALS
================================================== */

.signal-list {

  display: flex;
  flex-direction: column;

  gap: 10px;

  margin-top: 14px;
}

.signal-item {

  display: flex;
  align-items: center;

  gap: 10px;
}

/* clickable signal */
.signal-item.clickable {

  position: relative;

  overflow: hidden;

  padding: 12px 14px;

  border-radius: 14px;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  text-decoration: none;

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  transition:
    transform var(--motion-fast),
    border-color var(--motion-fast),
    background var(--motion-fast),
    box-shadow var(--motion-fast);
}

/* subtle lighting */
.signal-item.clickable::before {

  content: "";

  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.025),
      transparent 30%
    );

  pointer-events: none;

  opacity: 0.7;
}

/* hover feedback */
.signal-item.clickable:hover {

  transform:
    translateX(3px)
    translateY(-1px);

  border-color:
    color-mix(
      in srgb,
      var(--accent) 28%,
      var(--border)
    );

  background:
    var(--grad-mix);

  box-shadow:
    var(--glow-mid);
}

/* ==================================================
   SIGNAL ICON
================================================== */

.signal-icon {

  flex-shrink: 0;

  font-size: 0.95rem;

  color: var(--text);

  text-shadow:
    var(--glow-soft);
}

/* ==================================================
   SIGNAL TEXT
================================================== */

.signal-item strong {

  font-weight: 700;

  color: var(--text);
}

.signal-item .muted {
  color: var(--muted);
}

/* ==================================================
   BIRTHDAY SIGNAL
================================================== */

.signal-item.birthday {
  color: var(--text);
}

.signal-item.birthday .signal-icon {

  text-shadow:
    var(--glow-mid);
}
/* ==========================================================
   INTERACTIVE V3.3
========================================================== */

.interactive-pulse {
  margin: 22px 0 28px;
}

/* ==========================================================
   PULSE SHELL
========================================================== */

.pulse-shell {

  position: relative;

  overflow: hidden;

  margin-bottom: 14px;

  padding: 18px;

  border-radius: 24px;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);

  box-shadow:
    var(--glow-soft);
}

/* subtle atmosphere */
.pulse-shell::before {

  content: '';

  position: absolute;
  inset: 0;

  background:

    var(--glow-orb),

    linear-gradient(
      180deg,
      rgba(255,255,255,0.02),
      transparent 28%
    );

  pointer-events: none;

  opacity: 0.9;
}

/* ==========================================================
   PULSE BAR
========================================================== */

.pulse-bar {

  position: relative;

  display: flex;
  flex-wrap: wrap;

  gap: 10px;
}

/* ==========================================================
   PULSE PILL
========================================================== */

.pulse-pill {

  display: inline-flex;
  align-items: center;

  gap: 6px;

  padding: 10px 14px;

  border-radius: 999px;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  box-shadow:
    var(--glow-soft);

  font-size: 0.82rem;

  font-weight: 600;

  letter-spacing: 0.01em;

  color: var(--text);

  transition:
    transform var(--motion-fast),
    border-color var(--motion-fast),
    background var(--motion-fast),
    box-shadow var(--motion-fast);
}

.pulse-pill:hover {

  transform: translateY(-1px);

  border-color:
    color-mix(
      in srgb,
      var(--accent) 24%,
      var(--border)
    );

  background:
    var(--grad-mix);

  box-shadow:
    var(--glow-mid);
}

/* ==========================================================
   INSIGHT
========================================================== */

.pulse-insight {

  position: relative;

  overflow: hidden;

  width: 100%;

  margin-bottom: 16px;

  padding: 20px 22px;

  border-radius: 20px;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);

  box-shadow:
    var(--glow-soft);
}

/* subtle atmosphere */
.pulse-insight::before {

  content: "";

  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.02),
      transparent 34%
    );

  pointer-events: none;

  opacity: 0.7;
}

.pulse-insight p {

  position: relative;

  z-index: 2;

  margin: 0;

  line-height: 1.8;

  font-size: 0.95rem;

  color: var(--text);
}
/* ==========================================================
   MINI LIVE ROW
========================================================== */

.mini-live-row {
  margin-bottom: 18px;
}

/* ==========================================================
   ROW HEAD
========================================================== */

.mini-row-head,
.pathway-head {

  display: flex;
  flex-direction: column;
  align-items: flex-start;

  gap: 5px;

  margin-bottom: 14px;
}

.mini-row-head h3,
.pathway-head h3 {

  margin: 0;

  font-size: 1rem;

  font-weight: 700;

  letter-spacing: -0.02em;

  color: var(--text);
}

.mini-row-head span,
.pathway-head span {

  font-size: 0.82rem;

  line-height: 1.5;

  color: var(--muted);
}

/* ==========================================================
   LIVE GRID
========================================================== */

.mini-live-grid {

  display: grid;

  grid-template-columns:
    repeat(auto-fill, minmax(160px, 1fr));

  gap: 16px;
}

/* ==========================================================
   LIVE CARD
========================================================== */

.mini-live-card {

  position: relative;

  text-decoration: none;

  color: inherit;

  transition:
    transform var(--motion-fast),
    opacity var(--motion-fast);
}

.mini-live-card:hover {

  transform:
    translateY(-2px);
}

/* ==========================================================
   THUMB
========================================================== */

.mini-live-card img {

  width: 100%;
  height: 205px;

  display: block;

  object-fit: cover;

  margin-bottom: 10px;

  border-radius: 20px;

  border:
    1px solid var(--border);

  background:
    var(--grad-soft);

  box-shadow:
    var(--glow-soft);

  filter:
    contrast(1.03)
    saturate(1.02)
    brightness(0.96);

  transition:
    transform var(--motion-mid),
    border-color var(--motion-fast),
    box-shadow var(--motion-mid),
    filter var(--motion-mid);
}

.mini-live-card:hover img {

  transform: translateY(-1px);

  border-color:
    color-mix(
      in srgb,
      var(--accent) 24%,
      var(--border)
    );

  box-shadow:
    var(--glow-mid);

  filter:
    contrast(1.05)
    saturate(1.04)
    brightness(0.98);
}

/* ==========================================================
   META
========================================================== */

.mini-live-meta strong {

  display: block;

  margin-bottom: 4px;

  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;

  font-size: 0.9rem;

  font-weight: 700;

  letter-spacing: -0.01em;

  color: var(--text);
}

/* ==========================================================
   ARCHETYPE LABEL
========================================================== */

.archetype-label {

  display: block;

  font-size: 0.78rem;

  font-weight: 600;

  line-height: 1.4;

  color: var(--muted);
}

/* ==========================================================
   ARCHETYPE STYLING
========================================================== */

.archetype-fast .archetype-label {
  color: #ffbe78;
}

.archetype-crowd .archetype-label {
  color: #ff7f96;
}

.archetype-retention .archetype-label {
  color: #8fdfff;
}

.archetype-long .archetype-label {
  color: #c9b2ff;
}

.archetype-hd .archetype-label {
  color: #7fe0a7;
}

.archetype-climber .archetype-label {
  color: #82cfff;
}

/* ==========================================================
   VIEWER PATHWAYS
========================================================== */

.viewer-pathways {

  padding-top: 12px;

  border-top:
    1px solid var(--border);
}

.viewer-pathways .chip-row {

  display: flex;
  flex-wrap: wrap;

  gap: 10px;
}

/* ==========================================================
   RESPONSIVE
========================================================== */

@media (max-width: 820px) {

  .pulse-shell {

    padding: 14px;

    border-radius: 20px;
  }

  .pulse-pill {

    padding: 9px 12px;

    font-size: 0.8rem;
  }

  .pulse-insight {

    padding: 18px;

    border-radius: 18px;
  }

  .mini-live-grid {

    grid-template-columns:
      repeat(2, minmax(0, 1fr));

    gap: 14px;
  }

  .mini-live-card img {

    height: 180px;

    border-radius: 18px;
  }
}

@media (max-width: 560px) {

  .pulse-bar {

    overflow-x: auto;

    flex-wrap: nowrap;

    padding-bottom: 4px;

    scrollbar-width: none;

    -webkit-overflow-scrolling: touch;
  }

  .pulse-bar::-webkit-scrollbar {
    display: none;
  }

  .pulse-pill {
    flex: 0 0 auto;
  }

  .mini-live-grid {

    grid-template-columns:
      repeat(2, minmax(0, 1fr));

    gap: 12px;
  }

  .mini-live-card img {
    height: 155px;
  }
}
/* ==========================================================
   NATURAL.PHP — VERSION 3.4
   Loyalty / Stability Ecosystem Styling
========================================================== */

.natural-pulse {
  margin: 22px 0 32px;
}

/* ==========================================================
   FEATURED SECTION
========================================================== */

.natural-featured-section {
  margin-top: 20px;
}

/* ==========================================================
   FEATURED GRID
========================================================== */

.natural-featured-grid {

  display: grid;

  grid-template-columns:
    repeat(auto-fit, minmax(220px, 1fr));

  gap: 22px;
}

/* ==========================================================
   FEATURE CARD
========================================================== */

.natural-feature-card {

  position: relative;

  display: flex;
  flex-direction: column;

  overflow: hidden;

  border-radius: 26px;

  text-decoration: none;

  color: inherit;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);

  box-shadow:
    var(--glow-soft);

  transition:
    transform var(--motion-mid),
    border-color var(--motion-fast),
    box-shadow var(--motion-mid);
}

/* subtle atmosphere */
.natural-feature-card::before {

  content: "";

  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.02),
      transparent 28%
    );

  pointer-events: none;

  opacity: 0.8;
}

.natural-feature-card:hover {

  transform: translateY(-3px);

  border-color:
    color-mix(
      in srgb,
      var(--accent) 24%,
      var(--border)
    );

  box-shadow:
    var(--glow-mid);
}

/* ==========================================================
   IMAGE
========================================================== */

.natural-feature-card img {

  width: 100%;
  height: 320px;

  display: block;

  object-fit: cover;

  filter:
    contrast(1.03)
    saturate(1.01)
    brightness(0.97);

  transition:
    transform var(--motion-slow),
    filter var(--motion-slow);
}

.natural-feature-card:hover img {

  transform: scale(1.02);

  filter:
    contrast(1.05)
    saturate(1.03)
    brightness(0.99);
}

/* ==========================================================
   CARD BODY
========================================================== */

.natural-card-body {
  padding: 18px;
}

.natural-card-body strong {

  display: block;

  margin-bottom: 12px;

  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;

  font-size: 1rem;

  font-weight: 700;

  letter-spacing: -0.02em;

  color: var(--text);
}

/* ==========================================================
   META
========================================================== */

.natural-meta {

  display: flex;
  flex-direction: column;

  gap: 10px;
}

/* ==========================================================
   ARCHETYPE LABEL
========================================================== */

.archetype-label {

  display: inline-flex;
  align-items: center;

  width: fit-content;

  padding: 6px 10px;

  border-radius: 999px;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);

  font-size: 0.76rem;

  font-weight: 700;

  letter-spacing: 0.02em;

  color: var(--text);
}
/* ==========================================================
   SESSION DEPTH
========================================================== */

.session-depth {

  font-size: 0.82rem;

  font-weight: 600;

  line-height: 1.5;

  color: var(--muted);
}

/* ==========================================================
   ARCHETYPE ACCENTS
========================================================== */

.archetype-favourite .archetype-label {
  color: #ffd58a;
}

.archetype-loyal .archetype-label {
  color: #ccb3ff;
}

.archetype-consistent .archetype-label {
  color: #94e3ff;
}

.archetype-engagement .archetype-label {
  color: #8ce8b1;
}

.archetype-reliable .archetype-label {
  color: #f5d1ff;
}

/* ==========================================================
   SOFTER NATURAL FEEL
========================================================== */

.natural-pulse .pulse-shell {

  border-color:
    color-mix(
      in srgb,
      var(--border) 70%,
      transparent
    );
}

.natural-pulse .pulse-insight {

  background:
    color-mix(
      in srgb,
      var(--grad-soft) 82%,
      transparent
    );
}

/* ==========================================================
   RESPONSIVE
========================================================== */

@media (max-width: 1100px) {

  .natural-featured-grid {

    grid-template-columns:
      repeat(auto-fit, minmax(200px, 1fr));
  }

  .natural-feature-card img {
    height: 280px;
  }
}

@media (max-width: 820px) {

  .natural-featured-grid {

    grid-template-columns:
      repeat(2, minmax(0, 1fr));

    gap: 16px;
  }

  .natural-feature-card {
    border-radius: 22px;
  }

  .natural-feature-card img {
    height: 240px;
  }

  .natural-card-body {
    padding: 16px;
  }
}

@media (max-width: 560px) {

  .natural-featured-grid {
    grid-template-columns: 1fr;
  }

  .natural-feature-card img {
    height: 340px;
  }
}
/* ==========================================================
   BODY.PHP — VERSION 3.4
   Visual Density / Discovery Ecosystem Styling
========================================================== */

.body-pulse {
  margin: 22px 0 32px;
}

/* ==========================================================
   BODY DISCOVERY SECTION
========================================================== */

.body-discovery-section {
  margin-top: 20px;
}

/* ==========================================================
   BODY GRID
========================================================== */

.body-discovery-grid {

  display: grid;

  grid-template-columns:
    repeat(auto-fill, minmax(160px, 1fr));

  gap: 18px;
}

/* ==========================================================
   DISCOVERY CARD
========================================================== */

.body-discovery-card {

  position: relative;

  display: flex;
  flex-direction: column;

  overflow: hidden;

  border-radius: 22px;

  text-decoration: none;

  color: inherit;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  box-shadow:
    var(--glow-soft);

  transition:
    transform var(--motion-fast),
    border-color var(--motion-fast),
    box-shadow var(--motion-mid);
}

/* subtle atmosphere */
.body-discovery-card::before {

  content: "";

  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.02),
      transparent 28%
    );

  pointer-events: none;

  opacity: 0.8;
}

.body-discovery-card:hover {

  transform: translateY(-2px);

  border-color:
    color-mix(
      in srgb,
      var(--accent) 24%,
      var(--border)
    );

  box-shadow:
    var(--glow-mid);
}

/* ==========================================================
   THUMB
========================================================== */

.body-thumb {
  position: relative;
}

.body-thumb img {

  width: 100%;
  height: 235px;

  display: block;

  object-fit: cover;

  filter:
    contrast(1.03)
    saturate(1.02)
    brightness(0.96);

  transition:
    transform var(--motion-mid),
    filter var(--motion-mid);
}

.body-discovery-card:hover .body-thumb img {

  transform: scale(1.02);

  filter:
    contrast(1.05)
    saturate(1.04)
    brightness(0.98);
}

/* ==========================================================
   VIEWER BADGE
========================================================== */

.body-viewers {

  position: absolute;

  top: 10px;
  right: 10px;

  display: inline-flex;
  align-items: center;

  padding: 5px 10px;

  border-radius: 999px;

  background:
    var(--glass-bg);

  border:
    1px solid var(--border);

  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);

  font-size: 0.74rem;

  font-weight: 700;

  letter-spacing: 0.01em;

  color: var(--text);

  box-shadow:
    var(--glow-soft);
}

/* ==========================================================
   META
========================================================== */

.body-card-meta {
  padding: 14px;
}

.body-card-meta strong {

  display: block;

  margin-bottom: 8px;

  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;

  font-size: 0.88rem;

  font-weight: 700;

  letter-spacing: -0.01em;

  color: var(--text);
}

/* ==========================================================
   ARCHETYPE LABEL
========================================================== */

.body-card-meta .archetype-label {

  display: inline-flex;
  align-items: center;

  width: fit-content;

  padding: 5px 9px;

  border-radius: 999px;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);

  font-size: 0.72rem;

  font-weight: 700;

  color: var(--text);
}

/* ==========================================================
   ARCHETYPE COLORS
========================================================== */

.archetype-traffic .archetype-label {
  color: #ff8a8a;
}

.archetype-spike .archetype-label {
  color: #ffc184;
}

.archetype-hd .archetype-label {
  color: #8ce8b1;
}

.archetype-crowd .archetype-label {
  color: #96e4ff;
}

.archetype-trend .archetype-label {
  color: #ceb8ff;
}

.archetype-active .archetype-label {
  color: #d7d7d7;
}

/* ==========================================================
   BODY FEEL
========================================================== */

.body-pulse .pulse-shell {

  border-color:
    color-mix(
      in srgb,
      var(--border) 70%,
      transparent
    );
}

.body-pulse .pulse-insight {

  background:
    color-mix(
      in srgb,
      var(--grad-soft) 84%,
      transparent
    );
}

/* ==========================================================
   RESPONSIVE
========================================================== */

@media (max-width: 1100px) {

  .body-discovery-grid {

    grid-template-columns:
      repeat(auto-fill, minmax(150px, 1fr));
  }

  .body-thumb img {
    height: 215px;
  }
}

@media (max-width: 820px) {

  .body-discovery-grid {

    grid-template-columns:
      repeat(3, minmax(0, 1fr));

    gap: 14px;
  }

  .body-thumb img {
    height: 180px;
  }

  .body-card-meta {
    padding: 12px;
  }

  .body-card-meta strong {
    font-size: 0.82rem;
  }

  .body-card-meta .archetype-label {

    font-size: 0.68rem;

    padding: 4px 8px;
  }
}

@media (max-width: 560px) {

  .body-discovery-grid {

    grid-template-columns:
      repeat(2, minmax(0, 1fr));
  }

  .body-thumb img {
    height: 210px;
  }

  .body-viewers {

    font-size: 0.68rem;

    padding: 4px 8px;
  }
}
/* ==========================================================
   FETISH.PHP — VERSION 3.4
   Niche Exploration / Overlap Ecosystem Styling
========================================================== */

.fetish-pulse {
  margin: 22px 0 32px;
}

/* ==========================================================
   EXPLORE SECTION
========================================================== */

.fetish-explore-section {
  margin-top: 22px;
}

/* ==========================================================
   EXPLORE GRID
========================================================== */

.fetish-explore-grid {

  display: grid;

  grid-template-columns:
    repeat(auto-fit, minmax(220px, 1fr));

  gap: 22px;
}

/* ==========================================================
   EXPLORE CARD
========================================================== */

.fetish-explore-card {

  position: relative;

  display: flex;
  flex-direction: column;

  overflow: hidden;

  border-radius: 24px;

  text-decoration: none;

  color: inherit;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);

  box-shadow:
    var(--glow-soft);

  transition:
    transform var(--motion-mid),
    border-color var(--motion-fast),
    box-shadow var(--motion-mid);
}

/* subtle atmosphere */
.fetish-explore-card::before {

  content: "";

  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.02),
      transparent 28%
    );

  pointer-events: none;

  opacity: 0.8;
}

.fetish-explore-card:hover {

  transform: translateY(-3px);

  border-color:
    color-mix(
      in srgb,
      var(--accent) 24%,
      var(--border)
    );

  box-shadow:
    var(--glow-mid);
}

/* ==========================================================
   IMAGE
========================================================== */

.fetish-explore-card img {

  width: 100%;
  height: 300px;

  display: block;

  object-fit: cover;

  filter:
    contrast(1.03)
    saturate(1.02)
    brightness(0.96);

  transition:
    transform var(--motion-slow),
    filter var(--motion-slow);
}

.fetish-explore-card:hover img {

  transform: scale(1.02);

  filter:
    contrast(1.05)
    saturate(1.04)
    brightness(0.99);
}

/* ==========================================================
   BODY
========================================================== */

.fetish-card-body {
  padding: 16px 16px 18px;
}

.fetish-card-body strong {

  display: block;

  margin-bottom: 10px;

  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;

  font-size: 0.95rem;

  font-weight: 700;

  letter-spacing: -0.02em;

  color: var(--text);
}

/* ==========================================================
   META
========================================================== */

.fetish-meta {

  display: flex;
  flex-direction: column;

  gap: 9px;
}

/* ==========================================================
   ARCHETYPE LABEL
========================================================== */

.fetish-meta .archetype-label {

  display: inline-flex;
  align-items: center;

  width: fit-content;

  padding: 6px 10px;

  border-radius: 999px;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);

  font-size: 0.74rem;

  font-weight: 700;

  color: var(--text);
}

.theme-count {

  font-size: 0.78rem;

  font-weight: 600;

  line-height: 1.5;

  color: var(--muted);
}

/* ==========================================================
   ARCHETYPE COLORS
========================================================== */

.archetype-overlap .archetype-label {
  color: #ceb8ff;
}

.archetype-deep .archetype-label {
  color: #96e4ff;
}

.archetype-niche .archetype-label {
  color: #ffb3de;
}

.archetype-explore .archetype-label {
  color: #ffd88c;
}

.archetype-returning .archetype-label {
  color: #8ce8b1;
}

.archetype-active .archetype-label {
  color: #d7d7d7;
}

/* ==========================================================
   PATHWAY MAP
========================================================== */

.fetish-pathway-map {
  margin-top: 34px;
}

.fetish-pathway-grid {

  display: grid;

  grid-template-columns:
    repeat(auto-fit, minmax(170px, 1fr));

  gap: 16px;
}

/* ==========================================================
   PATHWAY CHIP
========================================================== */

.fetish-pathway-chip {

  display: flex;
  flex-direction: column;

  gap: 6px;

  padding: 18px;

  border-radius: 20px;

  text-decoration: none;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  transition:
    transform var(--motion-fast),
    border-color var(--motion-fast),
    background var(--motion-fast),
    box-shadow var(--motion-fast);
}

.fetish-pathway-chip:hover {

  transform: translateY(-2px);

  border-color:
    color-mix(
      in srgb,
      var(--accent) 24%,
      var(--border)
    );

  background:
    var(--grad-mix);

  box-shadow:
    var(--glow-mid);
}

.fetish-pathway-chip span {

  font-size: 0.9rem;

  font-weight: 700;

  letter-spacing: -0.01em;

  color: var(--text);
}

.fetish-pathway-chip small {

  font-size: 0.72rem;

  font-weight: 600;

  line-height: 1.5;

  color: var(--muted);
}

/* ==========================================================
   FETISH VISUAL FEEL
========================================================== */

.fetish-pulse .pulse-shell {

  border-color:
    color-mix(
      in srgb,
      var(--border) 70%,
      transparent
    );
}

.fetish-pulse .pulse-insight {

  background:
    color-mix(
      in srgb,
      var(--grad-soft) 82%,
      transparent
    );
}
/* ==========================================================
   RESPONSIVE
========================================================== */

@media (max-width: 1100px) {

  .fetish-explore-grid {

    grid-template-columns:
      repeat(auto-fit, minmax(200px, 1fr));
  }

  .fetish-explore-card img {
    height: 270px;
  }
}

@media (max-width: 820px) {

  .fetish-explore-grid {

    grid-template-columns:
      repeat(2, minmax(0, 1fr));

    gap: 16px;
  }

  .fetish-explore-card img {
    height: 240px;
  }

  .fetish-card-body {
    padding: 14px;
  }

  .fetish-pathway-grid {

    grid-template-columns:
      repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {

  .fetish-explore-grid {
    grid-template-columns: 1fr;
  }

  .fetish-explore-card img {
    height: 320px;
  }

  .fetish-pathway-grid {
    grid-template-columns: 1fr;
  }
}
/* ==========================================================
   REGIONAL.PHP — VERSION 3.4
   Audience Waves / Regional Timing Styling
========================================================== */

.regional-pulse {
  margin: 22px 0 32px;
}

/* ==========================================================
   REGIONAL SECTION
========================================================== */

.regional-wave-section {
  margin-top: 24px;
}

/* ==========================================================
   REGIONAL GRID
========================================================== */

.regional-wave-grid {

  display: grid;

  grid-template-columns:
    repeat(auto-fit, minmax(230px, 1fr));

  gap: 22px;
}

/* ==========================================================
   REGIONAL CARD
========================================================== */

.regional-wave-card {

  position: relative;

  display: flex;
  flex-direction: column;

  overflow: hidden;

  border-radius: 24px;

  text-decoration: none;

  color: inherit;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);

  box-shadow:
    var(--glow-soft);

  transition:
    transform var(--motion-mid),
    border-color var(--motion-fast),
    box-shadow var(--motion-mid);
}

/* subtle atmosphere */
.regional-wave-card::before {

  content: "";

  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.02),
      transparent 28%
    );

  pointer-events: none;

  opacity: 0.8;
}

.regional-wave-card:hover {

  transform: translateY(-3px);

  border-color:
    color-mix(
      in srgb,
      var(--accent) 24%,
      var(--border)
    );

  box-shadow:
    var(--glow-mid);
}

/* ==========================================================
   IMAGE
========================================================== */

.regional-wave-card img {

  width: 100%;
  height: 290px;

  display: block;

  object-fit: cover;

  filter:
    contrast(1.03)
    saturate(1.02)
    brightness(0.96);

  transition:
    transform var(--motion-slow),
    filter var(--motion-slow);
}

.regional-wave-card:hover img {

  transform: scale(1.02);

  filter:
    contrast(1.05)
    saturate(1.04)
    brightness(0.99);
}

/* ==========================================================
   BODY
========================================================== */

.regional-card-body {
  padding: 16px 16px 18px;
}

.regional-card-body strong {

  display: block;

  margin-bottom: 10px;

  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;

  font-size: 0.95rem;

  font-weight: 700;

  letter-spacing: -0.02em;

  color: var(--text);
}

/* ==========================================================
   META
========================================================== */

.regional-meta {

  display: flex;
  flex-direction: column;

  gap: 9px;
}

/* ==========================================================
   ARCHETYPE LABEL
========================================================== */

.regional-meta .archetype-label {

  display: inline-flex;
  align-items: center;

  width: fit-content;

  padding: 6px 10px;

  border-radius: 999px;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);

  font-size: 0.74rem;

  font-weight: 700;

  color: var(--text);
}

.regional-session {

  font-size: 0.78rem;

  font-weight: 600;

  line-height: 1.5;

  color: var(--muted);
}

/* ==========================================================
   ARCHETYPE COLORS
========================================================== */

.archetype-regional-fav .archetype-label {
  color: #96e4ff;
}

.archetype-time .archetype-label {
  color: #ffd88c;
}

.archetype-wave .archetype-label {
  color: #ffb3de;
}

.archetype-late .archetype-label {
  color: #ceb8ff;
}

.archetype-cross .archetype-label {
  color: #8ce8b1;
}

.archetype-active .archetype-label {
  color: #d7d7d7;
}

/* ==========================================================
   REGIONAL FEEL
========================================================== */

.regional-pulse .pulse-shell {

  border-color:
    color-mix(
      in srgb,
      var(--border) 70%,
      transparent
    );
}

.regional-pulse .pulse-insight {

  background:
    color-mix(
      in srgb,
      var(--grad-soft) 84%,
      transparent
    );
}

/* ==========================================================
   REGIONAL PATHWAYS
========================================================== */

.regional-pathways {
  margin-top: 34px;
}

/* ==========================================================
   RESPONSIVE
========================================================== */

@media (max-width: 1100px) {

  .regional-wave-grid {

    grid-template-columns:
      repeat(auto-fit, minmax(210px, 1fr));
  }

  .regional-wave-card img {
    height: 260px;
  }
}

@media (max-width: 820px) {

  .regional-wave-grid {

    grid-template-columns:
      repeat(2, minmax(0, 1fr));

    gap: 16px;
  }

  .regional-wave-card img {
    height: 235px;
  }

  .regional-card-body {
    padding: 14px;
  }
}

@media (max-width: 560px) {

  .regional-wave-grid {
    grid-template-columns: 1fr;
  }

  .regional-wave-card img {
    height: 320px;
  }
}
/* ==========================================================
   PERSONALITY.PHP — VERSION 3.4
   Emotional Attraction / Performer Vibe Ecosystem
========================================================== */

.personality-pulse {
  margin: 22px 0 32px;
}

/* ==========================================================
   PERSONALITY SECTION
========================================================== */

.personality-feature-section {
  margin-top: 24px;
}

/* ==========================================================
   PERSONALITY GRID
========================================================== */

.personality-grid {

  display: grid;

  grid-template-columns:
    repeat(auto-fit, minmax(240px, 1fr));

  gap: 22px;
}

/* ==========================================================
   PERSONALITY CARD
========================================================== */

.personality-card {

  position: relative;

  display: flex;
  flex-direction: column;

  overflow: hidden;

  border-radius: 26px;

  text-decoration: none;

  color: inherit;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);

  box-shadow:
    var(--glow-soft);

  transition:
    transform var(--motion-mid),
    border-color var(--motion-fast),
    box-shadow var(--motion-mid);
}

/* subtle atmosphere */
.personality-card::before {

  content: "";

  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.02),
      transparent 28%
    );

  pointer-events: none;

  opacity: 0.8;
}

.personality-card:hover {

  transform: translateY(-3px);

  border-color:
    color-mix(
      in srgb,
      var(--accent) 24%,
      var(--border)
    );

  box-shadow:
    var(--glow-mid);
}

/* ==========================================================
   IMAGE
========================================================== */

.personality-card img {

  width: 100%;
  height: 320px;

  display: block;

  object-fit: cover;

  filter:
    contrast(1.03)
    saturate(1.02)
    brightness(0.97);

  transition:
    transform var(--motion-slow),
    filter var(--motion-slow);
}

.personality-card:hover img {

  transform: scale(1.02);

  filter:
    contrast(1.05)
    saturate(1.04)
    brightness(0.99);
}

/* ==========================================================
   BODY
========================================================== */

.personality-card-body {
  padding: 18px;
}

.personality-card-body strong {

  display: block;

  margin-bottom: 10px;

  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;

  font-size: 0.96rem;

  font-weight: 700;

  letter-spacing: -0.02em;

  color: var(--text);
}

/* ==========================================================
   META
========================================================== */

.personality-meta {

  display: flex;
  flex-direction: column;

  gap: 9px;
}

/* ==========================================================
   ARCHETYPE LABEL
========================================================== */

.personality-meta .archetype-label {

  display: inline-flex;
  align-items: center;

  width: fit-content;

  padding: 6px 10px;

  border-radius: 999px;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);

  font-size: 0.74rem;

  font-weight: 700;

  color: var(--text);
}

.personality-hours {

  font-size: 0.78rem;

  font-weight: 600;

  line-height: 1.5;

  color: var(--muted);
}

/* ==========================================================
   PERSONALITY ARCHETYPE COLORS
========================================================== */

.archetype-soft .archetype-label {
  color: #ffc2ec;
}

.archetype-style .archetype-label {
  color: #d7c0ff;
}

.archetype-returning .archetype-label {
  color: #96e4ff;
}

.archetype-calm .archetype-label {
  color: #8ce8b1;
}

.archetype-mood .archetype-label {
  color: #ffd88c;
}

.archetype-active .archetype-label {
  color: #d7d7d7;
}

/* ==========================================================
   PERSONALITY VISUAL FEEL
========================================================== */

.personality-pulse .pulse-shell {

  border-color:
    color-mix(
      in srgb,
      var(--border) 70%,
      transparent
    );
}

.personality-pulse .pulse-insight {

  background:
    color-mix(
      in srgb,
      var(--grad-soft) 84%,
      transparent
    );
}
/* ==========================================================
   PERSONALITY PATHWAYS
========================================================== */

.personality-pathways {
  margin-top: 34px;
}

/* ==========================================================
   SOFTER VISUAL TONE
========================================================== */

.personality-card::after {

  content: '';

  position: absolute;
  inset: 0;

  pointer-events: none;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0),
      rgba(255,255,255,0.014)
    );

  opacity: 0.9;
}

/* ==========================================================
   RESPONSIVE
========================================================== */

@media (max-width: 1100px) {

  .personality-grid {

    grid-template-columns:
      repeat(auto-fit, minmax(220px, 1fr));
  }

  .personality-card img {
    height: 290px;
  }
}

@media (max-width: 820px) {

  .personality-grid {

    grid-template-columns:
      repeat(2, minmax(0, 1fr));

    gap: 16px;
  }

  .personality-card img {
    height: 250px;
  }

  .personality-card-body {
    padding: 16px;
  }
}

@media (max-width: 560px) {

  .personality-grid {
    grid-template-columns: 1fr;
  }

  .personality-card img {
    height: 340px;
  }
}
/* ==========================================================
   MALE.PHP — VERSION 3.4
   Male Audience / Performer Energy Ecosystem
========================================================== */

.male-pulse {
  margin: 22px 0 32px;
}

/* ==========================================================
   MALE FEATURE SECTION
========================================================== */

.male-feature-section {
  margin-top: 24px;
}

/* ==========================================================
   GRID
========================================================== */

.male-pulse .personality-grid {

  display: grid;

  grid-template-columns:
    repeat(auto-fit, minmax(240px, 1fr));

  gap: 22px;
}

/* ==========================================================
   CARD
========================================================== */

.male-pulse .personality-card {

  position: relative;

  display: flex;
  flex-direction: column;

  overflow: hidden;

  border-radius: 24px;

  text-decoration: none;

  color: inherit;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);

  box-shadow:
    var(--glow-soft);

  transition:
    transform var(--motion-mid),
    border-color var(--motion-fast),
    box-shadow var(--motion-mid);
}

/* subtle atmosphere */
.male-pulse .personality-card::before {

  content: "";

  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.02),
      transparent 28%
    );

  pointer-events: none;

  opacity: 0.8;
}

.male-pulse .personality-card:hover {

  transform: translateY(-3px);

  border-color:
    color-mix(
      in srgb,
      var(--accent) 24%,
      var(--border)
    );

  box-shadow:
    var(--glow-mid);
}

/* ==========================================================
   IMAGE
========================================================== */

.male-pulse .personality-card img {

  width: 100%;
  height: 320px;

  display: block;

  object-fit: cover;

  filter:
    contrast(1.04)
    saturate(1.03)
    brightness(0.96);

  transition:
    transform var(--motion-slow),
    filter var(--motion-slow);
}

.male-pulse .personality-card:hover img {

  transform: scale(1.02);

  filter:
    contrast(1.06)
    saturate(1.05)
    brightness(0.99);
}

/* ==========================================================
   BODY
========================================================== */

.male-pulse .personality-card-body {
  padding: 18px;
}

.male-pulse .personality-card-body strong {

  display: block;

  margin-bottom: 10px;

  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;

  font-size: 0.96rem;

  font-weight: 700;

  letter-spacing: -0.02em;

  color: var(--text);
}

/* ==========================================================
   META
========================================================== */

.male-pulse .personality-meta {

  display: flex;
  flex-direction: column;

  gap: 9px;
}

/* ==========================================================
   ARCHETYPE LABEL
========================================================== */

.male-pulse .archetype-label {

  display: inline-flex;
  align-items: center;

  width: fit-content;

  padding: 6px 10px;

  border-radius: 999px;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);

  font-size: 0.74rem;

  font-weight: 700;

  color: var(--text);
}

.male-pulse .personality-hours {

  font-size: 0.78rem;

  font-weight: 600;

  line-height: 1.5;

  color: var(--muted);
}
/* ==========================================================
   ARCHETYPE COLORS
========================================================== */

.male-pulse .archetype-crowd .archetype-label {
  color: #ff8a8a;
}

.male-pulse .archetype-strong .archetype-label {
  color: #8fd7ff;
}

.male-pulse .archetype-fast .archetype-label {
  color: #ffd88c;
}

.male-pulse .archetype-long .archetype-label {
  color: #8ce8b1;
}

.male-pulse .archetype-focus .archetype-label {
  color: #d8c2ff;
}

.male-pulse .archetype-active .archetype-label {
  color: #d7d7d7;
}

/* ==========================================================
   VISUAL STYLE
========================================================== */

.male-pulse .pulse-shell {

  border-color:
    color-mix(
      in srgb,
      var(--border) 70%,
      transparent
    );
}

.male-pulse .pulse-insight {

  background:
    color-mix(
      in srgb,
      var(--grad-soft) 84%,
      transparent
    );
}

/* ==========================================================
   CARD OVERLAY
========================================================== */

.male-pulse .personality-card::after {

  content: '';

  position: absolute;
  inset: 0;

  pointer-events: none;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0),
      rgba(255,255,255,0.016)
    );

  opacity: 0.9;
}

/* ==========================================================
   PATHWAYS
========================================================== */

.male-pathways {
  margin-top: 34px;
}

/* ==========================================================
   RESPONSIVE
========================================================== */

@media (max-width: 1100px) {

  .male-pulse .personality-grid {

    grid-template-columns:
      repeat(auto-fit, minmax(220px, 1fr));
  }

  .male-pulse .personality-card img {
    height: 290px;
  }
}

@media (max-width: 820px) {

  .male-pulse .personality-grid {

    grid-template-columns:
      repeat(2, minmax(0, 1fr));

    gap: 16px;
  }

  .male-pulse .personality-card img {
    height: 250px;
  }

  .male-pulse .personality-card-body {
    padding: 16px;
  }
}

@media (max-width: 560px) {

  .male-pulse .personality-grid {
    grid-template-columns: 1fr;
  }

  .male-pulse .personality-card img {
    height: 340px;
  }
}
/* ==========================================================
   FRESH.PHP — VERSION 3.4
   Emerging Discovery / Early Momentum Ecosystem
========================================================== */

.fresh-pulse {
  margin: 22px 0 32px;
}

/* ==========================================================
   FEATURE SECTION
========================================================== */

.fresh-feature-section {
  margin-top: 24px;
}

/* ==========================================================
   GRID
========================================================== */

.fresh-pulse .regional-wave-grid {

  display: grid;

  grid-template-columns:
    repeat(auto-fit, minmax(220px, 1fr));

  gap: 20px;
}

/* ==========================================================
   CARD
========================================================== */

.fresh-pulse .regional-wave-card {

  position: relative;

  display: flex;
  flex-direction: column;

  overflow: hidden;

  border-radius: 24px;

  text-decoration: none;

  color: inherit;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);

  box-shadow:
    var(--glow-soft);

  transition:
    transform var(--motion-mid),
    border-color var(--motion-fast),
    box-shadow var(--motion-mid);
}

/* subtle atmosphere */
.fresh-pulse .regional-wave-card::before {

  content: "";

  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.02),
      transparent 28%
    );

  pointer-events: none;

  opacity: 0.8;
}

.fresh-pulse .regional-wave-card:hover {

  transform: translateY(-3px);

  border-color:
    color-mix(
      in srgb,
      var(--accent) 24%,
      var(--border)
    );

  box-shadow:
    var(--glow-mid);
}
/* ==========================================================
   IMAGE
========================================================== */

.fresh-pulse .regional-wave-card img {

  width: 100%;
  height: 300px;

  display: block;

  object-fit: cover;

  filter:
    contrast(1.04)
    saturate(1.03)
    brightness(0.97);

  transition:
    transform var(--motion-slow),
    filter var(--motion-slow);
}

.fresh-pulse .regional-wave-card:hover img {

  transform: scale(1.02);

  filter:
    contrast(1.06)
    saturate(1.05)
    brightness(1);
}

/* ==========================================================
   BODY
========================================================== */

.fresh-pulse .regional-card-body {
  padding: 18px;
}

.fresh-pulse .regional-card-body strong {

  display: block;

  margin-bottom: 10px;

  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;

  font-size: 0.95rem;

  font-weight: 700;

  letter-spacing: -0.02em;

  color: var(--text);
}

/* ==========================================================
   META
========================================================== */

.fresh-pulse .regional-meta {

  display: flex;
  flex-direction: column;

  gap: 9px;
}

/* ==========================================================
   ARCHETYPE LABEL
========================================================== */

.fresh-pulse .archetype-label {

  display: inline-flex;
  align-items: center;

  width: fit-content;

  padding: 6px 10px;

  border-radius: 999px;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);

  font-size: 0.74rem;

  font-weight: 700;

  color: var(--text);
}

.fresh-pulse .regional-session {

  font-size: 0.78rem;

  font-weight: 600;

  line-height: 1.5;

  color: var(--muted);
}

/* ==========================================================
   ARCHETYPE COLORS
========================================================== */

.fresh-pulse .archetype-start .archetype-label {
  color: #ffd88c;
}

.fresh-pulse .archetype-velocity .archetype-label {
  color: #ffb184;
}

.fresh-pulse .archetype-discovery .archetype-label {
  color: #96e4ff;
}

.fresh-pulse .archetype-momentum .archetype-label {
  color: #ff8a8a;
}

.fresh-pulse .archetype-activity .archetype-label {
  color: #8ce8b1;
}

.fresh-pulse .archetype-fallback .archetype-label {
  color: #d7d7d7;
}

/* ==========================================================
   VISUAL STYLE
========================================================== */

.fresh-pulse .pulse-shell {

  border-color:
    color-mix(
      in srgb,
      var(--border) 70%,
      transparent
    );
}

.fresh-pulse .pulse-insight {

  background:
    color-mix(
      in srgb,
      var(--grad-soft) 84%,
      transparent
    );
}
/* ==========================================================
   CARD OVERLAY
========================================================== */

.fresh-pulse .regional-wave-card::after {

  content: '';

  position: absolute;
  inset: 0;

  pointer-events: none;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0),
      rgba(255,255,255,0.016)
    );

  opacity: 0.9;
}

/* ==========================================================
   RESPONSIVE
========================================================== */

@media (max-width: 1100px) {

  .fresh-pulse .regional-wave-grid {

    grid-template-columns:
      repeat(auto-fit, minmax(210px, 1fr));
  }

  .fresh-pulse .regional-wave-card img {
    height: 270px;
  }
}

@media (max-width: 820px) {

  .fresh-pulse .regional-wave-grid {

    grid-template-columns:
      repeat(2, minmax(0, 1fr));

    gap: 16px;
  }

  .fresh-pulse .regional-wave-card img {
    height: 240px;
  }

  .fresh-pulse .regional-card-body {
    padding: 16px;
  }
}

@media (max-width: 560px) {

  .fresh-pulse .regional-wave-grid {
    grid-template-columns: 1fr;
  }

  .fresh-pulse .regional-wave-card img {
    height: 340px;
  }
}
/* ==========================================================
   ECOSYSTEM ACTIONS
========================================================== */

.ecosystem-actions {

  display: flex;
  align-items: flex-end;
  justify-content: flex-end;

  gap: 14px;

  flex-wrap: wrap;

  text-align: right;
}

/* ==========================================================
   SIGNALS
========================================================== */

.ecosystem-primary-signal,
.ecosystem-secondary-signal {

  display: inline-flex;
  align-items: center;

  line-height: 1.3;

  font-size: 0.86rem;

  font-weight: 700;

  color: var(--text);
}

.ecosystem-primary-signal::before {

  content: '';

  width: 7px;
  height: 7px;

  margin-right: 8px;

  border-radius: 999px;

  background: var(--accent);

  box-shadow:
    var(--glow-soft);

  flex-shrink: 0;
}

.ecosystem-secondary-signal {

  color: var(--muted);

  font-weight: 600;
}
/* ==========================================================
   RESPONSIVE
========================================================== */

@media (max-width:820px){

  .ecosystem-actions {

    justify-content: flex-start;

    text-align: left;

    gap: 6px;
  }

  .ecosystem-primary-signal,
  .ecosystem-secondary-signal {

    width: 100%;

    font-size: 0.82rem;
  }
}

/* ==========================================================
   PLATFORM PULSE
========================================================== */

.platform-pulse-section {
  position: relative;
}

/* ==========================================================
   HERO
========================================================== */

.pulse-hero {

  display: grid;

  grid-template-columns:
    minmax(0, 1.15fr)
    minmax(320px, 0.85fr);

  gap: 18px;

  margin-top: 18px;

  align-items: stretch;
}

/* ==========================================================
   SURFACE SYSTEM
========================================================== */

.pulse-main,
.pulse-card,
.pulse-stat {

  position: relative;

  overflow: hidden;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  border-radius: 24px;

  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);

  box-shadow:
    var(--glow-soft);
}

/* subtle atmosphere */
.pulse-main::before,
.pulse-card::before,
.pulse-stat::before {

  content: '';

  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.02),
      transparent 28%
    );

  pointer-events: none;

  opacity: 0.8;
}

/* ==========================================================
   MAIN PANEL
========================================================== */

.pulse-main {

  padding: 30px;
}

/* atmosphere orb */
.pulse-main::after {

  content: '';

  position: absolute;

  top: -120px;
  right: -120px;

  width: 280px;
  height: 280px;

  border-radius: 50%;

  background:
    var(--glow-orb);

  pointer-events: none;
}

/* ==========================================================
   TEMPERATURE
========================================================== */

.pulse-temperature {

  margin-bottom: 14px;

  font-size: 0.78rem;

  font-weight: 800;

  letter-spacing: 0.14em;

  text-transform: uppercase;

  color:
    color-mix(
      in srgb,
      var(--accent) 72%,
      var(--text)
    );
}

/* ==========================================================
   HEADINGS
========================================================== */

.pulse-main h3 {

  margin-bottom: 14px;

  font-size:
    clamp(2rem, 3vw, 2.5rem);

  line-height: 1.15;

  letter-spacing: -0.04em;

  color: var(--text);
}

.pulse-main p {

  max-width: 780px;

  color: var(--muted);

  font-size: 0.95rem;

  line-height: 1.8;
}

/* ==========================================================
   CHIP
========================================================== */

.pulse-chip {

  display: inline-flex;
  align-items: center;

  gap: 8px;

  margin-top: 22px;

  padding: 10px 16px;

  border-radius: 999px;

  text-decoration: none;

  background:
    var(--grad-soft);

  border:
    1px solid var(--border);

  color: var(--text);

  font-weight: 700;

  transition:
    transform var(--motion-fast),
    background var(--motion-fast),
    border-color var(--motion-fast),
    box-shadow var(--motion-fast);
}

.pulse-chip:hover {

  transform: translateY(-2px);

  background:
    var(--grad-mix);

  border-color:
    color-mix(
      in srgb,
      var(--accent) 24%,
      var(--border)
    );

  box-shadow:
    var(--glow-mid);
}

/* ==========================================================
   STATS
========================================================== */

.pulse-stats {

  display: grid;

  grid-template-columns: 1fr 1fr;

  gap: 16px;
}

.pulse-stat {
  padding: 24px;
}

.pulse-stat span {

  display: block;

  margin-bottom: 10px;

  font-size: 0.72rem;

  font-weight: 700;

  letter-spacing: 0.12em;

  text-transform: uppercase;

  color: var(--muted);
}

.pulse-stat strong {

  font-size:
    clamp(2rem, 4vw, 2.5rem);

  line-height: 1;

  letter-spacing: -0.04em;

  color: var(--text);
}

/* ==========================================================
   GRID
========================================================== */

.pulse-grid {

  display: grid;

  grid-template-columns:
    repeat(3,1fr);

  gap: 22px;

  margin-top: 24px;
}

.pulse-card {
  padding: 26px;
}

/* ==========================================================
   CARD EYEBROW
========================================================== */

.pulse-card .eyebrow {

  margin-bottom: 10px;

  font-size: 0.72rem;

  font-weight: 800;

  letter-spacing: 0.14em;

  text-transform: uppercase;

  color:
    color-mix(
      in srgb,
      var(--accent) 70%,
      var(--text)
    );
}

.pulse-card h3 {

  margin-bottom: 18px;

  font-size: 1.45rem;

  line-height: 1.3;

  letter-spacing: -0.03em;

  color: var(--text);
}

/* ==========================================================
   ROWS
========================================================== */

.pulse-row {

  display: flex;
  align-items: center;
  justify-content: space-between;

  gap: 12px;

  padding: 14px 0;

  border-bottom:
    1px solid var(--border);

  text-decoration: none;

  transition:
    transform var(--motion-fast),
    color var(--motion-fast);
}

.pulse-row:last-child {
  border-bottom: none;
}

.pulse-row:hover {

  transform: translateX(3px);
}

.pulse-row span {

  color: var(--muted);
}

.pulse-row strong {

  font-size: 0.94rem;

  color: var(--text);
}

/* ==========================================================
   COPY
========================================================== */

.pulse-copy {

  margin-bottom: 18px;

  color: var(--muted);

  line-height: 1.8;
}

/* ==========================================================
   SIGNAL STACK
========================================================== */

.signal-stack {

  display: flex;
  flex-direction: column;

  gap: 14px;

  margin-bottom: 18px;
}

.signal-item {

  display: flex;
  align-items: center;
  justify-content: space-between;

  gap: 10px;

  padding-bottom: 12px;

  border-bottom:
    1px solid var(--border);
}

.signal-item span {
  color: var(--muted);
}

.signal-item strong {
  color: var(--text);
}

/* ==========================================================
   RESPONSIVE
========================================================== */

@media (max-width: 1100px) {

  .pulse-hero,
  .pulse-grid {

    grid-template-columns: 1fr;
  }
}

@media (max-width: 700px) {

  .pulse-main h3 {
    font-size: 2rem;
  }

  .pulse-stats {
    grid-template-columns: 1fr;
  }

  .pulse-card h3 {
    font-size: 1.3rem;
  }
}
/* ==================================================
   ENHANCED TAG CARDS
================================================== */

.tag-card-enhanced {

  position: relative;

  overflow: hidden;

  text-decoration: none;

  transition:
    transform 0.18s ease,
    border-color 0.18s ease,
    background 0.18s ease,
    box-shadow 0.18s ease;
}

.tag-card-enhanced:hover {

  transform: translateY(-2px);

  border-color:
    color-mix(
      in srgb,
      var(--highlight_color) 34%,
      rgba(255,255,255,0.08)
    );

  background:
    color-mix(
      in srgb,
      var(--card) 96%,
      transparent
    );

  box-shadow:
    0 12px 28px rgba(0,0,0,0.22);
}

.tag-card-inner {

  position: relative;

  z-index: 2;

  min-height: 100%;

  display: flex;
  flex-direction: column;

  gap: 12px;
}

/* ==================================================
   TAG CARD TOP
================================================== */

.tag-top {

  display: flex;

  align-items: flex-start;
  justify-content: space-between;

  gap: 12px;
}

.tag-top h3 {

  margin: 0;

  font-size: 1.05rem;

  line-height: 1.05;

  color: var(--text);
}

/* ==================================================
   TAG BADGE
================================================== */

.tag-badge {

  display: inline-flex;
  align-items: center;

  max-width: 110px;

  padding: 4px 8px;

  border-radius: 999px;

  background:
    color-mix(
      in srgb,
      var(--highlight_color) 18%,
      transparent
    );

  border:
    1px solid
    color-mix(
      in srgb,
      var(--highlight_color) 24%,
      transparent
    );

  color: var(--highlight_color);

  font-size: 0.66rem;
  font-weight: 700;

  line-height: 1;

  white-space: nowrap;

  overflow: hidden;

  text-overflow: ellipsis;
}

/* ==================================================
   TAG COUNT
================================================== */

.tag-card-enhanced .count {

  display: flex;

  align-items: baseline;
  flex-wrap: wrap;

  gap: 7px;

  margin: 0;

  font-size:
    clamp(1.8rem, 2.4vw, 2.45rem);

  line-height: 0.95;

  font-weight: 800;

  letter-spacing: -0.045em;

  color: var(--text);
}

.count-label {

  display: inline-block;

  max-width: 100%;

  font-size: 0.78rem;
  font-weight: 700;

  line-height: 1;

  letter-spacing: -0.01em;

  color:
    color-mix(
      in srgb,
      var(--text) 72%,
      transparent
    );

  white-space: nowrap;
}

/* ==================================================
   TAG META TEXT
================================================== */

.tag-card-enhanced .tag-meta {

  margin: 0;

  display: block;

  font-size: 0.9rem;

  line-height: 1.55;

  color: var(--muted);
}

/* ==================================================
   TAG CARD BACKGROUND GLOW
================================================== */

.tag-card-enhanced::before {

  content: "";

  position: absolute;

  inset: auto -48px -58px auto;

  width: 150px;
  height: 150px;

  border-radius: 50%;

  background:
    radial-gradient(
      circle,
      color-mix(
        in srgb,
        var(--highlight_color) 20%,
        transparent
      ),
      transparent 68%
    );

  opacity: 0.34;

  pointer-events: none;

  transition:
    opacity 0.18s ease,
    transform 0.18s ease;
}

.tag-card-enhanced:hover::before {

  opacity: 0.48;

  transform: scale(1.06);
}

/* ==================================================
   MOBILE TAG CARDS
================================================== */

@media (max-width: 768px) {

  .tag-card-inner {
    gap: 10px;
  }

  .tag-card-enhanced .count {
    font-size:
      clamp(1.55rem, 8vw, 2.05rem);
  }

  .count-label {
    font-size: 0.72rem;
  }

  .tag-card-enhanced .tag-meta {
    font-size: 0.86rem;
    line-height: 1.45;
  }

}

@media (max-width: 420px) {

  .tag-top {
    gap: 8px;
  }

  .tag-badge {
    max-width: 86px;

    padding: 4px 7px;

    font-size: 0.62rem;
  }

  .tag-card-enhanced .count {
    gap: 6px;
  }

}