/**
 * Agency Dashboard — Design "Elite 2026"
 * Structure atomique : variables, boutons, toolbar, cartes Bento.
 * Chargé uniquement sur page-agency-dashboard.php.
 */

/* ==========================================================================
   1. IDENTITÉ VISUELLE — Light Mode "Pro" (jumeau Premium Dashboard)
   ========================================================================== */
#avision-dashboard-root.agency-dashboard-root {
	--avi-navy: #0a0f1d;
	--avi-navy-light: #111827;
	--avi-indigo: #6366f1;
	--avi-indigo-light: #818cf8;
	--avi-indigo-glow: rgba(99, 102, 241, 0.45);
	--avi-gold: #d4af37;
	--avi-gold-soft: rgba(212, 175, 55, 0.2);
	--avi-gold-pill: linear-gradient(135deg, #d4af37 0%, #c9a227 50%, #b8960c 100%);
	--avi-text-on-navy: #e2e8f0;
	--avi-text-muted-on-navy: #94a3b8;
	--avi-border-navy: rgba(255, 255, 255, 0.08);
	--agency-page-bg: #f8fafc;
	--agency-card-bg: #ffffff;
	--agency-card-border: #e2e8f0;
	--agency-card-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
	--agency-text-main: #0f172a;
	--agency-text-muted: #64748b;
}

/* Fond de page : gris très clair (Light Mode) */
#avision-dashboard-root.agency-dashboard-root,
#avision-dashboard-root.agency-dashboard-root .container,
#avision-dashboard-root.agency-dashboard-root .dashboard-main,
#avision-dashboard-root.agency-dashboard-root .agency-fiches-section {
	background: var(--agency-page-bg);
}
#avision-dashboard-root.agency-dashboard-root .agency-fiches-section h2,
#avision-dashboard-root.agency-dashboard-root .agency-fiches-section p {
	color: var(--agency-text-main);
}
#avision-dashboard-root.agency-dashboard-root .agency-fiches-section p {
	color: var(--agency-text-muted);
}

/* ==========================================================================
   2. BOUTONS — Zéro "Années 2000"
   ========================================================================== */

/* Principal : gradient Indigo, 8px, ombre + glow hover */
.btn-avi-main,
#avision-dashboard-root.agency-dashboard-root .btn-primary,
#avision-dashboard-root.agency-dashboard-root .btn-view-dashboard {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 8px 16px;
	border: none;
	border-radius: 8px;
	font-weight: 700;
	font-size: 0.875rem;
	cursor: pointer;
	text-decoration: none;
	background: linear-gradient(135deg, #4f46e5 0%, #6366f1 50%, #4338ca 100%);
	color: #fff;
	box-shadow: 0 2px 8px rgba(99, 102, 241, 0.35);
	transition: box-shadow 0.25s ease, transform 0.2s ease;
}
.btn-avi-main:hover,
#avision-dashboard-root.agency-dashboard-root .btn-primary:hover,
#avision-dashboard-root.agency-dashboard-root .btn-view-dashboard:hover {
	box-shadow: 0 4px 20px var(--avi-indigo-glow), 0 0 32px rgba(99, 102, 241, 0.25);
	transform: translateY(-1px);
	color: #fff;
}

/* Outline : bordure fine Indigo, fond transparent */
.btn-avi-outline,
#avision-dashboard-root.agency-dashboard-root .btn-outline {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 8px 16px;
	border: 1px solid var(--avi-indigo);
	border-radius: 8px;
	font-weight: 600;
	font-size: 0.875rem;
	cursor: pointer;
	text-decoration: none;
	background: transparent;
	color: var(--avi-indigo-light);
	transition: background 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}
.btn-avi-outline:hover,
#avision-dashboard-root.agency-dashboard-root .btn-outline:hover {
	background: rgba(99, 102, 241, 0.12);
	color: #fff;
}

/* Carte : bouton Voir Dashboard (réutilise .btn-view-dashboard ci‑dessus) */
#avision-dashboard-root.agency-dashboard-root .agency-client-card .btn-view-dashboard {
	width: 100%;
	margin-top: auto;
	padding: 6px 12px;
	font-size: 0.8rem;
}

/* Connecter Google = style principal */
#avision-dashboard-root.agency-dashboard-root .btn-connect-google-agency {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 10px 20px;
	margin-right: 20px;
	border: none;
	border-radius: 8px;
	font-weight: 700;
	font-size: 0.95rem;
	cursor: pointer;
	background: linear-gradient(135deg, #4f46e5 0%, #6366f1 50%, #4338ca 100%);
	color: #fff;
	box-shadow: 0 2px 12px var(--avi-indigo-glow);
	transition: box-shadow 0.25s ease, transform 0.2s ease;
}
#avision-dashboard-root.agency-dashboard-root .btn-connect-google-agency:hover {
	box-shadow: 0 4px 24px var(--avi-indigo-glow), 0 0 32px rgba(99, 102, 241, 0.2);
	transform: translateY(-1px);
	color: #fff;
}
#avision-dashboard-root.agency-dashboard-root .btn-connect-google-agency.connected {
	background: rgba(34, 197, 94, 0.2);
	border: 1px solid #22c55e;
	color: #4ade80;
	box-shadow: none;
}

/* ==========================================================================
   3. NAV & HEADER (barre fine)
   ========================================================================== */
#avision-dashboard-root.agency-dashboard-root .top-nav {
	background: var(--avi-navy);
	border-bottom: 1px solid var(--avi-border-navy);
	min-height: 56px;
	padding: 0 20px;
}
#avision-dashboard-root.agency-dashboard-root .top-nav .logo { color: var(--avi-text-on-navy); }
#avision-dashboard-root.agency-dashboard-root .top-nav .logo .avision-header-logo-img {
	display: block;
	width: auto;
	height: auto;
	max-width: 2.5rem;
	max-height: 2.5rem;
	object-fit: contain;
	aspect-ratio: 1 / 1;
}
#avision-dashboard-root.agency-dashboard-root .top-nav .user-profile-trigger {
	background: rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	color: var(--avi-text-on-navy);
}
#avision-dashboard-root.agency-dashboard-root .top-nav .user-profile-trigger:hover {
	background: rgba(255, 255, 255, 0.15);
}
#avision-dashboard-root.agency-dashboard-root .nav-right .header-flags {
	background: rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	color: var(--avi-text-muted-on-navy);
}

/* Header : seul bloc restant Navy Indigo (Light Mode) */
#avision-dashboard-root.agency-dashboard-root .saas-header {
	padding: 12px 0 16px !important;
	min-height: 0 !important;
	background: var(--avi-navy);
	color: var(--avi-text-on-navy);
}
#avision-dashboard-root.agency-dashboard-root .saas-header .header-content {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 12px;
}
#avision-dashboard-root.agency-dashboard-root .saas-header .business-info .certif-badge,
#avision-dashboard-root.agency-dashboard-root .saas-header .business-info p {
	margin: 0;
	font-size: 0.8rem;
	opacity: 0.9;
	color: var(--avi-text-muted-on-navy);
}
#avision-dashboard-root.agency-dashboard-root .saas-header .business-info h1 {
	font-size: 1.1rem;
	font-weight: 800;
	margin: 0 0 2px 0;
	color: var(--avi-text-on-navy);
}
#avision-dashboard-root.agency-dashboard-root .saas-header #agencyQuotaDisplay {
	margin-top: 4px;
	font-size: 0.8rem;
	color: var(--avi-text-muted-on-navy);
}

/* ==========================================================================
   4. MARKETPLACE — Deux cartes Master (Gardien + Top 3)
   ========================================================================== */
#avision-dashboard-root .agency-marketplace-cards {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
	max-width: var(--max-width, 1200px);
	margin: 0 auto;
	padding: 20px;
}
#avision-dashboard-root .agency-marketplace-card {
	background: var(--agency-card-bg);
	border: 1px solid var(--agency-card-border);
	border-radius: 12px;
	padding: 20px;
	box-shadow: var(--agency-card-shadow);
	display: flex;
	flex-direction: column;
	gap: 14px;
}
#avision-dashboard-root .agency-marketplace-card-title {
	font-size: 1.1rem;
	font-weight: 800;
	margin: 0;
	color: var(--agency-text-main);
}
#avision-dashboard-root .agency-marketplace-tiers,
#avision-dashboard-root .agency-marketplace-plans {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
}
#avision-dashboard-root .agency-marketplace-tier,
#avision-dashboard-root .agency-marketplace-plan {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 0.9rem;
	color: var(--agency-text-main);
}
#avision-dashboard-root .agency-marketplace-tier-price {
	font-weight: 700;
	color: var(--avi-indigo);
}
#avision-dashboard-root .agency-marketplace-tier-range {
	color: var(--agency-text-muted);
	font-size: 0.85rem;
}
#avision-dashboard-root .agency-marketplace-plan-icon {
	font-size: 1.1rem;
	flex-shrink: 0;
}
#avision-dashboard-root .agency-marketplace-plan-label {
	font-weight: 600;
}
#avision-dashboard-root .agency-marketplace-card-guardian .agency-marketplace-tier-price { color: var(--avi-indigo); }
#avision-dashboard-root .agency-marketplace-card-top3 .agency-marketplace-plan-label { color: var(--agency-text-main); }
#avision-dashboard-root .agency-marketplace-btn {
	padding: 10px 16px;
	border-radius: 8px;
	font-size: 0.875rem;
	font-weight: 600;
	cursor: pointer;
	border: 1px solid transparent;
	transition: background 0.2s, color 0.2s, box-shadow 0.2s;
	align-self: flex-start;
	margin-top: 4px;
}
#avision-dashboard-root .agency-marketplace-btn.agency-top3-cta {
	background: var(--avi-gold-soft);
	color: var(--avi-gold);
	border-color: rgba(212, 175, 55, 0.5);
}
#avision-dashboard-root .agency-marketplace-btn.agency-top3-cta:hover {
	background: rgba(212, 175, 55, 0.3);
	box-shadow: 0 0 16px var(--avi-gold-soft);
}
#avision-dashboard-root .agency-marketplace-btn.agency-guardian-cta {
	background: rgba(99, 102, 241, 0.15);
	color: var(--avi-indigo);
	border-color: rgba(99, 102, 241, 0.5);
}
#avision-dashboard-root .agency-marketplace-btn.agency-guardian-cta:hover {
	background: rgba(99, 102, 241, 0.25);
	box-shadow: 0 0 16px var(--avi-indigo-glow);
}
@media (max-width: 768px) {
	#avision-dashboard-root .agency-marketplace-cards {
		grid-template-columns: 1fr;
		padding: 16px;
	}
}

/* ==========================================================================
   Accordéon Marketplace — Trigger + Tiroir (Design 2026)
   ========================================================================== */
#avision-dashboard-root .agency-marketplace-trigger-wrap {
	max-width: var(--max-width, 1200px);
	margin: 0 auto;
	padding: 0 20px 12px;
}
#avision-dashboard-root .agency-marketplace-drawer-trigger {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 14px;
	border: 1px solid var(--agency-card-border);
	border-radius: 8px;
	background: #fff;
	color: var(--agency-text-muted);
	font-size: 0.85rem;
	font-weight: 600;
	cursor: pointer;
	transition: color 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}
#avision-dashboard-root .agency-marketplace-drawer-trigger:hover {
	color: var(--avi-gold);
	border-color: rgba(212, 175, 55, 0.5);
	background: var(--avi-gold-soft);
}
#avision-dashboard-root .agency-marketplace-drawer-trigger[aria-expanded="true"] .agency-marketplace-drawer-trigger-chevron {
	transform: rotate(180deg);
}
#avision-dashboard-root .agency-marketplace-drawer-trigger-chevron {
	display: inline-block;
	transition: transform 0.25s ease;
}
/* Tiroir : fermé par défaut (max-height 0), fond blanc perle, bordure dorée, ombre en bas */
#avision-dashboard-root .agency-marketplace-drawer {
	max-width: var(--max-width, 1200px);
	margin: 0 auto;
	padding: 0 20px;
	max-height: 0;
	overflow: hidden;
	background: #fafaf9;
	border: 1px solid transparent;
	border-radius: 12px;
	box-shadow: none;
	transition: max-height 0.35s ease, padding 0.35s ease, margin 0.35s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}
#avision-dashboard-root .agency-marketplace-drawer.agency-marketplace-drawer-open {
	max-height: 620px;
	padding: 20px;
	margin-bottom: 24px;
	border-color: rgba(212, 175, 55, 0.35);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
}
#avision-dashboard-root .agency-marketplace-drawer .agency-marketplace-cards {
	padding: 0;
	margin: 0;
}
#avision-dashboard-root .agency-marketplace-drawer .agency-marketplace-card {
	background: #fff;
	border-color: rgba(212, 175, 55, 0.2);
}

/* Modale Configuration du Radar : choix du plan (radios) */
#avision-dashboard-root .agency-radar-config-modal .agency-radar-plan-choice {
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 12px 0;
}
#avision-dashboard-root .agency-radar-plan-option {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 12px 14px;
	border: 1px solid var(--agency-card-border, #e2e8f0);
	border-radius: 8px;
	cursor: pointer;
	transition: border-color 0.2s, background 0.2s;
}
#avision-dashboard-root .agency-radar-config-modal .agency-radar-plan-option:hover,
#avision-dashboard-root .agency-radar-config-modal .agency-radar-plan-option:has(input:checked) {
	border-color: var(--avi-gold);
	background: var(--avi-gold-soft);
}
#avision-dashboard-root .agency-radar-plan-option input[type="radio"] {
	margin: 0;
	width: 18px;
	height: 18px;
	accent-color: var(--avi-gold);
}
#avision-dashboard-root .agency-radar-plan-option-label {
	font-weight: 600;
	font-size: 0.9rem;
}

/* ==========================================================================
   5. FILTRE (sticky, Light Mode)
   ========================================================================== */
#avision-dashboard-root .agency-filter-bar {
	position: sticky;
	top: 80px;
	z-index: 100;
	margin-bottom: 16px;
	padding: 12px 16px;
	background: var(--agency-card-bg);
	border: 1px solid var(--agency-card-border);
	border-radius: 12px;
	box-shadow: var(--agency-card-shadow);
	overflow: visible;
}
#avision-dashboard-root .agency-filter-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem 1.25rem;
}
#avision-dashboard-root .agency-filter-search { flex: 1 1 200px; min-width: 180px; }
#avision-dashboard-root .agency-filter-input {
	width: 100%;
	padding: 8px 12px;
	font-size: 0.875rem;
	color: var(--agency-text-main);
	background: #fff;
	border: 1px solid var(--agency-card-border);
	border-radius: 8px;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
#avision-dashboard-root .agency-filter-input::placeholder { color: var(--agency-text-muted); }
#avision-dashboard-root .agency-filter-input:focus {
	outline: none;
	border-color: var(--avi-indigo);
	box-shadow: 0 0 0 3px var(--avi-indigo-glow);
}
#avision-dashboard-root .agency-filter-group { display: flex; align-items: center; gap: 0.5rem; }
#avision-dashboard-root .agency-filter-group label {
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--agency-text-muted);
	white-space: nowrap;
}
#avision-dashboard-root .agency-filter-select {
	padding: 8px 32px 8px 12px;
	font-size: 0.8125rem;
	color: var(--agency-text-main);
	background: #fff;
	border: 1px solid var(--agency-card-border);
	border-radius: 8px;
	cursor: pointer;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 12px center;
}
#avision-dashboard-root .agency-filter-select:focus {
	outline: none;
	border-color: var(--avi-indigo);
	box-shadow: 0 0 0 3px var(--avi-indigo-glow);
}
#avision-dashboard-root .agency-filter-counter {
	font-size: 0.8rem;
	color: var(--agency-text-muted);
	font-weight: 500;
}
#avision-dashboard-root .agency-filter-count-current { color: var(--avi-gold); font-weight: 700; }
#avision-dashboard-root .agency-filter-count-total { font-weight: 600; }
#avision-dashboard-root .agency-filter-bar .screen-reader-text {
	position: absolute;
	width: 1px; height: 1px; padding: 0; margin: -1px;
	overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}

/* ==========================================================================
   6. SWITCHER GRILLE / LISTE — Toggle Pill (fond sombre, pastille glissante)
   ========================================================================== */
#avision-dashboard-root .agency-view-switcher {
	display: flex;
	align-items: center;
	position: relative;
	width: 80px;
	height: 36px;
	border: none;
	border-radius: 999px;
	overflow: hidden;
	background: var(--avi-navy);
	box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.3);
}
#avision-dashboard-root .agency-view-switcher-thumb {
	position: absolute;
	left: 4px;
	top: 4px;
	width: calc(50% - 6px);
	height: calc(100% - 8px);
	background: var(--avi-indigo);
	border-radius: 999px;
	transition: left 0.28s cubic-bezier(0.4, 0, 0.2, 1);
	z-index: 0;
	pointer-events: none;
	box-shadow: 0 2px 8px var(--avi-indigo-glow);
}
#avision-dashboard-root .agency-view-switcher.is-list .agency-view-switcher-thumb { left: calc(50% + 2px); }
#avision-dashboard-root .agency-view-switcher button {
	position: relative;
	z-index: 1;
	flex: 1;
	width: 40px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: none;
	background: transparent;
	color: var(--avi-text-muted-on-navy);
	cursor: pointer;
	transition: color 0.2s;
}
#avision-dashboard-root .agency-view-switcher button:hover { color: var(--avi-text-on-navy); }
#avision-dashboard-root .agency-view-switcher button.active { color: #fff; }
#avision-dashboard-root .agency-view-switcher button svg { width: 16px; height: 16px; }

/* ==========================================================================
   7. CARTES BENTO COMPACT
   ========================================================================== */

/* Grille : 5 colonnes à 1440px, padding supprimé */
#avision-dashboard-root .agency-clients-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 8px;
	margin-top: 12px;
}
@media (min-width: 1440px) {
	#avision-dashboard-root .agency-clients-grid {
		grid-template-columns: repeat(5, 1fr);
		gap: 10px;
	}
}

/* Carte : fond blanc, bordure fine grise, ombre légère (Light Mode Pro) */
#avision-dashboard-root .agency-client-card {
	background: var(--agency-card-bg);
	border: 1px solid var(--agency-card-border);
	border-radius: 10px;
	padding: 6px 8px;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	text-align: left;
	position: relative;
	min-height: 0;
	box-shadow: var(--agency-card-shadow);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
#avision-dashboard-root .agency-client-card:hover {
	border-color: var(--avi-indigo);
	box-shadow: 0 4px 12px rgba(99, 102, 241, 0.15);
}

/* Header carte : Score 60px + Nom alignés verticalement (flex center, gap 12px) */
#avision-dashboard-root .agency-client-card .client-header-row {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 4px;
}
#avision-dashboard-root .agency-client-card .client-name-wrap { min-width: 0; flex: 1; }
#avision-dashboard-root .agency-client-card .client-name {
	font-size: 0.85rem;
	font-weight: 800;
	margin: 0;
	line-height: 1.2;
	color: var(--agency-text-main);
}
#avision-dashboard-root .agency-client-card .client-journey-start {
	font-size: 0.65rem;
	color: var(--agency-text-muted);
	margin: 2px 0 0 0;
}
#avision-dashboard-root .agency-client-card .client-score-wrap {
	flex-shrink: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0;
	contain: layout style;
}
#avision-dashboard-root .agency-client-card .client-score-wrap .circular-chart {
	width: 60px !important;
	height: 60px !important;
	min-width: 60px;
	min-height: 60px;
	flex-shrink: 0;
}
#avision-dashboard-root .agency-client-card .client-score-wrap .percentage { font-size: 0.48em !important; }
#avision-dashboard-root .agency-client-card .client-score-status { font-size: 0.65rem; margin: 0; }

#avision-dashboard-root .agency-client-card .client-status {
	font-size: 0.75rem;
	font-weight: 700;
	margin: 0 0 4px 0;
}
#avision-dashboard-root .agency-client-card .client-status.active { color: #059669; }
#avision-dashboard-root .agency-client-card .client-status.inactive { color: var(--agency-text-muted); }
#avision-dashboard-root .agency-client-card .client-guardian-slot {
	min-height: 24px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 0;
}
#avision-dashboard-root .agency-client-card .client-guardian-badge {
	display: inline-block;
	margin-bottom: 0;
	padding: 3px 8px;
	font-size: 0.7rem;
	font-weight: 700;
	background: var(--avi-gold-pill);
	color: var(--avi-navy);
	border-radius: 20px;
	box-shadow: 0 1px 3px rgba(212, 175, 55, 0.4);
}

/* Tri-Score : 3 pastilles colorées, chiffres uniquement (pas de texte) */
#avision-dashboard-root .agency-triscore {
	margin: 4px 0 6px 0;
}
#avision-dashboard-root .agency-triscore-label { display: none !important; }
#avision-dashboard-root .agency-triscore-pills {
	display: flex;
	align-items: center;
	gap: 0 6px;
	flex-wrap: wrap;
}
#avision-dashboard-root .agency-triscore-pill {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 3px 6px;
	border-radius: 6px;
	font-size: 0.75rem;
	font-weight: 700;
	line-height: 1.2;
}
#avision-dashboard-root .agency-triscore-pill::before {
	content: '';
	display: inline-block;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	flex-shrink: 0;
}
#avision-dashboard-root .agency-triscore-pill-label { display: none !important; }
#avision-dashboard-root .agency-triscore-pill:not(:last-child)::after {
	content: ' | ';
	margin-left: 4px;
	color: var(--agency-text-muted);
	font-weight: 600;
}
#avision-dashboard-root .agency-triscore-top3 {
	background: rgba(34, 197, 94, 0.2);
	color: #4ade80;
	border: 1px solid rgba(34, 197, 94, 0.4);
}
#avision-dashboard-root .agency-triscore-top3::before { background: #22c55e; }
#avision-dashboard-root .agency-triscore-top10 {
	background: rgba(249, 115, 22, 0.2);
	color: #fdba74;
	border: 1px solid rgba(249, 115, 22, 0.4);
}
#avision-dashboard-root .agency-triscore-top10::before { background: #f97316; }
#avision-dashboard-root .agency-triscore-over10 {
	background: rgba(239, 68, 68, 0.2);
	color: #f87171;
	border: 1px solid rgba(239, 68, 68, 0.4);
}
#avision-dashboard-root .agency-triscore-over10::before { background: #ef4444; }

/* Actions carte : en grille = lien pleine largeur + détacher en float */
#avision-dashboard-root .agency-client-card .agency-card-actions {
	margin-top: auto;
	display: flex;
	flex-direction: column;
	gap: 6px;
}
/* Vigilance Client : paramètres de vue (Privacy Masking) */
#avision-dashboard-root .agency-visibility-wrap {
	position: relative;
	display: inline-flex;
	align-self: flex-start;
}
#avision-dashboard-root .btn-agency-visibility {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	padding: 0;
	border: 1px solid var(--agency-card-border);
	border-radius: 6px;
	background: #fff;
	color: var(--agency-text-main);
	font-size: 1rem;
	cursor: pointer;
	transition: background 0.2s ease, border-color 0.2s ease;
}
#avision-dashboard-root .btn-agency-visibility:hover {
	background: var(--agency-page-bg);
	border-color: var(--avi-indigo);
}
#avision-dashboard-root .agency-visibility-dropdown {
	display: none;
	position: absolute;
	left: 0;
	bottom: 100%;
	margin-bottom: 4px;
	min-width: 220px;
	padding: 10px 12px;
	background: #fff;
	border: 1px solid var(--agency-card-border);
	border-radius: 8px;
	box-shadow: 0 8px 24px rgba(0,0,0,0.12);
	z-index: 2000;
}
/* Flèche vers le haut (pointe vers l'icône ⚙️) */
#avision-dashboard-root .agency-visibility-dropdown::before {
	content: '';
	position: absolute;
	left: 12px;
	bottom: -6px;
	width: 0;
	height: 0;
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 6px solid #fff;
	filter: drop-shadow(0 1px 0 var(--agency-card-border));
}
#avision-dashboard-root .agency-visibility-dropdown::after {
	content: '';
	position: absolute;
	left: 11px;
	bottom: -7px;
	width: 0;
	height: 0;
	border-left: 7px solid transparent;
	border-right: 7px solid transparent;
	border-top: 7px solid var(--agency-card-border);
	z-index: -1;
}
#avision-dashboard-root .agency-visibility-dropdown[aria-hidden="false"] {
	display: block;
}
#avision-dashboard-root .agency-visibility-option {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 6px 0;
	font-size: 0.8rem;
	color: var(--agency-text-main);
	cursor: pointer;
}
#avision-dashboard-root .agency-visibility-option + .agency-visibility-option {
	border-top: 1px solid var(--agency-card-border);
}
#avision-dashboard-root .agency-visibility-cb {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	cursor: pointer;
}
#avision-dashboard-root .agency-client-card .agency-card-actions .btn-detach { display: none; }
/* Détacher en grille (position absolue) */
#avision-dashboard-root .agency-client-card .btn-detach-float {
	position: absolute;
	top: 6px;
	right: 6px;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: rgba(239, 68, 68, 0.15);
	border: 1px solid #ef4444;
	color: #f87171;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.85rem;
	transition: all 0.2s;
	z-index: 2;
}
#avision-dashboard-root .agency-client-card .btn-detach-float:hover {
	background: #ef4444;
	color: #fff;
}

/* ==========================================================================
   8. MODE LISTE (Pro) — 48px par ligne, colonnes [Checkbox] [Nom] [Score] [Tri-Score] [Statut] [Actions]
   ========================================================================== */
#avision-dashboard-root .agency-clients-grid.view-list {
	display: flex;
	flex-direction: column;
	gap: 4px;
	grid-template-columns: none;
}
/* Vue Liste : colonnes fixes (50px 2fr 100px 150px 150px 120px), alignement strict sans fuite */
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card {
	display: grid;
	grid-template-columns: 50px 2fr 100px 150px 150px 120px;
	grid-template-rows: 48px;
	align-items: center;
	min-height: 48px;
	height: 48px;
	padding: 0 12px;
	gap: 0 12px;
}
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .client-header-row { display: contents; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .agency-card-checkbox-wrap { grid-column: 1; position: static; justify-self: start; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .client-name-wrap { grid-column: 2; min-width: 0; overflow: hidden; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .client-score-wrap { grid-column: 3; margin: 0; flex-direction: row; align-items: center; gap: 6px; justify-self: center; min-width: 0; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .agency-triscore { grid-column: 4; margin: 0; justify-self: center; min-width: 0; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .agency-card-status-cell { grid-column: 5; display: flex; align-items: center; gap: 6px; margin: 0; justify-self: center; min-width: 0; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .agency-card-status-cell .client-status { margin: 0; font-size: 0.75rem; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .agency-card-status-cell .client-guardian-slot { min-height: 0; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .agency-card-actions { grid-column: 6; margin: 0; flex-direction: row; gap: 8px; justify-content: flex-end; align-items: center; justify-self: end; min-width: 0; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .btn-detach-float { display: none !important; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .agency-card-actions .btn-detach { display: inline-flex !important; width: 28px; height: 28px; min-width: 28px; padding: 0; align-items: center; justify-content: center; font-size: 0.85rem; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .client-name { font-size: 0.8rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .client-journey-start { display: none; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .client-score-wrap .circular-chart { width: 36px !important; height: 36px !important; min-width: 36px; min-height: 36px; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .client-score-wrap .percentage { font-size: 0.4em !important; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .client-score-status { margin: 0; font-size: 0.7rem; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .agency-triscore-label { display: none; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .agency-triscore-pills { gap: 0 4px; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .agency-triscore-pill { padding: 2px 5px; font-size: 0.65rem; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .agency-triscore-pill-label { display: none; }
#avision-dashboard-root .agency-client-card .agency-heatmap-wrap { display: none !important; }
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .btn-view-dashboard { width: auto; margin: 0; padding: 5px 12px; font-size: 0.75rem; }

/* ==========================================================================
   9. CHECKBOX BULK
   ========================================================================== */
#avision-dashboard-root .agency-client-card .agency-card-checkbox-wrap {
	position: absolute;
	top: 6px;
	left: 6px;
	z-index: 2;
}
#avision-dashboard-root .agency-client-card .agency-card-checkbox-wrap input[type="checkbox"] {
	width: 16px;
	height: 16px;
	cursor: pointer;
	accent-color: var(--avi-indigo);
}
#avision-dashboard-root .agency-clients-grid.view-list .agency-client-card .agency-card-checkbox-wrap { position: static; order: -1; }

/* ==========================================================================
   10. FLOATING ISLAND BULK (Navy + Or)
   ========================================================================== */
#avision-dashboard-root .agency-bulk-island,
.agency-bulk-island {
	position: fixed;
	bottom: 24px;
	left: 50%;
	transform: translateX(-50%) translateY(100%);
	z-index: 1000;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.25s ease, visibility 0.25s;
}
#avision-dashboard-root .agency-bulk-island.is-visible,
.agency-bulk-island.is-visible {
	transform: translateX(-50%) translateY(0);
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	animation: agency-bulk-island-bounce 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
}
@keyframes agency-bulk-island-bounce {
	0% { transform: translateX(-50%) translateY(100%); opacity: 0; }
	60% { transform: translateX(-50%) translateY(-6px); opacity: 1; }
	100% { transform: translateX(-50%) translateY(0); opacity: 1; }
}
#avision-dashboard-root .agency-bulk-island-inner,
.agency-bulk-island-inner {
	display: flex;
	align-items: center;
	gap: 0.75rem 1.25rem;
	flex-wrap: wrap;
	padding: 12px 20px 14px;
	background: var(--avi-navy);
	border: 1px solid var(--avi-gold);
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.5), 0 0 24px var(--avi-gold-soft);
	border-radius: 28px;
}
.agency-bulk-island-count { color: var(--avi-text-on-navy); font-size: 0.9rem; font-weight: 700; }
.agency-bulk-island-actions { display: flex; align-items: center; gap: 0.25rem; }
.agency-bulk-island-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 12px;
	border: none;
	border-radius: 8px;
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--avi-text-muted-on-navy);
	background: transparent;
	cursor: pointer;
	transition: background 0.2s, color 0.2s;
}
.agency-bulk-island-btn:hover { background: rgba(255, 255, 255, 0.08); color: var(--avi-text-on-navy); }
.agency-bulk-island-btn .agency-bulk-icon { flex-shrink: 0; opacity: 0.9; }
.agency-bulk-island-btn .agency-bulk-btn-text { white-space: nowrap; }
.agency-bulk-island-select { color: var(--avi-gold); }
.agency-bulk-island-select:hover { background: var(--avi-gold-soft); color: var(--avi-gold); }
.agency-bulk-hidden-hint { font-size: 0.75rem; color: var(--avi-text-muted-on-navy); font-weight: 500; margin-left: 2px; }
#avision-dashboard-root .agency-bulk-bar-count,
.agency-bulk-bar-count { color: inherit; }
#avision-dashboard-root .agency-bulk-bar-actions,
.agency-bulk-bar-actions { display: inherit; gap: inherit; }

/* ==========================================================================
   11. CARTES — Transition & état masqué
   ========================================================================== */
#avision-dashboard-root .agency-client-card {
	transition: opacity 0.28s ease, transform 0.28s ease, box-shadow 0.2s ease, border-color 0.2s ease;
	backface-visibility: hidden;
}
#avision-dashboard-root .agency-client-card.agency-card-hidden {
	opacity: 0;
	transform: scale(0.96);
	pointer-events: none;
	visibility: hidden;
}
#avision-dashboard-root .agency-clients-grid { perspective: 800px; }
#avision-dashboard-root .agency-clients-grid .agency-client-card { transform-origin: center center; }
#avision-dashboard-root .agency-clients-grid .agency-client-card:not(.agency-card-hidden) {
	animation: agency-card-enter 0.3s ease forwards;
}
@keyframes agency-card-enter {
	from { opacity: 0; transform: scale(0.96); }
	to { opacity: 1; transform: scale(1); }
}

/* ==========================================================================
   12. FOOTER & MODALES (contexte Navy)
   ========================================================================== */
#avision-dashboard-root.agency-dashboard-root .app-footer {
	background: var(--avi-navy-light);
	border-top: 1px solid var(--avi-border-navy);
	color: var(--avi-text-muted-on-navy);
}
#avision-dashboard-root.agency-dashboard-root .app-footer a { color: var(--avi-indigo-light); }
#avision-dashboard-root.agency-dashboard-root .modal-overlay {
	background: rgba(10, 15, 29, 0.85);
}
#avision-dashboard-root.agency-dashboard-root .modal-box {
	background: var(--avi-navy-light);
	border: 1px solid var(--avi-border-navy);
	color: var(--avi-text-on-navy);
}
#avision-dashboard-root.agency-dashboard-root .modal-title { color: var(--avi-text-on-navy); }
#avision-dashboard-root.agency-dashboard-root .modal-desc { color: var(--avi-text-muted-on-navy); }
#avision-dashboard-root.agency-dashboard-root .quota-info {
	background: rgba(99, 102, 241, 0.1);
	border: 1px solid var(--avi-indigo);
	color: var(--avi-text-on-navy);
}
#avision-dashboard-root.agency-dashboard-root .agency-draft-item {
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid var(--avi-border-navy);
	color: var(--avi-text-on-navy);
}

/* Modal Google Auth (homologation) */
#avision-dashboard-root.agency-dashboard-root .google-auth-modal-box {
	max-width: 420px;
	text-align: center;
	padding: 28px 24px;
}
#avision-dashboard-root.agency-dashboard-root .google-auth-logo-wrap {
	margin-bottom: 16px;
}
#avision-dashboard-root.agency-dashboard-root .google-auth-logo {
	width: 64px;
	height: 64px;
	display: inline-block;
	vertical-align: middle;
}
#avision-dashboard-root.agency-dashboard-root .google-auth-title {
	font-size: 1.35rem;
	font-weight: 800;
	color: var(--avi-text-on-navy);
	margin: 0 0 12px 0;
}
#avision-dashboard-root.agency-dashboard-root .google-auth-desc,
#avision-dashboard-root.agency-dashboard-root .google-auth-note {
	font-size: 0.9rem;
	color: var(--avi-text-muted-on-navy);
	margin: 0 0 12px 0;
	text-align: left;
}
#avision-dashboard-root.agency-dashboard-root .google-auth-permissions {
	text-align: left;
	list-style: disc;
	padding-left: 1.25rem;
	margin: 12px 0 16px 0;
	font-size: 0.9rem;
	color: var(--avi-text-muted-on-navy);
}
#avision-dashboard-root.agency-dashboard-root .google-auth-permissions li {
	margin-bottom: 6px;
}
#avision-dashboard-root.agency-dashboard-root .google-auth-actions {
	display: flex;
	gap: 12px;
	justify-content: center;
	margin-top: 20px;
	flex-wrap: wrap;
}
#avision-dashboard-root.agency-dashboard-root .btn-google-connect-modal {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 12px 24px;
	font-size: 1rem;
	font-weight: 700;
	background: #fff;
	color: #3c4043;
	border: 1px solid #dadce0;
	border-radius: 8px;
	box-shadow: 0 1px 2px rgba(60, 64, 67, 0.3);
}
#avision-dashboard-root.agency-dashboard-root .btn-google-connect-modal:hover {
	background: #f8f9fa;
	box-shadow: 0 2px 6px rgba(60, 64, 67, 0.2);
}

/* ==========================================================================
   13. VOLET MON COMPTE — Section Mon Identité Agence (Grey-Label)
   ========================================================================== */
#avision-dashboard-root .user-orbit-agency-identity-form label {
	display: block;
	font-size: 0.8rem;
	color: var(--avi-text-muted-on-navy);
	margin-bottom: 0.25rem;
}
#avision-dashboard-root .user-orbit-agency-identity-form input[type="text"],
#avision-dashboard-root .user-orbit-agency-identity-form input[type="url"] {
	width: 100%;
	margin-bottom: 0.75rem;
	padding: 8px 12px;
	font-size: 0.875rem;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid var(--avi-border-navy);
	border-radius: 8px;
	color: var(--avi-text-on-navy);
}
#avision-dashboard-root .user-orbit-logo-row {
	display: flex;
	gap: 8px;
	margin-bottom: 0.5rem;
}
#avision-dashboard-root .user-orbit-logo-row input { flex: 1; margin-bottom: 0; }
#avision-dashboard-root .user-orbit-logo-preview { margin: 0.5rem 0 0.75rem 0; }
#avision-dashboard-root .user-orbit-checkbox-label {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	font-size: 0.8rem;
	color: var(--avi-text-muted-on-navy);
	margin-bottom: 0.75rem;
	cursor: pointer;
}
#avision-dashboard-root .user-orbit-checkbox-label input[type="checkbox"] { margin-top: 2px; accent-color: var(--avi-indigo); }
