/* =========================================================
   AW AO – DESIGN SYSTEM (Pro, cohérent, scoppé)
   Scope : pages module AW AO + widgets home
   ========================================================= */

/* -------------------------
   Variables / couleurs
------------------------- */
:root{
  --ao-font: "Inter", "Segoe UI", Roboto, Arial, sans-serif;

  --ao-text: #0f172a;
  --ao-muted: #64748b;

  --ao-border: #e2e8f0;
  --ao-bg: #ffffff;
  --ao-bg-soft: #f8fafc;

  /* Couleurs pro */
  --ao-blue:  #2563eb;    /* bleu primaire */
  --ao-blue-soft: #e8f1ff;

  --ao-green: #16a34a;    /* vert primary */
  --ao-green-soft: #e7f7ec;

  --ao-red:   #dc2626;    /* rouge alerte */
  --ao-red-soft: #ffe5e5;

  --ao-violet: #7c3aed;   /* violet famille */
  --ao-violet-soft: #f3e8ff;

  --ao-orange: #f59e0b;
  --ao-orange-soft: #fff3e6;
	
	  --ao-brand-blue: #0b5fa6;        /* bleu pro */
  --ao-brand-blue-dark: #08457a;
  --ao-brand-blue-soft: #e7f1fb;
  --ao-text-main: #0f172a;
  --ao-text-muted: #64748b;
}

/* Police fine & pro */
#module-aw_ao-ref,
#module-aw_ao-encours,
#module-aw_ao-region,
#module-aw_ao-departement,
#module-aw_ao-activity,
#module-aw_ao-activities,
.aw-ao-widget {
  font-family: var(--ao-font);
  color: var(--ao-text);
}

/* =========================================================
   MARKET CARD (encours + activité + widgets)
   ========================================================= */

/*
 * IMPORTANT:
 * Certains thèmes / overrides n'injectent pas toujours l'id body attendu
 * (module-aw_ao-region / module-aw_ao-departement). On garde les sélecteurs
 * scopés, mais on ajoute aussi un fallback global sur .ao-market-card.
 */

.ao-market-card{
  background: var(--ao-bg) !important;
  border: 1px solid var(--ao-border) !important;
  border-radius: 14px !important;
  padding: 16px 18px !important;
  margin-bottom: 16px !important;
  box-shadow: 0 6px 20px rgba(15, 23, 42, 0.04) !important;
  transition: all .18s ease !important;
}

.ao-market-card:hover{
  transform: translateY(-2px);
  border-color: #cbd5e1 !important;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.08) !important;
}

#module-aw_ao-encours .ao-market-card,
#module-aw_ao-region .ao-market-card,
#module-aw_ao-departement .ao-market-card,
#module-aw_ao-activity .ao-market-card,
#module-aw_ao-activities .ao-market-card,
.aw-ao-widget .ao-market-card{
  background: var(--ao-bg);
  border: 1px solid var(--ao-border);
  border-radius: 14px;
  padding: 16px 18px;
  margin-bottom: 16px;
  box-shadow: 0 6px 20px rgba(15, 23, 42, 0.04);
  transition: all .18s ease;
}

#module-aw_ao-encours .ao-market-card:hover,
#module-aw_ao-region .ao-market-card:hover,
#module-aw_ao-departement .ao-market-card:hover,
#module-aw_ao-activity .ao-market-card:hover,
#module-aw_ao-activities .ao-market-card:hover,
.aw-ao-widget .ao-market-card:hover{
  transform: translateY(-2px);
  border-color: #cbd5e1;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.08);
}

/* HEADER */
.ao-market-header{
  display:flex;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}

.ao-market-title{
  font-size:15px;
  font-weight:700;
  margin:0;
  line-height:1.3;
}

.ao-market-title a{
  color: var(--ao-text) !important;
  text-decoration:none !important;
}

.ao-market-title a:hover{
  color: var(--ao-blue) !important;
}

/* DEADLINE (date limite) */
.ao-market-deadline{
  text-align:right;
  min-width:190px;
  flex:0 0 auto;
}

.ao-market-deadline span{
  display:block;
  font-size:11px;
  color: #aa0717;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.02em;
}

.ao-datelimite{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top:4px;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  background: var(--ao-red-soft);
  color: var(--ao-red);
  border: 1px solid #fecaca;
}

/* INFOS TAGS */
.ao-market-infos{
  margin-top:10px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

/* TAGS (span ou a) */
.ao-tag,
a.ao-tag{
  display:inline-flex !important;
  align-items:center;
  padding:6px 12px !important;
  border-radius:999px !important;
  font-size:12px !important;
  font-weight:700 !important;
  line-height:1 !important;
  border: 1px solid transparent !important;
  text-decoration:none !important;
  white-space:nowrap !important;
  transition: all .15s ease;
}

/* Famille = violet clair */
.ao-tag-family,
a.ao-tag-family{
  background: var(--ao-violet-soft) !important;
  border-color: #e9d5ff !important;
  color: var(--ao-violet) !important;
}

/* Type = bleu clair */
.ao-tag-type,
a.ao-tag-type{
  background: var(--ao-blue-soft) !important;
  border-color: #cfe3ff !important;
  color: var(--ao-blue) !important;
}

/* Département = vert clair */
.ao-tag-dep,
a.ao-tag-dep{
  background: var(--ao-green-soft) !important;
  border-color: #bbf7d0 !important;
  color: var(--ao-green) !important;
}

/* Publié = vert clair (spécifique) */
.ao-tag-date, a.ao-tag-date {
    background: #232323 !important;
    border-color: #dee2e6 !important;
    color: #dee2e6 !important;
}

/* Descripteurs = orange doux */
.ao-tag-desc,
a.ao-tag-desc{
  background: var(--ao-orange-soft) !important;
  border-color: #fde68a !important;
  color: #92400e !important;
  white-space: normal !important;
  line-height: 1.2 !important;
}

/* Hover tags */
a.ao-tag:hover{
  transform: translateY(-1px);
  filter: brightness(.98);
}

/* =========================================================
   ACTIONS (boutons)
   ========================================================= */
.ao-market-actions{
  margin-top:14px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}

/* Bouton base */
a.ao-btn,
.ao-btn{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:8px;

  padding:10px 14px !important;
  border-radius:12px !important;

  font-size:13px !important;
  font-weight:800 !important;
  line-height:1 !important;

  border:1px solid transparent !important;
  text-decoration:none !important;
  white-space:nowrap !important;

  width:auto !important;
  max-width:240px !important;
  transition: all .15s ease;
}

/* Bleu = CTA principal */
a.ao-btn-primary{
  background: var(--ao-blue) !important;
  border-color: var(--ao-blue) !important;
  color:#fff !important;
}
a.ao-btn-primary:hover{
  background:#1d4ed8 !important;
  border-color:#1d4ed8 !important;
  transform: translateY(-1px);
}

/* Vert = secondaire */
a.ao-btn-secondary{
 /* background: var(--ao-green-soft) !important;*/
  border-color:#28208D !important;
  /*color: var(--ao-green) !important;*/
}
a.ao-btn-secondary:hover{
  /*background:#416EE8 !important;*/
  transform: translateY(-1px);
}

/* Rouge clair = action importante (si besoin) */
a.ao-btn-danger{
  background: var(--ao-red-soft) !important;
  border-color:#fecaca !important;
  color: var(--ao-red) !important;
}
a.ao-btn-danger:hover{
  background:#fecaca !important;
  transform: translateY(-1px);
}

/* Outline */
a.ao-btn-outline{
  background: #fff !important;
  border:1px solid #cbd5e1 !important;
  color: var(--ao-text) !important;
}
a.ao-btn-outline:hover{
  background: var(--ao-bg-soft) !important;
  transform: translateY(-1px);
}

/* Fix visited (souvent le thème écrase les couleurs) */
a.ao-btn:visited,
a.ao-btn:active,
a.ao-btn:focus{
  /*color: inherit !important;*/
  text-decoration:none !important;
}


/* Responsive */
@media(max-width:576px){
  .ao-market-actions a.ao-btn{
    width:100% !important;
    max-width:100% !important;
  }
}

/* =========================================================
   PAGE REF – Deadline box rouge à droite
   ========================================================= */
#module-aw_ao-ref .ao-deadline-box{
  background: var(--ao-red-soft) !important;
  border: 2px solid #fecaca !important;
  border-radius: 14px !important;
  padding: 12px 14px !important;
  text-align:right;
  min-width:220px;
}

#module-aw_ao-ref .ao-deadline-label{
  font-size:12px;
  font-weight:700;
  color:#991b1b;
}

#module-aw_ao-ref .ao-deadline-value{
  font-size:18px;
  font-weight:900;
  color: var(--ao-red);
}


.ao-header-btn,  .ao-header-btn {
    display: inline-flex;
    align-items: center;
    font-size: 13px;
    font-weight: 800;
    box-shadow: rgba(220, 38, 38, 0.18) 0px 6px 16px;
    color: rgb(255, 255, 255) !important;
    gap: 8px;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgb(220, 38, 38);
    text-decoration: none !important;
}


/* =========================================================
   FIX THEME OVERRIDES : liens ao-btn sur ref
========================================================= */

/* Base */
#module-aw_ao-ref a.ao-btn{
  text-decoration:none !important;
  outline:none !important;
}

/* Force les couleurs sur tous les états */
#module-aw_ao-ref a.ao-btn:link,
#module-aw_ao-ref a.ao-btn:visited,
#module-aw_ao-ref a.ao-btn:hover,
#module-aw_ao-ref a.ao-btn:active,
#module-aw_ao-ref a.ao-btn:focus{
  text-decoration:none !important;
  box-shadow:none !important;
}

/* Couleurs par type - FORCE */
#module-aw_ao-ref a.ao-btn-blue:link,
#module-aw_ao-ref a.ao-btn-blue:visited,
#module-aw_ao-ref a.ao-btn-blue:focus,
#module-aw_ao-ref a.ao-btn-blue:active{
  background:#2f73ff !important;
  color:#fff !important;
  border-color:#2f73ff !important;
}

/* Rouge clair pro */
#module-aw_ao-ref a.ao-btn-red:link,
#module-aw_ao-ref a.ao-btn-red:visited,
#module-aw_ao-ref a.ao-btn-red:focus,
#module-aw_ao-ref a.ao-btn-red:active{
  background:#ffe5e5 !important;
  color:#b91c1c !important;
  border:1px solid #ffb3b3 !important;
}

/* Vert clair pro */
#module-aw_ao-ref a.ao-btn-green:link,
#module-aw_ao-ref a.ao-btn-green:visited,
#module-aw_ao-ref a.ao-btn-green:focus,
#module-aw_ao-ref a.ao-btn-green:active{
  background:#dff7ea !important;
  color:#0f7b3e !important;
  border:1px solid #b8eed3 !important;
}

/* Outline */
#module-aw_ao-ref a.ao-btn-outline:link,
#module-aw_ao-ref a.ao-btn-outline:visited,
#module-aw_ao-ref a.ao-btn-outline:focus,
#module-aw_ao-ref a.ao-btn-outline:active{
  background:#fff !important;
  color:#111827 !important;
  border:1px dashed #cbd5e1 !important;
}

/* Tag publié vert clair */
#module-aw_ao-ref .ao-tag-published,
#module-aw_ao-ref a.ao-tag-published{
  background:#dff7ea !important;
  color:#0f7b3e !important;
  border:1px solid #b8eed3 !important;
}

/* Tag type violet clair */
#module-aw_ao-ref .ao-tag-type,
#module-aw_ao-ref a.ao-tag-type{
  background:#f3e8ff !important;
  color:#6b21a8 !important;
  border:1px solid #e9d5ff !important;
}

/* Tag main bleu clair */
#module-aw_ao-ref .ao-tag-main,
#module-aw_ao-ref a.ao-tag-main{
  background:#e8f2ff !important;
  color:#1456b5 !important;
  border:1px solid #cfe3ff !important;
}

/* Tag budget (vert) */
#module-aw_ao-ref .ao-tag-emph,
#module-aw_ao-ref a.ao-tag-emph{
  background: rgba(16,185,129,.12) !important;
  color: #047857 !important;
  border: 1px solid rgba(16,185,129,.25) !important;
}

/* Tag visite / important (ambre) */
#module-aw_ao-ref .ao-tag-warn,
#module-aw_ao-ref a.ao-tag-warn{
  background: rgba(245,158,11,.12) !important;
  color: #92400e !important;
  border: 1px solid rgba(245,158,11,.25) !important;
}


/* Base des cartes widgets */
.ao-widget-topdep.card,
.ao-widget-topregions.card,
.ao-widget-top-tags.card,
.ao-widget-topcpv.card{
  border: 1px solid #e6eef7 !important;
  border-radius: 14px !important;
  box-shadow: 0 6px 20px rgba(15, 23, 42, 0.04) !important;
  background: #fff !important;
  overflow: hidden;
}

/* Body */
.ao-widget-topdep .card-body,
.ao-widget-topregions .card-body,
.ao-widget-top-tags .card-body,
.ao-widget-topcpv .card-body{
  padding: 18px 18px !important;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  color: var(--ao-text-main);
}

/* Titre widget */
.ao-widget-topdep h3,
.ao-widget-topregions h3,
.ao-widget-top-tags h3,
.ao-widget-topcpv h3{
  font-weight: 700 !important;
  font-size: 14px !important;
  letter-spacing: -0.2px;
  color: var(--ao-text-main) !important;
}

/* Bouton "Voir tous" */
.ao-widget-topdep a.btn,
.ao-widget-topregions a.btn,
.ao-widget-top-tags a.btn,
.ao-widget-topcpv a.btn{
  font-size: 12px !important;
  padding: 6px 10px !important;
  border-radius: 10px !important;
  font-weight: 700 !important;
  border: 1px solid #cfe3f7 !important;
  color: var(--ao-brand-blue) !important;
  background: #fff !important;
  text-decoration: none !important;
}

.ao-widget-topdep a.btn:hover,
.ao-widget-topregions a.btn:hover,
.ao-widget-top-tags a.btn:hover,
.ao-widget-topcpv a.btn:hover{
  background: var(--ao-brand-blue-soft) !important;
  border-color: #b9d8f3 !important;
  color: var(--ao-brand-blue-dark) !important;
}

/* Liste */
.ao-widget-topdep .list-group-item,
.ao-widget-topregions .list-group-item,
.ao-widget-top-tags .list-group-item,
.ao-widget-topcpv .list-group-item{
  border: none !important;
  border-bottom: 1px solid #eef3f8 !important;
  padding: 10px 0 !important;
  font-size: 13px !important;
  background: transparent !important;
}

.ao-widget-topdep .list-group-item:last-child,
.ao-widget-topregions .list-group-item:last-child,
.ao-widget-top-tags .list-group-item:last-child,
.ao-widget-topcpv .list-group-item:last-child{
  border-bottom: none !important;
}

/* Liens */
.ao-widget-topdep .list-group-item a,
.ao-widget-topregions .list-group-item a,
.ao-widget-top-tags .list-group-item a,
.ao-widget-topcpv .list-group-item a{
  font-weight: 600 !important;
  color: #0f2f4a !important;
  text-decoration: none !important;
  line-height: 1.25;
}

.ao-widget-topdep .list-group-item a:hover,
.ao-widget-topregions .list-group-item a:hover,
.ao-widget-top-tags .list-group-item a:hover,
.ao-widget-topcpv .list-group-item a:hover{
  color: var(--ao-brand-blue) !important;
  text-decoration: underline !important;
}

/* Badge compteur */
.ao-widget-topdep .badge,
.ao-widget-topregions .badge,
.ao-widget-top-tags .badge,
.ao-widget-topcpv .badge{
  background: var(--ao-brand-blue) !important;
  color: #fff !important;
  font-weight: 800 !important;
  font-size: 12px !important;
  padding: 6px 10px !important;
  border-radius: 999px !important;
  min-width: 46px;
  text-align: center;
  box-shadow: 0 4px 10px rgba(11, 95, 166, 0.16) !important;
}

/* Hover carte */
.ao-widget-topdep.card:hover,
.ao-widget-topregions.card:hover,
.ao-widget-top-tags.card:hover,
.ao-widget-topcpv.card:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.06) !important;
  transition: all .18s ease;
}


/* =====================================================
   CPV - STYLE PRO LISTE + RECHERCHE (AxiPerf / Marché Public)
   ===================================================== */

/* Scope : page CPV ou page qui contient la liste */
#module-aw_ao-cpvs .ao-search-wrapper,
#module-aw_ao-cpv  .ao-search-wrapper,
.ao-search-wrapper{
  margin-bottom: 14px;
}

/* Champ recherche */
#module-aw_ao-cpvs #ao-cpv-search,
#module-aw_ao-cpv  #ao-cpv-search,
#ao-cpv-search{
  width: 100%;
  padding: 11px 14px;
  border-radius: 10px;
  border: 1px solid #d8e3f2;
  background: #ffffff;
  font-size: 13px;
  font-weight: 500;
  color: #0b2d45;
  outline: none;
  transition: all .18s ease;
  box-shadow: 0 2px 10px rgba(0,0,0,0.03);
}

/* Focus pro */
#module-aw_ao-cpvs #ao-cpv-search:focus,
#module-aw_ao-cpv  #ao-cpv-search:focus,
#ao-cpv-search:focus{
  border-color: #2b73d6;
  box-shadow: 0 0 0 4px rgba(43,115,214,0.12);
}

/* Table CPV */
#module-aw_ao-cpvs .ao-cpv-table,
#module-aw_ao-cpv  .ao-cpv-table,
.ao-cpv-table{
  border: 1px solid #dbe7f3;
  border-radius: 14px;
  overflow: hidden;
  background: #ffffff;
  box-shadow: 0 8px 22px rgba(11,94,215,0.06);
}

/* Ligne CPV = lien */
#module-aw_ao-cpvs a.ao-cpv-line,
#module-aw_ao-cpv  a.ao-cpv-line,
a.ao-cpv-line{
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  text-decoration: none !important;
  border-bottom: 1px solid #eef3f8;
  transition: all .16s ease;
  position: relative;
}

/* Dernière ligne */
#module-aw_ao-cpvs a.ao-cpv-line:last-child,
#module-aw_ao-cpv  a.ao-cpv-line:last-child,
a.ao-cpv-line:last-child{
  border-bottom: none;
}

/* Hover */
#module-aw_ao-cpvs a.ao-cpv-line:hover,
#module-aw_ao-cpv  a.ao-cpv-line:hover,
a.ao-cpv-line:hover{
  background: #f5f9ff;
  transform: translateY(-1px);
}

/* Icône gauche (bullet) */
#module-aw_ao-cpvs a.ao-cpv-line::before,
#module-aw_ao-cpv  a.ao-cpv-line::before,
a.ao-cpv-line::before{
  content: "";
  width: 14px;
  height: 14px;
  background: #2b73d6;
  border-radius: 50%;
  box-shadow: 0 0 0 3px rgba(43,115,214,0.12);
  flex: 0 0 auto;
}

/* Code CPV */
#module-aw_ao-cpvs .ao-cpv-code,
#module-aw_ao-cpv  .ao-cpv-code,
.ao-cpv-code{
  min-width: 130px;
  font-weight: 750;
  font-size: 13px;
  color: #0b5ed7;
  letter-spacing: .2px;
}

/* Libellé CPV */
#module-aw_ao-cpvs .ao-cpv-label,
#module-aw_ao-cpv  .ao-cpv-label,
.ao-cpv-label{
  flex: 1;
  font-size: 13px;
  font-weight: 520;
  color: #0b2d45;
  line-height: 1.35;
}

/* Effet focus/accessibilité */
#module-aw_ao-cpvs a.ao-cpv-line:focus,
#module-aw_ao-cpv  a.ao-cpv-line:focus,
a.ao-cpv-line:focus{
  outline: none;
  background: #eef6ff;
}

/* Mobile : plus compact */
@media (max-width: 576px){
  #module-aw_ao-cpvs a.ao-cpv-line,
  #module-aw_ao-cpv  a.ao-cpv-line,
  a.ao-cpv-line{
    padding: 11px 12px;
  }

  #module-aw_ao-cpvs .ao-cpv-code,
  #module-aw_ao-cpv  .ao-cpv-code,
  .ao-cpv-code{
    min-width: 110px;
    font-size: 12px;
  }

  #module-aw_ao-cpvs .ao-cpv-label,
  #module-aw_ao-cpv  .ao-cpv-label,
  .ao-cpv-label{
    font-size: 12px;
  }
}


body#module-aw_ao-saved .card{
  border: 1px solid #e6eef7 !important;
  border-radius: 16px !important;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.05) !important;

/* =========================================================
   AW AO - UI PRO (Saved + Offers)
   ========================================================= */

/* Variables (tu peux ajuster) */
:root{
  --ao-primary: #0b5fa6;
  --ao-primary-soft: rgba(11, 95, 166, .08);
  --ao-text: #0f172a;
  --ao-muted: #64748b;
  --ao-border: #e6eef7;
  --ao-bg: #ffffff;
  --ao-shadow: 0 10px 30px rgba(15, 23, 42, 0.05);
  --ao-radius: 16px;
  --ao-radius-sm: 12px;
}

/* Typo globale pour les pages du module */
.ao-saved-page,
.ao-offer-page{
  font-family: -apple-system, BlinkMacSystemFont, "Inter", "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  color: var(--ao-text);
}

/* Titres (fins + pro) */
.ao-saved-page h1,
.ao-offer-page h1{
  font-weight: 650;
  letter-spacing: -0.02em;
  color: var(--ao-text);
}

.ao-saved-page .h4,
.ao-offer-page .h4{
  font-weight: 650;
}

/* Cards globales */
.ao-saved-list-card,
.ao-offer-card{
  border: 1px solid var(--ao-border);
  border-radius: var(--ao-radius);
  background: var(--ao-bg);
  box-shadow: var(--ao-shadow);
  overflow: hidden;
}

/* Header action buttons */
.ao-saved-actions .btn{
  border-radius: 999px;
  font-weight: 650;
  font-size: 13px;
  letter-spacing: -0.01em;
  padding: 10px 14px;
  line-height: 1.1;
  box-shadow: none !important;
}

/* Bouton primaire (plus élégant) */
.ao-saved-actions .btn-primary,
.ao-offer-page .btn-primary{
  background: var(--ao-primary);
  border-color: var(--ao-primary);
}

.ao-saved-actions .btn-primary:hover,
.ao-offer-page .btn-primary:hover{
  filter: brightness(0.95);
  transform: translateY(-1px);
  transition: all .18s ease;
}

/* Bouton outline */
.ao-saved-actions .btn-outline-primary,
.ao-offer-page .btn-outline-primary{
  border-color: rgba(11, 95, 166, .25);
  color: var(--ao-primary);
  background: #fff;
}

.ao-saved-actions .btn-outline-primary:hover,
.ao-offer-page .btn-outline-primary:hover{
  background: var(--ao-primary-soft);
  border-color: rgba(11, 95, 166, .35);
}

/* List items */
.ao-saved-list-card .list-group-item{
  border: none;
  border-bottom: 1px solid rgba(230, 238, 247, .8);
  padding: 14px 18px;
  background: transparent;
}

.ao-saved-list-card .list-group-item:last-child{
  border-bottom: none;
}

/* Titre marché */
.ao-saved-title a,
.ao-saved-list-card .list-group-item a{
  font-weight: 650;
  font-size: 14px;
  line-height: 1.25;
  color: var(--ao-text);
  text-decoration: none;
}

.ao-saved-title a:hover,
.ao-saved-list-card .list-group-item a:hover{
  color: var(--ao-primary);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Meta infos */
.ao-saved-list-card .text-muted,
.ao-offer-card .text-muted{
  color: var(--ao-muted) !important;
  font-size: 12.5px;
  font-weight: 450;
}

/* Badge */
.ao-saved-list-card .badge,
.ao-offer-page .badge{
  background: var(--ao-primary-soft) !important;
  color: var(--ao-primary) !important;
  border: 1px solid rgba(11, 95, 166, .18);
  font-weight: 700;
  font-size: 12px;
  padding: 7px 10px;
  border-radius: 999px;
}

/* Hover effect sur item */
.ao-saved-list-card .list-group-item:hover{
  background: rgba(11, 95, 166, 0.03);
  transition: background .15s ease;
}

/* Offer page */
.ao-offer-card .card-body{
  padding: 18px 18px;
}

.ao-offer-card p{
  font-size: 13.5px;
  color: var(--ao-text);
  font-weight: 450;
}

.ao-offer-card strong{
  font-weight: 700;
}

/* Alert style plus “soft” */
.ao-offer-page .alert{
  border-radius: var(--ao-radius-sm);
  border: 1px solid rgba(15, 23, 42, 0.08);
  font-size: 13px;
  font-weight: 500;
}

/* Form check */
.ao-offer-page .form-check-label{
  font-size: 13.5px;
  color: var(--ao-text);
  font-weight: 500;
}

.ao-offer-page .form-check-input{
  width: 18px;
  height: 18px;
}

/* Liens secondaires */
.ao-offer-page .btn-link{
  font-size: 13px;
  font-weight: 600;
  color: var(--ao-muted);
  text-decoration: none;
}

.ao-offer-page .btn-link:hover{
  color: var(--ao-primary);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Mobile responsive */
@media (max-width: 768px){
  .ao-saved-actions{
    flex-direction: column;
    width: 100%;
    gap: 8px;
  }
  .ao-saved-actions .btn{
    width: 100%;
    justify-content: center;
  }
  .ao-saved-list-card .list-group-item{
    padding: 14px 14px;
  }
}

/* ===== JSON tree (page ref) ===== */
.ao-json-wrap{max-height:520px;overflow:auto;padding:.75rem;border:1px solid rgba(0,0,0,.08);border-radius:8px;background:rgba(0,0,0,.02)}
.ao-json-level{list-style:none;margin:0;padding-left:1rem}
.ao-json-item{margin:.15rem 0}
.ao-json-key{font-weight:600}
.ao-json-sep{margin:0 .25rem;color:rgba(0,0,0,.5)}
.ao-json-val{word-break:break-word}
/* =========================================================
   MARKET DETAIL (REF) – lecture agréable (2 colonnes)
   ========================================================= */
#module-aw_ao-ref .ao-kvlist{
  display:grid;
  gap:10px;
}

#module-aw_ao-ref .ao-kvline{
  display:grid;
  grid-template-columns: minmax(180px, 32%) 1fr;
  gap:12px;
  padding:10px 12px;
  background: var(--ao-bg-soft);
  border: 1px solid var(--ao-border);
  border-radius: 12px;
}

#module-aw_ao-ref .ao-kvline .ao-k{
  font-size:12px;
  font-weight:700;
  color: var(--ao-text-muted);
}

#module-aw_ao-ref .ao-kvline .ao-v{
  font-size:14px;
  font-weight:600;
  color: var(--ao-text-main);
  overflow-wrap:anywhere;
}

@media (max-width: 576px){
  #module-aw_ao-ref .ao-kvline{
    grid-template-columns: 1fr;
  }
  #module-aw_ao-ref .ao-kvline .ao-v{
    font-weight:700;
  }
}

/* Debug repliable */
#module-aw_ao-ref details.ao-debug{
  border:1px solid var(--ao-border);
  border-radius:12px;
  background:#fff;
  padding:10px 12px;
}
#module-aw_ao-ref .ao-debug-summary{
  cursor:pointer;
  font-weight:800;
  color: var(--ao-text);
}
#module-aw_ao-ref .ao-debug-body{
  margin-top:10px;
}
#module-aw_ao-ref .ao-debug-body pre{
  max-height: 480px;
  overflow:auto;
  background:#0b1220;
  color:#d1e7ff;
  padding:12px;
  border-radius:12px;
  font-size:12px;
}

.aw-ao-results-list { display:flex; flex-direction:column; gap:16px; }

.aw-ao-market-card{
  background:#fff;
  border:1px solid #e6e6e6;
  border-radius:10px;
  box-shadow:0 2px 10px rgba(0,0,0,0.05);
  padding:16px;
}

.aw-ao-market-header{
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  align-items:flex-start;
  margin-bottom:10px;
}

.aw-ao-market-title{
  font-size:18px;
  font-weight:700;
  margin:0;
}

.aw-ao-market-title a{
  color:#111827;
  text-decoration:none;
}

.aw-ao-market-title a:hover{
  text-decoration:underline;
}

.aw-ao-market-deadline{
  text-align:right;
  font-size:12px;
  color:#6b7280;
}

.aw-ao-market-deadline strong{
  display:block;
  font-size:14px;
  color:#111827;
}

.ao-market-infos{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:10px 0;
}

.ao-tag{
  display:inline-block;
  padding:5px 10px;
  border-radius:999px;
  background:#f3f4f6;
  color:#374151;
  font-size:12px;
  font-weight:600;
}

.ao-market-actions{
  display:flex;
  gap:10px;
  justify-content:flex-end;
  margin-top:12px;
}

.ao-btn{
  display:inline-block;
  padding:8px 12px;
  border-radius:8px;
  text-decoration:none;
  font-weight:700;
  font-size:13px;
}

.ao-btn-primary{
  background:#2563eb;
  color:#fff;
}

.ao-btn-secondary{
  background:#f3f4f6;
  color:#111827;
  border:none;
}
	