/* DM Prep Material Card - Inline Display Styling
 * ==============================================
 * Styles for DM prep materials (rumor tables, NPC cards, broadsheets, handouts)
 * displayed in the narrative panel when shared with the party.
 */

/* Card container */
.dm-prep-card {
  --card-accent: var(--text-muted);

  margin: var(--spacing-md) 0;
  padding: var(--spacing-md);
  background: var(--surface-elevated);
  border: 1px solid var(--border-subtle);
  border-left: 4px solid var(--card-accent);
  border-radius: var(--radius-md);
  animation: dm-prep-reveal 0.4s ease-out;
}

@keyframes dm-prep-reveal {
  from {
    opacity: 0;
    transform: translateY(-8px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* Material type accent colors */
.dm-prep-card--rumor {
  --card-accent: #a78bfa; /* Purple - mysterious rumors */
  background: linear-gradient(135deg, var(--surface-elevated) 0%, rgba(167, 139, 250, 0.05) 100%);
}

.dm-prep-card--npc {
  --card-accent: #4ade80; /* Green - NPCs */
  background: linear-gradient(135deg, var(--surface-elevated) 0%, rgba(74, 222, 128, 0.05) 100%);
}

.dm-prep-card--broadsheet {
  --card-accent: #fbbf24; /* Yellow/Gold - newspaper */
  background: linear-gradient(135deg, var(--surface-elevated) 0%, rgba(251, 191, 36, 0.05) 100%);
}

.dm-prep-card--handout {
  --card-accent: #60a5fa; /* Blue - handouts */
  background: linear-gradient(135deg, var(--surface-elevated) 0%, rgba(96, 165, 250, 0.05) 100%);
}

.dm-prep-card--session {
  --card-accent: #fb923c; /* Orange - session planning */
  background: linear-gradient(135deg, var(--surface-elevated) 0%, rgba(251, 146, 60, 0.05) 100%);
}

/* Card header */
.dm-prep-card__header {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-sm);
}

.dm-prep-card__icon {
  font-size: 1.5em;
  flex-shrink: 0;
  line-height: 1;
}

.dm-prep-card__title-group {
  flex: 1;
  min-width: 0;
}

.dm-prep-card__title {
  font-family: var(--font-display);
  font-size: var(--font-size-lg);
  font-weight: 600;
  color: var(--card-accent);
  margin: 0;
  line-height: 1.2;
}

.dm-prep-card__type {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  margin-top: 2px;
  display: block;
}

/* Card content */
.dm-prep-card__content {
  color: var(--text-primary);
}

.dm-prep-card__preview {
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  margin: 0;
  padding: var(--spacing-xs) var(--spacing-sm);
  background: rgba(0, 0, 0, 0.15);
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
}

/* Metadata badges */
.dm-prep-card__badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-xs);
  margin-top: var(--spacing-sm);
}

.dm-prep-card__badge {
  font-size: var(--font-size-xs);
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-muted);
}

.dm-prep-card__badge--dice {
  background: rgba(167, 139, 250, 0.15);
  color: #a78bfa;
}

.dm-prep-card__badge--stat {
  background: rgba(74, 222, 128, 0.15);
  color: #4ade80;
}

.dm-prep-card__badge--voice {
  background: rgba(96, 165, 250, 0.15);
  color: #60a5fa;
}

.dm-prep-card__badge--date {
  background: rgba(251, 191, 36, 0.15);
  color: #fbbf24;
}

.dm-prep-card__badge--reward {
  background: rgba(251, 146, 60, 0.15);
  color: #fb923c;
}

.dm-prep-card__badge--status {
  background: rgba(248, 113, 113, 0.15);
  color: #f87171;
}

/* Card actions */
.dm-prep-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-xs);
  margin-top: var(--spacing-md);
  padding-top: var(--spacing-sm);
  border-top: 1px solid var(--border-subtle);
}

.dm-prep-card__action {
  font-family: var(--font-mono);
  font-size: var(--font-size-xs);
  padding: var(--spacing-xs) var(--spacing-sm);
  background: var(--surface-secondary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.15s ease;
}

.dm-prep-card__action:hover {
  background: var(--surface-tertiary);
  color: var(--text-primary);
  border-color: var(--card-accent);
}

.dm-prep-card__action--primary {
  background: var(--card-accent);
  color: var(--surface-elevated);
  border-color: var(--card-accent);
}

.dm-prep-card__action--primary:hover {
  filter: brightness(1.1);
  color: var(--surface-elevated);
}

/* Type-specific icon colors (inherited from card accent) */
.dm-prep-card--rumor .dm-prep-card__icon {
  color: #a78bfa;
}

.dm-prep-card--npc .dm-prep-card__icon {
  color: #4ade80;
}

.dm-prep-card--broadsheet .dm-prep-card__icon {
  color: #fbbf24;
}

.dm-prep-card--handout .dm-prep-card__icon {
  color: #60a5fa;
}

.dm-prep-card--session .dm-prep-card__icon {
  color: #fb923c;
}

/* Parchment effect for handouts */
.dm-prep-card--handout {
  position: relative;
}

.dm-prep-card--handout::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 24px 24px 0;
  border-color: transparent var(--surface-secondary) transparent transparent;
  opacity: 0.5;
}

/* Newspaper effect for broadsheets */
.dm-prep-card--broadsheet .dm-prep-card__title {
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.dm-prep-card--broadsheet .dm-prep-card__preview {
  font-style: italic;
  background: transparent;
  border-left: 2px solid var(--card-accent);
  padding-left: var(--spacing-sm);
}

/* Dice styling for rumor tables */
.dm-prep-card--rumor .dm-prep-card__preview {
  position: relative;
  padding-left: calc(var(--spacing-sm) + 1.5em);
}

.dm-prep-card--rumor .dm-prep-card__preview::before {
  content: '🎲';
  position: absolute;
  left: var(--spacing-xs);
  top: 50%;
  transform: translateY(-50%);
  font-size: 1em;
}

/* Tool result integration */
.tool-result-item.dm-prep {
  padding: 0;
  background: transparent;
  border: none;
}

.tool-result-item.dm-prep .dm-prep-card {
  margin: 0;
}

/* Narrative segment integration */
.narrative-segment.dm-prep-material .dm-prep-card {
  margin: 0;
}

/* Responsive adjustments */
@media (max-width: 600px) {
  .dm-prep-card {
    padding: var(--spacing-sm);
  }

  .dm-prep-card__header {
    flex-wrap: wrap;
  }

  .dm-prep-card__title {
    font-size: var(--font-size-base);
  }

  .dm-prep-card__actions {
    flex-direction: column;
  }

  .dm-prep-card__action {
    width: 100%;
    text-align: center;
  }
}

/* Print styles for export */
@media print {
  .dm-prep-card {
    break-inside: avoid;
    border: 1px solid #333;
    background: #fff;
    color: #000;
  }

  .dm-prep-card__actions {
    display: none;
  }

  .dm-prep-card__title {
    color: #000;
  }

  .dm-prep-card__preview {
    background: #f5f5f5;
  }
}
