/* Salon Form – Admin */
.sf-admin h1{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.sf-badge{background:#1d4ed8;color:#fff;border-radius:20px;padding:2px 12px;font-size:13px;font-weight:700}

/* Tarifs layout */
.sf-tarifs-layout{display:grid;grid-template-columns:1fr 280px;gap:20px;align-items:start;margin-top:16px}
.sf-tarifs-single{grid-template-columns:1fr !important}

/* Prices card */
.sf-prices-card,.sf-settings-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:24px}
.sf-prices-card h2,.sf-settings-card h2{font-size:16px;margin:0 0 16px;padding-bottom:10px;border-bottom:2px solid #e2e8f0}

.sf-prices-table{width:100%;border-collapse:collapse;font-size:14px}
.sf-prices-table th{background:#1e293b;color:#fff;padding:9px 12px;text-align:left;font-size:13px}
.sf-section-row td{background:#eff6ff;color:#1d4ed8;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.06em;padding:7px 12px;border-bottom:1px solid #bfdbfe}
.sf-prices-table td{padding:7px 10px;border-bottom:1px solid #f1f5f9;vertical-align:middle}
.sf-prices-table tr:hover td{background:#f8fafc}

.sf-label-input{width:100%;border:1px solid #e2e8f0;border-radius:4px;padding:5px 8px;font-size:13px}
.sf-price-wrap{display:flex;align-items:center;gap:5px}
.sf-price-input{width:90px;border:1.5px solid #e2e8f0;border-radius:4px;padding:5px 8px;font-size:14px;font-weight:700;text-align:right}
.sf-price-input:focus{border-color:#1d4ed8;outline:none;box-shadow:0 0 0 2px rgba(29,78,216,.15)}

/* Settings card */
.sf-setting-field{margin-bottom:16px}
.sf-setting-field label{display:block;font-size:13px;font-weight:600;color:#475569;margin-bottom:5px}
.sf-setting-field input[type=text],.sf-setting-field input[type=email],.sf-setting-field input[type=number]{width:100%;padding:7px 10px;border:1.5px solid #e2e8f0;border-radius:5px;font-size:13px}
.sf-setting-field input:focus{border-color:#1d4ed8;outline:none}
.sf-desc{font-size:11px;color:#94a3b8;margin-top:3px}
.sf-shortcode{display:block;background:#f1f5f9;padding:8px 12px;border-radius:5px;font-size:14px;margin-top:4px}
.sf-save-btn{width:100%!important;padding:10px!important;font-size:14px!important;font-weight:700!important}

/* Submissions */
.sf-submissions-table th{background:#1e293b!important;color:#fff!important;font-size:13px}
.sf-submissions-table td{padding:10px 12px;vertical-align:middle}
.sf-sub-row:hover td{background:#f0f9ff}
.sf-status-sel{font-size:12px;padding:3px 7px;border-radius:4px;border:1px solid #ddd;font-weight:600}
.sf-status-pill{display:inline-block;font-size:12px;font-weight:700;padding:4px 9px;border-radius:999px}
.sf-expand-btn:hover{background:#1d4ed8!important;color:#fff!important;border-color:#1d4ed8!important}
.sf-del-btn:hover{background:#ef4444!important;color:#fff!important;border-color:#ef4444!important}

/* Detail row */
.sf-detail-row td{background:#f8fafc!important;padding:0!important}
.sf-detail-inner{padding:16px 20px}
.sf-detail-info{margin-bottom:12px;font-size:13px;color:#475569}
.sf-detail-table{width:100%;border-collapse:collapse;font-size:13px}
.sf-detail-table th{background:#e2e8f0;padding:7px 10px;text-align:left}
.sf-detail-table td{padding:7px 10px;border-bottom:1px solid #e2e8f0}
.sf-detail-table tfoot td{padding:8px 10px;font-size:14px}

.sf-pagination{margin-top:14px;display:flex;gap:6px}
.sf-pagination a{padding:5px 12px;background:#fff;border:1px solid #ddd;border-radius:4px;text-decoration:none;font-size:13px}
.sf-pagination a.current{background:#1d4ed8;color:#fff;border-color:#1d4ed8}

.sf-tarifs-single .sf-settings-card{max-width:100%}
.sf-tarifs-single .sf-settings-inner{display:grid;grid-template-columns:1fr 1fr;gap:0 24px}
.sf-tarifs-single .sf-setting-field-full{grid-column:1/-1}
@media(max-width:900px){.sf-tarifs-layout{grid-template-columns:1fr}}

.sf-admin-free-badge{display:inline-block;background:#dcfce7;color:#15803d;border:1px solid #bbf7d0;font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;letter-spacing:.04em}

.sf-admin-mandatory-lock{font-size:14px;cursor:help;opacity:.7}
.sf-admin-mandatory-lock:hover{opacity:1}

/* ── Attachment picker ── */
.sf-attachment-wrap{ display:flex; flex-direction:column; gap:8px; }
.sf-attachment-preview{
  display:flex; align-items:center; gap:8px;
  background:#f0fdf4; border:1px solid #bbf7d0;
  border-radius:6px; padding:8px 12px;
}
.sf-att-icon{ font-size:20px; flex-shrink:0; }
.sf-att-name{ font-size:13px; font-weight:600; color:#15803d; flex:1; word-break:break-all; }
.sf-att-remove{
  background:none; border:none; color:#dc2626;
  font-size:14px; cursor:pointer; flex-shrink:0;
  width:22px; height:22px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  transition:background .15s;
}
.sf-att-remove:hover{ background:#fee2e2; }

/* ── Upload zone ── */
.sf-upload-zone{ display:flex; align-items:center; gap:10px; margin-top:4px; }
.sf-upload-hint{ font-size:12px; color:#94a3b8; }
.sf-progress-bar{
  height:8px; background:#e2e8f0; border-radius:4px;
  overflow:hidden; margin-top:6px; max-width:300px;
}
.sf-progress-fill{
  height:100%; width:0%; background:#1d4ed8;
  border-radius:4px; transition:width .2s;
}
#sf-progress-label{ font-size:12px; color:#64748b; }

/* ── Native file input styled ── */
#sf-file-input {
  display: block;
  font-size: 13px;
  padding: 6px 0;
  cursor: pointer;
  color: #1d4ed8;
  max-width: 350px;
}
#sf-file-input::file-selector-button {
  background: #1d4ed8;
  color: #fff;
  border: none;
  border-radius: 5px;
  padding: 6px 14px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  margin-right: 10px;
  transition: background .15s;
}
#sf-file-input::file-selector-button:hover {
  background: #1e40af;
}

/* ── Articles personnalisés ─────────────────────────────── */
.sf-custom-add-form {
  background: #f8fafc;
  border: 1.5px dashed #cbd5e1;
  border-radius: 10px;
  padding: 18px 20px;
  margin-bottom: 8px;
}
.sf-custom-add-grid {
  display: grid;
  grid-template-columns: 2fr 3fr 1.2fr 1.4fr;
  gap: 12px;
  margin-bottom: 14px;
}
.sf-custom-field label {
  display: block;
  font-size: 12px;
  font-weight: 700;
  color: #475569;
  margin-bottom: 5px;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.sf-custom-field input {
  width: 100%;
  padding: 7px 10px;
  border: 1.5px solid #e2e8f0;
  border-radius: 6px;
  font-size: 13px;
  transition: border-color .2s;
}
.sf-custom-field input:focus {
  border-color: #1d4ed8;
  outline: none;
}
.sf-custom-table td input[type="text"],
.sf-custom-table td input[type="number"] {
  padding: 5px 8px;
  border: 1.5px solid #e2e8f0;
  border-radius: 5px;
  font-size: 13px;
}
.sf-custom-table td input:focus {
  border-color: #1d4ed8;
  outline: none;
}
@media (max-width: 900px) {
  .sf-custom-add-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .sf-custom-add-grid { grid-template-columns: 1fr; }
}

.sf-section-row td{position:relative}
.sf-section-row td span{display:inline-block;padding-right:12px}
.sf-section-row .sf-delete-section-btn{float:right;text-transform:none;letter-spacing:0;font-size:12px;color:#dc2626;margin-top:-2px}
.sf-order-up,.sf-order-down{min-width:30px;padding:0 8px!important}
.sf-delete-item-btn{margin-left:4px!important}

.sf-section-row td{position:relative}
.sf-section-row td>span{font-weight:700}
.sf-section-actions{float:right;display:inline-flex;gap:6px;align-items:center}
.sf-section-up,.sf-section-down{min-width:82px;padding:0 8px!important}

/* ── Champs du formulaire exposant ───────────────────── */
.sf-fields-table input[type=text],
.sf-fields-table select,
.sf-fields-table textarea,
.sf-field-add-grid input[type=text],
.sf-field-add-grid select,
.sf-field-add-grid textarea{
  width:100%;
  border:1.5px solid #e2e8f0;
  border-radius:5px;
  padding:6px 8px;
  font-size:13px;
}
.sf-fields-table textarea,
.sf-field-add-grid textarea{resize:vertical;min-height:68px}
.sf-fields-table td{vertical-align:top}
.sf-fields-table .button-small{margin:0 2px 4px 0}
.sf-danger-link{color:#dc2626!important}
.sf-field-add-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px 20px;
}
.sf-field-check{display:flex;align-items:end}
.sf-field-check label{font-weight:600;color:#475569}
@media(max-width:900px){.sf-field-add-grid{grid-template-columns:1fr}}

/* ── Édition réservation ─────────────────────────────── */
.sf-edit-meta-grid,
.sf-edit-info-grid,
.sf-edit-payment-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px 20px;
}
.sf-edit-meta-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.sf-edit-field-full{grid-column:1/-1}
.sf-edit-field label{
  display:block;
  font-size:12px;
  font-weight:700;
  color:#475569;
  margin-bottom:5px;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.sf-edit-field input,
.sf-edit-field select,
.sf-edit-field textarea,
.sf-edit-meta-grid input,
.sf-edit-meta-grid select,
.sf-edit-payment-grid input,
.sf-edit-payment-grid textarea,
.sf-edit-items-table input[type=number]{
  width:100%;
  border:1.5px solid #e2e8f0;
  border-radius:5px;
  padding:7px 10px;
  font-size:13px;
}
.sf-edit-field textarea{resize:vertical}
.sf-edit-items-table td{vertical-align:middle}
.sf-edit-items-table input[readonly]{background:#f8fafc;color:#64748b}
.sf-edit-total-card div{font-size:14px;margin:6px 0}
.sf-payment-summary{
  background:#f8fafc;
  border:1px solid #e2e8f0;
  border-radius:6px;
  padding:10px 12px;
  color:#475569;
  margin:8px 0 0;
}
.sf-payment-lines{overflow-x:auto}
.sf-payment-lines-table{
  min-width:1080px;
  table-layout:fixed;
}
.sf-payment-lines-table th:nth-child(1){width:170px}
.sf-payment-lines-table th:nth-child(2),
.sf-payment-lines-table td:nth-child(2){width:170px;min-width:170px}
.sf-payment-lines-table th:nth-child(3){width:165px}
.sf-payment-lines-table th:nth-child(4),
.sf-payment-lines-table th:nth-child(5){width:140px}
.sf-payment-lines-table th:nth-child(7){width:70px}
.sf-payment-lines-table input[type=text],
.sf-payment-lines-table input[type=number],
.sf-payment-lines-table input[type=date]{
  width:100%;
  box-sizing:border-box;
  border:1.5px solid #e2e8f0;
  border-radius:5px;
  padding:7px 10px;
  font-size:13px;
}
.sf-payment-lines-table .sf-payment-amount-input{
  min-width:130px;
  min-height:42px;
  font-size:17px;
  font-weight:800;
  color:#1d4ed8;
}
.sf-payment-mini-list{
  display:flex;
  flex-direction:column;
  gap:3px;
  margin-top:6px;
  padding-top:6px;
  border-top:1px solid #e2e8f0;
}
.sf-payment-mini-list small{
  color:#475569;
  line-height:1.25;
}
.sf-history-list{display:flex;flex-direction:column;gap:8px}
.sf-history-entry{
  background:#f8fafc;
  border:1px solid #e2e8f0;
  border-left:4px solid #1d4ed8;
  border-radius:6px;
  padding:10px 12px;
}
.sf-history-meta{
  font-size:12px;
  color:#64748b;
  font-weight:700;
  margin-bottom:4px;
}
@media(max-width:900px){
  .sf-edit-meta-grid,
  .sf-edit-info-grid,
  .sf-edit-payment-grid{grid-template-columns:1fr}
  .sf-edit-field-full{grid-column:1}
}

/* ── Statuts ─────────────────────────────────────────── */
.sf-statuses-table input[type=text]{
  width:100%;
  border:1.5px solid #e2e8f0;
  border-radius:5px;
  padding:6px 8px;
  font-size:13px;
}
.sf-statuses-table input[type=color],
.sf-status-add-grid input[type=color]{
  width:52px;
  height:34px;
  padding:2px;
  border:1.5px solid #e2e8f0;
  border-radius:5px;
  background:#fff;
}
.sf-statuses-table td{vertical-align:middle}
.sf-status-add-grid{
  display:grid;
  grid-template-columns:1fr 120px;
  gap:14px 20px;
  max-width:620px;
}
@media(max-width:700px){.sf-status-add-grid{grid-template-columns:1fr}}

/* ── Front salon-reservations : édition dense ───────── */
.sf-front-edit-reservation .sf-edit-meta-grid{
  display:grid!important;
  grid-template-columns:minmax(220px,1.2fr) minmax(150px,.7fr) minmax(190px,.9fr)!important;
  align-items:end;
}
.sf-front-edit-reservation .sf-edit-payment-grid{
  display:grid!important;
  grid-template-columns:minmax(220px,1.35fr) minmax(190px,1fr) minmax(145px,.75fr) minmax(165px,.85fr)!important;
  align-items:end;
}
.sf-front-edit-reservation .sf-edit-meta-grid .sf-setting-field,
.sf-front-edit-reservation .sf-edit-payment-grid .sf-setting-field{
  min-width:0;
  margin-bottom:0;
}
.sf-front-edit-reservation .sf-payment-amount-input{
  width:100% !important;
  min-width:130px !important;
  box-sizing:border-box;
  min-height:44px;
  font-size:18px;
  font-weight:800;
  color:#1d4ed8;
}
.sf-front-edit-reservation .sf-edit-payment-grid .sf-edit-field-full{
  grid-column:1/-1;
}
@media(max-width:1050px){
  .sf-front-edit-reservation .sf-edit-payment-grid{grid-template-columns:minmax(220px,1.35fr) minmax(190px,1fr) minmax(145px,.75fr) minmax(165px,.85fr)!important}
}
@media(max-width:760px){
  .sf-front-edit-reservation .sf-edit-meta-grid,
  .sf-front-edit-reservation .sf-edit-payment-grid{grid-template-columns:1fr!important}
}

.sf-front-login-box{
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:8px;
  padding:14px 16px;
  margin:0 0 18px;
  display:grid;
  grid-template-columns:minmax(220px,1fr) auto;
  gap:16px;
  align-items:center;
}
.sf-front-login-box p{margin:4px 0 0;color:#64748b;font-size:13px}
.sf-front-login-box form{
  display:flex;
  align-items:end;
  gap:10px;
  flex-wrap:wrap;
  margin:0;
}
.sf-front-login-box .login-username,
.sf-front-login-box .login-password,
.sf-front-login-box .login-remember,
.sf-front-login-box .login-submit{margin:0}
.sf-front-login-box label{display:block;font-size:12px;font-weight:700;color:#475569;margin-bottom:4px}
.sf-front-login-box input[type=text],
.sf-front-login-box input[type=password]{
  min-width:180px;
  border:1.5px solid #e2e8f0;
  border-radius:5px;
  padding:7px 9px;
}
.sf-front-login-box .login-remember label{display:flex;align-items:center;gap:5px;margin-bottom:7px;font-weight:600}
.sf-front-login-ok{grid-template-columns:1fr auto}
@media(max-width:820px){
  .sf-front-login-box{grid-template-columns:1fr}
  .sf-front-login-box form{align-items:stretch}
  .sf-front-login-box input[type=text],
  .sf-front-login-box input[type=password]{width:100%;min-width:0}
}


/* ── v2.79 : Front salon-réservations plus large et boutons alignés ── */
.sf-front-reservations{
  width:min(1560px, calc(100vw - 48px));
  max-width:none!important;
  margin-left:50%!important;
  margin-right:0!important;
  transform:translateX(-50%);
  box-sizing:border-box;
}
.sf-front-reservations .sf-submissions-table{
  width:100%;
  table-layout:auto;
}
.sf-front-reservations .sf-submissions-table th,
.sf-front-reservations .sf-submissions-table td{
  vertical-align:middle;
}
.sf-front-reservations .sf-actions-cell{
  white-space:nowrap;
  min-width:230px;
}
.sf-front-reservations .sf-actions-row{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:6px;
  flex-wrap:nowrap;
}
.sf-front-reservations .sf-actions-row .button{
  display:inline-flex!important;
  align-items:center;
  justify-content:center;
  min-height:30px;
  line-height:1.2!important;
  margin:0!important;
}
.sf-dossier-status-sel,
.sf-setting-field select[name="dossier_status"]{
  font-size:12px;
  padding:3px 7px;
  border-radius:4px;
  border:1px solid #ddd;
  font-weight:600;
  font-family:inherit;
  color:#1e293b;
  background:#fff;
  min-height:30px;
}
.sf-setting-field select[name="dossier_status"],
.sf-setting-field select[name="status"]{
  width:100%;
  min-height:36px;
  font-size:13px;
}
@media(max-width:900px){
  .sf-front-reservations{
    width:100%;
    margin-left:0!important;
    transform:none;
  }
  .sf-front-reservations .sf-submissions-table{
    display:block;
    overflow-x:auto;
    white-space:nowrap;
  }
}
