/* ===== PASTEF – Charte graphique officielle ===== */

:root {
  /* Couleurs primaires PASTEF */
  --pastef-green: #1b5e20;
  --pastef-green-dark: #0f4a2e;
  --pastef-green-light: #2e7d32;
  --pastef-red: #b71c1c;
  --pastef-red-dark: #8b0000;
  --pastef-red-light: #d32d2a;
  --pastef-cream: #faf8f3;
  --pastef-gold: #d4af37;

  /* Aliases sémantiques */
  --brand: var(--pastef-green);
  --brand-dark: var(--pastef-green-dark);
  --accent: var(--pastef-red);
}

* { box-sizing: border-box; }
body {
  font-family: "Inter", "Segoe UI", Roboto, system-ui, sans-serif;
  color: #1f2937;
  background: var(--pastef-cream);
}

/* =============================================================
   NAVBAR
   ============================================================= */
.navbar.pastef-nav {
  background: #ffffff;
  border-bottom: 4px solid var(--pastef-green);
  padding: .75rem 0;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .04);
}
.navbar.pastef-nav .navbar-brand {
  font-weight: 800;
  color: var(--pastef-green);
  letter-spacing: -.01em;
}
.navbar.pastef-nav .navbar-brand img {
  height: 48px;
  width: auto;
  margin-right: .65rem;
}
.navbar.pastef-nav .navbar-brand .brand-sub {
  display: block;
  font-size: .72rem;
  font-weight: 500;
  color: var(--pastef-red);
  letter-spacing: .02em;
  margin-top: -2px;
}
.navbar.pastef-nav .nav-link {
  color: #374151;
  font-weight: 500;
  padding: .5rem 1rem !important;
  border-radius: 8px;
  transition: background .15s, color .15s;
}
.navbar.pastef-nav .nav-link:hover,
.navbar.pastef-nav .nav-link.active {
  color: var(--pastef-green);
  background: rgba(27, 94, 32, .08);
}

/* =============================================================
   BOUTONS
   ============================================================= */
.btn-pastef,
.btn-primary {
  background: var(--pastef-green);
  border: 2px solid var(--pastef-green);
  color: #fff;
  font-weight: 700;
  padding: .65rem 1.4rem;
  border-radius: 10px;
  transition: transform .12s, background .15s, box-shadow .15s;
}
.btn-pastef:hover,
.btn-primary:hover {
  background: var(--pastef-green-dark);
  border-color: var(--pastef-green-dark);
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 8px 20px -10px rgba(15, 74, 46, .5);
}
.btn-pastef-accent {
  background: var(--pastef-red);
  border: 2px solid var(--pastef-red);
  color: #fff;
  font-weight: 700;
  padding: .65rem 1.4rem;
  border-radius: 10px;
}
.btn-pastef-accent:hover {
  background: var(--pastef-red-dark);
  border-color: var(--pastef-red-dark);
  color: #fff;
}
.btn-pastef-outline {
  background: transparent;
  color: var(--pastef-green);
  border: 2px solid var(--pastef-green);
  font-weight: 700;
  padding: .65rem 1.4rem;
  border-radius: 10px;
}
.btn-pastef-outline:hover {
  background: var(--pastef-green);
  color: #fff;
}

/* =============================================================
   HERO
   ============================================================= */
.hero {
  position: relative;
  background:
    radial-gradient(circle at top right, rgba(212, 175, 55, .15), transparent 50%),
    linear-gradient(135deg, var(--pastef-green-dark) 0%, var(--pastef-green) 100%);
  color: #fff;
  padding: 4rem 0 5rem;
  overflow: hidden;
}
.hero::after {
  /* Accent rouge en bas du hero */
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 6px;
  background: var(--pastef-red);
}
.hero h1 {
  font-weight: 800;
  letter-spacing: -.02em;
  font-size: clamp(2rem, 5vw, 3.4rem);
  margin-bottom: 1rem;
}
.hero p.lead {
  color: #e5e7eb;
  font-size: 1.1rem;
  max-width: 36rem;
}
.hero .hero-badge {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  background: var(--pastef-red);
  color: #fff;
  padding: .35rem .9rem;
  border-radius: 999px;
  font-weight: 700;
  font-size: .85rem;
  text-transform: uppercase;
  letter-spacing: .05em;
}

/* =============================================================
   PAGE TITLE (sous-titre cohérent)
   ============================================================= */
.page-title {
  background: #fff;
  border-bottom: 3px solid var(--pastef-green);
  padding: 1.75rem 0 1.25rem;
  margin-bottom: 2rem;
}
.page-title h1 { color: var(--pastef-green); font-weight: 800; margin: 0; }
.page-title .crumb {
  color: var(--pastef-red);
  font-size: .85rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
}

/* =============================================================
   CARTES (tiers)
   ============================================================= */
.tier-card {
  border-radius: 1.25rem;
  overflow: hidden;
  border: none;
  background: #fff;
  box-shadow: 0 18px 50px -25px rgba(15, 23, 42, .35);
  transition: transform .25s, box-shadow .25s;
}
.tier-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 30px 60px -25px rgba(15, 23, 42, .45);
}
.tier-card .tier-preview {
  aspect-ratio: 1.4 / 1;
  padding: 1.25rem;
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  overflow: hidden;
}
.tier-card .tier-preview::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top right, rgba(255,255,255,.15), transparent 60%);
}
.tier-bronze   { background: linear-gradient(135deg, #fafafa 0%, #f0f0f0 100%); }
.tier-bronze::before {
  content: "";
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 40%;
  background: var(--pastef-red);
  clip-path: polygon(0 30%, 100% 0, 100% 100%, 0 100%);
}
.tier-argent   { background: linear-gradient(135deg, #e5e5e5 0%, #c8c8c8 100%); }
.tier-argent::before {
  content: "";
  position: absolute;
  bottom: 0; left: 0;
  width: 35%; height: 100%;
  background: var(--pastef-green);
  clip-path: polygon(0 60%, 100% 100%, 0 100%);
}
.tier-gold     { background: linear-gradient(135deg, var(--pastef-green-dark) 0%, var(--pastef-green) 100%); }
.tier-gold::before {
  content: "";
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 30%;
  background: linear-gradient(180deg, var(--pastef-gold), #f4d575);
  clip-path: polygon(0 40%, 100% 20%, 100% 100%, 0 100%);
}
.tier-premium  { background: linear-gradient(135deg, var(--pastef-green-dark) 0%, #0a3d24 100%); }
.tier-premium::before {
  content: "👑";
  position: absolute;
  top: 1rem;
  right: 1rem;
  font-size: 1.6rem;
}

/* Bronze & Argent ont un fond clair : le texte du haut (PASTEF + sous-titre)
   doit être en vert pour rester lisible. */
.tier-card .tier-bronze > div:first-child,
.tier-card .tier-argent > div:first-child {
  color: var(--pastef-green-dark);
}
.tier-card .tier-bronze > div:first-child .opacity-75,
.tier-card .tier-argent > div:first-child .opacity-75 {
  opacity: 1 !important;
  color: var(--pastef-green);
}

/* Bronze : l'étiquette "CARTE" passe en vert (elle est juste au-dessus de la
   diagonale du ruban rouge), le nom du tier reste blanc (sur le ruban). */
.tier-card .tier-bronze > div:last-child > div:first-child {
  color: var(--pastef-green) !important;
  opacity: 1 !important;
}

/* Argent : tout le bloc du bas en vert (fond gris clair). */
.tier-card .tier-argent > div:last-child {
  color: var(--pastef-green-dark);
}
.tier-card .tier-argent > div:last-child .opacity-75 {
  opacity: 1 !important;
  color: var(--pastef-green);
}

.tier-price {
  font-size: 2rem;
  font-weight: 800;
  color: var(--pastef-green);
  letter-spacing: -.02em;
}
.tier-card .card-body {
  padding: 1.5rem 1.25rem;
}

/* =============================================================
   VÉRIFICATION (page publique)
   ============================================================= */
.verify-banner {
  border-radius: 1rem;
  padding: 1.5rem;
  font-weight: 600;
  border: 2px solid;
}
.verify-valid     { background: #f0fdf4; color: var(--pastef-green-dark); border-color: var(--pastef-green); }
.verify-warn      { background: #fffbeb; color: #92400e; border-color: #fbbf24; }
.verify-danger    { background: #fef2f2; color: var(--pastef-red-dark); border-color: var(--pastef-red); }

/* =============================================================
   STAT CARDS (secondary stats)
   ============================================================= */
.stat-card {
  border-radius: 1rem;
  border: none;
  background: #fff;
  box-shadow: 0 8px 30px -20px rgba(15, 23, 42, .3);
  border-left: 4px solid var(--pastef-green);
}
.stat-card .stat-value {
  font-size: 1.85rem;
  font-weight: 800;
  color: var(--pastef-green-dark);
}

/* =============================================================
   KPI CARDS (dashboard principal)
   ============================================================= */
.kpi-card {
  position: relative;
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.5rem;
  background: #fff;
  border-radius: 1rem;
  border: none;
  box-shadow: 0 8px 30px -20px rgba(15, 23, 42, .3);
  transition: transform .15s, box-shadow .15s;
  overflow: hidden;
}
.kpi-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 40px -22px rgba(15, 23, 42, .4);
}

/* KPI principal (vendu / montant total) */
.kpi-card-primary {
  background: linear-gradient(135deg, var(--pastef-green-dark) 0%, var(--pastef-green) 100%);
  color: #fff;
}
.kpi-card-primary .kpi-icon {
  background: rgba(255, 255, 255, .15);
  color: var(--pastef-gold);
}
.kpi-card-primary .kpi-label { color: rgba(255, 255, 255, .85); }
.kpi-card-primary .kpi-trend { color: rgba(255, 255, 255, .85); }
.kpi-card-primary .text-muted { color: rgba(255, 255, 255, .65) !important; }

.kpi-icon {
  flex: 0 0 64px;
  width: 64px;
  height: 64px;
  border-radius: 16px;
  background: rgba(27, 94, 32, .1);
  color: var(--pastef-green);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
}
.kpi-body { flex: 1; min-width: 0; }
.kpi-label {
  text-transform: uppercase;
  letter-spacing: .05em;
  font-size: .72rem;
  font-weight: 700;
  color: #6b7280;
  margin-bottom: .25rem;
}
.kpi-value {
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: 800;
  letter-spacing: -.02em;
  line-height: 1.1;
}
.kpi-unit {
  font-size: .65em;
  font-weight: 600;
  margin-left: .25rem;
  opacity: .8;
}
.kpi-trend {
  font-size: .78rem;
  margin-top: .35rem;
}
.kpi-sub {
  font-size: .78rem;
  color: #6b7280;
  margin-top: .2rem;
}

/* Variante compacte pour les KPI par tier (moins de padding, valeur un peu plus petite) */
.kpi-tier-compact { padding: 1rem 1rem 1rem 1.25rem; }
.kpi-tier-compact .kpi-value { font-size: clamp(1.4rem, 2vw, 1.8rem); }
.kpi-tier-compact .kpi-label { font-size: .68rem; }

/* Indicateurs de tendance */
.trend-up   { color: #10b981; font-weight: 700; }
.trend-down { color: #ef4444; font-weight: 700; }
.trend-flat { color: #6b7280; font-weight: 600; }
.kpi-card-primary .trend-up   { color: #6ee7b7; }
.kpi-card-primary .trend-down { color: #fca5a5; }
.kpi-card-primary .trend-flat { color: rgba(255, 255, 255, .7); }

/* KPI par tier — bande colorée à gauche, valeur en couleur de la marque */
.kpi-tier {
  padding-left: 1rem;
}
.kpi-tier-strip {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 6px;
  border-top-left-radius: 1rem;
  border-bottom-left-radius: 1rem;
}
.kpi-tier-bronze  .kpi-tier-strip { background: linear-gradient(180deg, #b45309, #f59e0b); }
.kpi-tier-argent  .kpi-tier-strip { background: linear-gradient(180deg, #6b7280, #cbd5e1); }
.kpi-tier-gold    .kpi-tier-strip { background: linear-gradient(180deg, var(--pastef-gold), #f4d575); }
.kpi-tier-premium .kpi-tier-strip {
  background: linear-gradient(180deg, var(--pastef-green-dark), var(--pastef-gold));
}
.kpi-tier-bronze  .kpi-value { color: #b45309; }
.kpi-tier-argent  .kpi-value { color: #6b7280; }
.kpi-tier-gold    .kpi-value { color: #92400e; }
.kpi-tier-premium .kpi-value { color: var(--pastef-green-dark); }
.kpi-tier .kpi-label {
  color: var(--pastef-green-dark);
}

/* =============================================================
   BAR CHART (répartition par tier)
   ============================================================= */
.tier-bar-chart {
  display: flex;
  flex-direction: column;
  gap: .85rem;
}
.tier-bar-row {
  display: grid;
  grid-template-columns: 90px 1fr 48px;
  align-items: center;
  gap: .75rem;
}
.tier-bar-label {
  font-weight: 700;
  font-size: .85rem;
  text-align: right;
}
.tier-label-bronze  { color: #b45309; }
.tier-label-argent  { color: #6b7280; }
.tier-label-gold    { color: #92400e; }
.tier-label-premium { color: var(--pastef-green-dark); }

.tier-bar-track {
  background: #f1f5f9;
  border-radius: 999px;
  height: 22px;
  overflow: hidden;
}
.tier-bar-fill {
  height: 100%;
  border-radius: 999px;
  transition: width .4s ease;
  min-width: 4px;
}
.tier-fill-bronze  { background: linear-gradient(90deg, #b45309, #f59e0b); }
.tier-fill-argent  { background: linear-gradient(90deg, #6b7280, #cbd5e1); }
.tier-fill-gold    { background: linear-gradient(90deg, #92400e, var(--pastef-gold)); }
.tier-fill-premium { background: linear-gradient(90deg, var(--pastef-green-dark), var(--pastef-gold)); }

.tier-bar-value {
  font-weight: 700;
  font-size: .9rem;
  text-align: right;
  color: var(--pastef-green-dark);
}

/* Responsive : sur très petit écran le bar chart se compacte */
@media (max-width: 480px) {
  .tier-bar-row { grid-template-columns: 70px 1fr 40px; gap: .5rem; }
  .tier-bar-label { font-size: .75rem; }
  .kpi-icon { flex-basis: 48px; width: 48px; height: 48px; font-size: 1.5rem; border-radius: 12px; }
  .kpi-card { padding: 1rem; gap: .75rem; }
}

/* =============================================================
   FORMULAIRES
   ============================================================= */
.form-control:focus {
  border-color: var(--pastef-green);
  box-shadow: 0 0 0 .2rem rgba(27, 94, 32, .15);
}
.form-label {
  font-weight: 600;
  color: #374151;
}

/* =============================================================
   ALERTS / BADGES
   ============================================================= */
.alert-pastef {
  background: rgba(27, 94, 32, .08);
  color: var(--pastef-green-dark);
  border: 1px solid rgba(27, 94, 32, .25);
  border-left: 4px solid var(--pastef-green);
  border-radius: 12px;
}

.badge.bg-pastef { background: var(--pastef-green) !important; color: #fff; }
.badge.bg-pastef-accent { background: var(--pastef-red) !important; color: #fff; }

/* =============================================================
   FOOTER
   ============================================================= */
footer.pastef-footer {
  background: var(--pastef-green-dark);
  color: rgba(255, 255, 255, .85);
  padding: 2.5rem 0 1.5rem;
  border-top: 6px solid var(--pastef-red);
}
footer.pastef-footer a { color: var(--pastef-gold); text-decoration: none; }
footer.pastef-footer a:hover { color: #fff; text-decoration: underline; }

/* =============================================================
   MISC
   ============================================================= */
.mini-card { border-radius: .5rem; height: 60px; object-fit: cover; }
.text-pastef { color: var(--pastef-green) !important; }
.text-pastef-accent { color: var(--pastef-red) !important; }
.bg-pastef-soft { background: rgba(27, 94, 32, .06); }

/* Animated underline for links */
.link-pastef {
  color: var(--pastef-green);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: border-color .15s;
}
.link-pastef:hover { border-bottom-color: var(--pastef-red); color: var(--pastef-green-dark); }

/* =============================================================
   RESPONSIVE — tablette / mobile
   ============================================================= */
@media (max-width: 991.98px) {
  /* Tablette : navbar verticale repliée → boutons à pleine largeur */
  .navbar.pastef-nav .navbar-nav { padding-top: .75rem; gap: .25rem; }
  .navbar.pastef-nav .btn { width: 100%; text-align: center; }
  .navbar.pastef-nav .brand-sub { display: none; } /* gagne de la place */
}

@media (max-width: 767.98px) {
  /* Mobile : compacter le hero et les sections */
  .hero { padding: 2.5rem 0 3rem; }
  .hero .lead { font-size: 1rem; }
  .hero .btn-lg { width: 100%; }
  .hero .btn-lg + .btn-lg { margin-top: .5rem; }

  /* Page-title plus aéré sur mobile */
  .page-title { padding: 1.25rem 0; margin-bottom: 1.25rem; }
  .page-title h1 { font-size: 1.4rem; }
  .page-title .btn { width: 100%; margin-top: .5rem; }

  /* Tuiles de tier prennent toute la largeur dispo */
  .tier-card { margin-bottom: 1rem; }

  /* Boutons de téléchargement de carte en colonne sur mobile */
  .card-body .d-flex.gap-2.flex-wrap .btn { flex: 1 1 100%; }

  /* Tables horizontalement scrollables (déjà géré par .table-responsive
     mais on s'assure que les cellules ne wrappent pas n'importe comment) */
  .table th, .table td { white-space: nowrap; }
  .table td.fw-semibold, .table td:first-child { white-space: normal; }

  /* Récap formule au-dessus du formulaire d'achat */
  .tier-price { font-size: 1.5rem; }

  /* Footer compacté */
  footer.pastef-footer { padding: 1.5rem 0 1rem; }
  footer.pastef-footer .col-md-6 { text-align: center; }
}

@media (max-width: 575.98px) {
  /* Téléphones étroits : aérer encore plus */
  h1 { font-size: 1.6rem !important; }
  .stat-card .stat-value { font-size: 1.4rem; }
  .navbar.pastef-nav .navbar-brand img { height: 38px; }
  .navbar.pastef-nav .navbar-brand { font-size: 1rem; }
}

/* Images & médias : ne jamais déborder */
img { max-width: 100%; height: auto; }

/* Garantir que les éléments d'aperçu de carte (tier-preview) ne se déforment
   pas si l'aspect-ratio n'est pas supporté (anciens navigateurs). */
@supports not (aspect-ratio: 1) {
  .tier-card .tier-preview { min-height: 180px; }
}
