/* Reset + base */
* { margin: 0; padding: 0; box-sizing: border-box; }

:root{
  /* Gold + ink palette */
  --page-bg: #0b132b;         /* deep navy around card */
  --gold-1: #ffd54f;
  --gold-2: #ffc107;          /* primary */
  --gold-3: #ffb300;
  --ink: #111;
  --divider-dark: rgba(0,0,0,0.25);

  /* Consistent card size (responsive) */
  --card-w: clamp(320px, 90vw, 680px);
  --card-h: clamp(420px, 80vh, 520px);
}

html, body {
  height: 100%;
  overflow: hidden;                /* no page scrolling */
  font-family: 'Trebuchet MS', Arial, sans-serif;
  background: var(--page-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  color-scheme: light;
}

/* Joke Card */
.joke-card {
  width: var(--card-w);
  height: var(--card-h);
  border-radius: 12px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  text-align: center;
  background: linear-gradient(180deg, var(--gold-1), var(--gold-2) 55%, var(--gold-3));
  color: var(--ink);
  box-shadow: 0 12px 34px rgba(0,0,0,0.28),
              0 0 0 1px rgba(0,0,0,0.08);
  cursor: pointer;
  transition: filter 0.15s ease-in-out;
}
.joke-card:hover { filter: brightness(1.02); }
.joke-card:focus-visible {
  outline: 3px solid #0f2b61; /* blue focus ring for accessibility */
  outline-offset: 3px;
  border-radius: 14px;
}

/* Title */
.card-title {
  font-size: 1.4rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  margin-bottom: 12px;
}

/* Content (centers jokes) */
.content {
  flex: 1;                         /* fixed card, flexible middle */
  display: flex;
  flex-direction: column;
  justify-content: center;         /* vertical center */
  align-items: center;             /* horizontal center */
  gap: 16px;
  overflow: auto;                  /* scroll inside if long joke */
  -webkit-overflow-scrolling: touch;
  padding: 4px 2px;
}

/* Make inner scrollbar subtle */
.content::-webkit-scrollbar { width: 8px; }
.content::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.2); border-radius: 8px; }
.content { scrollbar-width: thin; scrollbar-color: rgba(0,0,0,0.25) transparent; }

/* Joke Text */
.joke-text {
  font-size: clamp(1.1rem, 4.5vw, 1.8rem);
  font-weight: 800;
  line-height: 1.3;
  text-wrap: balance;
  word-break: break-word;
  hyphens: auto;
  transition: opacity 0.35s, transform 0.35s;
  opacity: 0;
  transform: translateY(16px);
}
.joke-text.show {
  opacity: 1;
  transform: translateY(0);
}
.joke-text .punchline {
  display: block;
  margin-top: 18px;
  padding-top: 12px;
  border-top: 2px solid var(--divider-dark);
}

/* Click Hint */
.click-hint {
  font-size: 0.85rem;
  opacity: 0.9;
  text-transform: uppercase;
  margin-top: 20px;
}

/* Footer */
.card-footer {
  font-size: 0.9rem;
  margin-top: 12px;
  opacity: 0.9;
}

/* Keep old theme classes working but force gold look */
.joke-card.forest,
.joke-card.amber,
.joke-card.burnt,
.joke-card.firebrick {
  background: linear-gradient(180deg, var(--gold-1), var(--gold-2) 55%, var(--gold-3));
  color: var(--ink);
  box-shadow: 0 12px 34px rgba(0,0,0,0.28),
              0 0 0 1px rgba(0,0,0,0.08);
}

/* Reduced motion respect */
@media (prefers-reduced-motion: reduce) {
  .joke-text, .joke-card { transition: none; }
}
