/*
Theme Name: Vaerfel Idle
Theme URI: https://vaerfel-idle.com
Author: Vaerfel
Author URI: https://vaerfel-idle.com
Description: Child theme of Twenty Twenty-Five for Vaerfel Idle with Play CTA and Firebase account linking page.
Template: twentytwentyfive
Version: 0.1.1
Text Domain: vaerfel-idle
*/

/* Custom font face */
@font-face {
  font-family: 'Alagard';
  src: url('/wp-content/themes/vaerfel-idle/assets/alagard.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

/* Minimal brand accents; most styling will live in theme.json */
:root {
  --vfi-brand: #6b5cff; /* example accent */
  --vfi-accent: #00e0a4;
}

/* Header Play button (if rendered as a link in navigation or template) */
.vfi-play-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--vfi-brand);
  color: #fff;
  padding: 0.65rem 1rem;
  border-radius: 8px;
  text-decoration: none;
  font-weight: 600;
}
.vfi-play-btn:hover,
.vfi-play-btn:focus {
  background: #574cff;
  color: #fff;
}

/* Link Account button */
#vfi-link-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--vfi-accent);
  color: #0e0e0e;
  padding: 0.6rem 1rem;
  border-radius: 8px;
  font-weight: 600;
  border: 0;
  cursor: pointer;
}
#vfi-link-btn:hover,
#vfi-link-btn:focus {
  filter: brightness(0.95);
}

/* ===============================
   Vaerfel Idle Beta/V1 book theme
   Style guide-driven utilities
   =============================== */

/* CSS variables (Book Theme) */
:root {
  --book-parchment: #f4e8d0;
  --book-ink: #2c2416;
  --book-ink-light: #5a4a3a;
  --book-accent: #d4a574;
  --book-binding: #8b4513;

  /* Rarity colors */
  --rarity-common: #9e9e9e;
  --rarity-uncommon: #4caf50;
  --rarity-rare: #2196f3;
  --rarity-epic: #9c27b0;
  --rarity-legendary: #ff9800;

  /* Action gradients */
  --grad-attack: linear-gradient(135deg, #dc3545 0%, #a82835 100%);
  --grad-defense: linear-gradient(135deg, #007bff 0%, #0056b3 100%);
  --grad-healing: linear-gradient(135deg, #28a745 0%, #1e7e34 100%);
  --grad-balanced: linear-gradient(135deg, #6f42c1 0%, #5a32a3 100%);
  --grad-neutral: linear-gradient(135deg, #d4a574 0%, #b88a5a 100%);
  --grad-brand: linear-gradient(135deg, var(--vfi-brand) 0%, #574cff 100%);
}

/* Global defaults (fallbacks; theme.json is primary) */
body {
  background-color: var(--book-parchment) !important;
  color: var(--book-ink) !important;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
}

/* Utility: smooth hover transition */
.vfi-transition {
  transition: all 0.2s ease;
}

/* Buttons - style guide variants */
.btn-primary {
  background: var(--grad-neutral);
  color: var(--book-ink);
  border: 2px solid #8b6f47;
  padding: 8px 14px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 0.95rem;
  font-weight: bold;
  box-shadow: 0 2px 4px rgba(0,0,0,0.2);
  transition: all 0.2s ease;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}
.btn-primary:hover,
.btn-primary:focus { transform: translateY(-1px); }

.btn-attack   { background: var(--grad-attack);   color: #fff; border: 2px solid #8b1e2a; }
.btn-defense  { background: var(--grad-defense);  color: #fff; border: 2px solid #0a4692; }
.btn-healing  { background: var(--grad-healing);  color: #fff; border: 2px solid #17642a; }
.btn-balanced { background: var(--grad-balanced); color: #fff; border: 2px solid #4a278e; }
.btn-neutral  { background: var(--grad-neutral);  color: var(--book-ink); border: 2px solid #8b6f47; }
.btn-attack:hover,
.btn-defense:hover,
.btn-healing:hover,
.btn-balanced:hover,
.btn-neutral:hover { transform: translateY(-1px); }

/* Existing CTAs */
.vfi-play-btn { transition: all 0.2s ease; }
.vfi-play-btn:hover { transform: translateY(-1px); }

/* Link Account button (id preserved) */
#vfi-link-btn { transition: all 0.2s ease; }
#vfi-link-btn:hover { transform: translateY(-1px); }

/* Cards */
.vfi-card {
  position: relative;
  border: 3px solid var(--rarity-border, var(--rarity-common));
  border-radius: 12px;
  padding: 14px;
  background: var(--book-parchment);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: all 0.2s ease;
  box-shadow: 0 2px 6px rgba(0,0,0,0.1);
  transform: translateY(0);
}
.vfi-card:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.15); }
.vfi-card.is-selected {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}

/* Rarity helpers (sets border variable) */
.rarity-common    { --rarity-border: var(--rarity-common); }
.rarity-uncommon  { --rarity-border: var(--rarity-uncommon); }
.rarity-rare      { --rarity-border: var(--rarity-rare); }
.rarity-epic      { --rarity-border: var(--rarity-epic); }
.rarity-legendary { --rarity-border: var(--rarity-legendary); }

/* Headings & Body helpers */
.vfi-heading {
  margin: 0 0 10px 0;
  color: var(--book-ink);
  font-family: 'Alagard', serif;
  font-weight: normal;
  letter-spacing: 1px;
}
.vfi-text {
  margin: 0;
  color: var(--book-ink-light);
  font-weight: 500;
}

/* Apply Alagard font to main title only */
h1 {
  font-family: 'Alagard', serif;
  font-weight: normal;
  letter-spacing: 1px;
}

/* Apply to specific elements - main title */
.has-3-xl-font-size {
  font-family: 'Alagard', serif !important;
  font-weight: normal !important;
  letter-spacing: 1px !important;
}

/* Account page styles */
.vfi-achievement {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem;
  margin-bottom: 0.75rem;
  border-radius: 8px;
  border: 2px solid;
  background: rgba(139, 69, 19, 0.05);
  transition: all 0.2s ease;
}

.vfi-achievement.unlocked {
  background: rgba(40, 167, 69, 0.1);
  border-color: #28a745;
}

.vfi-achievement.locked {
  background: rgba(108, 117, 125, 0.1);
  border-color: #6c757d;
  opacity: 0.7;
}

.vfi-achievement.rarity-rare {
  border-color: #2196f3;
  background: rgba(33, 150, 243, 0.1);
}

.vfi-achievement.rarity-epic {
  border-color: #9c27b0;
  background: rgba(156, 39, 176, 0.1);
}

.vfi-achievement.rarity-legendary {
  border-color: #ff9800;
  background: rgba(255, 152, 0, 0.1);
}

.achievement-icon {
  font-size: 2rem;
  min-width: 2rem;
  text-align: center;
}

.achievement-content h4 {
  margin: 0 0 0.25rem 0;
  color: var(--book-ink);
  font-family: 'Alagard', serif;
  font-size: 1.1rem;
}

.achievement-content p {
  margin: 0;
  color: var(--book-ink-light);
  font-size: 0.9rem;
}

.achievement-date,
.achievement-locked {
  font-size: 0.8rem;
  color: var(--book-ink-light);
}

.achievement-locked {
  font-style: italic;
}

/* Stats grid */
.vfi-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 1rem;
  margin-top: 1rem;
}

.vfi-stat {
  text-align: center;
  padding: 1rem;
  background: rgba(139, 69, 19, 0.05);
  border-radius: 8px;
  border: 2px solid var(--book-binding);
}

.stat-number {
  display: block;
  font-size: 2rem;
  font-weight: bold;
  color: var(--book-ink);
  font-family: 'Alagard', serif;
}

.stat-label {
  display: block;
  font-size: 0.9rem;
  color: var(--book-ink-light);
  margin-top: 0.25rem;
}

/* Control bar pattern */
.vfi-control-bar {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
  margin-top: 12px;
  padding: 10px;
  background: rgba(139,69,19,0.05);
  border-radius: 8px;
}

/* Responsive grid utilities */
.grid-responsive {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 12px;
  padding: 12px;
  overflow-x: hidden;
  overflow-y: auto;
  background: rgba(139,69,19,0.02);
  border-radius: 8px;
}
@media (max-width: 1100px) {
  .grid-responsive { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)) !important; }
}
@media (max-width: 700px) {
  .grid-responsive { grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)) !important; }
}
@media (max-width: 480px) {
  .grid-responsive { grid-template-columns: repeat(2, 1fr) !important; }
}

/* Scrollbar styling for scrollable containers */
.scrollable-container::-webkit-scrollbar { width: 8px; }
.scrollable-container::-webkit-scrollbar-track {
  background: rgba(139,69,19,0.1);
  border-radius: 4px;
}
.scrollable-container::-webkit-scrollbar-thumb {
  background: rgba(139,69,19,0.4);
  border-radius: 4px;
}
.scrollable-container::-webkit-scrollbar-thumb:hover {
  background: rgba(139,69,19,0.6);
}

/* Banner styling for intro-screen.gif and class-based usage */
.vfi-banner,
.wp-block-image img[alt="Vaerfel Idle intro"] {
  width: 100%;
  height: auto;
  max-height: 420px;
  object-fit: cover;
  border-radius: 12px;
  /* Book frame + depth */
  border: 4px solid var(--book-binding);
  background: var(--book-parchment);
  box-shadow: 0 6px 18px rgba(0,0,0,.25);
  /* Subtle entrance */
  opacity: 0;
  animation: vfiFadeIn .6s ease forwards;
}

@keyframes vfiFadeIn { to { opacity: 1; } }

/* Responsive banner max-heights */
@media (max-width: 1100px) {
  .vfi-banner,
  .wp-block-image img[alt="Vaerfel Idle intro"] { max-height: 360px; }
}
@media (max-width: 700px) {
  .vfi-banner,
  .wp-block-image img[alt="Vaerfel Idle intro"] { max-height: 300px; }
}
@media (max-width: 480px) {
  .vfi-banner,
  .wp-block-image img[alt="Vaerfel Idle intro"] { max-height: 220px; }
}

/* Modal styles */
@keyframes modalFadeIn {
  from { opacity: 0; transform: scale(0.9); }
  to { opacity: 1; transform: scale(1); }
}

#vfi-auth-modal .vfi-google-btn:hover {
  transform: translateY(-1px);
}

/* Auth button visibility - default state (logged out) */
a#vfi-account-link.wp-block-button__link {
  display: none !important;
}

a#vfi-login-btn.wp-block-button__link {
  display: inline-block !important;
}

button#vfi-logout-btn.wp-block-button__link {
  display: none !important;
}

/* Auth button visibility - logged in state */
body.vfi-logged-in a#vfi-account-link.wp-block-button__link {
  display: inline-block !important;
}

body.vfi-logged-in a#vfi-login-btn.wp-block-button__link {
  display: none !important;
}

body.vfi-logged-in button#vfi-logout-btn.wp-block-button__link {
  display: inline-block !important;
}


/* Account Page - Achievements */
.vfi-achievement {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  padding: 1.5rem;
  margin-bottom: 1rem;
  border-radius: 8px;
  background: var(--grad-neutral, #f5f5f5);
  border: 2px solid #8b6f47;
  transition: transform 0.2s, box-shadow 0.2s;
}

.vfi-achievement:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.vfi-achievement.unlocked {
  opacity: 1;
}

.vfi-achievement.locked {
  opacity: 0.5;
  filter: grayscale(1);
}

.achievement-icon {
  font-size: 3rem;
  min-width: 60px;
  text-align: center;
}

.achievement-content {
  flex: 1;
}

.achievement-title {
  margin: 0 0 0.5rem 0;
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--book-ink, #2c2416);
}

.achievement-description {
  margin: 0 0 0.5rem 0;
  color: #666;
  font-size: 0.95rem;
}

.achievement-date {
  color: #999;
  font-size: 0.85rem;
}

.achievement-locked {
  color: #999;
  font-style: italic;
  font-size: 0.85rem;
}

/* Rarity colors */
.vfi-achievement.rarity-common {
  border-color: #8b6f47;
}

.vfi-achievement.rarity-rare {
  border-color: #4a90e2;
  background: linear-gradient(135deg, #f5f5f5 0%, #e3f2fd 100%);
}

.vfi-achievement.rarity-epic {
  border-color: #9c27b0;
  background: linear-gradient(135deg, #f5f5f5 0%, #f3e5f5 100%);
}

.vfi-achievement.rarity-legendary {
  border-color: #ff9800;
  background: linear-gradient(135deg, #f5f5f5 0%, #fff3e0 100%);
}

/* Stats Grid */
.vfi-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1.5rem;
  margin-top: 1.5rem;
}

.vfi-stat {
  text-align: center;
  padding: 2rem;
  background: var(--grad-neutral, #f5f5f5);
  border: 2px solid #8b6f47;
  border-radius: 8px;
}

.stat-number {
  display: block;
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--book-ink, #2c2416);
  margin-bottom: 0.5rem;
}

.stat-label {
  display: block;
  font-size: 0.95rem;
  color: #666;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Responsive */
@media (max-width: 768px) {
  .vfi-achievement {
    flex-direction: column;
    text-align: center;
  }
  
  .achievement-icon {
    font-size: 2.5rem;
  }
  
  .vfi-stats-grid {
    grid-template-columns: 1fr;
  }
}
