/*
 * Divine Power 48 - Design System
 *
 * Color palette:
 * - Gold Primary: #CEA52F
 * - Gold Light: #DAA520
 * - Gold Dark: #816309
 * - Black Background: #000000
 * - Card Background: #1E1E1E
 * - Secondary Card: #2A2A2A
 */

/* ============================================
   CSS Custom Properties (Design Tokens)
   ============================================ */
:root {
  --dp-gold: #CEA52F;
  --dp-gold-light: #DAA520;
  --dp-gold-dark: #816309;
  --dp-black: #000000;
  --dp-card: #1E1E1E;
  --dp-card-secondary: #2A2A2A;
  --dp-nav-start: #38301E;
}

/* ============================================
   Typography
   ============================================ */
body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
}

h1, h2, h3, h4, h5, h6 {
  font-family: Georgia, 'Times New Roman', serif;
}

/* Gold text utility */
.text-gold {
  color: var(--dp-gold);
}

/* Text shadow for emphasis */
.text-shadow-gold {
  text-shadow: 0 0 10px rgba(206, 165, 47, 0.5);
}

/* ============================================
   Buttons
   ============================================ */
.btn-gold {
  background-color: var(--dp-gold);
  color: var(--dp-black);
  font-weight: 600;
  padding: 0.75rem 1.5rem;
  border-radius: 0.5rem;
  transition: background-color 0.2s ease;
}

.btn-gold:hover {
  background-color: var(--dp-gold-light);
}

.btn-gold:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Outline button variant */
.btn-gold-outline {
  background-color: transparent;
  border: 2px solid var(--dp-gold);
  color: var(--dp-gold);
  font-weight: 600;
  padding: 0.75rem 1.5rem;
  border-radius: 0.5rem;
  transition: all 0.2s ease;
}

.btn-gold-outline:hover {
  background-color: var(--dp-gold);
  color: var(--dp-black);
}

/* ============================================
   Cards
   ============================================ */
.card-dp {
  background-color: var(--dp-card);
  border-radius: 1rem;
  padding: 1rem;
  border: 1px solid rgba(206, 165, 47, 0.2);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.45);
}

/* Card with gold glow effect */
.card-dp-glow {
  box-shadow: 0 0 20px rgba(206, 165, 47, 0.3);
}

/* ============================================
   Inputs
   ============================================ */
.input-dp {
  width: 100%;
  background-color: var(--dp-card-secondary);
  border: 1px solid rgba(206, 165, 47, 0.3);
  border-radius: 0.5rem;
  padding: 0.75rem 1rem;
  color: white;
  transition: border-color 0.2s ease;
}

.input-dp::placeholder {
  color: rgba(255, 255, 255, 0.5);
}

.input-dp:focus {
  outline: none;
  border-color: var(--dp-gold);
}

/* ============================================
   Backgrounds
   ============================================ */
.bg-dp-gradient {
  background: radial-gradient(
    ellipse at top,
    var(--dp-gold-dark) 0%,
    #312604 40%,
    var(--dp-black) 100%
  );
}

.bg-dp-nav {
  background: linear-gradient(to top, var(--dp-black) 0%, var(--dp-nav-start) 100%);
}

/* ============================================
   Flash Messages
   ============================================ */
.flash-notice {
  background-color: rgba(54, 211, 153, 0.9);
  color: #000;
  padding: 1rem;
  border-radius: 0.5rem;
  font-weight: 500;
}

.flash-error {
  background-color: rgba(248, 114, 114, 0.9);
  color: #000;
  padding: 1rem;
  border-radius: 0.5rem;
  font-weight: 500;
}

/* ============================================
   Animations
   ============================================ */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(-10px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes fadeOut {
  from { opacity: 1; transform: translateY(0); }
  to { opacity: 0; transform: translateY(-10px); }
}

@keyframes slideUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes pulse-gold {
  0%, 100% { box-shadow: 0 0 0 0 rgba(206, 165, 47, 0.4); }
  50% { box-shadow: 0 0 0 10px rgba(206, 165, 47, 0); }
}

.animate-fade-in {
  animation: fadeIn 0.3s ease-out forwards;
}

.animate-fade-out {
  animation: fadeOut 0.3s ease-out forwards;
}

.animate-slide-up {
  animation: slideUp 0.4s ease-out forwards;
}

.animate-pulse-gold {
  animation: pulse-gold 2s infinite;
}

/* Staggered animation delays */
.animate-delay-100 { animation-delay: 100ms; }
.animate-delay-200 { animation-delay: 200ms; }
.animate-delay-300 { animation-delay: 300ms; }
.animate-delay-400 { animation-delay: 400ms; }
.animate-delay-500 { animation-delay: 500ms; }

/* ============================================
   Card Flip Animation
   ============================================ */
.card-flip-container {
  perspective: 1000px;
}

.card-flipper {
  position: relative;
  width: 100%;
  transition: transform 0.6s;
  transform-style: preserve-3d;
}

.card-flipper.flipped {
  transform: rotateY(180deg);
}

.card-front,
.card-back {
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.card-back {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  transform: rotateY(180deg);
}

/* ============================================
   Loading Spinner
   ============================================ */
.spinner-gold {
  width: 2rem;
  height: 2rem;
  border: 4px solid rgba(206, 165, 47, 0.3);
  border-top-color: var(--dp-gold);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* ============================================
   Utilities
   ============================================ */
/* Blur for locked content */
.blur-content {
  filter: blur(4px);
  user-select: none;
}

/* Safe area padding for notched devices */
.pb-safe {
  padding-bottom: env(safe-area-inset-bottom, 0);
}

.pt-safe {
  padding-top: env(safe-area-inset-top, 0);
}

/* Hide scrollbar but keep functionality */
.scrollbar-hide {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.scrollbar-hide::-webkit-scrollbar {
  display: none;
}

/* Touch optimization */
.touch-target {
  min-height: 44px;
  min-width: 44px;
}
