/* ====================================================================
   TERRITORIA — Thème personnalisé
   Palette : vert forêt + ocre/ambre (conquête) + parchemin (fond)
   Police  : Outfit (Google Fonts)
   ==================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap');

/* ── Variables de couleur ─────────────────────────────────────────── */
:root {
    /* Palette Territoria */
    --t-forest:        #2D6A4F;   /* vert forêt profond  */
    --t-forest-dark:   #1A3D2E;   /* vert très sombre    */
    --t-forest-mid:    #3B8462;   /* vert moyen           */
    --t-forest-light:  #52B788;   /* vert clair (succès) */
    --t-amber:         #C8820A;   /* ambre/or (conquête) */
    --t-amber-light:   #F4B942;   /* or clair (podium)   */
    --t-parchment:     #F2EFE7;   /* parchemin (fond)    */
    --t-parchment-mid: #E4DED3;   /* parchemin foncé     */
    --t-text:          #1C2B1F;   /* texte principal     */
    --t-text-muted:    #5A6E61;   /* texte secondaire    */

    /* Overrides Bootstrap 5.3 via CSS custom properties */
    --bs-primary:                  var(--t-forest);
    --bs-primary-rgb:              45, 106, 79;
    --bs-primary-text-emphasis:    var(--t-forest-dark);
    --bs-primary-bg-subtle:        #d4ede2;
    --bs-primary-border-subtle:    #a4d4bc;

    --bs-link-color:               var(--t-forest);
    --bs-link-hover-color:         var(--t-forest-dark);
    --bs-link-color-rgb:           45, 106, 79;

    --bs-body-font-family:         'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --bs-body-bg:                  var(--t-parchment);
    --bs-body-color:               var(--t-text);

    --bs-light:                    var(--t-parchment);
    --bs-light-rgb:                242, 239, 231;

    --bs-border-color:             #D5CFCA;
    --bs-border-color-translucent: rgba(28, 43, 31, 0.13);

    --bs-success-rgb:              82, 183, 136;
    --bs-warning-rgb:              200, 130, 10;
}

/* ── Typographie ──────────────────────────────────────────────────── */
body {
    font-family: var(--bs-body-font-family);
    letter-spacing: -0.01em;
    background-color: var(--t-parchment);
}

h1, h2, h3, h4, h5, h6 {
    letter-spacing: -0.025em;
    font-weight: 700;
}

/* ── Navbar ───────────────────────────────────────────────────────── */
.navbar.bg-primary,
nav.navbar.bg-primary {
    background-color: var(--t-forest-dark) !important;
    border-bottom: 2px solid var(--t-amber);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.22);
}

/* Liens de navigation */
.navbar .nav-link {
    position: relative;
    transition: color 0.15s;
}

.navbar .nav-link::after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--t-amber-light);
    border-radius: 2px;
    transform: scaleX(0);
    transition: transform 0.2s ease;
}

.navbar .nav-link:hover::after {
    transform: scaleX(1);
}

/* Avatar utilisateur */
.user-avatar {
    background: rgba(255, 255, 255, 0.14) !important;
    border: 2px solid var(--t-amber) !important;
    color: #fff !important;
    transition: background 0.15s, border-color 0.15s;
}

.user-avatar:hover {
    background: rgba(255, 255, 255, 0.28) !important;
    border-color: var(--t-amber-light) !important;
}

/* ── Boutons ──────────────────────────────────────────────────────── */
.btn-primary {
    background-color: var(--t-forest);
    border-color: var(--t-forest);
    font-weight: 600;
    letter-spacing: 0.01em;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
    background-color: var(--t-forest-dark);
    border-color: var(--t-forest-dark);
}

.btn-outline-primary {
    color: var(--t-forest);
    border-color: var(--t-forest);
}

.btn-outline-primary:hover {
    background-color: var(--t-forest);
    border-color: var(--t-forest);
}

.btn-outline-light:hover {
    color: var(--t-forest-dark);
}

/* ── Cards ────────────────────────────────────────────────────────── */
.card {
    border-color: var(--t-parchment-mid);
    border-radius: 0.8rem;
    background-color: #fff;
}

.card.shadow-sm {
    box-shadow: 0 2px 14px rgba(28, 43, 31, 0.09) !important;
}

.card-header {
    background-color: #fff;
    border-bottom-color: var(--t-parchment-mid);
    font-weight: 600;
    border-radius: 0.8rem 0.8rem 0 0 !important;
}

/* Cartes de métriques : bordure d'accentuation en haut */
.card.border-primary {
    border-top: 3px solid var(--t-forest) !important;
    border-left-color: var(--t-parchment-mid) !important;
    border-right-color: var(--t-parchment-mid) !important;
    border-bottom-color: var(--t-parchment-mid) !important;
}

/* ── Valeurs métriques ────────────────────────────────────────────── */
.metric-value {
    font-size: 1.8rem;
    font-weight: 800;
    letter-spacing: -0.04em;
    line-height: 1.1;
}

.metric-value.text-primary  { color: var(--t-forest)       !important; }
.metric-value.text-success  { color: var(--t-forest-mid)   !important; }
.metric-value.text-warning  { color: var(--t-amber)        !important; }

/* ── Zone de dépôt de fichier ─────────────────────────────────────── */
.drop-zone {
    border: 2px dashed var(--t-parchment-mid) !important;
    background: #fafaf8;
    border-radius: 0.8rem !important;
    transition: border-color 0.2s, background 0.2s;
}

.drop-zone:focus-within {
    border-color: var(--t-forest) !important;
    background: #f0f7f3;
}

/* ── Stats communauté (index) ─────────────────────────────────────── */
.fw-bold.fs-4.text-primary { color: var(--t-forest) !important; }
.fw-bold.fs-4.text-warning { color: var(--t-amber)  !important; }

/* ── Tableaux ─────────────────────────────────────────────────────── */
.table-light {
    --bs-table-color:    var(--t-text);
    --bs-table-bg:       #EDEAE2;
    --bs-table-border-color: var(--t-parchment-mid);
}

.table-hover > tbody > tr:hover > * {
    --bs-table-color-state: var(--t-text);
    background-color: rgba(45, 106, 79, 0.05) !important;
}

th[data-sort]:hover {
    background-color: rgba(45, 106, 79, 0.07) !important;
}

/* Lignes dépliables de l'historique par année */
.year-row:hover {
    background-color: rgba(45, 106, 79, 0.05) !important;
}

/* ── Onglets nav-tabs ─────────────────────────────────────────────── */
.nav-tabs {
    --bs-nav-tabs-border-color:             var(--t-parchment-mid);
    --bs-nav-tabs-link-active-color:        var(--t-forest);
    --bs-nav-tabs-link-active-bg:           var(--t-parchment);
    --bs-nav-tabs-link-active-border-color: var(--t-parchment-mid) var(--t-parchment-mid) var(--t-parchment);
}

.nav-tabs .nav-link {
    color: var(--t-text-muted);
    font-weight: 500;
}

.nav-tabs .nav-link:hover {
    color: var(--t-forest);
    border-color: transparent transparent var(--t-parchment-mid);
}

.nav-tabs .nav-link.active {
    color: var(--t-forest);
    font-weight: 700;
}

/* Sub-nav (historique) */
.bg-white.border-bottom {
    background-color: #faf9f7 !important;
    border-bottom-color: var(--t-parchment-mid) !important;
}

/* ── Badges Bootstrap ─────────────────────────────────────────────── */
.badge.bg-primary   { background-color: var(--t-forest) !important; }
.badge.bg-secondary { background-color: #7B8F81         !important; }

/* ── Classement (leaderboard) ─────────────────────────────────────── */
tr.podium-gold   { background-color: rgba(200, 130, 10, 0.09) !important; }
tr.podium-silver { background-color: rgba(150, 150, 150, 0.06) !important; }
tr.podium-bronze { background-color: rgba(140, 85, 25, 0.07) !important; }

.rank-gold   { color: var(--t-amber)       !important; }
.rank-silver { color: #A0A8A2              !important; }
.rank-bronze { color: #A06C2A              !important; }

/* ── Alertes ──────────────────────────────────────────────────────── */
.alert-secondary {
    background-color: var(--t-parchment-mid);
    border-color: #C8C3B8;
    color: var(--t-text-muted);
}

.alert-info {
    --bs-alert-color:        #1A4A3A;
    --bs-alert-bg:           #d7f0e4;
    --bs-alert-border-color: #a4d4bc;
}

/* ── Formulaires ──────────────────────────────────────────────────── */
.form-control:focus,
.form-select:focus {
    border-color: var(--t-forest-mid);
    box-shadow: 0 0 0 0.2rem rgba(45, 106, 79, 0.22);
}

.input-group > .btn-outline-primary {
    border-color: var(--t-forest);
}

/* ── Liens dans le menu déroulant ─────────────────────────────────── */
.dropdown-item:active,
.dropdown-item:focus {
    background-color: var(--t-forest);
    color: #fff;
}

/* Avatar dans le dropdown */
.dropdown-menu .user-avatar {
    background: var(--t-forest) !important;
    border-color: var(--t-forest) !important;
}

/* ── Page badges : styles spécifiques ────────────────────────────── */
.category-header {
    border-left: 4px solid var(--t-forest) !important;
    padding-left: 0.75rem;
}

.badge-card.obtained {
    background: linear-gradient(135deg, #fffbf0 0%, #fff5d6 100%) !important;
    border: 2px solid var(--t-amber) !important;
    box-shadow: 0 2px 8px rgba(200, 130, 10, 0.2) !important;
}

.badge-card.obtained:hover {
    box-shadow: 0 6px 16px rgba(200, 130, 10, 0.3) !important;
}

.badge-card.obtained .badge-img-wrap {
    border-color: var(--t-amber) !important;
    box-shadow: 0 0 0 3px rgba(200, 130, 10, 0.2) !important;
}

.obtained-at { color: var(--t-amber) !important; }

.progress-pill {
    background: var(--t-parchment-mid) !important;
    color: var(--t-text-muted) !important;
}

/* ── Spinner / indicateur HTMX ────────────────────────────────────── */
.spinner-border.text-primary { color: var(--t-forest) !important; }

/* ── Footer ───────────────────────────────────────────────────────── */
/* Les couleurs inline du footer sont surchargées via les balises style
   directement dans navbar.html (voir ci-dessous) */
