/**
 * grand-line-app.css — Thème Grand Line pour les pages application
 * S'active via body.lt-gl-app (toutes pages hors accueil/acheter)
 * Dépend de loguetown-design-2026.css pour les variables de base.
 */

/* =====================================================================
   VARIABLES & BASE
   ===================================================================== */
body.lt-gl-app {
  --gl-gold:         #d4a017;
  --gl-gold-l:       #f0c842;
  --gl-gold-xl:      #ffe680;
  --gl-gold-dim:     rgba(212,160,23,0.55);
  --gl-ocean-0:      #050a1a;
  --gl-ocean-1:      #0a1628;
  --gl-ocean-2:      #0d1f3c;
  --gl-ocean-3:      #112244;
  --gl-text:         #e8e0d0;
  --gl-text-soft:    rgba(232,224,208,0.65);
  --gl-text-muted:   rgba(232,224,208,0.40);
  --gl-border:       rgba(212,160,23,0.16);
  --gl-border-mid:   rgba(212,160,23,0.28);
  --gl-border-hover: rgba(212,160,23,0.48);
  --gl-card:         rgba(10,22,40,0.75);
  --gl-card-hover:   rgba(13,31,60,0.88);
  --gl-ease:         cubic-bezier(0.16,1,0.3,1);
  --gl-gold-line-xs: rgba(212,160,23,0.04);
  --gl-gold-line-sm: rgba(212,160,23,0.06);
  --gl-gold-surface: rgba(212,160,23,0.08);
  --gl-gold-line: rgba(212,160,23,0.12);
  --gl-gold-line-soft: rgba(212,160,23,0.14);
  --gl-gold-line-medium: rgba(212,160,23,0.15);
  --gl-gold-line-strong: rgba(212,160,23,0.18);
  --gl-gold-glow: rgba(212,160,23,0.35);
  --gl-gold-hover: rgba(212,160,23,0.5);
  --gl-gold-shadow: rgba(212,160,23,0.6);
  --gl-black-shadow: rgba(0,0,0,0.4);
  --gl-black-shadow-strong: rgba(0,0,0,0.5);
  --gl-success-soft: #86efac;
  --gl-danger-soft: #fca5a5;
}

/* Fond global + lueurs ambiantes */
body.lt-gl-app {
  background: var(--gl-ocean-0);
  color: var(--gl-text);
  min-height: 100vh;
  min-height: 100dvh;
  font-family: Rajdhani, Inter, system-ui, sans-serif;
}

body.lt-gl-app::before {
  content: '';
  position: fixed;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 45% at 15% 10%, rgba(212,160,23,0.05) 0%, transparent 55%),
    radial-gradient(ellipse 70% 50% at 85% 90%, rgba(56,94,107,0.08) 0%, transparent 55%),
    radial-gradient(ellipse 60% 40% at 50% 50%, rgba(192,57,43,0.03) 0%, transparent 65%);
  pointer-events: none;
  z-index: 0;
}

/* =====================================================================
   COMPTE-LAYOUT (sidebar + contenu)
   ===================================================================== */
body.lt-gl-app .compte-layout {
  background: transparent;
  padding-top: 32px;
}

body.lt-gl-app .compte-content {
  background: transparent;
  min-height: 60vh;
}

/* Sidebar vitrine-side */
body.lt-gl-app .vitrine-side {
  background: linear-gradient(180deg, var(--gl-ocean-1) 0%, var(--gl-ocean-0) 100%);
  border: 1px solid var(--gl-border);
  border-radius: 18px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 8px 40px rgba(0,0,0,0.45);
  padding: 1.5rem 1.25rem;
}

body.lt-gl-app .vitrine-side__user {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-bottom: 1.25rem;
  margin-bottom: 1.25rem;
  border-bottom: 1px solid var(--gl-border);
}

body.lt-gl-app .vitrine-side__avatar {
  background: linear-gradient(135deg, var(--gl-ocean-2), var(--gl-ocean-3));
  border: 2px solid var(--gl-gold);
  box-shadow: 0 0 16px rgba(212,160,23,0.25);
  color: var(--gl-gold-l);
  font-family: Cinzel, serif;
  font-weight: 700;
}

body.lt-gl-app .vitrine-side__avatar-ring {
  border-color: var(--gl-gold);
  opacity: 0.5;
}

body.lt-gl-app .vitrine-side__name {
  color: var(--gl-text);
  font-family: Cinzel, serif;
  font-size: 0.95rem;
}

body.lt-gl-app .vitrine-side__nav .vitrine-side__item {
  color: var(--gl-text-soft);
  border-radius: 12px;
  padding: 10px 14px;
  transition: background 0.2s var(--gl-ease), color 0.2s var(--gl-ease), border-color 0.2s var(--gl-ease);
  border: 1px solid transparent;
  font-size: 0.92rem;
  font-weight: 600;
}

body.lt-gl-app .vitrine-side__nav .vitrine-side__item:hover {
  background: var(--gl-gold-surface);
  color: var(--gl-gold-l);
  border-color: var(--gl-border);
}

body.lt-gl-app .vitrine-side__nav .vitrine-side__item.is-active {
  background: linear-gradient(135deg, var(--gl-gold-line-strong), var(--gl-gold-surface));
  border-color: var(--gl-border-mid);
  color: var(--gl-gold-l);
  box-shadow: 0 0 12px var(--gl-gold-line);
}

/* =====================================================================
   DASHBOARD (mon-espace)
   ===================================================================== */
body.lt-gl-app .dashboard-lbc {
  background: transparent;
  padding-top: 32px;
  max-width: 1060px;
}

body.lt-gl-app .dashboard-profile-card,
body.lt-gl-app .dashboard-wallet-card {
  background: var(--gl-card);
  border: 1px solid var(--gl-border);
  border-radius: 18px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 8px 40px var(--gl-black-shadow), 0 1px 0 rgba(255,255,255,0.04) inset;
  color: var(--gl-text);
}

body.lt-gl-app .dashboard-profile-avatar {
  background: linear-gradient(135deg, var(--gl-ocean-2), var(--gl-ocean-3));
  border: 2px solid var(--gl-gold);
  color: var(--gl-gold-l);
  box-shadow: 0 0 20px rgba(212,160,23,0.22);
  font-family: Cinzel, serif;
}

body.lt-gl-app .dashboard-profile-name {
  color: var(--gl-text);
  font-family: Cinzel, serif;
  font-size: 1.1rem;
}

body.lt-gl-app .dashboard-profile-rating,
body.lt-gl-app .dashboard-profile-rating i {
  color: var(--gl-gold);
}

body.lt-gl-app .dashboard-profile-edit {
  color: var(--gl-gold-dim);
  transition: color 0.2s;
}
body.lt-gl-app .dashboard-profile-edit:hover { color: var(--gl-gold-l); }

body.lt-gl-app .dashboard-wallet-card::before {
  background: radial-gradient(circle at 15% 25%, var(--gl-gold-line) 0%, transparent 60%);
}

body.lt-gl-app .dashboard-wallet-title {
  color: var(--gl-text-muted);
  font-family: Cinzel, serif;
  font-size: 0.7rem;
  letter-spacing: 4px;
  text-transform: uppercase;
}

body.lt-gl-app .dashboard-wallet-amount {
  color: var(--gl-gold-l);
  font-family: Cinzel, serif;
  font-size: 2rem;
  font-weight: 700;
  text-shadow: 0 0 20px var(--gl-gold-glow);
}

body.lt-gl-app .dashboard-wallet-status {
  color: var(--gl-text-muted);
  font-size: 0.82rem;
}

/* Bandeau CTA */
body.lt-gl-app .dashboard-cta-banner {
  background: linear-gradient(135deg, var(--gl-gold-line-soft) 0%, var(--gl-gold-line-sm) 100%);
  border: 1px solid var(--gl-border-mid);
  border-radius: 18px;
  box-shadow: 0 4px 24px var(--gl-gold-surface);
}

body.lt-gl-app .dashboard-cta-title {
  color: var(--gl-text);
  font-family: Cinzel, serif;
}

body.lt-gl-app .dashboard-cta-subtitle { color: var(--gl-text-soft); }

body.lt-gl-app .dashboard-cta-btn {
  background: linear-gradient(135deg, var(--gl-gold-l), var(--gl-bronze, #b8860b));
  color: var(--gl-ocean-0);
  border: none;
  border-radius: 12px;
  font-family: Cinzel, serif;
  font-size: 0.78rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  font-weight: 700;
  padding: 0.85rem 1.6rem;
  box-shadow: 0 4px 20px var(--gl-gold-glow);
  transition: transform 0.2s var(--gl-ease), box-shadow 0.2s var(--gl-ease);
}
body.lt-gl-app .dashboard-cta-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 28px var(--gl-gold-hover);
  color: var(--gl-ocean-0);
  background: linear-gradient(135deg, var(--gl-gold-xl), var(--gl-gold));
}

/* Titre section cartes */
body.lt-gl-app .dashboard-cards-title {
  color: var(--gl-text);
  font-family: Cinzel, serif;
  font-size: 0.78rem;
  letter-spacing: 5px;
  text-transform: uppercase;
  opacity: 0.6;
}

/* Cartes fonctionnelles */
body.lt-gl-app .dashboard-func-card {
  background: var(--gl-card);
  border: 1px solid var(--gl-border);
  border-radius: 16px;
  color: var(--gl-text);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: 0 6px 28px rgba(0,0,0,0.35);
  transition: transform 0.25s var(--gl-ease), border-color 0.25s, box-shadow 0.25s var(--gl-ease), background 0.25s;
  overflow: hidden;
  position: relative;
}

body.lt-gl-app .dashboard-func-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--gl-gold-line-sm) 0%, transparent 60%);
  opacity: 0;
  transition: opacity 0.3s;
}

body.lt-gl-app .dashboard-func-card:hover {
  transform: translateY(-5px);
  border-color: var(--gl-border-mid);
  box-shadow: 0 16px 48px var(--gl-black-shadow-strong), 0 0 24px var(--gl-gold-surface);
  background: var(--gl-card-hover);
}

body.lt-gl-app .dashboard-func-card:hover::before { opacity: 1; }

body.lt-gl-app .dashboard-func-icon {
  background: var(--gl-gold-line);
  border: 1px solid var(--gl-border);
  color: var(--gl-gold);
  border-radius: 12px;
  box-shadow: 0 0 12px var(--gl-gold-line);
}

body.lt-gl-app .dashboard-func-card h3 {
  color: var(--gl-text);
  font-family: Cinzel, serif;
  font-size: 0.92rem;
}

body.lt-gl-app .dashboard-func-card p { color: var(--gl-text-soft); }

body.lt-gl-app .dashboard-func-badge {
  background: var(--gl-gold);
  color: var(--gl-ocean-0);
}

/* Bouton logout */
body.lt-gl-app .dashboard-logout-btn {
  color: var(--gl-text-muted);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px;
  padding: 10px 22px;
  font-size: 0.85rem;
  transition: color 0.2s, border-color 0.2s;
}
body.lt-gl-app .dashboard-logout-btn:hover {
  color: var(--gl-text-soft);
  border-color: rgba(255,255,255,0.16);
}

/* =====================================================================
   ACCOUNT-PAGE (pages avec sidebar)
   ===================================================================== */
body.lt-gl-app .account-page-header {
  background: linear-gradient(135deg, var(--gl-gold-line-soft) 0%, rgba(13,31,60,0.9) 100%);
  border: 1px solid var(--gl-border-mid);
  border-radius: 18px;
  color: var(--gl-text);
  box-shadow: 0 8px 32px var(--gl-black-shadow);
}

body.lt-gl-app .account-page-header h1,
body.lt-gl-app .account-page-header h2 {
  color: var(--gl-text);
  font-family: Cinzel, serif;
}

body.lt-gl-app .account-page-subtitle { color: var(--gl-text-soft); }

body.lt-gl-app .btn-account-primary {
  background: var(--gl-card);
  color: var(--gl-text);
  border: 1px solid var(--gl-border-mid);
  transition: transform 0.2s var(--gl-ease), box-shadow 0.2s;
}
body.lt-gl-app .btn-account-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px var(--gl-gold-line-strong);
  color: var(--gl-gold-l);
  border-color: var(--gl-border-hover);
}

body.lt-gl-app .account-page-content {
  background: transparent;
  color: var(--gl-text);
}

body.lt-gl-app .account-page-stats {
  background: var(--gl-card);
  border: 1px solid var(--gl-border);
  border-radius: 14px;
  color: var(--gl-text);
}

/* =====================================================================
   FORMULAIRES
   ===================================================================== */
body.lt-gl-app .form-group label,
body.lt-gl-app .gl-field label,
body.lt-gl-app .filter-field-centrale label {
  color: var(--gl-text-soft);
  font-family: Cinzel, serif;
  font-size: 0.72rem;
  letter-spacing: 2px;
  text-transform: uppercase;
}

body.lt-gl-app .form-group input,
body.lt-gl-app .form-group select,
body.lt-gl-app .form-group textarea,
body.lt-gl-app .lt-input,
body.lt-gl-app .filter-input {
  background: rgba(10,22,40,0.8);
  border: 1px solid var(--gl-border);
  border-radius: 10px;
  color: var(--gl-text);
  padding: 12px 16px;
  transition: border-color 0.2s, box-shadow 0.2s;
}

body.lt-gl-app .form-group input:focus,
body.lt-gl-app .form-group select:focus,
body.lt-gl-app .form-group textarea:focus,
body.lt-gl-app .lt-input:focus,
body.lt-gl-app .filter-input:focus {
  outline: none;
  border-color: var(--gl-gold);
  box-shadow: 0 0 0 3px var(--gl-gold-line-medium);
}

body.lt-gl-app .form-group input::placeholder,
body.lt-gl-app .lt-input::placeholder,
body.lt-gl-app .filter-input::placeholder {
  color: var(--gl-text-muted);
}

body.lt-gl-app .modern-btn.primary,
body.lt-gl-app button[type="submit"].modern-btn {
  background: linear-gradient(135deg, var(--gl-gold-l), var(--gl-bronze, #b8860b));
  color: var(--gl-ocean-0);
  border: none;
  border-radius: 12px;
  font-family: Cinzel, serif;
  font-size: 0.8rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  font-weight: 700;
  padding: 0.9rem 2rem;
  box-shadow: 0 4px 20px var(--gl-gold-glow);
  transition: transform 0.2s var(--gl-ease), box-shadow 0.2s;
}
body.lt-gl-app .modern-btn.primary:hover,
body.lt-gl-app button[type="submit"].modern-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 28px var(--gl-gold-hover);
}

/* =====================================================================
   AUTH CARDS (login, register)
   ===================================================================== */
body.lt-gl-app .modern-auth-container {
  background: transparent;
  min-height: 80vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem 1rem;
}

body.lt-gl-app .auth-card {
  background: linear-gradient(160deg, var(--gl-ocean-1) 0%, var(--gl-ocean-0) 100%);
  border: 1px solid var(--gl-border-mid);
  border-radius: 20px;
  box-shadow: 0 24px 72px rgba(0,0,0,0.55), 0 0 40px var(--gl-gold-line-sm);
  color: var(--gl-text);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

body.lt-gl-app .auth-header h1,
body.lt-gl-app .auth-header h2 {
  color: var(--gl-text);
  font-family: Cinzel, serif;
}

body.lt-gl-app .auth-header p { color: var(--gl-text-soft); }

body.lt-gl-app .auth-footer a { color: var(--gl-gold-dim); transition: color 0.2s; }
body.lt-gl-app .auth-footer a:hover { color: var(--gl-gold-l); }

body.lt-gl-app .input-icon { color: var(--gl-gold-dim); }

/* =====================================================================
   CARTES GÉNÉRIQUES (annonces, listings)
   ===================================================================== */
body.lt-gl-app .listing-card,
body.lt-gl-app .lt26-card,
body.lt-gl-app .lt-card {
  background: var(--gl-card);
  border: 1px solid var(--gl-border);
  border-radius: 16px;
  color: var(--gl-text);
  transition: transform 0.25s var(--gl-ease), border-color 0.25s, box-shadow 0.25s;
}

body.lt-gl-app .listing-card:hover,
body.lt-gl-app .lt26-card:hover,
body.lt-gl-app .lt-card:hover {
  transform: translateY(-4px);
  border-color: var(--gl-border-mid);
  box-shadow: 0 14px 44px var(--gl-black-shadow-strong);
}

/* =====================================================================
   PAGE SHELL GÉNÉRIQUE
   ===================================================================== */
body.lt-gl-app .page-shell,
body.lt-gl-app .lt26-page-wrap,
body.lt-gl-app .page-content-wrap {
  background: transparent;
}

body.lt-gl-app .lt26-section-title,
body.lt-gl-app .section-title,
body.lt-gl-app h1.lt26-serif,
body.lt-gl-app h2.lt26-serif {
  font-family: Cinzel, serif;
  color: var(--gl-text);
}

/* Lien standard sur fond sombre */
body.lt-gl-app a:not([class]) { color: var(--gl-gold-dim); }
body.lt-gl-app a:not([class]):hover { color: var(--gl-gold-l); }

/* =====================================================================
   ANIMATIONS — SCROLL REVEAL
   ===================================================================== */
.lt-app-rv {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.7s var(--gl-ease), transform 0.7s var(--gl-ease);
}
.lt-app-rv.lt-app-visible {
  opacity: 1;
  transform: none;
}
.lt-app-rv.lt-app-d1 { transition-delay: 0.10s; }
.lt-app-rv.lt-app-d2 { transition-delay: 0.20s; }
.lt-app-rv.lt-app-d3 { transition-delay: 0.30s; }
.lt-app-rv.lt-app-d4 { transition-delay: 0.45s; }

/* Shimmer sur avatar */
@keyframes lt-app-shimmer {
  0%   { background-position: -200% center; }
  100% { background-position:  200% center; }
}
body.lt-gl-app .vitrine-side__avatar,
body.lt-gl-app .dashboard-profile-avatar {
  position: relative;
  overflow: hidden;
}
body.lt-gl-app .vitrine-side__avatar::after,
body.lt-gl-app .dashboard-profile-avatar::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, var(--gl-gold-line-medium), transparent);
  background-size: 200% 100%;
  animation: lt-app-shimmer 2.5s ease-in-out infinite;
  border-radius: inherit;
}

/* Glow pulsant sur le bouton CTA */
@keyframes lt-app-glow-pulse {
  0%, 100% { box-shadow: 0 4px 20px var(--gl-gold-glow); }
  50%       { box-shadow: 0 4px 32px var(--gl-gold-shadow); }
}
body.lt-gl-app .dashboard-cta-btn {
  animation: lt-app-glow-pulse 3s ease-in-out infinite;
}
body.lt-gl-app .dashboard-cta-btn:hover {
  animation: none;
}

/* Ligne décorative dorée */
.lt-app-divider {
  width: 48px;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--gl-gold), transparent);
  margin: 1rem 0;
}

/* Curseur enrichi sur les cartes (cohérence avec accueil-grand-line) */
body.lt-gl-app .dashboard-func-card,
body.lt-gl-app .listing-card {
  cursor: pointer;
}

/* =====================================================================
   COMPTEURS ANIMÉS
   ===================================================================== */
.lt-app-counter {
  display: inline-block;
  font-variant-numeric: tabular-nums;
}

/* =====================================================================
   SIDEBAR — CTA ET INDICATEUR ACTIF
   ===================================================================== */
body.lt-gl-app .vitrine-side__indicator {
  background: var(--gl-gold);
  box-shadow: 0 0 8px var(--gl-gold-dim);
}

body.lt-gl-app .vitrine-side__cta {
  border-top-color: var(--gl-border);
}

body.lt-gl-app .vitrine-side__bar {
  background: var(--gl-gold-line);
}

body.lt-gl-app .vitrine-side__bar span {
  background: linear-gradient(90deg, var(--gl-gold), var(--gl-gold-l));
  box-shadow: 0 0 8px var(--gl-gold-glow);
}

body.lt-gl-app .lt26-mono--meta { color: var(--gl-text-muted); }
body.lt-gl-app .lt26-eyebrow { color: var(--gl-gold-dim); }

/* =====================================================================
   PAGE-SHELL & SECTIONS GÉNÉRIQUES
   ===================================================================== */
body.lt-gl-app .lt-section {
  background: transparent;
}

/* Tableaux */
body.lt-gl-app table {
  border-color: var(--gl-border);
  color: var(--gl-text);
}

body.lt-gl-app th {
  background: var(--gl-gold-surface);
  color: var(--gl-gold);
  font-family: Cinzel, serif;
  font-size: 0.72rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  border-color: var(--gl-border);
}

body.lt-gl-app td {
  border-color: var(--gl-border);
  color: var(--gl-text-soft);
}

body.lt-gl-app tbody tr:hover td {
  background: var(--gl-gold-line-xs);
}

/* Badges et tags */
body.lt-gl-app .badge,
body.lt-gl-app .tag {
  background: var(--gl-gold-line);
  border: 1px solid var(--gl-border);
  color: var(--gl-gold-l);
}

/* Alertes */
body.lt-gl-app .alert-success {
  background: rgba(22, 101, 52, 0.2);
  border-color: rgba(22, 163, 74, 0.25);
  color: var(--gl-success-soft);
}

body.lt-gl-app .alert-error,
body.lt-gl-app .alert-danger {
  background: rgba(185, 28, 28, 0.2);
  border-color: rgba(220, 38, 38, 0.25);
  color: var(--gl-danger-soft);
}

/* Séparateurs */
body.lt-gl-app hr {
  border-color: var(--gl-border);
}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 900px) {
  body.lt-gl-app .vitrine-side {
    border-radius: 14px;
    padding: 1rem;
  }
}

@media (max-width: 640px) {
  body.lt-gl-app .dashboard-wallet-amount { font-size: 1.6rem; }
  body.lt-gl-app .auth-card { border-radius: 16px; }
  body.lt-gl-app .dashboard-func-card { border-radius: 14px; }
}
