/* Quest Theme Styles
 * Contextual theming for quest cards based on quest type
 * Themes: wanted_poster, treasure_map, sealed_letter, battle_orders, royal_decree
 */

/* ============================================
   Base Quest Card Styles
   ============================================ */

.quest-card {
  --quest-bg: var(--panel-bg);
  --quest-border: var(--border-color);
  --quest-accent: var(--accent-color);
  --quest-text: var(--text-primary);
  --quest-seal-color: #8b4513;

  position: relative;
  padding: var(--spacing-md);
  border: 2px solid var(--quest-border);
  border-radius: var(--radius-md);
  background: var(--quest-bg);
  color: var(--quest-text);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  overflow: hidden;
}

.quest-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.quest-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
  opacity: 0.05;
}

/* ============================================
   Wanted Poster Theme
   For rescue/bounty missions
   ============================================ */

.quest-card[data-theme="wanted_poster"] {
  --quest-bg: linear-gradient(135deg, #d4a574 0%, #c4956a 50%, #b8855a 100%);
  --quest-border: #8b4513;
  --quest-text: #2d1810;

  background: var(--quest-bg);
  border: 3px solid var(--quest-border);
  box-shadow:
    inset 0 0 20px rgba(139, 69, 19, 0.2),
    0 2px 8px rgba(0, 0, 0, 0.3);
}

.quest-card[data-theme="wanted_poster"]::before {
  background:
    repeating-linear-gradient(
      90deg,
      transparent,
      transparent 2px,
      rgba(139, 69, 19, 0.03) 2px,
      rgba(139, 69, 19, 0.03) 4px
    );
  opacity: 1;
}

.quest-card[data-theme="wanted_poster"] .quest-card__header {
  text-align: center;
  font-family: 'Courier New', monospace;
  font-weight: 900;
  font-size: 1.5rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #2d1810;
  text-shadow: 1px 1px 0 rgba(255, 255, 255, 0.3);
  border-bottom: 2px double #8b4513;
  padding-bottom: var(--spacing-sm);
  margin-bottom: var(--spacing-md);
}

.quest-card[data-theme="wanted_poster"] .quest-card__stamp {
  position: absolute;
  top: 10px;
  right: 10px;
  padding: 4px 12px;
  background: #8b0000;
  color: #fff;
  font-weight: bold;
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  transform: rotate(12deg);
  border: 2px solid #5a0000;
  box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
}

.quest-card[data-theme="wanted_poster"] .quest-card__reward {
  text-align: center;
  font-size: 1.25rem;
  font-weight: bold;
  color: #5a3d2b;
  margin-top: var(--spacing-md);
  padding: var(--spacing-sm);
  border: 1px dashed #8b4513;
}

/* Torn edges effect */
.quest-card[data-theme="wanted_poster"]::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 8px;
  background:
    linear-gradient(135deg, transparent 33.33%, #c4956a 33.33%, #c4956a 66.66%, transparent 66.66%),
    linear-gradient(225deg, transparent 33.33%, #c4956a 33.33%, #c4956a 66.66%, transparent 66.66%);
  background-size: 16px 8px;
}

/* ============================================
   Treasure Map Theme
   For dungeon/exploration quests
   ============================================ */

.quest-card[data-theme="treasure_map"] {
  --quest-bg: linear-gradient(135deg, #e8dcc4 0%, #d4c4a8 50%, #c9b896 100%);
  --quest-border: #6b5344;
  --quest-text: #3d2817;

  background: var(--quest-bg);
  border: 2px solid var(--quest-border);
  border-radius: 4px;
}

.quest-card[data-theme="treasure_map"]::before {
  background:
    radial-gradient(circle at 20% 30%, rgba(139, 90, 43, 0.1) 0%, transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(139, 90, 43, 0.08) 0%, transparent 40%),
    url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 5 L35 25 L55 30 L35 35 L30 55 L25 35 L5 30 L25 25 Z' fill='none' stroke='%238b5a2b' stroke-width='0.5' opacity='0.1'/%3E%3C/svg%3E");
  opacity: 1;
}

.quest-card[data-theme="treasure_map"] .quest-card__compass {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 40px;
  height: 40px;
  border: 2px solid #6b5344;
  border-radius: 50%;
  background: radial-gradient(circle, #f5f0e6 0%, #d4c4a8 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
}

.quest-card[data-theme="treasure_map"] .quest-card__x-mark {
  color: #8b0000;
  font-weight: bold;
  font-size: 1.5rem;
  text-shadow: 1px 1px 0 rgba(0, 0, 0, 0.3);
}

.quest-card[data-theme="treasure_map"] .quest-card__path {
  border-left: 2px dashed #6b5344;
  padding-left: var(--spacing-md);
  margin-left: var(--spacing-sm);
  position: relative;
}

.quest-card[data-theme="treasure_map"] .quest-card__path::before {
  content: '';
  position: absolute;
  left: -5px;
  top: 0;
  width: 8px;
  height: 8px;
  background: #6b5344;
  border-radius: 50%;
}

/* ============================================
   Sealed Letter Theme
   For mystery/investigation quests
   ============================================ */

.quest-card[data-theme="sealed_letter"] {
  --quest-bg: linear-gradient(180deg, #f5f0e6 0%, #e8e0d4 100%);
  --quest-border: #a09080;
  --quest-text: #2d2d2d;

  background: var(--quest-bg);
  border: 1px solid var(--quest-border);
  box-shadow:
    2px 2px 8px rgba(0, 0, 0, 0.15),
    inset 0 1px 0 rgba(255, 255, 255, 0.5);
}

.quest-card[data-theme="sealed_letter"] .quest-card__seal {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 60px;
  height: 60px;
  background: radial-gradient(circle, #8b0000 0%, #5a0000 70%, #3d0000 100%);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow:
    0 2px 8px rgba(0, 0, 0, 0.4),
    inset 0 2px 4px rgba(255, 255, 255, 0.2);
  cursor: pointer;
  transition: transform 0.2s ease;
  z-index: 10;
}

.quest-card[data-theme="sealed_letter"] .quest-card__seal:hover {
  transform: translate(-50%, -50%) scale(1.05);
}

.quest-card[data-theme="sealed_letter"] .quest-card__seal-icon {
  color: #ffd700;
  font-size: 1.5rem;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.quest-card[data-theme="sealed_letter"][data-opened="true"] .quest-card__seal {
  display: none;
}

.quest-card[data-theme="sealed_letter"] .quest-card__content {
  font-family: 'Georgia', serif;
  font-style: italic;
  line-height: 1.6;
}

.quest-card[data-theme="sealed_letter"] .quest-card__signature {
  text-align: right;
  margin-top: var(--spacing-md);
  font-family: 'Brush Script MT', cursive;
  font-size: 1.2rem;
  color: #1a1a1a;
}

/* Folded corners */
.quest-card[data-theme="sealed_letter"]::after {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  border-style: solid;
  border-width: 0 20px 20px 0;
  border-color: transparent #c9c0b0 transparent transparent;
  box-shadow: -2px 2px 3px rgba(0, 0, 0, 0.1);
}

/* ============================================
   Battle Orders Theme
   For combat/urgent missions
   ============================================ */

.quest-card[data-theme="battle_orders"] {
  --quest-bg: linear-gradient(135deg, #2d2d2d 0%, #1a1a1a 100%);
  --quest-border: #8b0000;
  --quest-accent: #ff4444;
  --quest-text: #e0e0e0;

  background: var(--quest-bg);
  border: 3px solid var(--quest-border);
  box-shadow:
    0 0 10px rgba(139, 0, 0, 0.3),
    inset 0 0 20px rgba(0, 0, 0, 0.5);
}

.quest-card[data-theme="battle_orders"] .quest-card__header {
  color: var(--quest-accent);
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  border-bottom: 2px solid var(--quest-border);
  padding-bottom: var(--spacing-sm);
}

.quest-card[data-theme="battle_orders"] .quest-card__urgent-banner {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  background: linear-gradient(90deg, #8b0000, #5a0000, #8b0000);
  color: #fff;
  text-align: center;
  padding: 4px;
  font-size: 0.75rem;
  font-weight: bold;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  animation: urgent-pulse 2s ease-in-out infinite;
}

@keyframes urgent-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.7; }
}

.quest-card[data-theme="battle_orders"] .quest-card__objective {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm) 0;
  border-bottom: 1px solid rgba(139, 0, 0, 0.3);
}

.quest-card[data-theme="battle_orders"] .quest-card__objective-marker {
  color: var(--quest-accent);
  font-weight: bold;
}

/* ============================================
   Royal Decree Theme
   For main story/important quests
   ============================================ */

.quest-card[data-theme="royal_decree"] {
  --quest-bg: linear-gradient(135deg, #f8f4e8 0%, #e8dcc4 50%, #d4c4a8 100%);
  --quest-border: #b8860b;
  --quest-accent: #daa520;
  --quest-text: #2d1810;

  background: var(--quest-bg);
  border: 4px double var(--quest-border);
  box-shadow:
    0 0 15px rgba(218, 165, 32, 0.2),
    inset 0 0 30px rgba(218, 165, 32, 0.05);
}

.quest-card[data-theme="royal_decree"]::before {
  background:
    linear-gradient(90deg,
      transparent 0%,
      rgba(218, 165, 32, 0.1) 10%,
      transparent 20%,
      transparent 80%,
      rgba(218, 165, 32, 0.1) 90%,
      transparent 100%
    );
  opacity: 1;
}

.quest-card[data-theme="royal_decree"] .quest-card__crown {
  text-align: center;
  font-size: 2rem;
  margin-bottom: var(--spacing-sm);
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.quest-card[data-theme="royal_decree"] .quest-card__header {
  text-align: center;
  font-family: 'Times New Roman', serif;
  font-variant: small-caps;
  font-size: 1.25rem;
  letter-spacing: 0.1em;
  color: #5a3d2b;
  border-bottom: 1px solid var(--quest-border);
  padding-bottom: var(--spacing-sm);
}

.quest-card[data-theme="royal_decree"] .quest-card__royal-seal {
  position: absolute;
  bottom: 10px;
  right: 10px;
  width: 50px;
  height: 50px;
  background: radial-gradient(circle, #daa520 0%, #b8860b 70%, #8b6914 100%);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
}

/* ============================================
   Urgency Modifiers
   Apply on top of any theme
   ============================================ */

.quest-card[data-urgency="urgent"] {
  border-color: #ff6b35;
  box-shadow:
    0 0 8px rgba(255, 107, 53, 0.4),
    inset 0 0 8px rgba(255, 107, 53, 0.1);
}

.quest-card[data-urgency="urgent"]::before {
  box-shadow: inset 0 0 0 2px rgba(255, 107, 53, 0.3);
}

.quest-card[data-urgency="critical"] {
  border-color: #ff0000;
  animation: critical-glow 1.5s ease-in-out infinite;
}

@keyframes critical-glow {
  0%, 100% {
    box-shadow:
      0 0 10px rgba(255, 0, 0, 0.5),
      0 0 20px rgba(255, 0, 0, 0.3),
      inset 0 0 10px rgba(255, 0, 0, 0.1);
  }
  50% {
    box-shadow:
      0 0 15px rgba(255, 0, 0, 0.7),
      0 0 30px rgba(255, 0, 0, 0.4),
      inset 0 0 15px rgba(255, 0, 0, 0.15);
  }
}

/* ============================================
   Faction Color Modifiers
   ============================================ */

.quest-card[data-faction-color] {
  --faction-color: attr(data-faction-color);
}

.quest-card .quest-card__faction-ribbon {
  position: absolute;
  top: 0;
  left: 20px;
  width: 30px;
  padding: 8px 4px;
  background: var(--faction-color, var(--accent-color));
  color: #fff;
  text-align: center;
  font-size: 0.7rem;
  font-weight: bold;
  clip-path: polygon(0 0, 100% 0, 100% 85%, 50% 100%, 0 85%);
  box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
}

/* ============================================
   Discovery Level Modifiers
   ============================================ */

.quest-card[data-discovery="minimal"] {
  filter: blur(1px) grayscale(0.3);
}

.quest-card[data-discovery="minimal"] .quest-card__content {
  visibility: hidden;
}

.quest-card[data-discovery="minimal"]::after {
  content: '???';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 2rem;
  color: rgba(255, 255, 255, 0.5);
}

.quest-card[data-discovery="moderate"] .quest-card__details {
  filter: blur(2px);
  pointer-events: none;
}

.quest-card[data-discovery="full"] {
  /* No modifications - full reveal */
}

/* ============================================
   Status Indicators
   ============================================ */

.quest-card__status {
  position: absolute;
  top: 8px;
  left: 8px;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-size: 0.7rem;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.quest-card__status--active {
  background: var(--success-color);
  color: #fff;
}

.quest-card__status--available {
  background: var(--accent-color);
  color: #fff;
}

.quest-card__status--completed {
  background: #666;
  color: #fff;
}

.quest-card__status--failed {
  background: var(--error-color);
  color: #fff;
}

/* ============================================
   Interactive States
   ============================================ */

.quest-card--clickable {
  cursor: pointer;
}

.quest-card--selected {
  outline: 3px solid var(--accent-color);
  outline-offset: 2px;
}

.quest-card--pinned::before {
  content: '';
  position: absolute;
  top: -8px;
  left: 50%;
  transform: translateX(-50%);
  width: 16px;
  height: 16px;
  background: radial-gradient(circle, #c0392b 0%, #8b0000 70%);
  border-radius: 50%;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
  z-index: 10;
}
