/* Advanced export modal specific styles (extracted from modal.css and drawer.css) */

#modal-advanced-export-modal .modal-header-advanced-export-modal h2 {
  flex: 1;
}

/* ==========================
 * Advanced Export - Context Preview (externalisation des styles inline)
 * ========================== */
#modal-advanced-export-modal .aexp-context-preview .aexp-preview-container {
  width: 100%;
  max-width: 680px;
  margin: 0 auto;
  border: 1px solid #ddd;
  background: #ffffff;
  position: relative;
  border-radius: 4px;
  overflow: hidden;
}

#modal-advanced-export-modal .aexp-context-preview--map .aexp-preview-container {
  width: min(100%, 460px);
  aspect-ratio: 1 / 1;
  min-height: 260px;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-preview-map {
  width: 100%;
  height: 100%;
  background: #e9ecef;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

#modal-advanced-export-modal .aexp-context-preview #aexpContextLeafletMap,
#modal-advanced-export-modal .aexp-context-preview #aexpContextLeafletMap.leaflet-container {
  position: relative !important;
  inset: auto !important;
  left: auto !important;
  top: auto !important;
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  overflow: hidden !important;
  contain: layout paint size;
  cursor: zoom-in;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-preview-map.leaflet-container {
  position: relative !important;
  left: auto !important;
  top: auto !important;
  transform: none !important;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-preview-map .leaflet-pane,
#modal-advanced-export-modal .aexp-context-preview .aexp-preview-map .leaflet-map-pane {
  will-change: transform;
}

#modal-advanced-export-modal .aexp-context-preview #aexpContextLeafletMap.is-wheel-focused,
#modal-advanced-export-modal .aexp-context-preview #aexpContextLeafletMap.is-wheel-focused.leaflet-container {
  cursor: grab;
  box-shadow: inset 0 0 0 2px rgba(39, 95, 146, 0.35);
}

#modal-advanced-export-modal .aexp-context-preview #aexpContextLeafletMap::after {
  content: attr(data-wheel-hint);
  position: absolute;
  left: 10px;
  bottom: 10px;
  z-index: 420;
  padding: 4px 8px;
  border-radius: 8px;
  font-size: 11px;
  font-weight: 600;
  color: #274f7a;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(39, 95, 146, 0.25);
  pointer-events: none;
  transition: opacity 160ms ease;
}

#modal-advanced-export-modal .aexp-context-preview #aexpContextLeafletMap.is-wheel-focused::after {
  opacity: 0;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-preview-map .leaflet-interactive {
  pointer-events: none;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-preview-map .leaflet-popup,
#modal-advanced-export-modal .aexp-context-preview .aexp-preview-map .leaflet-tooltip {
  display: none !important;
}

#modal-advanced-export-modal .aexp-context-preview #aexpContextLeafletMap .leaflet-control-zoom {
  border: 1px solid rgba(39, 95, 146, 0.75);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 8px 18px rgba(10, 34, 64, 0.25);
  background: rgba(255, 255, 255, 0.85);
}

#modal-advanced-export-modal .aexp-context-preview #aexpContextLeafletMap .leaflet-control-zoom a {
  width: 34px;
  height: 34px;
  line-height: 34px;
  text-align: center;
  color: #0f6fb8;
  font-size: 20px;
  font-weight: 700;
  background: rgba(255, 255, 255, 0.92);
  border-bottom: 1px solid rgba(39, 95, 146, 0.2);
}

#modal-advanced-export-modal .aexp-context-preview #aexpContextLeafletMap .leaflet-control-zoom a:last-child {
  border-bottom: 0;
}

#modal-advanced-export-modal .aexp-context-preview #aexpContextLeafletMap .leaflet-control-zoom a:hover {
  background: #eaf4ff;
  color: #0a5f9d;
}
.offscreen-map-capture-container,
.offscreen-map-capture-container * {
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-preview-overlay {
  position: absolute;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.78);
  backdrop-filter: blur(1px);
  z-index: 5;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-preview-overlay.is-visible {
  display: flex;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-preview-overlay .preview-placeholder {
  width: calc(100% - 16px);
  max-width: 320px;
  margin: 8px;
}

#modal-advanced-export-modal .aexp-context-preview {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-preview-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
  padding: 8px 10px;
  border: 1px solid #e2e6ea;
  border-radius: 4px;
  background: #f8f9fa;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-preview-title {
  color: #2c3e50;
  font-size: 12px;
  font-weight: 700;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-preview-subtitle {
  color: #28a745;
  font-size: 11px;
  font-weight: 600;
}

#modal-advanced-export-modal .template-preview-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

#modal-advanced-export-modal .template-preview-header h5 {
  margin: 0;
}

#modal-advanced-export-modal .btn-context-current {
  white-space: nowrap;
}

#modal-advanced-export-modal .context-view-tools {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 6px;
  margin-bottom: 8px;
}

#modal-advanced-export-modal .context-view-tools-row {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

/* .context-view-tools .btn {
  min-width: 32px;
  padding-left: 8px !important;
  padding-right: 8px !important;
} */

#modal-advanced-export-modal .context-view-tools .btn-context-icon,
#modal-advanced-export-modal .context-view-tools #contextViewportReset {
  width: 34px;
  min-width: 34px;
  height: 34px;
  padding: 0 !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

#modal-advanced-export-modal .context-view-tools-row .btn-context-layers {
  margin-left: auto;
  order: 99;
}

#modal-advanced-export-modal .context-view-state-row {
  display: flex;
  justify-content: flex-start;
}

#modal-advanced-export-modal .context-view-state {
  margin-left: 4px;
  padding: 3px 8px;
  border: 1px solid #d8dee4;
  border-radius: 10px;
  background: #f6f8fa;
  color: #2c3e50;
  font-size: 11px;
  font-weight: 600;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-preview-image {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  cursor: default;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-layers-info {
  margin-top: 10px;
  padding: 10px;
  background: #f8f9fa;
  border-radius: 4px;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-layers-title {
  margin: 0 0 8px 0;
  color: #2c3e50;
  font-size: 12px;
  font-weight: bold;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-layers-scroll {
  /* max-height: 120px; */
  overflow-y: auto;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-group {
  margin-bottom: 8px;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-group-title {
  font-weight: bold;
  font-size: 11px;
  margin-bottom: 4px;
}

/* Variantes de couleur par groupe connu */
#modal-advanced-export-modal .aexp-context-preview .aexp-group-title--suivi {
  color: #007bff;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-group-title--territoire {
  color: #6c757d;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-group-title--geometries {
  color: #28a745;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-group-title--synthese {
  color: var(--error-color);
}

#modal-advanced-export-modal .aexp-context-preview .aexp-group-title--autre {
  color: #6f42c1;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-layer-item {
  font-size: 10px;
  color: #666;
  margin: 1px 0 1px 10px;
  display: flex;
  align-items: center;
  gap: 6px;
}

#modal-advanced-export-modal .aexp-context-preview .aexp-layer-dot {
  color: #28a745;
}

/* Placeholder d'erreur générique pour l'aperçu contexte */
#modal-advanced-export-modal .aexp-error-placeholder {
  padding: 20px;
  text-align: center;
  color: #999;
}

#modal-advanced-export-modal .export-layers-section {
  margin-top: 12px;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  padding: 10px;
  background: #fafafa;
}

#modal-advanced-export-modal .export-section--context {
  position: relative;
  transition: flex-basis 220ms ease, width 220ms ease, min-width 220ms ease, max-width 220ms ease, padding 180ms ease;
}

#modal-advanced-export-modal .context-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

#modal-advanced-export-modal .context-section-header h4 {
  margin: 0;
}

#modal-advanced-export-modal .context-section-toggle {
  width: 32px;
  min-width: 32px;
  height: 32px;
  border: 1px solid #bfc8d2;
  border-radius: 999px;
  background: #ecf0f3;
  color: #5f7082;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  cursor: pointer;
  transition: background-color 150ms ease, color 150ms ease, border-color 150ms ease, box-shadow 150ms ease;
}

#modal-advanced-export-modal .context-section-toggle:hover {
  background: #dde5ec;
  border-color: #9eacb9;
  color: #3c4d5d;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

#modal-advanced-export-modal .context-section-toggle:focus-visible {
  outline: 2px solid rgba(40, 94, 255, 0.45);
  outline-offset: 1px;
}

#modal-advanced-export-modal .context-section-toggle i {
  font-size: 13px;
}

#modal-advanced-export-modal .context-collapsed-hint {
  display: none;
  align-items: flex-start;
  justify-content: flex-start;
  width: 100%;
  height: 100%;
  min-height: 170px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease;
  position: relative;
  overflow: hidden;
  padding-top: 0;
  box-sizing: border-box;
}

#modal-advanced-export-modal .context-collapsed-hint span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  position: absolute;
  top: 10px;
  left: 50%;
  writing-mode: vertical-rl;
  transform: translateX(-50%) rotate(180deg);
  transform-origin: center;
  line-height: 1;
  white-space: nowrap;
  color: #274f7a;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

#modal-advanced-export-modal .context-collapsed-hint span i {
  font-size: 14px;
}

#modal-advanced-export-modal .context-section-body {
  overflow: hidden;
  max-height: 10000px;
  opacity: 1;
  transition: max-height 220ms ease, opacity 180ms ease, margin-top 180ms ease;
}

#modal-advanced-export-modal .advanced-export-form > .export-section--context.is-collapsed {
  flex: 0 0 50px !important;
  min-width: 50px !important;
  max-width: 50px !important;
  width: 50px !important;
  padding: 10px 6px;
  overflow: hidden;
  cursor: pointer;
  position: sticky;
  top: 0;
  align-self: stretch;
  max-height: calc(100vh - 180px);
  min-height: 170px;
  background: #f2f5f8;
}

#modal-advanced-export-modal .export-section--context.is-collapsed .context-section-body {
  max-height: 0;
  opacity: 0;
  pointer-events: none;
  margin-top: 0;
}

#modal-advanced-export-modal .export-section--context.is-collapsed .context-section-header {
  opacity: 0;
  max-height: 0;
  pointer-events: none;
  overflow: hidden;
  margin: 0;
}

#modal-advanced-export-modal .export-section--context.is-collapsed .export-layers-section {
  opacity: 0 !important;
  pointer-events: none !important;
  transform: translateX(12px) !important;
}

#modal-advanced-export-modal .export-section--context.is-collapsed .context-collapsed-hint {
  display: flex;
  opacity: 1;
  pointer-events: auto;
  min-height: 100%;
}

#modal-advanced-export-modal .export-section--context.is-collapsed:hover {
  background: #e7edf3;
  box-shadow: inset 0 0 0 1px rgba(145, 165, 184, 0.45);
}

#modal-advanced-export-modal .export-section--context.is-collapsed .context-collapsed-hint span {
  transition: color 140ms ease, letter-spacing 140ms ease;
}

#modal-advanced-export-modal .export-section--context.is-collapsed:hover .context-collapsed-hint span {
  color: #1f4468;
  letter-spacing: 0.05em;
}

#modal-advanced-export-modal .context-client-row {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 140px;
  gap: 12px;
  margin-bottom: 12px;
}

#modal-advanced-export-modal .context-client-logo-card {
  display: flex;
  align-items: stretch;
}

#modal-advanced-export-modal .context-client-logo-frame {
  width: 100%;
  min-height: 64px;
  border: 1px solid #d8dee4;
  border-radius: 8px;
  background: #f6f8fa;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4px;
}

#modal-advanced-export-modal #contextClientLogoImg {
  max-width: 100%;
  max-height: 56px;
  object-fit: contain;
}

#modal-advanced-export-modal #contextClientLogoEmpty {
  font-size: 11px;
  color: #607089;
  font-weight: 600;
}

#modal-advanced-export-modal .context-item--layers {
  justify-content: flex-end;
}

#modal-advanced-export-modal .context-item--layers label {
  visibility: hidden;
}

#modal-advanced-export-modal .btn-context-layers {
  min-height: 38px;
  min-width: 120px;
  font-size: 13px !important;
  font-weight: 700;
}

/* .context-view-tools #contextViewportApply.is-pending {
  box-shadow: 0 0 0 2px rgba(40, 167, 69, 0.25);
} */

#modal-advanced-export-modal .export-layers-section h5 {
  margin: 0 0 8px 0;
  color: #2c3e50;
  font-size: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}

#modal-advanced-export-modal .export-layers-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}

#modal-advanced-export-modal .export-layers-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
}

#modal-advanced-export-modal .export-layers-header h5 {
  margin: 0;
}

#modal-advanced-export-modal .export-layers-section {
  position: absolute;
  top: 110px;
  right: 0;
  z-index: 20;
  width: min(460px, 95%);
  max-height: calc(100vh - 240px);
  overflow: auto;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
  opacity: 0;
  transform: translateX(12px);
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

#modal-advanced-export-modal .export-layers-section.is-open {
  opacity: 1;
  transform: translateX(0);
  pointer-events: auto;
}

#modal-advanced-export-modal .modal-content.modal-responsive-small .export-layers-section,
#modal-advanced-export-modal .modal-content.modal-responsive-medium .export-layers-section {
  top: 10px;
  right: 10px;
  left: 10px;
  width: auto;
  max-height: 65vh;
}

#modal-advanced-export-modal .modal-content.modal-responsive-small .context-client-row,
#modal-advanced-export-modal .modal-content.modal-responsive-medium .context-client-row {
  grid-template-columns: 1fr;
}

#modal-advanced-export-modal .modal-content.modal-responsive-small .context-section-header,
#modal-advanced-export-modal .modal-content.modal-responsive-medium .context-section-header {
  flex-wrap: wrap;
}

#modal-advanced-export-modal .modal-content.modal-responsive-small .advanced-export-form > .export-section--context.is-collapsed,
#modal-advanced-export-modal .modal-content.modal-responsive-medium .advanced-export-form > .export-section--context.is-collapsed {
  flex: 0 0 auto !important;
  width: 100% !important;
  min-width: 100% !important;
  max-width: 100% !important;
  min-height: 52px;
  padding: 8px 12px;
}

#modal-advanced-export-modal .modal-content.modal-responsive-small .export-section--context.is-collapsed .context-collapsed-hint,
#modal-advanced-export-modal .modal-content.modal-responsive-medium .export-section--context.is-collapsed .context-collapsed-hint {
  min-height: 32px;
}

#modal-advanced-export-modal .modal-content.modal-responsive-small .context-collapsed-hint span,
#modal-advanced-export-modal .modal-content.modal-responsive-medium .context-collapsed-hint span {
  position: static;
  writing-mode: horizontal-tb;
  transform: none;
  font-size: 13px;
  letter-spacing: 0.02em;
}

#modal-advanced-export-modal .export-rasters-panel {
  border: 1px solid #ddd;
  border-radius: 4px;
  background: #fff;
  min-height: 70px;
  max-height: 140px;
  overflow: auto;
  padding: 8px;
  margin-bottom: 8px;
}

#modal-advanced-export-modal .export-layers-panel {
  border: 1px solid #ddd;
  border-radius: 4px;
  background: #fff;
  min-height: 120px;
  max-height: 280px;
  overflow: auto;
  padding: 8px;
}

#modal-advanced-export-modal .aexp-empty-layers {
  padding: 10px;
  color: #6c757d;
  font-size: 12px;
}

#modal-advanced-export-modal .aexp-layer-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

#modal-advanced-export-modal .aexp-layer-group-title {
  font-size: 12px;
  font-weight: 700;
  color: #2c3e50;
  margin-bottom: 4px;
}

#modal-advanced-export-modal .aexp-layer-group-body {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

#modal-advanced-export-modal .aexp-layer-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 3px 0;
  font-size: 12px;
  color: #495057;
}

#modal-advanced-export-modal .aexp-layer-row--radio input[type="radio"] {
  margin-top: 0;
}

#modal-advanced-export-modal .aexp-layer-toggle {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  min-width: 0;
}

#modal-advanced-export-modal .aexp-layer-name {
  flex: 1;
  min-width: 0;
  line-height: 1.2;
}

#modal-advanced-export-modal .aexp-layer-opacity {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 124px;
}

#modal-advanced-export-modal .aexp-layer-opacity input[type="range"] {
  width: 86px;
  margin: 0;
}

#modal-advanced-export-modal .aexp-layer-opacity-value {
  min-width: 32px;
  font-size: 11px;
  font-weight: 700;
  color: #6c757d;
  text-align: right;
}

#modal-advanced-export-modal .aexp-layer-badge {
  margin-left: auto;
  font-size: 10px;
  font-weight: 700;
  color: #495057;
  background: #e9ecef;
  border: 1px solid #d1d7dc;
  border-radius: 10px;
  padding: 1px 8px;
}

#modal-advanced-export-modal .aexp-solid-color-control {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px dashed #d5dbe2;
  font-size: 12px;
}

#modal-advanced-export-modal .aexp-solid-color-control label {
  margin: 0;
  font-weight: 600;
  color: #405263;
}

#modal-advanced-export-modal .aexp-solid-color-control input[type="color"] {
  width: 34px;
  height: 22px;
  border: 1px solid #c8d0d8;
  border-radius: 4px;
  padding: 0;
  background: #ffffff;
  cursor: pointer;
}

#modal-advanced-export-modal .aexp-solid-color-control span {
  font-family: monospace;
  font-size: 11px;
  color: #647284;
}

#modal-advanced-export-modal .aexp-solid-color-control span.is-disabled {
  opacity: 0.55;
}


#modal-advanced-export-modal .advanced-export-form .north-arrow-options,
#modal-advanced-export-modal .advanced-export-form .scale-layout-options,
#modal-advanced-export-modal .advanced-export-form .checkboxes-options,
#modal-advanced-export-modal .advanced-export-form .legend-layout-options {
  margin-top: 8px;
  padding: 8px;
  border: 1px solid #d7dee6;
  border-radius: 8px;
  background: #f9fbfd;
  min-width: fit-content;
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  flex: 1;
}

#modal-advanced-export-modal .advanced-export-form .legend-layout-options h6,
#modal-advanced-export-modal .advanced-export-form .north-arrow-options h6,
#modal-advanced-export-modal .advanced-export-form .scale-layout-options h6 {
  margin: 0 0 8px 0;
  font-size: 12px;
  color: #34506b;
  width: 100%;
}

#modal-advanced-export-modal .advanced-export-form .north-arrow-options label {
  font-size: 12px;
  min-width: none;
  width: auto;
}

#modal-advanced-export-modal .advanced-export-form .north-arrow-options.is-collapsed-options .legend-layout-row,
#modal-advanced-export-modal .advanced-export-form .north-arrow-options.is-collapsed-options .north-arrow-position-grid {
  display: none;
}

#modal-advanced-export-modal .advanced-export-form .scale-layout-options.is-collapsed-options .legend-layout-row {
  display: none;
}


#modal-advanced-export-modal .advanced-export-form .aexp-toggle-grid {
  width: 100%;
  display: flex;
  gap: 8px;
  flex-direction: column;
}

#modal-advanced-export-modal .advanced-export-form .aexp-toggle-grid--legend {
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}

#modal-advanced-export-modal .advanced-export-form .aexp-toggle-grid--single {
  margin-bottom: 8px;
}

#modal-advanced-export-modal .advanced-export-form .legend-layout-row {
  display: flex;
  gap: 5px;
  align-items: center;
  justify-content: center;
  align-items: center;
  min-width: max-content;
  max-width: 100%;
  flex: 1;
  padding: 10px;
  border: 1px solid var(--accent-color-hover-table);
  border-radius: 10px;
  background-color: white;
}

#modal-advanced-export-modal .advanced-export-form .legend-layout-row:last-child {
  margin-bottom: 0;
}

#modal-advanced-export-modal .advanced-export-form .legend-layout-row label {
  margin: 0;
  font-size: 12px;
  color: #30465f;
  flex: 1;
}

#modal-advanced-export-modal .advanced-export-form .legend-layout-row select {
  flex: 1;
  border: 1px solid var(--accent-color);
  background-color: var(--accent-color-clear);
  border-radius: 5px;
  font-size: 14px;
  min-height: 30px;
}

#modal-advanced-export-modal .advanced-export-form .north-arrow-position-grid {
  display: grid;
  grid-template-columns: repeat(2, 36px);
  grid-template-rows: repeat(2, 36px);
  gap: 0;
  justify-content: center;
}

#modal-advanced-export-modal .advanced-export-form .north-arrow-picker {
  position: relative;
  width: auto;
}

#modal-advanced-export-modal .advanced-export-form .scale-style-picker {
  position: relative;
  width: 100%;
}

#modal-advanced-export-modal .advanced-export-form .north-arrow-picker-toggle {
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: 36px;
  padding: 4px 8px;
}

#modal-advanced-export-modal .advanced-export-form .scale-style-picker-toggle {
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: 36px;
  padding: 4px 8px;
}

#modal-advanced-export-modal .advanced-export-form .north-arrow-picker-toggle img {
  width: 24px;
  height: 24px;
  object-fit: contain;
  background: #fff;
  border: 1px solid #d7dee6;
  border-radius: 4px;
}

#modal-advanced-export-modal .advanced-export-form .north-arrow-picker-toggle span {
  flex: 1;
  text-align: left;
  font-size: 12px;
}

#modal-advanced-export-modal .advanced-export-form .scale-style-picker-toggle span {
  flex: 1;
  text-align: left;
  font-size: 12px;
}

#modal-advanced-export-modal .advanced-export-form .scale-style-preview {
  width: 42px;
  height: 24px;
  border: 1px solid #d7dee6;
  border-radius: 4px;
  background: #f8fafc;
  position: relative;
  display: inline-block;
  overflow: hidden;
}

#modal-advanced-export-modal .advanced-export-form .scale-style-preview::before,
#modal-advanced-export-modal .advanced-export-form .scale-style-preview::after {
  content: '';
  position: absolute;
}

#modal-advanced-export-modal .advanced-export-form .scale-style-preview--qgis_classic_line::before {
  left: 5px;
  right: 5px;
  bottom: 7px;
  height: 2px;
  background: #111111;
}

#modal-advanced-export-modal .advanced-export-form .scale-style-preview--qgis_classic_line::after {
  left: 5px;
  bottom: 4px;
  width: 2px;
  height: 8px;
  background: #111111;
  box-shadow: 30px 0 0 #111111;
}

#modal-advanced-export-modal .advanced-export-form .scale-style-preview--qgis_dual_tick::before {
  left: 5px;
  right: 5px;
  bottom: 7px;
  height: 2px;
  background: #1f2937;
}

#modal-advanced-export-modal .advanced-export-form .scale-style-preview--qgis_dual_tick::after {
  left: 5px;
  bottom: 4px;
  width: 2px;
  height: 8px;
  background: #1f2937;
  box-shadow: 15px 0 0 #1f2937, 30px 0 0 #1f2937;
}

#modal-advanced-export-modal .advanced-export-form .scale-style-preview--qgis_alternating_blocks {
  background: linear-gradient(90deg, #111 0 25%, #fff 25% 50%, #111 50% 75%, #fff 75% 100%);
}

#modal-advanced-export-modal .advanced-export-form .scale-style-preview--qgis_alternating_blocks::before {
  left: 5px;
  right: 5px;
  bottom: 7px;
  height: 6px;
  border: 1px solid #111111;
  background: transparent;
}

#modal-advanced-export-modal .advanced-export-form .scale-style-preview--qgis_dark_compact {
  background: #111827;
}

#modal-advanced-export-modal .advanced-export-form .scale-style-preview--qgis_dark_compact::before {
  left: 5px;
  right: 5px;
  bottom: 7px;
  height: 2px;
  background: #f9fafb;
}

#modal-advanced-export-modal .advanced-export-form .scale-style-preview--qgis_dark_compact::after {
  left: 5px;
  bottom: 4px;
  width: 2px;
  height: 8px;
  background: #f9fafb;
  box-shadow: 30px 0 0 #f9fafb;
}

#modal-advanced-export-modal .advanced-export-form .north-arrow-picker-panel {
  position: absolute;
  top: calc(100% + -15px);
  left: 0;
  right: 0;
  display: none;
  max-height: 210px;
  overflow-y: auto;
  padding: 8px;
  border: 1px solid #d7dee6;
  border-radius: 8px;
  background: #ffffff;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.16);
  z-index: 30;
}

#modal-advanced-export-modal .advanced-export-form .scale-style-picker-panel {
  position: absolute;
  top: calc(100% + 2px);
  left: 0;
  right: 0;
  display: none;
  max-height: 210px;
  overflow-y: auto;
  padding: 8px;
  border: 1px solid #d7dee6;
  border-radius: 8px;
  background: #ffffff;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.16);
  z-index: 30;
}

#modal-advanced-export-modal .advanced-export-form .scale-style-picker-panel.is-open {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 6px;
}

#modal-advanced-export-modal .advanced-export-form .north-arrow-picker-panel.is-open {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(60px, 2fr));
  gap: 5px;
}

#modal-advanced-export-modal .advanced-export-form .north-arrow-item {
  border: 1px solid #d2d9e2;
  border-radius: 8px;
  background: #f8fbfe;
  min-height: 72px;
  padding: 6px;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}

#modal-advanced-export-modal .advanced-export-form .scale-style-item {
  border: 1px solid #d2d9e2;
  border-radius: 8px;
  background: #f8fbfe;
  min-height: 58px;
  padding: 8px;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-align: center;
}

#modal-advanced-export-modal .advanced-export-form .scale-style-item > span:last-child {
  font-size: 11px;
  color: #3b5269;
  line-height: 1.1;
}

#modal-advanced-export-modal .advanced-export-form .scale-style-item.is-active {
  border-color: #0fa9e6;
  background: #e8f8fe;
  box-shadow: inset 0 0 0 1px rgba(15, 169, 230, 0.35);
}

#modal-advanced-export-modal .advanced-export-form .north-arrow-item:hover {
  border-color: #3a9cc8;
  background: #eef9ff;
}

#modal-advanced-export-modal .advanced-export-form .north-arrow-item.is-active {
  border-color: #0fa9e6;
  background: #e8f8fe;
  box-shadow: inset 0 0 0 1px rgba(15, 169, 230, 0.35);
}

#modal-advanced-export-modal .advanced-export-form .north-arrow-item img {
  width: 24px;
  height: 24px;
  object-fit: contain;
}

#modal-advanced-export-modal .advanced-export-form .north-arrow-item span {
  font-size: 10px;
  color: #30465f;
  text-align: center;
  letter-spacing: -1px;
}

#modal-advanced-export-modal .advanced-export-form .north-arrow-empty {
  font-size: 12px;
  color: #6a7f93;
  text-align: center;
  padding: 8px;
}

#modal-advanced-export-modal .advanced-export-form .north-arrow-color-row {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

#modal-advanced-export-modal .advanced-export-form .north-arrow-preset-btn {
  width: 28px;
  min-width: 28px;
  height: 28px;
  border: 1px solid #c7d2de;
  border-radius: 6px;
  background: #ffffff;
  cursor: pointer;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.65);
}

#modal-advanced-export-modal .advanced-export-form #northArrowPresetBlack {
  background: #111111;
}

#modal-advanced-export-modal .advanced-export-form #northArrowPresetWhite {
  background: #ffffff;
}

#modal-advanced-export-modal .advanced-export-form #northArrowColor {
  width: 48px;
  min-width: 48px;
  height: 30px;
  border: 1px solid #cdd7e4;
  border-radius: 6px;
  padding: 1px;
}

#modal-advanced-export-modal .advanced-export-form #northArrowColorValue {
  font-size: 12px;
  color: #324f68;
  min-width: 70px;
  text-transform: lowercase;
}

#modal-advanced-export-modal .advanced-export-form .north-pos-option {
  position: relative;
  cursor: pointer;
  margin: 0 !important;
  padding: 0 !important;
}

#modal-advanced-export-modal .advanced-export-form .north-pos-option input {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

#modal-advanced-export-modal .advanced-export-form .north-pos-option span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 8px;
  border: 1px solid #c7d2df;
  background: #ffffff;
  color: #325171;
  font-size: 18px;
  transition: all 0.15s ease-in-out;
}

#modal-advanced-export-modal .advanced-export-form .north-pos-option input:checked + span {
  border-color: #0fa9e6;
  background: #e8f8fe;
  color: #0c6f98;
  box-shadow: inset 0 0 0 1px rgba(15, 169, 230, 0.35);
}

#modal-advanced-export-modal .advanced-export-form #legendFontSizeValue,
#modal-advanced-export-modal .advanced-export-form #legendLineSpacingValue {
  min-width: 34px;
  text-align: right;
  font-weight: 600;
  color: #324f68;
}

/* Advanced export - format/orientation/template group */
#modal-advanced-export-modal .advanced-export-form .form-orientation-template-group {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  align-items: self-start;
}

#modal-advanced-export-modal .advanced-export-form .export-section .radio-label {
  width: auto;
  min-width: 110px;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  padding: 6px 8px;
  border-radius: 8px;
  transition: color 0.2s ease;
}

#modal-advanced-export-modal .advanced-export-form .export-section .radio-option {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  cursor: pointer;
  padding: 8px 12px;
  border-radius: 8px;
  border: 1px solid #d7dee6;
  background: #fff;
  min-height: 40px;
  transition: background-color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

#modal-advanced-export-modal .advanced-export-form .export-section .radio-option:hover {
  background-color: #f2f7fc;
  border-color: #c4d8ed;
  box-shadow: inset 0 0 0 1px rgba(47, 127, 201, 0.1);
}

#modal-advanced-export-modal .advanced-export-form .export-section .radio-option input[type="radio"] {
  position: absolute;
  inset: 0;
  opacity: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  cursor: pointer;
  appearance: none;
}

#modal-advanced-export-modal .advanced-export-form .export-section .radio-option:hover .radio-label {
  color: #2a5f90;
}

#modal-advanced-export-modal .advanced-export-form .export-section .radio-option .radio-label::before {
  content: "";
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 2px solid #9ab0c8;
  background: #fff;
  box-shadow: inset 0 0 0 3px #fff;
  transition: all 0.18s ease;
  flex-shrink: 0;
}

#modal-advanced-export-modal .advanced-export-form .export-section .radio-option input[type="radio"]:checked + .radio-label::before {
  border-color: #2f7fc9;
  background: #2f7fc9;
}

#modal-advanced-export-modal .advanced-export-form .export-section .radio-option input[type="radio"]:checked + .radio-label {
  color: #214f79;
  font-weight: 600;
}

#modal-advanced-export-modal .advanced-export-form .export-section .radio-option:has(input[type="radio"]:checked) {
  border-color: #2f7fc9;
  background: #eaf3fc;
  box-shadow: inset 0 0 0 1px rgba(47, 127, 201, 0.12);
}

#modal-advanced-export-modal .advanced-export-form .export-section .radio-option input[type="radio"]:focus-visible + .radio-label::before {
  outline: 2px solid rgba(47, 127, 201, 0.4);
  outline-offset: 2px;
}

#modal-advanced-export-modal .advanced-export-form .export-section .radio-option:has(input[type="radio"]:focus-visible) {
  box-shadow: inset 0 0 0 2px rgba(47, 127, 201, 0.22);
}

#modal-advanced-export-modal .group-form-group{
  display: flex;
  flex-wrap: wrap;
  flex: 2;
  gap: 15px;
}

/* Advanced export - north arrow + legend layout options */
#modal-advanced-export-modal .advanced-export-form .export-section .form-group {
  background-color: white;
  border-radius: 10px;
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  justify-content: center;
  align-items: flex-start;
  border: 1px solid #e0e0e0;
  min-height: fit-content;
  flex: 1;
  padding: 5px;
  margin-bottom: 0;
  gap: 6px;
}

#modal-advanced-export-modal .advanced-export-form .export-section .form-group.options-group h5 {
  width: 100%;
  margin: 5px;
}

#modal-advanced-export-modal .advanced-export-form .export-section .form-group label {
  /* width: 100%; */
  height: 30px;
  line-height: 20px;
  border-radius: 10px;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 10px 5px;
  margin: 0px;
}

#modal-advanced-export-modal .advanced-export-form .export-section .form-group>label {
  font-size: 12px;
  width: 100%;
  margin: 0;
  padding: 0;
}

#modal-advanced-export-modal .advanced-export-form .export-section .form-group.options-group label {
  padding-left: 10px;
  text-align: left;
  display: contents;
  min-width: 80px;
  font-size: 14px;
}

#modal-advanced-export-modal .advanced-export-form .export-section .form-group.options-group .legend-layout-options label{
  font-size: 12px;
}

#modal-advanced-export-modal .advanced-export-form .aexp-toggle-input {
  display: none;
}

#modal-advanced-export-modal .advanced-export-form .export-section .form-group.options-group .aexp-toggle-option {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  min-height: 40px;
  border-radius: 8px;
  border: 1px solid #d7dee6;
  background: #fff;
  line-height: 1.2;
  cursor: pointer;
  width: 100%;
  margin: 0;
  text-align: left;
  font-size: 13px;
  justify-content: flex-start;
  appearance: none;
  outline: none;
  font-family: inherit;
  transition: background-color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

#modal-advanced-export-modal .advanced-export-form .export-section .form-group.options-group .aexp-toggle-option:hover {
  background: #f2f7fc;
  border-color: #c4d8ed;
  box-shadow: inset 0 0 0 1px rgba(47, 127, 201, 0.1);
}

#modal-advanced-export-modal .advanced-export-form .export-section .form-group.options-group .aexp-toggle-option .aexp-toggle-icon {
  width: 22px;
  height: 22px;
  border: 1px solid #b8c9db;
  border-radius: 6px;
  background: #f4f8fc;
  color: #5a7390;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all 0.18s ease;
}

#modal-advanced-export-modal .advanced-export-form .export-section .form-group.options-group .aexp-toggle-option .aexp-toggle-text {
  flex: 1;
  color: #304b67;
  font-weight: 600;
  min-width: 0;
}

#modal-advanced-export-modal .advanced-export-form .export-section .form-group.options-group .aexp-toggle-option.aexp-toggle-option--required {
  border-style: dashed;
}

#modal-advanced-export-modal .advanced-export-form .export-section .form-group.options-group .aexp-toggle-option.is-active {
  border-color: #2f7fc9;
  background: #eaf3fc;
  box-shadow: inset 0 0 0 1px rgba(47, 127, 201, 0.12);
}

#modal-advanced-export-modal .advanced-export-form .export-section .form-group.options-group .aexp-toggle-option.is-active .aexp-toggle-text {
  color: #214f79;
  font-weight: 600;
}

#modal-advanced-export-modal .advanced-export-form .export-section .form-group.options-group .aexp-toggle-option.is-active .aexp-toggle-icon {
  background: #2f7fc9;
  border-color: #2f7fc9;
  color: #fff;
}

#modal-advanced-export-modal .advanced-export-form .export-section .form-group.options-group .aexp-toggle-option:focus-visible {
  box-shadow: inset 0 0 0 2px rgba(47, 127, 201, 0.28);
}

#modal-advanced-export-modal .advanced-export-form .export-section .form-group.options-group .aexp-toggle-option.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

#modal-advanced-export-modal .advanced-export-form select#pageFormat.form-control,
#modal-advanced-export-modal .advanced-export-form select#templateSelect.form-control {
  background-color: #f6f6f6;
  width: 100%;
  height: 30px;
  border-radius: 10px;
  min-width: 180px;
  border: 1px solid #e0e0e0;
  margin-bottom: 10px;
}

#modal-advanced-export-modal .advanced-export-form .template-availability-badge {
  display: inline-flex;
  align-items: center;
  margin-left: 8px;
  padding: 2px 8px;
  border-radius: 12px;
  border: 1px solid #ccd7e6;
  font-size: 11px;
  font-weight: 600;
  line-height: 1.2;
  background: #f4f7fb;
  color: #4e6175;
}

#modal-advanced-export-modal .advanced-export-form .template-availability-badge.is-loading {
  border-color: #d4a017;
  background: #fff8e1;
  color: #8a6d00;
}

#modal-advanced-export-modal .advanced-export-form .template-availability-badge.is-empty,
#modal-advanced-export-modal .advanced-export-form .template-availability-badge.is-error {
  border-color: #d9534f;
  background: #ffeaea;
  color: #b73a35;
}

#modal-advanced-export-modal .advanced-export-form .template-availability-badge.is-ready {
  border-color: #22a745;
  background: #e9f8ef;
  color: #1f7f3f;
}

#modal-advanced-export-modal .advanced-export-form .aexp-hidden-radio-group {
  display: none;
}

#modal-advanced-export-modal .advanced-export-form .aexp-orientation-picker {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(2, minmax(100px, 1fr));
  gap: 8px;
  margin-bottom: 8px;
}

#modal-advanced-export-modal .advanced-export-form .aexp-orientation-btn {
  border: 1px solid #bfd0e2;
  background: #f8fafc;
  border-radius: 10px;
  min-height: 46px;
  padding: 8px 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-align: left;
  cursor: pointer;
  font-family: inherit;
  transition: all 0.16s ease;
  padding-right: 10%;
}

#modal-advanced-export-modal .advanced-export-form .aexp-orientation-btn:hover {
  border-color: #80a5cb;
  background: #eef5fc;
}

#modal-advanced-export-modal .advanced-export-form .aexp-orientation-btn.is-active {
  border-color: #2f87c8;
  background: #e8f4ff;
  box-shadow: inset 0 0 0 1px rgba(47, 135, 200, 0.25);
}

#modal-advanced-export-modal .advanced-export-form .aexp-orientation-btn:focus-visible {
  outline: 2px solid rgba(47, 127, 201, 0.3);
  outline-offset: 2px;
}

#modal-advanced-export-modal .advanced-export-form .aexp-orientation-btn-title {
  color: #274f7a;
  font-weight: 700;
  line-height: 1.2;
  display: block;
}

#modal-advanced-export-modal .advanced-export-form .aexp-native-select--hidden {
  position: absolute;
  width: 1px !important;
  height: 1px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  overflow: hidden;
  white-space: nowrap;
}

#modal-advanced-export-modal .advanced-export-form .aexp-format-picker {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(2, minmax(100px, 1fr));
  gap: 8px;
  margin-bottom: 8px;
}

#modal-advanced-export-modal .advanced-export-form .aexp-format-btn {
  border: 1px solid #bfd0e2;
  background: #f8fafc;
  border-radius: 10px;
  min-height: 56px;
  padding: 8px 10px;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  gap: 10px;
  text-align: left;
  cursor: pointer;
  transition: all 0.16s ease;
}

#modal-advanced-export-modal .advanced-export-form .aexp-format-btn:hover {
  border-color: #80a5cb;
  background: #eef5fc;
}

#modal-advanced-export-modal .advanced-export-form .aexp-format-btn.is-active {
  border-color: #2f87c8;
  background: #e8f4ff;
  box-shadow: inset 0 0 0 1px rgba(47, 135, 200, 0.25);
}

#modal-advanced-export-modal .advanced-export-form .aexp-format-btn-title {
  font-weight: 700;
  color: #274f7a;
  line-height: 1.2;
  display: block;
}

#modal-advanced-export-modal .advanced-export-form .aexp-format-btn-sub {
  margin-top: 2px;
  font-size: 11px;
  color: #617892;
  line-height: 1.2;
  display: block;
}

#modal-advanced-export-modal .advanced-export-form .aexp-format-sheet {
  width: 18px;
  height: 26px;
  border-radius: 3px;
  border: 1px solid #b8c8d9;
  background: linear-gradient(180deg, #ffffff 0%, #ecf2f8 100%);
  box-shadow: 0 1px 3px rgba(28, 56, 86, 0.12);
  position: relative;
  flex: 0 0 auto;
}

#modal-advanced-export-modal .advanced-export-form .aexp-format-sheet::after {
  content: '';
  position: absolute;
  left: 2px;
  right: 2px;
  bottom: 3px;
  height: 4px;
  border-radius: 2px;
  background: rgba(47, 135, 200, 0.18);
}

#modal-advanced-export-modal .advanced-export-form .aexp-format-sheet--a3 {
  width: 22px;
  height: 31px;
}

#modal-advanced-export-modal .advanced-export-form .aexp-orient-icon {
  width: 14px;
  height: 14px;
  border: 1px solid #c4d0dc;
  border-radius: 2px;
  background: linear-gradient(180deg, #ffffff 0%, #eef3f8 100%);
  display: inline-block;
  margin-right: 0;
}

#modal-advanced-export-modal .advanced-export-form .aexp-orient-icon--portrait {
  width: 40px;
  height: 56px;
}

#modal-advanced-export-modal .advanced-export-form .aexp-orient-icon--landscape {
  width: 56px;
  height: 40px;
}

#modal-advanced-export-modal .advanced-export-form .aexp-quality-picker {
  flex: 1;
  width: 100%;
  display: grid;
  grid-template-columns: repeat(2, minmax(110px, 1fr));
  gap: 8px;
}

#modal-advanced-export-modal .advanced-export-form .aexp-quality-btn {
  border: 1px solid #bfd0e2;
  background: #f8fafc;
  border-radius: 8px;
  min-height: 34px;
  padding: 6px 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  cursor: pointer;
  font-family: inherit;
  transition: all 0.16s ease;
}

#modal-advanced-export-modal .advanced-export-form .aexp-quality-btn:not(.is-active) {
  opacity: 0.86;
}

#modal-advanced-export-modal .advanced-export-form .aexp-quality-btn:hover {
  border-color: #80a5cb;
  background: #eef5fc;
}

#modal-advanced-export-modal .advanced-export-form .aexp-quality-btn.is-active {
  border-color: #2f87c8;
  background: #2f87c8;
  box-shadow: 0 2px 8px rgba(47, 135, 200, 0.28);
  opacity: 1;
}

#modal-advanced-export-modal .advanced-export-form .aexp-quality-btn:focus-visible {
  outline: 2px solid rgba(47, 127, 201, 0.3);
  outline-offset: 2px;
}

#modal-advanced-export-modal .advanced-export-form .aexp-quality-btn-title {
  color: #274f7a;
  font-weight: 600;
  line-height: 1.2;
}

#modal-advanced-export-modal .advanced-export-form .aexp-quality-btn.is-active .aexp-quality-btn-title {
  color: #ffffff;
  font-weight: 700;
}

#modal-advanced-export-modal .advanced-export-form .aexp-template-grid {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 8px;
  margin-bottom: 6px;
}

#modal-advanced-export-modal .advanced-export-form .aexp-template-grid-empty {
  grid-column: 1 / -1;
  padding: 10px;
  border: 1px dashed #cfd8e3;
  border-radius: 10px;
  color: #617892;
  font-size: 12px;
  text-align: center;
  background: #f8fafc;
}

#modal-advanced-export-modal .advanced-export-form .aexp-template-card {
  border: 1px solid #c8d6e6;
  border-radius: 10px;
  background: #ffffff;
  padding: 6px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: stretch;
  cursor: pointer;
  transition: border-color 0.16s ease, background-color 0.16s ease, box-shadow 0.16s ease;
}

#modal-advanced-export-modal .advanced-export-form .aexp-template-card:hover {
  border-color: #8bb2d5;
  background: #f7fbff;
}

#modal-advanced-export-modal .advanced-export-form .aexp-template-card.is-active {
  border-color: #2f87c8;
  background: #e9f5ff;
  box-shadow: inset 0 0 0 1px rgba(47, 135, 200, 0.25);
}

#modal-advanced-export-modal .advanced-export-form .aexp-template-card-thumb {
  width: 100%;
  min-height: 96px;
  max-height: 120px;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid #d4dde8;
  background: linear-gradient(180deg, #f9fbfd 0%, #eff3f7 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 6px;
}

#modal-advanced-export-modal .advanced-export-form .aexp-template-card-sheet {
  --sheet-ar: 210 / 297;
  --sheet-scale: 1;
  --map-left: 10%;
  --map-top: 14%;
  --map-width: 80%;
  --map-height: 62%;
  width: min(92%, calc(78px * var(--sheet-scale)));
  aspect-ratio: var(--sheet-ar);
  border: 1px solid #9fb6cd;
  border-radius: 4px;
  background: #ffffff;
  position: relative;
  overflow: hidden;
  box-shadow: 0 1px 4px rgba(13, 35, 60, 0.14);
}

#modal-advanced-export-modal .advanced-export-form .aexp-template-card-svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.3;
  mix-blend-mode: multiply;
  margin: 0 !important;
  padding: 0 !important;
}

#modal-advanced-export-modal .advanced-export-form .aexp-template-card-svg.is-hidden {
  display: none;
}

#modal-advanced-export-modal .advanced-export-form .aexp-template-card-mapzone {
  position: absolute;
  left: var(--map-left);
  top: var(--map-top);
  width: var(--map-width);
  height: var(--map-height);
  border: 1px solid rgba(31, 120, 255, 0.7);
  border-radius: 3px;
  background: rgba(31, 120, 255, 0.12);
}

#modal-advanced-export-modal .advanced-export-form .aexp-template-card.is-no-image .aexp-template-card-sheet::before {
  content: 'SVG';
  position: absolute;
  right: 5px;
  bottom: 4px;
  font-size: 11px;
  font-weight: 700;
  color: #5f7892;
  letter-spacing: 0.08em;
}

#modal-advanced-export-modal .advanced-export-form .aexp-template-card-name {
  font-size: 12px;
  font-weight: 600;
  color: #29445e;
  line-height: 1.25;
  text-align: left;
}

/* ===== STYLES POUR MODAL FULLSCREEN ===== */

#modal-advanced-export-modal .modal-content .export-section {
    margin-bottom: 15px;
    padding: 15px;
    flex: 1 1 calc(50% - 7.5px);
    min-width: calc(50% - 7.5px);
}

#modal-advanced-export-modal .modal-content .template-preview {
    flex: 1;
    min-height: 300px;
    display: flex;
    align-items: center;
    justify-content: center;
}

#modal-advanced-export-modal .modal-content .preview-container {
    max-width: 100%;
    max-height: 100%;
}

#modal-advanced-export-modal .modal-content .preview-container img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

/* Layout pour le plein écran */
#modal-advanced-export-modal .modal-content .advanced-export-form {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
}

#modal-advanced-export-modal .modal-content .export-actions {
    display: flex;
    gap: 15px;
    justify-content: center;
    margin-top: 25px;
    padding-top: 20px;
    border-top: 1px solid #e9ecef;
    width: 100%;
}

#modal-advanced-export-modal .export-progress {
    margin-top: 20px;
    padding: 15px;
    background: #e3f2fd;
    border-radius: 6px;
    border: 1px solid #bbdefb;
}

#modal-advanced-export-modal .progress-bar {
    width: 100%;
    height: 8px;
    background: #e0e0e0;
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 10px;
}

#modal-advanced-export-modal .progress-fill {
    height: 100%;
    background: linear-gradient(90deg, #007bff, #0056b3);
    width: 0%;
    animation: aexp-progress-animation 2s ease-in-out infinite;
}

#modal-advanced-export-modal .progress-text {
    text-align: center;
    color: #1565c0;
    font-weight: 500;
    font-size: 0.9em;
}

/* ===== STYLES POUR LES APERÇUS ===== */

#modal-advanced-export-modal .template-preview-section,
#modal-advanced-export-modal .context-preview-section {
    margin: 15px 0;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    padding: 15px;
    background: #fafafa;
}

#modal-advanced-export-modal .template-preview-section h5,
#modal-advanced-export-modal .context-preview-section h5 {
    margin: 0 0 10px 0;
    color: #2c3e50;
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 8px;
}

#modal-advanced-export-modal .template-preview-section .template-preview-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}

#modal-advanced-export-modal .template-preview-section .template-preview-header h5 {
    margin: 0;
}

#modal-advanced-export-modal .template-preview,
#modal-advanced-export-modal .context-preview,
#modal-advanced-export-modal .final-preview {
    min-height: 200px;
    border: 1px solid #ddd;
    border-radius: 4px;
    background: white;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 10px;
    position: relative;
}

#modal-advanced-export-modal .final-preview-section {
    margin-top: 20px;
    border: 2px solid #28a745;
    border-radius: 8px;
    padding: 15px;
    background: #f8fff8;
}

#modal-advanced-export-modal .final-preview-section h4 {
    margin: 0 0 15px 0;
    color: #28a745;
    font-size: 16px;
    display: flex;
    align-items: center;
    gap: 8px;
}

#modal-advanced-export-modal .final-preview {
    min-height: 250px;
    border: 2px solid #28a745;
    border-radius: 4px;
    background: white;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 10px;
}

#modal-advanced-export-modal .preview-placeholder {
    text-align: center;
    color: #999;
    font-size: 14px;
}

#modal-advanced-export-modal .preview-placeholder i {
    font-size: 24px;
    margin-bottom: 8px;
    display: block;
}

#modal-advanced-export-modal .preview-container {
    border: 1px solid #ddd;
    border-radius: 4px;
    overflow: hidden;
    background: white;
}

/* ===== STYLES POUR LA SECTION CONTEXTE ===== */

#modal-advanced-export-modal .context-selectors {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    margin-bottom: 20px;
    padding: 15px;
    background: #f8f9fa;
    border-radius: 8px;
    border: 1px solid #e9ecef;
}

#modal-advanced-export-modal .context-selectors .context-item {
    display: flex;
    flex-direction: column;
}

#modal-advanced-export-modal .context-selectors label {
    font-weight: 600;
    color: #2c3e50;
    margin-bottom: 5px;
    font-size: 12px;
}

#modal-advanced-export-modal .context-selectors select {
    padding: 8px 12px;
    border: 1px solid #ddd;
    border-radius: 4px;
    font-size: 13px;
    background-color: #fff;
    transition: all 0.3s ease;
}

#modal-advanced-export-modal .context-selectors select:focus {
    border-color: #007bff;
    box-shadow: 0 0 0 2px rgba(0, 123, 255, 0.25);
    outline: none;
}

#modal-advanced-export-modal .context-info {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
    margin-bottom: 15px;
}

#modal-advanced-export-modal .context-item {
    display: flex;
    flex-direction: column;
}

#modal-advanced-export-modal .context-item label {
    font-weight: 600;
    color: #2c3e50;
    margin-bottom: 5px;
    font-size: 12px;
}

#modal-advanced-export-modal .context-item input {
    padding: 8px 12px;
    border: 1px solid #ddd;
    border-radius: 4px;
    font-size: 13px;
    background-color: #f8f9fa;
    transition: all 0.3s ease;
}

#modal-advanced-export-modal .context-item input.editing {
    background-color: #fff;
    border-color: #007bff;
    box-shadow: 0 0 0 2px rgba(0, 123, 255, 0.25);
}

#modal-advanced-export-modal .context-actions {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
}

#modal-advanced-export-modal .btn-sm {
    font-size: 12px !important;
    padding: 6px 12px !important;
}

/* Responsive basé sur la largeur de la modale, pas de l'écran */
#modal-advanced-export-modal .modal-content.modal-responsive-small .advanced-export-form,
#modal-advanced-export-modal .modal-content.modal-responsive-medium .advanced-export-form,
#modal-advanced-export-modal .modal-content.modal-responsive-large .advanced-export-form {
    flex-direction: column;
    flex-wrap: nowrap;
}

#modal-advanced-export-modal .modal-content.modal-responsive-small .export-section,
#modal-advanced-export-modal .modal-content.modal-responsive-medium .export-section,
#modal-advanced-export-modal .modal-content.modal-responsive-large .export-section {
    min-width: 100%;
}

#modal-advanced-export-modal .modal-content.modal-responsive-small .context-selectors,
#modal-advanced-export-modal .modal-content.modal-responsive-medium .context-selectors,
#modal-advanced-export-modal .modal-content.modal-responsive-large .context-selectors {
    flex-direction: column;
    flex-wrap: nowrap;
}

#modal-advanced-export-modal .modal-content.modal-responsive-small .context-actions,
#modal-advanced-export-modal .modal-content.modal-responsive-medium .context-actions,
#modal-advanced-export-modal .modal-content.modal-responsive-large .context-actions {
    flex-direction: column;
}

#modal-advanced-export-modal .modal-content.modal-responsive-small .advanced-export-form .aexp-orientation-picker,
#modal-advanced-export-modal .modal-content.modal-responsive-medium .advanced-export-form .aexp-orientation-picker,
#modal-advanced-export-modal .modal-content.modal-responsive-large .advanced-export-form .aexp-orientation-picker,
#modal-advanced-export-modal .modal-content.modal-responsive-small .advanced-export-form .aexp-quality-picker,
#modal-advanced-export-modal .modal-content.modal-responsive-medium .advanced-export-form .aexp-quality-picker,
#modal-advanced-export-modal .modal-content.modal-responsive-large .advanced-export-form .aexp-quality-picker {
    grid-template-columns: 1fr;
}

#modal-advanced-export-modal .modal-content.modal-responsive-small .export-actions,
#modal-advanced-export-modal .modal-content.modal-responsive-medium .export-actions {
    flex-direction: column;
}


/* Placeholders professionnels */
#modal-advanced-export-modal .professional-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
    border: 2px dashed #dee2e6;
    border-radius: 12px;
    position: relative;
    overflow: hidden;
    min-height: 200px;
    transition: all 0.3s ease;
}

#modal-advanced-export-modal .professional-placeholder:hover {
    border-color: #007bff;
    background: linear-gradient(135deg, #f8f9fa 0%, #e3f2fd 100%);
}

#modal-advanced-export-modal .professional-placeholder.loading {
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
    border-color: #007bff;
}

#modal-advanced-export-modal .placeholder-icon {
    margin-bottom: 20px;
    position: relative;
}

/* Icône document */
#modal-advanced-export-modal .document-icon {
    width: 60px;
    height: 80px;
    position: relative;
    background: #fff;
    border: 2px solid #dee2e6;
    border-radius: 4px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

#modal-advanced-export-modal .doc-body {
    width: 100%;
    height: 100%;
    background: #fff;
    border-radius: 2px;
}

#modal-advanced-export-modal .doc-fold {
    position: absolute;
    top: 0;
    right: 0;
    width: 0;
    height: 0;
    border-left: 20px solid transparent;
    border-top: 20px solid #dee2e6;
}

/* Icône carte */
#modal-advanced-export-modal .map-icon {
    width: 60px;
    height: 60px;
    position: relative;
    background: #e3f2fd;
    border-radius: 8px;
    border: 2px solid #bbdefb;
}

#modal-advanced-export-modal .map-base {
    width: 100%;
    height: 100%;
    background: linear-gradient(45deg, #e3f2fd 0%, #bbdefb 100%);
    border-radius: 6px;
}

#modal-advanced-export-modal .map-layers {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

#modal-advanced-export-modal .layer {
    position: absolute;
    border-radius: 2px;
    opacity: 0.7;
}

#modal-advanced-export-modal .layer-1 {
    top: 10px;
    left: 10px;
    width: 40px;
    height: 8px;
    background: #4caf50;
    animation: layerPulse 2s infinite;
}

#modal-advanced-export-modal .layer-2 {
    top: 25px;
    left: 15px;
    width: 30px;
    height: 6px;
    background: #ff9800;
    animation: layerPulse 2s infinite 0.5s;
}

#modal-advanced-export-modal .layer-3 {
    top: 40px;
    left: 20px;
    width: 25px;
    height: 5px;
    background: var(--error-color);
    animation: layerPulse 2s infinite 1s;
}

@keyframes aexp-progress-animation {
    0% {
        width: 0%;
    }

    50% {
        width: 70%;
    }

    100% {
        width: 100%;
    }
}

@keyframes layerPulse {

    0%,
    100% {
        opacity: 0.7;
        transform: scale(1);
    }

    50% {
        opacity: 1;
        transform: scale(1.05);
    }
}

/* Spinner professionnel */
#modal-advanced-export-modal .spinner {
    width: 50px;
    height: 50px;
    position: relative;
}

#modal-advanced-export-modal .spinner-ring {
    position: absolute;
    width: 100%;
    height: 100%;
    border: 3px solid transparent;
    border-top: 3px solid #007bff;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

#modal-advanced-export-modal .spinner-ring:nth-child(2) {
    width: 80%;
    height: 80%;
    top: 10%;
    left: 10%;
    border-top-color: #28a745;
    animation-duration: 1.2s;
    animation-direction: reverse;
}

#modal-advanced-export-modal .spinner-ring:nth-child(3) {
    width: 60%;
    height: 60%;
    top: 20%;
    left: 20%;
    border-top-color: #ffc107;
    animation-duration: 0.8s;
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

#modal-advanced-export-modal .placeholder-title {
    font-size: 18px;
    font-weight: 600;
    color: #495057;
    margin-bottom: 8px;
    text-align: center;
}

#modal-advanced-export-modal .placeholder-subtitle {
    font-size: 14px;
    color: #6c757d;
    text-align: center;
    line-height: 1.4;
}

#modal-advanced-export-modal .placeholder-shimmer {
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.4), transparent);
    animation: shimmer 2s infinite;
}

@keyframes shimmer {
    0% {
        left: -100%;
    }

    100% {
        left: 100%;
    }
}

/* Responsive */
@media (max-width: 768px) {
    #modal-advanced-export-modal .professional-placeholder {
        padding: 30px 15px;
        min-height: 150px;
    }

    #modal-advanced-export-modal .placeholder-icon {
        margin-bottom: 15px;
    }

    #modal-advanced-export-modal .document-icon,
    #modal-advanced-export-modal .map-icon {
        width: 50px;
        height: 50px;
    }

    #modal-advanced-export-modal .placeholder-title {
        font-size: 16px;
    }

    #modal-advanced-export-modal .placeholder-subtitle {
        font-size: 12px;
    }
}

