/* ═══════════════════════════════════════════════════════════
   Claude Code Plugin Hub — Lobby Styles
   Design: Deep space launchpad · Two glowing portal cards
   Aesthetic: Brutally dark, precise glows, refined motion
═══════════════════════════════════════════════════════════ */

/* ─────────────────────────────────
   Design Tokens
───────────────────────────────── */
:root {
  /* Base */
  --bg-void:       #060810;
  --bg-surface:    #0a0e1a;
  --bg-card:       rgba(10, 14, 26, 0.75);
  --bg-card-hover: rgba(12, 17, 32, 0.92);
  --bg-border:     rgba(255, 255, 255, 0.06);

  /* Plugin 1 — Teal */
  --teal:          #00d9c0;
  --teal-mid:      #00b8a3;
  --teal-dim:      rgba(0, 217, 192, 0.10);
  --teal-glow-sm:  rgba(0, 217, 192, 0.18);
  --teal-glow-lg:  rgba(0, 217, 192, 0.08);
  --teal-border:   rgba(0, 217, 192, 0.22);
  --teal-border-h: rgba(0, 217, 192, 0.55);

  /* Plugin 2 — Voice (purple-to-blue gradient) */
  --voice-a:       #a855f7;
  --voice-b:       #3b82f6;
  --voice-mid:     #7c3aed;
  --voice-dim:     rgba(168, 85, 247, 0.10);
  --voice-glow-sm: rgba(168, 85, 247, 0.18);
  --voice-glow-lg: rgba(168, 85, 247, 0.08);
  --voice-border:  rgba(168, 85, 247, 0.22);
  --voice-border-h:rgba(168, 85, 247, 0.55);

  /* Text */
  --text-primary:   #eef2f8;
  --text-secondary: #7e96b0;
  --text-muted:     #394d61;

  /* Typography */
  --font-display: 'Plus Jakarta Sans', sans-serif;
  --font-body:    'Inter', sans-serif;
  --font-mono:    'JetBrains Mono', monospace;

  /* Spacing */
  --sp-2:  8px;
  --sp-3:  12px;
  --sp-4:  16px;
  --sp-5:  20px;
  --sp-6:  24px;
  --sp-8:  32px;
  --sp-10: 40px;
  --sp-12: 48px;
  --sp-16: 64px;
  --sp-20: 80px;

  /* Shape */
  --radius-sm: 6px;
  --radius-md: 14px;
  --radius-lg: 24px;
  --radius-xl: 32px;

  /* Motion */
  --ease-out:  cubic-bezier(0.16, 1, 0.3, 1);
  --ease-snap: cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ─────────────────────────────────
   Reset
───────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
}

body {
  background-color: var(--bg-void);
  color: var(--text-primary);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  word-break: keep-all;
  overflow-wrap: break-word;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

ul, ol { list-style: none; }
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }

/* ─────────────────────────────────
   Star Field Canvas
───────────────────────────────── */
.star-field {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

/* ─────────────────────────────────
   Hub Header
───────────────────────────────── */
.hub-header {
  position: relative;
  z-index: 1;
  text-align: center;
  padding: var(--sp-20) var(--sp-6) var(--sp-12);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-5);
}

/* Faint radial light above header */
.hub-header::before {
  content: '';
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: 700px; height: 340px;
  background: radial-gradient(
    ellipse at 50% 0%,
    rgba(0, 217, 192, 0.06) 0%,
    rgba(168, 85, 247, 0.04) 40%,
    transparent 70%
  );
  pointer-events: none;
}

.hub-header__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 5px 14px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: 100px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-muted);
  letter-spacing: .08em;
  animation: fadeSlideDown .6s var(--ease-out) both;
}

.hub-header__dot {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--teal);
  box-shadow: 0 0 6px var(--teal);
  animation: pulse 2.4s ease-in-out infinite;
}

@keyframes pulse {
  0%, 100% { box-shadow: 0 0 5px var(--teal); }
  50% { box-shadow: 0 0 12px var(--teal), 0 0 22px rgba(0,217,192,.35); }
}

.hub-header__title {
  font-family: var(--font-display);
  font-size: clamp(44px, 8vw, 88px);
  font-weight: 800;
  line-height: .95;
  letter-spacing: -.04em;
  display: flex;
  flex-direction: column;
  gap: .05em;
}

.hub-header__title-line {
  display: block;
  color: var(--text-primary);
  animation: fadeSlideDown .65s var(--ease-out) .08s both;
}

.hub-header__title-line--accent {
  background: linear-gradient(
    100deg,
    var(--teal) 0%,
    #4fffff 30%,
    var(--voice-a) 70%,
    var(--voice-b) 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation-delay: .14s;
}

.hub-header__sub {
  font-size: clamp(14px, 2vw, 17px);
  color: var(--text-secondary);
  line-height: 1.8;
  max-width: 520px;
  animation: fadeSlideDown .65s var(--ease-out) .22s both;
}

.hub-header__meta {
  display: flex;
  align-items: baseline;
  gap: var(--sp-2);
  animation: fadeSlideDown .65s var(--ease-out) .32s both;
}

.hub-header__count {
  font-family: var(--font-display);
  font-size: 36px;
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: -.04em;
  line-height: 1;
}

.hub-header__count-label {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--text-muted);
  letter-spacing: .06em;
}

/* ─────────────────────────────────
   Plugin Grid
───────────────────────────────── */
.hub-main {
  position: relative;
  z-index: 1;
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 var(--sp-6) var(--sp-16);
}

.plugin-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-6);
  width: 100%;
  max-width: 940px;
}

/* ─────────────────────────────────
   Plugin Card — Base
───────────────────────────────── */
.plugin-card {
  position: relative;
  display: block;
  background: var(--bg-card);
  border-radius: var(--radius-xl);
  overflow: hidden;
  cursor: pointer;
  text-decoration: none;

  /* Entrance animation */
  opacity: 0;
  transform: translateY(32px) scale(.97);
  animation: cardEntrance .75s var(--ease-out) forwards;

  /* Hover transition */
  transition:
    transform .4s var(--ease-snap),
    box-shadow .4s var(--ease-out),
    border-color .35s var(--ease-out);
}

.plugin-card:nth-child(1) { animation-delay: .35s; }
.plugin-card:nth-child(2) { animation-delay: .50s; }

@keyframes cardEntrance {
  to { opacity: 1; transform: translateY(0) scale(1); }
}

/* ─────────────────────────────────
   Plugin Card — Glow Overlay
   (Ambient light behind the card)
───────────────────────────────── */
.plugin-card__glow {
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  opacity: 0;
  pointer-events: none;
  transition: opacity .45s var(--ease-out);
  z-index: 0;
}

/* ─────────────────────────────────
   Plugin Card — Shimmer Border
───────────────────────────────── */
.plugin-card__shimmer {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  z-index: 0;
}

.plugin-card__shimmer::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(
    135deg,
    rgba(255,255,255,0.05) 0%,
    transparent 50%,
    rgba(255,255,255,0.02) 100%
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box,
                linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  transition: background .4s var(--ease-out);
}

/* ─────────────────────────────────
   Plugin Card — Inner Content
───────────────────────────────── */
.plugin-card__inner {
  position: relative;
  z-index: 1;
  padding: var(--sp-8);
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
  height: 100%;
  min-height: 460px;
}

.plugin-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}

.plugin-card__icon-wrap {
  width: 72px; height: 72px;
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform .35s var(--ease-snap), box-shadow .35s;
}

.plugin-card__icon {
  font-size: 36px;
  line-height: 1;
  display: block;
  transition: transform .35s var(--ease-snap);
}

.plugin-card__status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 11px;
  border-radius: 100px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-muted);
  letter-spacing: .06em;
}

.plugin-card__status-dot {
  width: 5px; height: 5px;
  border-radius: 50%;
  flex-shrink: 0;
}

.plugin-card__body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}

.plugin-card__name {
  font-family: var(--font-display);
  font-size: clamp(20px, 2.5vw, 26px);
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -.025em;
  line-height: 1.15;
}

.plugin-card__tagline {
  font-size: 15px;
  color: var(--text-secondary);
  line-height: 1.65;
  text-wrap: pretty;
}

.plugin-card__badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
}

.plugin-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 100px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: .04em;
  transition: transform .2s var(--ease-snap);
}

.plugin-badge--teal {
  background: rgba(0, 217, 192, 0.08);
  color: var(--teal);
  border: 1px solid rgba(0, 217, 192, 0.2);
}

.plugin-badge--voice {
  background: rgba(168, 85, 247, 0.08);
  color: var(--voice-a);
  border: 1px solid rgba(168, 85, 247, 0.2);
}

.plugin-card__features {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  margin-top: var(--sp-2);
}

.plugin-card__feature {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.5;
}

.plugin-card__feature-icon {
  font-size: 12px;
  flex-shrink: 0;
  opacity: 0.4;
  transition: opacity .2s, transform .2s var(--ease-snap);
}

.plugin-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--sp-5);
  border-top: 1px solid rgba(255,255,255,.05);
}

.plugin-card__cta {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 11px 22px;
  border-radius: var(--radius-md);
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -.01em;
  transition: transform .3s var(--ease-snap), box-shadow .3s, background .3s;
}

.plugin-card__cta-arrow {
  flex-shrink: 0;
  transition: transform .3s var(--ease-snap);
}

.plugin-card__slug {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-muted);
  letter-spacing: .04em;
}

/* ─────────────────────────────────
   Plugin Card — Scan-line texture
   (Subtle horizontal grid lines)
───────────────────────────────── */
.plugin-card::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background-image: repeating-linear-gradient(
    to bottom,
    transparent 0px,
    transparent 3px,
    rgba(255,255,255,0.012) 3px,
    rgba(255,255,255,0.012) 4px
  );
  pointer-events: none;
  z-index: 0;
}

/* ─────────────────────────────────
   Plugin Card — Teal Theme
───────────────────────────────── */
.plugin-card--teal {
  border: 1px solid var(--teal-border);
  box-shadow:
    0 0 0 1px rgba(0,217,192,.04),
    0 8px 40px rgba(0,0,0,.5),
    inset 0 1px 0 rgba(255,255,255,.04);
}

.plugin-card--teal .plugin-card__glow {
  background: radial-gradient(
    ellipse 70% 60% at 30% 20%,
    rgba(0, 217, 192, 0.11) 0%,
    transparent 65%
  );
}

.plugin-card--teal .plugin-card__icon-wrap {
  background: rgba(0, 217, 192, 0.08);
  border: 1px solid rgba(0, 217, 192, 0.18);
}

.plugin-card--teal .plugin-card__status-dot {
  background: var(--teal);
  box-shadow: 0 0 6px rgba(0, 217, 192, .6);
  animation: pulse 2.4s ease-in-out infinite;
}

.plugin-card--teal .plugin-card__feature-icon {
  color: var(--teal);
}

.plugin-card--teal .plugin-card__cta {
  background: var(--teal);
  color: var(--bg-void);
  box-shadow:
    0 0 20px rgba(0,217,192,.25),
    0 4px 12px rgba(0,217,192,.18);
}

.plugin-card--teal .plugin-card__shimmer::before {
  background: linear-gradient(
    135deg,
    rgba(0, 217, 192, 0.12) 0%,
    transparent 50%,
    rgba(0, 217, 192, 0.04) 100%
  );
}

/* Hover state — teal */
.plugin-card--teal:hover {
  border-color: var(--teal-border-h);
  transform: translateY(-6px) scale(1.015);
  box-shadow:
    0 0 0 1px rgba(0,217,192,.12),
    0 24px 64px rgba(0,0,0,.6),
    0 0 80px rgba(0,217,192,.12),
    inset 0 1px 0 rgba(0,217,192,.08);
}

.plugin-card--teal:hover .plugin-card__glow {
  opacity: 1;
}

.plugin-card--teal:hover .plugin-card__icon-wrap {
  box-shadow: 0 0 30px rgba(0,217,192,.3);
  transform: scale(1.06);
}

.plugin-card--teal:hover .plugin-card__icon {
  transform: scale(1.08) rotate(-3deg);
}

.plugin-card--teal:hover .plugin-card__feature-icon {
  opacity: 1;
  transform: translateX(4px);
}

.plugin-card--teal:hover .plugin-card__cta {
  transform: translateY(-1px);
  box-shadow:
    0 0 32px rgba(0,217,192,.4),
    0 8px 20px rgba(0,217,192,.3);
}

.plugin-card--teal:hover .plugin-card__cta-arrow {
  transform: translateX(4px);
}

.plugin-card--teal:hover .plugin-badge--teal {
  background: rgba(0, 217, 192, 0.14);
  border-color: rgba(0, 217, 192, 0.35);
}

/* ─────────────────────────────────
   Plugin Card — Voice Theme
───────────────────────────────── */
.plugin-card--voice {
  border: 1px solid var(--voice-border);
  box-shadow:
    0 0 0 1px rgba(168,85,247,.04),
    0 8px 40px rgba(0,0,0,.5),
    inset 0 1px 0 rgba(255,255,255,.04);
}

.plugin-card--voice .plugin-card__glow {
  background: radial-gradient(
    ellipse 70% 60% at 70% 20%,
    rgba(168, 85, 247, 0.11) 0%,
    rgba(59, 130, 246, 0.06) 40%,
    transparent 70%
  );
}

.plugin-card--voice .plugin-card__icon-wrap {
  background: rgba(168, 85, 247, 0.08);
  border: 1px solid rgba(168, 85, 247, 0.18);
}

.plugin-card--voice .plugin-card__status-dot--new {
  background: var(--voice-a);
  box-shadow: 0 0 6px rgba(168, 85, 247, .6);
  animation: pulseVoice 2.4s ease-in-out infinite;
}

@keyframes pulseVoice {
  0%, 100% { box-shadow: 0 0 5px var(--voice-a); }
  50% { box-shadow: 0 0 12px var(--voice-a), 0 0 22px rgba(168,85,247,.35); }
}

.plugin-card--voice .plugin-card__feature-icon {
  color: var(--voice-a);
}

.plugin-card--voice .plugin-card__cta {
  background: linear-gradient(100deg, var(--voice-a) 0%, var(--voice-b) 100%);
  color: #fff;
  box-shadow:
    0 0 20px rgba(168,85,247,.25),
    0 4px 12px rgba(168,85,247,.18);
}

.plugin-card--voice .plugin-card__shimmer::before {
  background: linear-gradient(
    135deg,
    rgba(168, 85, 247, 0.12) 0%,
    transparent 50%,
    rgba(59, 130, 246, 0.06) 100%
  );
}

/* Hover state — voice */
.plugin-card--voice:hover {
  border-color: var(--voice-border-h);
  transform: translateY(-6px) scale(1.015);
  box-shadow:
    0 0 0 1px rgba(168,85,247,.12),
    0 24px 64px rgba(0,0,0,.6),
    0 0 80px rgba(168,85,247,.10),
    inset 0 1px 0 rgba(168,85,247,.06);
}

.plugin-card--voice:hover .plugin-card__glow {
  opacity: 1;
}

.plugin-card--voice:hover .plugin-card__icon-wrap {
  box-shadow: 0 0 30px rgba(168,85,247,.3);
  transform: scale(1.06);
}

.plugin-card--voice:hover .plugin-card__icon {
  transform: scale(1.08) rotate(3deg);
}

.plugin-card--voice:hover .plugin-card__feature-icon {
  opacity: 1;
  transform: translateX(4px);
}

.plugin-card--voice:hover .plugin-card__cta {
  transform: translateY(-1px);
  box-shadow:
    0 0 32px rgba(168,85,247,.4),
    0 8px 20px rgba(168,85,247,.3);
}

.plugin-card--voice:hover .plugin-card__cta-arrow {
  transform: translateX(4px);
}

.plugin-card--voice:hover .plugin-badge--voice {
  background: rgba(168, 85, 247, 0.14);
  border-color: rgba(168, 85, 247, 0.35);
}

/* ─────────────────────────────────
   Hub Footer
───────────────────────────────── */
.hub-footer {
  position: relative;
  z-index: 1;
  border-top: 1px solid rgba(255,255,255,.05);
  padding: var(--sp-6) var(--sp-6);
}

.hub-footer__inner {
  max-width: 940px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  flex-wrap: wrap;
}

.hub-footer__brand {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}

.hub-footer__logo-icon {
  font-size: 18px;
}

.hub-footer__logo-text {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 700;
  color: var(--text-secondary);
  letter-spacing: -.01em;
}

.hub-footer__link {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: 14px;
  color: var(--text-muted);
  font-family: var(--font-mono);
  transition: color .2s;
}

.hub-footer__link:hover {
  color: var(--teal);
}

.hub-footer__copy {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-muted);
  letter-spacing: .03em;
}

/* ─────────────────────────────────
   Entrance Keyframes
───────────────────────────────── */
@keyframes fadeSlideDown {
  from { opacity: 0; transform: translateY(-14px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ─────────────────────────────────
   Focus & Accessibility
───────────────────────────────── */
:focus-visible {
  outline: 2px solid var(--teal);
  outline-offset: 4px;
  border-radius: 4px;
}

.plugin-card:focus-visible {
  outline-offset: 6px;
}

/* ─────────────────────────────────
   Responsive — Tablet
───────────────────────────────── */
@media (max-width: 760px) {
  .hub-header {
    padding: var(--sp-16) var(--sp-5) var(--sp-8);
    gap: var(--sp-4);
  }

  .plugin-grid {
    grid-template-columns: 1fr;
    max-width: 480px;
    gap: var(--sp-5);
  }

  .plugin-card__inner {
    min-height: 380px;
    padding: var(--sp-6);
  }

  .hub-header__sub br { display: none; }
}

/* ─────────────────────────────────
   Responsive — Mobile
───────────────────────────────── */
@media (max-width: 480px) {
  .hub-header {
    padding: var(--sp-12) var(--sp-5) var(--sp-6);
  }

  .plugin-card__inner {
    min-height: auto;
    padding: var(--sp-5);
    gap: var(--sp-4);
  }

  .plugin-card__icon-wrap {
    width: 60px; height: 60px;
    border-radius: 16px;
  }

  .plugin-card__icon { font-size: 28px; }

  .plugin-card__cta {
    padding: 10px 18px;
    font-size: 14px;
  }

  .hub-footer__inner {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--sp-3);
  }
}

/* ─────────────────────────────────
   Reduced Motion
───────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
  .plugin-card {
    opacity: 1;
    transform: none;
  }
  .hub-header__eyebrow,
  .hub-header__title-line,
  .hub-header__sub,
  .hub-header__meta {
    opacity: 1;
    transform: none;
  }
}
