
.sap-commander{background:#fbfaf7;padding:28px 0}
.sap-wrap{max-width:980px;margin:0 auto;padding:0 16px;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:#121212}
.sap-hero{display:grid;grid-template-columns:1.2fr .8fr;gap:18px;align-items:start;margin-bottom:16px}
@media (max-width:860px){.sap-hero{grid-template-columns:1fr}}
.sap-title{margin:0 0 8px 0;font-size:30px;line-height:1.15}
.sap-subtitle{margin:0;color:rgba(18,18,18,.72)}
.sap-card{background:#fff;border:1px solid rgba(18,18,18,.10);border-radius:18px;padding:16px;box-shadow:0 8px 24px rgba(0,0,0,.05);margin-top:14px}
.sap-card--soft{background:rgba(255,255,255,.9)}
.sap-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:720px){.sap-grid{grid-template-columns:1fr}}
.sap-field{margin:0 0 12px 0}
.sap-label{display:block;font-weight:700;margin:0 0 6px 0}
.sap-req{color:#c9b07a}
.sap-input{width:100%;padding:10px 12px;border:1px solid rgba(18,18,18,.18);border-radius:14px;font-size:14px}
.sap-input:focus{outline:none;border-color:rgba(201,176,122,.95);box-shadow:0 0 0 3px rgba(201,176,122,.18)}
.sap-help{font-size:12px;color:rgba(18,18,18,.55);margin-top:8px}
.sap-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.sap-btn{appearance:none;border:1px solid rgba(18,18,18,.18);background:#fff;color:#121212;padding:10px 14px;border-radius:14px;font-weight:750;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}
.sap-btn--primary{background:#121212;color:#fff;border-color:#121212}
.sap-btn--ghost{background:transparent}
.sap-status{margin-top:10px;font-size:13px}
.sap-note{background:rgba(18,18,18,.04);border:1px solid rgba(18,18,18,.10);padding:10px 12px;border-radius:14px;font-size:13px;color:rgba(18,18,18,.78)}
.sap-note--ok{background:rgba(0,128,0,.06);border-color:rgba(0,128,0,.16)}
.sap-note--error{background:rgba(180,0,0,.06);border-color:rgba(180,0,0,.16);color:rgba(180,0,0,.95)}
.sap-check{display:flex;gap:10px;align-items:center;font-weight:750}
.sap-toggle{padding:10px 12px;border:1px solid rgba(18,18,18,.10);border-radius:14px;background:rgba(18,18,18,.02)}
.sap-radio label{display:block;margin:6px 0}

.sap-drop{position:relative;border:1px dashed rgba(18,18,18,.22);border-radius:16px;padding:14px;background:rgba(18,18,18,.015)}
.sap-drop.is-drag{background:rgba(201,176,122,.10);border-color:rgba(201,176,122,.85)}
.sap-drop__main{text-align:center;padding:10px 6px}
.sap-drop__title{font-weight:800}
.sap-drop__sub{font-size:12px;color:rgba(18,18,18,.62);margin-top:4px}
.sap-drop__actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:10px}
.sap-drop__meta{display:grid;grid-template-columns:120px 1fr;gap:12px;align-items:center;margin-top:10px;padding-top:10px;border-top:1px solid rgba(18,18,18,.08)}
@media (max-width:620px){.sap-drop__meta{grid-template-columns:1fr}}
.sap-thumb{width:120px;height:80px;border-radius:12px;overflow:hidden;border:1px solid rgba(18,18,18,.10);background:#fff}
.sap-thumb img{width:100%;height:100%;object-fit:cover}
.sap-meta__row{display:flex;justify-content:space-between;gap:10px;margin:2px 0}
.sap-meta__row span{color:rgba(18,18,18,.65);font-size:13px}
.sap-meta__row strong{font-size:13px}
.sap-meta__rule{margin-top:6px;font-size:12px;color:rgba(18,18,18,.65)}
.sap-meta__hint{margin-top:6px;font-size:12px;color:rgba(18,18,18,.55)}
.sap-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;font-weight:800;font-size:12px;border:1px solid rgba(18,18,18,.12)}
.sap-badge.ok{background:rgba(0,128,0,.08);border-color:rgba(0,128,0,.20);color:rgba(0,128,0,.95)}
.sap-badge.warn{background:rgba(255,165,0,.10);border-color:rgba(255,165,0,.25);color:rgba(160,95,0,1)}

.sap-progress{margin-top:10px;display:flex;align-items:center;gap:10px}
.sap-progress__bar{flex:1;height:10px;border-radius:999px;background:rgba(18,18,18,.10);overflow:hidden}
.sap-progress__bar span{display:block;height:100%;background:rgba(201,176,122,.95);width:0%}
.sap-progress__txt{min-width:44px;text-align:right;font-weight:800;font-size:12px;color:rgba(18,18,18,.75)}

.sap-format-alt{margin-top:10px}
.sap-modal{max-width:720px;margin:0 auto}
.sap-modal__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.sap-modal__title{margin:0;font-size:18px}
.sap-x{border:none;background:transparent;font-size:24px;line-height:1;cursor:pointer}
.sap-modal__foot{margin-top:10px;opacity:.75}


/* Why accordion */
.sap-linkbtn{
  margin-top:10px;
  border:none;
  background:transparent;
  color:rgba(18,18,18,.85);
  font-weight:800;
  cursor:pointer;
  text-decoration:underline;
  padding:0;
}
.sap-why{
  margin-top:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(18,18,18,.10);
  background:rgba(18,18,18,.02);
  font-size:12px;
  color:rgba(18,18,18,.75);
}
.sap-why ul{margin:8px 0 0 18px}
.sap-why li{margin:6px 0}



.sap-hidden{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;}

/* CTA inline when image is "À analyser" */
.sap-meta__cta{margin-top:8px}
.sap-linkbtn2{border:none;background:transparent;color:#467ff7;font-weight:900;cursor:pointer;text-decoration:underline;padding:0;}
.sap-thumb{cursor:pointer}
.sap-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.72);display:none;align-items:center;justify-content:center;z-index:999999}
.sap-lightbox__inner{max-width:min(980px,92vw);max-height:90vh;background:#111;border-radius:16px;overflow:hidden;position:relative}
.sap-lightbox__inner img{display:block;max-width:100%;max-height:90vh}
.sap-lightbox__close{position:absolute;top:10px;right:12px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);color:#fff;border-radius:999px;width:36px;height:36px;cursor:pointer;font-size:20px;line-height:34px}

/* Strong message when photo is too small */
.sap-meta--warn #sapMetaHint{
  font-size:15px;
  font-weight:900;
  color:rgba(160,90,0,.95);
}
.sap-meta--warn{
  background:rgba(201,176,122,.08);
  border:1px solid rgba(201,176,122,.28);
  border-radius:14px;
  padding:10px 12px;
}

/* Disabled state for submit when photo too small */
.sap-btn.is-disabled,
button.is-disabled{
  opacity:.45;
  cursor:not-allowed;
}

/* Terms (CG) */
.sap-terms{margin-top:6px;}
.sap-check--terms a{ text-decoration:underline; }
.sap-terms-help{ margin-top:6px; }

/* Analysis modal overlay + feedback */
#sapAnalysisModal{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.55);
  z-index:999999;
  padding:18px;
}
#sapAnalysisModal .sap-modal{
  margin:0 auto;
  max-width:760px;
  background:#fff;
  border-radius:18px;
  box-shadow:0 30px 80px rgba(0,0,0,.35);
  overflow:hidden;
}
.sap-spinner{
  display:inline-block;
  width:16px;height:16px;
  border:2px solid rgba(0,0,0,.18);
  border-top-color:rgba(0,0,0,.55);
  border-radius:999px;
  animation:sapspin .8s linear infinite;
  vertical-align:-3px;
  margin-right:8px;
}
@keyframes sapspin{to{transform:rotate(360deg)}}

#sapProgress2{display:none;margin-top:10px}
#sapProgress2 .sap-progress__bar{height:8px;background:rgba(0,0,0,.10);border-radius:999px;overflow:hidden}
#sapProgressFill2{height:100%;width:0;background:rgba(201,176,122,.9)}
#sapProgressTxt2{font-size:12px;opacity:.75;margin-top:6px}

.sap-meta--warn #sapMetaHint{font-size:15px;font-weight:900;color:rgba(160,90,0,.95)}

/* v3.1.3 mobile/layout fixes */
@media (max-width:720px){
  .sap-hero{padding:18px 14px !important}
  .sap-card{padding:14px !important}
  .sap-drop{padding:14px !important; min-height:160px !important}
  .sap-drop__inner{gap:10px !important}
  .sap-meta{padding:10px 10px !important}
  .sap-field{margin-top:10px !important}
  .sap-lightbox__inner{max-width:92vw !important}
}

/* Analysis modal: ensure close button works and content scrolls */
#sapAnalysisModal{align-items:center;justify-content:center}
#sapAnalysisModal .sap-modal__dialog{
  max-height:85vh;
  overflow:auto;
  -webkit-overflow-scrolling:touch;
}
#sapCloseAnalysis{
  cursor:pointer;
  pointer-events:auto;
}

/* v3.1.4 modal fixes */
#sapAnalysisModal{
  position:fixed !important;
  inset:0 !important;
  display:none;
  z-index:2147483647 !important;
  padding:14px !important;
}
#sapAnalysisModal .sap-modal__dialog{
  width:min(920px, 96vw) !important;
  max-height:88vh !important;
  overflow:auto !important;
  border-radius:16px !important;
  background:#fff !important;
}
#sapAnalysisModal .sap-modal__close{
  position:sticky;
  top:0;
  float:right;
  margin:10px 10px 0 0;
  z-index:3;
}
#sapAnalysisModal img, #sapAnalysisModal svg{
  max-width:100%;
  height:auto;
}

/* Hide oversized branding/logo in modal on small screens */
@media (max-width:720px){
  #sapAnalysisModal .sap-modal__brand{
    display:none !important;
  }
  #sapAnalysisModal .sap-modal__dialog{
    width:96vw !important;
    max-height:90vh !important;
  }
  #sapAnalysisModal .sap-modal__content{
    padding:14px !important;
  }
}

/* Ensure remark field spacing */
.sap-remark textarea{resize:vertical}

/* v3.2.0 format auto display */
.sap-format-display{font-weight:700}
.sap-format-auto__row{display:flex;gap:10px;align-items:center}
.sap-format-display{background:#fff}
.sap-hidden{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}

/* modal stacking + body lock */
body.sap-modal-open{overflow:hidden !important}

/* ensure modal always above theme header */
#sapAnalysisModal{position:fixed !important; inset:0 !important; z-index:2147483647 !important;}
#sapAnalysisModal .sap-modal__dialog{position:relative; z-index:2147483647 !important;}
#sapAnalysisModal .sap-x{position:relative; z-index:2147483647 !important;}

/* v3.2.1 modal layout polish (desktop + mobile) */
#sapAnalysisModal .sap-modal__dialog{
  padding:18px 18px 14px 18px !important;
  box-sizing:border-box;
}
#sapAnalysisModal .sap-modal__content{
  padding:10px 2px 0 2px !important;
}
#sapAnalysisModal .sap-modal__title{
  margin:0 0 12px 0 !important;
  font-size:18px !important;
  font-weight:800 !important;
}
#sapAnalysisModal label{
  display:block;
  margin:10px 0 6px 0 !important;
  font-weight:700 !important;
}
#sapAnalysisModal .sap-input,
#sapAnalysisModal select,
#sapAnalysisModal textarea{
  width:100% !important;
  margin:0 !important;
}
#sapAnalysisModal .sap-form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
#sapAnalysisModal .sap-form-row--single{ grid-template-columns:1fr; }
#sapAnalysisModal .sap-actions{
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:flex-start;
  padding-top:12px !important;
  margin-top:8px !important;
  border-top:1px solid rgba(0,0,0,.08);
}
#sapAnalysisModal .sap-actions .sap-btn{min-height:44px}
#sapAnalysisModal .sap-modal__footer{
  margin-top:10px !important;
  padding-top:8px !important;
  font-size:12px !important;
  color:rgba(0,0,0,.65);
}
@media (max-width:720px){
  #sapAnalysisModal{padding:10px !important}
  #sapAnalysisModal .sap-modal__dialog{padding:14px 14px 12px 14px !important; border-radius:16px !important}
  #sapAnalysisModal .sap-form-row{grid-template-columns:1fr; gap:12px}
  #sapAnalysisModal .sap-actions{flex-direction:column; align-items:stretch}
  #sapAnalysisModal .sap-actions .sap-btn{width:100%}
}
#sapMetaCTA{margin-top:10px}

/* v3.2.2 edge padding fixes: ensure modal content never touches edges */
#sapAnalysisModal{
  padding:16px !important; /* outer gutter */
  box-sizing:border-box;
}
#sapAnalysisModal .sap-modal__dialog{
  margin:0 auto !important;
  padding:20px 20px 16px 20px !important; /* inner gutter */
  box-sizing:border-box;
}
#sapAnalysisModal .sap-modal__header{
  padding:4px 0 12px 0 !important;
  margin:0 0 6px 0 !important;
}
#sapAnalysisModal .sap-modal__title{
  padding-right:44px !important; /* space for close button */
}
#sapAnalysisModal .sap-modal__close{
  position:absolute !important;
  top:14px !important;
  right:14px !important;
  float:none !important;
  margin:0 !important;
}
#sapAnalysisModal .sap-modal__content{
  padding:6px 2px 0 2px !important;
}
#sapAnalysisModal .sap-modal__footer{
  padding:10px 0 0 0 !important;
}

/* Mobile: more gutter so nothing clips */
@media (max-width:720px){
  #sapAnalysisModal{padding:12px !important}
  #sapAnalysisModal .sap-modal__dialog{
    width:96vw !important;
    margin:0 auto !important;
    padding:16px 16px 14px 16px !important;
  }
  #sapAnalysisModal .sap-modal__close{
    top:10px !important;
    right:10px !important;
  }
  #sapAnalysisModal .sap-modal__title{
    font-size:18px !important;
    line-height:1.2 !important;
    margin-top:2px !important;
  }
}




/* ==================================================
SAP v3.2.4 — FIX "Analyse" : overlay + marges + scroll
IMPORTANT : ne touche PAS au système d'upload.
Le conteneur #sapAnalysisModal devient l'overlay plein écran.
Le bloc .sap-modal reste la "carte" blanche.
================================================== */

#sapAnalysisModal{
  position:fixed !important;
  inset:0 !important;
  z-index:99999 !important;
  display:none; /* JS met display:block */
  background:rgba(0,0,0,.55);
  padding:24px !important; /* marge autour */
  box-sizing:border-box !important;
  overflow:auto !important; /* scroll global si très petit écran */
}

#sapAnalysisModal .sap-modal{
  max-width:980px !important;
  margin:0 auto !important;
  background:#fff;
  border-radius:18px !important;
  padding:22px !important;
  box-sizing:border-box !important;
  box-shadow:0 18px 60px rgba(0,0,0,.22);
}

/* Close button toujours accessible */
#sapAnalysisModal .sap-x{
  position:sticky;
  top:0;
  margin-left:auto;
}

/* Empêche le contenu de coller aux bords */
#sapAnalysisModal .sap-form{
  margin-top:10px;
}

@media (max-width:720px){
  #sapAnalysisModal{ padding:12px !important; }
  #sapAnalysisModal .sap-modal{
    border-radius:16px !important;
    padding:16px !important;
  }
}
