/* Calculateur MGA - Styles WordPress */
.calculateur-mga-container{max-width:1400px;margin:0 auto;padding:20px}
.mga-header{background:#fff;border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 10px 15px -3px rgba(0,0,0,.1)}
.mga-title{font-size:28px;font-weight:700;color:#334155;margin-bottom:8px}
.mga-subtitle{color:#64748b;font-size:14px}
.mga-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}
@media (max-width:1024px){.mga-grid{grid-template-columns:1fr}}
.mga-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 10px 15px -3px rgba(0,0,0,.1)}
.mga-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid #e2e8f0}
.mga-card-title{font-size:18px;font-weight:600;margin:0}
.mga-badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}
.mga-badge-primary{background:#e2e8f0;color:#334155}
.mga-badge-success{background:#d1fae5;color:#10b981}
.mga-form-group{margin-bottom:16px}
.mga-label{display:block;font-size:13px;font-weight:600;color:#64748b;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}
.mga-select,.mga-input{width:100%;padding:10px 14px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;transition:all .2s}
.mga-select:focus,.mga-input:focus{outline:0;border-color:#334155;box-shadow:0 0 0 3px rgba(51,65,85,.15)}
.mga-input[readonly]{background:#f8fafc;color:#64748b;font-weight:600}
.mga-form-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.mga-form-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.mga-form-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.mga-btn{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px}
.mga-btn-primary{background:#334155;color:#fff}
.mga-btn-primary:hover{background:#1f2937;transform:translateY(-1px)}
.mga-btn-secondary{background:#64748b;color:#fff}
.mga-btn-danger{background:#ef4444;color:#fff}
.mga-btn-success{background:#10b981;color:#fff}
.mga-btn-group{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}
.mga-btn-icon{padding:6px 10px;border-radius:8px}
.mga-btn-xs{padding:6px 10px;border-radius:8px;font-size:12px}

.mga-month-actions{display:flex;gap:6px;justify-content:flex-end}

.mga-manual-fix{margin:14px 0 10px;padding:14px;border:1px solid rgba(148,163,184,.35);border-radius:14px;background:rgba(15,23,42,.03)}
.mga-manual-title{font-weight:700;margin-bottom:10px}
.mga-manual-hint{margin-top:8px;font-size:13px;opacity:.85}
.mga-result-box{background:linear-gradient(135deg,#334155,#1f2937);color:#fff;padding:20px;border-radius:10px;margin-top:16px}
.mga-result-label{font-size:12px;opacity:.9;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}
.mga-result-value{font-size:32px;font-weight:700}
.mga-year-group{background:#f8fafc;border-radius:8px;padding:16px;margin-bottom:16px}
.mga-year-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid #e2e8f0}
.mga-year-title{font-size:16px;font-weight:600;color:#334155}
.mga-month-item{display:grid;grid-template-columns:100px 1fr auto;padding:10px;background:#fff;border-radius:6px;margin-bottom:6px;align-items:center;transition:all .2s}
.mga-month-item:hover{box-shadow:0 1px 3px 0 rgba(0,0,0,.1);transform:translateX(4px)}
.mga-month-label{font-weight:600;color:#64748b}
.mga-month-value{font-family:monospace;font-size:16px;font-weight:700;color:#334155}
.mga-value-pos{color:#16a34a}
.mga-value-neg{color:#ef4444}
.mga-value-zero{color:#334155}
.mga-total-box{background:linear-gradient(135deg,#334155,#0f172a);color:#fff;padding:24px;border-radius:12px;text-align:center;margin-top:24px}
.mga-total-label{font-size:14px;opacity:.9;margin-bottom:8px;text-transform:uppercase;letter-spacing:1px}
.mga-total-value{font-size:48px;font-weight:700}
.mga-quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-top:16px}
.mga-quick-action{padding:16px;background:#fff;border:2px solid #e2e8f0;border-radius:8px;text-align:center;cursor:pointer;transition:all .2s}
.mga-quick-action:hover{border-color:#334155;box-shadow:0 1px 3px 0 rgba(0,0,0,.1);transform:translateY(-2px)}
.mga-quick-icon{font-size:24px;margin-bottom:8px}
.mga-quick-label{font-size:13px;font-weight:600;color:#64748b}
.mga-toast{position:fixed;bottom:24px;right:24px;background:#334155;color:#fff;padding:16px 24px;border-radius:8px;box-shadow:0 10px 15px -3px rgba(0,0,0,.1);display:none;animation:mgaSlideIn .3s;z-index:9999}
.mga-toast.show{display:block}
@keyframes mgaSlideIn{from{transform:translateX(400px)}to{transform:translateX(0)}}
.mga-empty-state{text-align:center;padding:40px;color:#64748b}
.mga-empty-icon{font-size:48px;margin-bottom:16px;opacity:.3}

/* Options (auto-save / firebase) */
.mga-inline-options{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:12px;color:#475569;font-size:13px}
.mga-checkbox{display:inline-flex;align-items:center;gap:6px;cursor:pointer;user-select:none}
.mga-checkbox input{width:auto;padding:0;border:0;transform:translateY(1px)}
.mga-sync-status{padding:4px 10px;border-radius:999px;background:#f1f5f9;border:1px solid #e2e8f0;color:#475569;font-size:12px;font-weight:600}
.mga-current-diff{margin:12px 0;padding:12px 16px;border-radius:10px;border:1px solid #e2e8f0;background:#f8fafc;color:#0f172a;font-weight:600}
.mga-year-total{font-weight:700;background:#f1f5f9}
.mga-year-total .mga-month-label{color:#334155}
@media print{.mga-btn,.mga-quick-actions,.mga-toast{display:none}}


/* Mode switch + périodicité */
.mga-hidden{display:none!important;}
.mga-mode-switch{display:flex;gap:10px;justify-content:flex-end;margin:10px 0 18px;}
.mga-card-compact{padding-bottom:10px;}
.mga-form-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
@media (max-width: 900px){
  .mga-form-grid-4{grid-template-columns:repeat(2,1fr);}
}
.mga-period-result{font-weight:700;margin-left:auto;}
.mga-help{margin:10px 0 0;font-size:0.9em;opacity:.85;}


/* Mode périodicité : 1 seul tableau visible */
.mga-grid.mga-grid-single{grid-template-columns:1fr !important}

/* Modal d'édition */
.mga-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
}

.mga-modal-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.5);
}

.mga-modal-content {
    position: relative;
    background: white;
    border-radius: 12px;
    max-width: 1200px;
    width: 90%;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 10px 40px rgba(0,0,0,0.2);
    z-index: 10000;
}

/* Modal large (liste) */
.mga-modal-wide{max-width:1100px;}

/* Table (liste) */
/* Workflow : pas de scroll horizontal, table compacte et stable */
.mga-table-wrap{overflow:visible;}
.mga-table{width:100%;border-collapse:separate;border-spacing:0;}
.mga-table th,.mga-table td{padding:10px 12px;border-bottom:1px solid #e5e7eb;text-align:left;white-space:nowrap;}
.mga-table thead th{position:sticky;top:0;background:#f9fafb;z-index:1;font-weight:700;color:#374151;}
.mga-table tbody tr:hover{background:#f9fafb;}

.mga-action-group{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;}
.mga-action-group .mga-btn{padding:6px 10px;border-radius:8px;font-size:12px;}
.mga-empty{padding:14px;border:1px dashed #d1d5db;border-radius:12px;text-align:center;opacity:0.8;margin-top:10px;}
.mga-empty{padding:16px;border:1px dashed #e5e7eb;border-radius:12px;text-align:center;color:#6b7280;}

/* Boutons actions petits */
.mga-btn-icon{padding:6px 10px;font-size:12px;min-height:32px;}

/* Boutons d'actions en icônes (Workflow) */
.mga-icon-btn{background:transparent;border:0;cursor:pointer;padding:6px 8px;border-radius:8px;line-height:1;font-size:16px;opacity:.85}
.mga-icon-btn:hover{background:rgba(148,163,184,.25);opacity:1}
.mga-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-start;}

.mga-modal-header {
    padding: 20px 24px;
    border-bottom: 1px solid #e5e7eb;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.mga-modal-header h3 {
    margin: 0;
    font-size: 1.25rem;
    color: #1f2937;
}

.mga-modal-close {
    background: none;
    border: none;
    font-size: 1.5rem;
    cursor: pointer;
    color: #6b7280;
    padding: 0;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    transition: all 0.2s;
}

.mga-modal-close:hover {
    background: #f3f4f6;
    color: #1f2937;
}

.mga-modal-body {
    padding: 24px;
}

.mga-modal-footer {
    padding: 16px 24px;
    border-top: 1px solid #e5e7eb;
    display: flex;
    justify-content: flex-end;
    gap: 12px;
}

/* --------------------------------------------------------------
   Multi-édition (Option A + B)
-------------------------------------------------------------- */

.mga-multiedit-toolbar {
    background: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    padding: 14px;
    margin: 14px 0;
}

.mga-multiedit-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.mga-multiedit-left {
    display: flex;
    align-items: center;
    gap: 10px;
}

.mga-multiedit-right {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.mga-month-check {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
}

.mga-multi-check {
    width: 16px;
    height: 16px;
}


/* Workflow : table compacte (sans scroll horizontal) et alignements stables */
/* Ancien style scroll (désactivé) */
.mga-table-wrap--scroll{overflow:visible;border:0;border-radius:0}

.mga-table--workflow{table-layout:fixed;width:100%;}
.mga-table--workflow th,
.mga-table--workflow td{padding:14px 16px;vertical-align:top;}
.mga-table--workflow th{white-space:nowrap;}
.mga-table--workflow td{white-space:normal;}
.mga-table--workflow .mga-input,
.mga-table--workflow .mga-select{width:100%;min-height:38px;}

/* Layout internes des cellules (harmonieux, pas de règles en double) */
.wf-stack{display:flex;flex-direction:column;gap:10px;}
.wf-stack--readonly{gap:8px;}
.wf-grade-classe{display:flex;flex-direction:column;gap:10px;}
.wf-classe-ech{display:flex;gap:12px;align-items:flex-end;}
.wf-field{display:flex;flex-direction:column;gap:4px;min-width:0;}
.wf-field--date{min-width:0;}
.wf-mini-label{font-size:12px;color:#64748b;margin:0;font-weight:600;}

/* Menus déroulants Mois/Année */
.wf-ym{display:flex;gap:10px;align-items:center;}
.wf-ym__m{max-width:88px;}
.wf-ym__y{max-width:110px;}

/* Colonne Actions : 2 boutons empilés, sans encadré */
.wf-actions-col{width:84px;}
.wf-actions{padding-right:8px;}
.wf-actions-stack{display:flex;flex-direction:column;align-items:center;gap:10px;}
.mga-icon-btn{background:transparent;border:0;padding:6px;cursor:pointer;border-radius:10px;line-height:1;opacity:.85}
.mga-icon-btn:hover{background:rgba(15,23,42,0.06);opacity:1}

/* MGA différence : très lisible */
.mga-table--workflow td.wf-diff{vertical-align:middle;}
.mga-table--workflow .wf-diff-box{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  font-weight:800;
  font-size:16px;
  text-align:right;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,0.06);
  white-space:nowrap;
}
.wf-diff--zero .wf-diff-box{background:rgba(15,23,42,0.04);color:#0f172a;}
.wf-diff--pos .wf-diff-box{background:rgba(34,197,94,0.12);color:#166534;border-color:rgba(34,197,94,0.22);}
.wf-diff--neg .wf-diff-box{background:rgba(239,68,68,0.12);color:#7f1d1d;border-color:rgba(239,68,68,0.22);}

@media (max-width:768px){
  .mga-table--workflow th,.mga-table--workflow td{padding:12px 12px}
  .wf-classe-ech{gap:10px}
}


/* Workflow : message d'erreur (année hors barème) */
.mga-table--workflow .wf-error{
  margin-top:6px;
  font-size:12px;
  line-height:1.2;
  opacity:.75;
}
