/* ═══════════ EMPIRE — Récapitulatif (dashboard agrégé) ═══════════ */
/* width:100% + flex:1 → .emp-wrap remplit le conteneur de section (qui est en display:flex,
   sinon l'élément se réduit à la largeur de son contenu ~650px). max-width plafonne à 1600. */
.emp-wrap { width: 100%; flex: 1 1 auto; padding: 20px 28px 40px; max-width: 1600px; margin: 0 auto; }
.emp-hero { margin-bottom: 18px; }
.emp-hero-title { font-family: var(--font-display); font-size: var(--fs-2xl); font-weight: 900; letter-spacing: 3px; color: var(--textbright); display: flex; align-items: center; gap: 10px; }
.emp-hero-sub { font-family: var(--font-mono); font-size: var(--fs-sm); color: var(--textsoft); letter-spacing: 2px; text-transform: uppercase; margin-top: 4px; }

.emp-grid { display: flex; flex-direction: column; gap: 16px; }

/* Onglets Ressources · Armées · Simulateur */
.emp-tabs { display: flex; gap: 8px; margin-bottom: 16px; border-bottom: 1px solid var(--tint-3); padding-bottom: 0; }
.emp-tab { background: none; border: none; border-bottom: 2px solid transparent; color: var(--textsoft); font-family: var(--font-display); font-size: var(--fs-sm); font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; padding: 10px 16px; cursor: pointer; transition: all .18s; display: flex; align-items: center; gap: 7px; margin-bottom: -1px; }
.emp-tab:hover { color: var(--textmid); }
.emp-tab.active { color: var(--accent2); border-bottom-color: var(--accent); }

/* Simulateur intégré : la boîte interne de #simModal réutilisée inline */
.emp-sim-host { display: block; width: 100%; }
.emp-sim-host > div.emp-sim-embed { width: 100% !important; max-width: 100% !important; max-height: none !important; border: 1px solid rgba(var(--accent-rgb),0.22) !important; box-shadow: none !important; animation: none !important; }
.emp-sim-host > div.emp-sim-embed > div:first-child { display: none !important; } /* masque l'en-tête modale (l'onglet fait le titre) */
/* Pleine largeur : les 2 sections du simulateur (Vos effectifs | Cible) côte à côte */
.emp-sim-host #simContent { display: grid !important; grid-template-columns: 1fr 1fr; gap: 18px; align-items: start; max-height: none !important; overflow: visible !important; }
@media (max-width: 900px) { .emp-sim-host #simContent { grid-template-columns: 1fr; } }
/* Intégré pleine page → on exploite la hauteur dispo (vs 220px en modale) */
.emp-sim-host .sim-atk-list { max-height: 62vh !important; }
.emp-sim-host .sim-pvp-list { max-height: 44vh !important; }

.emp-panel { background: linear-gradient(170deg, rgba(8,14,30,0.92), rgba(4,10,22,0.97)); border: 1px solid rgba(var(--accent-rgb),0.22); border-radius: var(--radius-lg); padding: 14px 16px 16px; }
.emp-panel-hd { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 12px; flex-wrap: wrap; }
.emp-panel-title { font-family: var(--font-display); font-size: var(--fs-md); font-weight: 700; letter-spacing: 1.5px; color: var(--accent2); text-transform: uppercase; display: flex; align-items: center; gap: 7px; }
.emp-panel-sub { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--textsoft); letter-spacing: 1px; text-transform: none; }

/* Sélecteur de fenêtre de production */
.emp-win { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--textsoft); display: flex; align-items: center; gap: 5px; }
.emp-win-btn { background: var(--tint-1); border: 1px solid var(--tint-4); color: var(--textmid); border-radius: var(--radius-sm); padding: 4px 9px; cursor: pointer; font-family: var(--font-mono); font-size: var(--fs-xs); transition: all .18s; }
.emp-win-btn:hover { border-color: rgba(var(--accent-rgb),0.4); }
.emp-win-btn.active { background: rgba(var(--accent-rgb),0.16); border-color: var(--accent); color: var(--accent2); }

/* Tables */
.emp-table { width: 100%; border-collapse: collapse; font-family: var(--font-body); }
.emp-table th { font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: 600; color: var(--textsoft); text-transform: uppercase; letter-spacing: 1px; text-align: right; padding: 4px 8px; border-bottom: 1px solid var(--tint-3); }
.emp-table th:first-child { text-align: left; }
.emp-table td { padding: 8px; border-bottom: 1px solid rgba(255,255,255,0.04); font-size: var(--fs-base); vertical-align: middle; }
.emp-table tr:last-child td { border-bottom: none; }
.emp-res-name { color: var(--textbright); font-weight: 600; white-space: nowrap; }
.emp-num { text-align: right; font-family: var(--font-mono); color: var(--textmid); white-space: nowrap; }
.emp-cap { color: var(--textsoft); font-size: var(--fs-xs); }
.emp-prodv { color: var(--success); }
.emp-bar-cell { width: 130px; }
.emp-bar { display: inline-block; width: 92px; height: 7px; background: var(--tint-2); border-radius: 4px; overflow: hidden; vertical-align: middle; margin-right: 6px; }
.emp-bar-fill { height: 100%; background: linear-gradient(90deg, var(--accent), var(--accent2)); border-radius: 4px; transition: width .3s; }
.emp-bar-fill.emp-bar-warn { background: linear-gradient(90deg, #d8920a, #f5c542); }
.emp-bar-fill.emp-bar-full { background: linear-gradient(90deg, #c0392b, #e74c3c); }
.emp-pct { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--textsoft); }

.emp-energy { margin-top: 10px; padding: 8px 10px; border-radius: var(--radius-sm); background: var(--tint-1); font-size: var(--fs-base); color: var(--textmid); }
.emp-energy b { color: var(--accent2); }
.emp-energy-neg { background: rgba(231,76,60,0.08); border: 1px solid rgba(231,76,60,0.25); }
.emp-energy-neg b { color: var(--danger); }

/* Militaire */
.emp-mil-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.emp-mil-kpi { text-align: center; padding: 12px 6px; background: var(--tint-1); border: 1px solid var(--tint-3); border-radius: var(--radius-md); }
.emp-mil-val { font-family: var(--font-display); font-size: var(--fs-xl); font-weight: 900; color: var(--textbright); }
.emp-mil-lbl { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--textsoft); text-transform: uppercase; letter-spacing: 1px; margin-top: 4px; display: flex; align-items: center; justify-content: center; gap: 4px; }
.emp-upkeep { margin-top: 10px; font-size: var(--fs-base); color: var(--textmid); display: flex; align-items: center; gap: 6px; }
.emp-upkeep b { color: var(--accent2); }
.emp-note { margin-top: 10px; font-size: var(--fs-xs); color: var(--textsoft); font-style: italic; opacity: 0.8; }
.emp-mil-coef { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 12px; }
.emp-coef { display: flex; align-items: center; gap: 7px; padding: 10px 12px; border-radius: var(--radius-md); background: var(--tint-1); border: 1px solid var(--tint-3); font-family: var(--font-mono); font-size: var(--fs-sm); color: var(--textsoft); text-transform: uppercase; letter-spacing: 1px; }
.emp-coef span { flex: 1; }
.emp-coef b { font-family: var(--font-display); font-size: var(--fs-lg); letter-spacing: 0; }
.emp-coef-atk { border-color: rgba(231,76,60,0.3); } .emp-coef-atk b { color: #ff7a6c; }
.emp-coef-def { border-color: rgba(91,170,255,0.3); } .emp-coef-def b { color: var(--accent2); }
.emp-dispo { margin-top: 10px; font-size: var(--fs-base); color: var(--textmid); display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.emp-dispo b { color: var(--textbright); }
.emp-dispo-sep { color: var(--textsoft); opacity: 0.5; }
/* Détail par unité (onglet Armées) — lignes illustrées + chips ATK/DEF */
.emp-unit-detail { margin-top: 18px; display: grid; grid-template-columns: repeat(auto-fit, minmax(340px, 1fr)); gap: 18px; }
.emp-unit-cat-hd { font-family: var(--font-display); font-size: var(--fs-sm); font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: var(--accent2); margin-bottom: 8px; display: flex; align-items: center; gap: 6px; padding-bottom: 6px; border-bottom: 1px solid var(--tint-3); }
.emp-unit-cat-hd .emp-cap { margin-left: auto; background: var(--tint-2); border-radius: 999px; padding: 1px 8px; font-family: var(--font-mono); }
.emp-u-list { display: flex; flex-direction: column; gap: 5px; }
.emp-u-row { display: flex; align-items: center; gap: 10px; padding: 6px 8px; border-radius: var(--radius-md); background: linear-gradient(90deg, var(--tint-1), transparent); border: 1px solid transparent; transition: all .15s; }
.emp-u-row:hover { border-color: rgba(var(--accent-rgb),0.2); background: rgba(var(--accent-rgb),0.05); }
.emp-u-thumb { width: 40px; height: 40px; flex-shrink: 0; border-radius: 7px; background-size: cover; background-position: center; box-shadow: 0 0 8px rgba(0,0,0,0.45); border: 1px solid var(--tint-3); }
.emp-u-thumb-ph { display: flex; align-items: center; justify-content: center; color: var(--textsoft); background: var(--tint-2); }
.emp-u-name { flex: 1; min-width: 0; font-family: var(--font-body); font-weight: 600; font-size: var(--fs-base); color: var(--textbright); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.emp-u-count { font-family: var(--font-mono); font-size: var(--fs-base); color: var(--textmid); margin-right: 4px; }
.emp-u-chip { display: inline-flex; align-items: center; gap: 3px; font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: 700; padding: 2px 7px; border-radius: 999px; }
.emp-u-atk { color: #ff8a7c; background: rgba(231,76,60,0.12); }
.emp-u-def { color: var(--accent2); background: rgba(var(--accent-rgb),0.12); }

/* Hub cliquable */
.emp-clk { cursor: pointer; }
tr.emp-clk { transition: background .15s; }
tr.emp-clk:hover { background: rgba(var(--accent-rgb),0.08) !important; }
.emp-q-item.emp-clk:hover { border-color: rgba(var(--accent-rgb),0.45) !important; background: rgba(var(--accent-rgb),0.1) !important; }
.emp-u-row.emp-clk:hover { border-color: rgba(var(--accent-rgb),0.35); }

/* Synthèse santé empire */
.emp-health { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.emp-h-chip { display: inline-flex; align-items: center; gap: 5px; font-family: var(--font-mono); font-size: var(--fs-xs); padding: 4px 10px; border-radius: 999px; background: var(--tint-2); color: var(--textmid); border: 1px solid var(--tint-3); }
.emp-h-warn { color: var(--warn); border-color: rgba(216,146,10,0.35); background: rgba(216,146,10,0.08); }
.emp-h-ok { color: var(--success); border-color: rgba(46,204,136,0.25); }

/* Mobile : tables scrollables, grilles repliées, paddings réduits */
@media (max-width: 760px) {
  .emp-wrap { padding: 14px 12px 32px; }
  .emp-hero-title { font-size: var(--fs-xl); }
  .emp-tabs { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .emp-tab { padding: 9px 12px; font-size: var(--fs-xs); white-space: nowrap; }
  .emp-panel { overflow-x: auto; }
  .emp-table { min-width: 520px; }
  .emp-mil-grid, .emp-q-grid { grid-template-columns: repeat(2, 1fr); }
  .emp-mil-coef { grid-template-columns: 1fr; }
  .emp-unit-detail { grid-template-columns: 1fr; }
}

/* Files actives */
.emp-q-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.emp-q-item { text-align: center; padding: 12px 4px; background: var(--tint-1); border: 1px solid var(--tint-3); border-radius: var(--radius-md); opacity: 0.55; }
.emp-q-item.active { opacity: 1; border-color: rgba(var(--accent-rgb),0.4); background: rgba(var(--accent-rgb),0.07); }
.emp-q-ico { display: block; color: var(--accent2); margin-bottom: 4px; }
.emp-q-n { font-family: var(--font-display); font-size: var(--fs-xl); font-weight: 900; color: var(--textbright); display: block; }
.emp-q-lbl { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--textsoft); text-transform: uppercase; letter-spacing: 0.5px; }
