/* ===========================================================
   forge.css — Format Forge v2
   S'appuie entièrement sur les tokens de style.css
   =========================================================== */


/* ===========================================================
   ZONE D'UPLOAD (inchangée)
   =========================================================== */

.upload-zone {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px dashed var(--color-border-strong);
  border-radius: var(--radius-lg);
  padding: var(--space-xl) var(--space-lg);
  background: var(--color-surface);
  transition: background var(--t-fast), border-color var(--t-fast);
  cursor: pointer;
  min-height: 60vh;
}

.upload-zone.is-dragging {
  background: color-mix(in srgb, var(--color-accent) 8%, var(--color-surface));
  border-color: var(--color-accent);
}

.upload-inner {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-md);
  max-width: 480px;
}

.upload-icon {
  width: 96px;
  height: 96px;
  color: var(--color-text-faint);
  margin-bottom: var(--space-sm);
}

.upload-icon svg { width: 100%; height: 100%; }

.upload-title {
  font-size: var(--text-2xl);
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1.1;
}

.upload-subtitle {
  color: var(--color-text-soft);
  font-size: var(--text-base);
}

.upload-hint {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  letter-spacing: 0.05em;
  margin-top: calc(-1 * var(--space-xs));
}

.upload-error {
  margin-top: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  background: color-mix(in srgb, var(--color-error) 12%, transparent);
  color: var(--color-error);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  text-align: left;
  max-width: 400px;
  line-height: 1.5;
}


/* ===========================================================
   WORKSPACE V2 — Layout général
   =========================================================== */

.workspace-v2 {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  flex: 1;
  min-height: 0;
}


/* ===========================================================
   ONGLETS PRINCIPAUX
   =========================================================== */

.main-tabs {
  display: flex;
  gap: 2px;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--color-border);
  padding-bottom: 0;
}

.main-tab {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 500;
  padding: var(--space-sm) var(--space-md);
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--color-text-soft);
  cursor: pointer;
  transition: color var(--t-fast), border-color var(--t-fast);
  margin-bottom: -1px;
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
}

.main-tab:hover { color: var(--color-text); }

.main-tab.is-active {
  color: var(--color-text);
  border-bottom-color: var(--color-accent);
  font-weight: 600;
}

.main-tab-icon {
  display: inline-flex;
  align-items: center;
  width: 14px;
  height: 14px;
  color: currentColor;
}

.main-tab-icon svg { width: 100%; height: 100%; }

.main-tab-badge {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  background: var(--color-border);
  color: var(--color-text-soft);
  padding: 1px 6px;
  border-radius: var(--radius-pill);
  margin-left: var(--space-xs);
  font-weight: 500;
}


/* ===========================================================
   BANDEAU IMAGE SOURCE (visible sur tous les onglets)
   =========================================================== */

.source-bar {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

.source-bar-thumb {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.source-bar-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.source-bar-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.source-bar-name {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 400px;
}

.source-bar-specs {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-faint);
}

.source-bar-flags {
  display: flex;
  gap: var(--space-xs);
  margin-left: auto;
  flex-wrap: wrap;
}

.source-bar-flag {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 2px var(--space-xs);
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  color: var(--color-text-soft);
  border: 1px solid var(--color-border);
}

.source-bar-flag--alpha {
  background: color-mix(in srgb, var(--color-info) 15%, transparent);
  color: var(--color-info);
  border-color: var(--color-info);
}

.source-bar-flag--warning {
  background: color-mix(in srgb, var(--color-warning) 15%, transparent);
  color: var(--color-warning);
  border-color: var(--color-warning);
  cursor: help;
}

.source-bar-flag--good {
  background: color-mix(in srgb, var(--color-success) 15%, transparent);
  color: var(--color-success);
  border-color: var(--color-success);
  cursor: help;
}


/* ===========================================================
   PANES (onglets de contenu)
   =========================================================== */

.tab-pane {
  display: none;
  flex-direction: column;
  gap: var(--space-lg);
}

.tab-pane.is-active {
  display: flex;
}

.pane-intro {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.pane-title {
  font-size: var(--text-xl);
  font-weight: 700;
  letter-spacing: -0.03em;
}

.pane-description {
  font-size: var(--text-base);
  color: var(--color-text-soft);
  line-height: 1.5;
  max-width: 720px;
}


/* ===========================================================
   PAGE RATIOS MAÎTRES — sections et grilles
   =========================================================== */

.masters-section {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.masters-section-header {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--color-border);
}

.masters-section-title {
  font-size: var(--text-lg);
  font-weight: 600;
  letter-spacing: -0.02em;
}

.masters-section-hint {
  font-size: var(--text-sm);
  color: var(--color-text-soft);
}

.masters-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--space-md);
}

/* Carte de ratio maître */
.master-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  padding: var(--space-sm);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: border-color var(--t-fast), background var(--t-fast);
  text-align: left;
  width: 100%;
  font-family: inherit;
  color: inherit;
}

.master-card:hover {
  border-color: var(--color-text);
  background: var(--color-bg);
}

.master-card.is-customized {
  border-color: var(--color-accent);
}

.master-card-preview {
  position: relative;
  background: var(--color-bg);
  border-radius: var(--radius-sm);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 160px;
}

.master-card-preview canvas {
  display: block;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border: 1px solid var(--color-border);
}

.master-card-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.master-card-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-sm);
}

.master-card-label {
  font-family: var(--font-mono);
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-text);
  letter-spacing: 0.02em;
}

.master-card-status {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-text-faint);
}

.master-card.is-customized .master-card-status {
  color: var(--color-accent);
}

.master-card-sublabel {
  font-size: var(--text-sm);
  color: var(--color-text-soft);
  font-weight: 500;
}

.master-card-export {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-faint);
}

.master-card-usage {
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  font-style: italic;
  line-height: 1.4;
  margin-top: var(--space-xs);
  padding-top: var(--space-xs);
  border-top: 1px solid var(--color-border);
}

.master-card-warning {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  background: color-mix(in srgb, var(--color-warning) 15%, transparent);
  color: var(--color-warning);
  padding: 2px var(--space-xs);
  border-radius: var(--radius-sm);
  margin-top: var(--space-xs);
}


/* ===========================================================
   RATIOS SECONDAIRES — accordéons
   =========================================================== */

.masters-categories {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.masters-category {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.masters-category-summary {
  padding: var(--space-md);
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-md);
  list-style: none;
  transition: background var(--t-fast);
}

.masters-category-summary::-webkit-details-marker {
  display: none;
}

.masters-category-summary:hover {
  background: var(--color-bg);
}

.masters-category-summary-left {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.masters-category-summary-title {
  font-size: var(--text-md);
  font-weight: 600;
  color: var(--color-text);
}

.masters-category-summary-sub {
  font-size: var(--text-sm);
  color: var(--color-text-soft);
}

.masters-category-summary-meta {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex-shrink: 0;
}

.masters-category-count {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-faint);
}

.masters-category-chevron {
  width: 12px;
  height: 12px;
  transition: transform var(--t-fast);
  color: var(--color-text-faint);
}

.masters-category[open] .masters-category-chevron {
  transform: rotate(180deg);
}

.masters-category-body {
  padding: 0 var(--space-md) var(--space-md);
  border-top: 1px solid var(--color-border);
  padding-top: var(--space-md);
}


/* ===========================================================
   PAGES CANAUX — Headers et listes de formats
   =========================================================== */

.channel-pane-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: var(--space-md);
  flex-wrap: wrap;
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--color-border);
}

.channel-pane-actions {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
}

.channel-pane-count {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--color-text-faint);
  align-self: center;
}

.channel-groups {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.channel-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.channel-group-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--color-text-faint);
  padding-bottom: var(--space-xs);
  border-bottom: 1px solid var(--color-border);
}

.format-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--space-md);
}

/* Carte format dérivé */
.format-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  padding: var(--space-sm);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: border-color var(--t-fast);
}

.format-card:hover { border-color: var(--color-border-strong); }

.format-preview {
  position: relative;
  background: var(--color-bg);
  border-radius: var(--radius-sm);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 140px;
}

.format-preview canvas {
  display: block;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border: 1px solid var(--color-border);
}

.format-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.format-label {
  font-size: var(--text-base);
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--color-text);
}

.format-specs {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-soft);
}

.format-master-link {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  margin-top: 2px;
}

.format-master-link strong {
  color: var(--color-accent);
  font-weight: 500;
}

.format-notes {
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  font-style: italic;
  line-height: 1.4;
}

.format-actions {
  display: flex;
  gap: var(--space-xs);
  margin-top: auto;
}

.format-actions .btn-small {
  flex: 1;
}

.format-export-buttons {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xs);
  margin-top: auto;
}

.format-export-btn {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: var(--space-xs) var(--space-sm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--color-text);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  transition: border-color var(--t-fast), background var(--t-fast);
}

.format-export-btn:hover:not(:disabled) {
  border-color: var(--color-border-strong);
  background: var(--color-bg);
}

.format-export-btn:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

.format-export-btn-label {
  font-weight: 700;
}

.format-export-btn-weight {
  font-size: 0.65rem;
  color: var(--color-text-faint);
  text-transform: none;
  letter-spacing: 0;
}

.format-export-btn-weight.is-loading {
  font-style: italic;
}

.format-export-btn-weight.is-over {
  color: var(--color-warning);
  font-weight: 700;
}

.format-edit-link {
  /* deprecated, kept for safety */
  display: none;
}

.format-preview--clickable {
  cursor: pointer;
  transition: border-color var(--t-fast), background var(--t-fast);
}

.format-preview--clickable canvas {
  transition: transform var(--t-fast), box-shadow var(--t-fast);
}

.format-preview--clickable:hover canvas {
  transform: scale(1.02);
  box-shadow: 0 4px 12px color-mix(in srgb, var(--color-text) 12%, transparent);
}

.format-preview--clickable::after {
  content: '';
  position: absolute;
  inset: 0;
  border: 2px solid transparent;
  border-radius: var(--radius-sm);
  pointer-events: none;
  transition: border-color var(--t-fast);
}

.format-preview--clickable:hover::after {
  border-color: var(--color-accent);
}

/* Badge résolution */
.format-resolution-badge {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 2px 6px;
  border-radius: var(--radius-sm);
  font-weight: 500;
}

.format-resolution-badge--ok {
  background: color-mix(in srgb, var(--color-success) 15%, transparent);
  color: var(--color-success);
}

.format-resolution-badge--limit {
  background: color-mix(in srgb, var(--color-warning) 15%, transparent);
  color: var(--color-warning);
}

.format-resolution-badge--insufficient {
  background: color-mix(in srgb, var(--color-error) 15%, transparent);
  color: var(--color-error);
}

.format-resolution-badge--blocked {
  background: var(--color-border);
  color: var(--color-text-faint);
}

/* État global de la carte selon résolution */
.format-card.is-blocked {
  opacity: 0.6;
}

.format-card.is-blocked .format-export-buttons button {
  pointer-events: none;
  opacity: 0.4;
}

/* Optimisation poids (display IAB) */
.format-weight-info {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-xs) 0;
  border-top: 1px solid var(--color-border);
  margin-top: var(--space-xs);
}

.format-weight-info-value {
  color: var(--color-text);
  font-weight: 500;
}

.format-weight-info-value.is-over {
  color: var(--color-warning);
}

.format-weight-info-value.is-ok {
  color: var(--color-success);
}

.format-optimize-btn {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 2px var(--space-xs);
  border: 1px solid var(--color-warning);
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--color-warning);
  cursor: pointer;
  transition: background var(--t-fast);
}

.format-optimize-btn:hover {
  background: color-mix(in srgb, var(--color-warning) 12%, transparent);
}

.format-optimize-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}


/* ===========================================================
   ÉDITEUR DE CROP (modale plein écran)
   =========================================================== */

.crop-modal-backdrop {
  /* Hérite de .modal-backdrop pour fond+blur */
  padding: 0;
  align-items: stretch;
  justify-content: stretch;
}

.crop-modal {
  width: 100%;
  max-width: 1400px;
  max-height: 95vh;
  margin: auto;
  padding: var(--space-md);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  overflow: hidden;
}

.crop-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--color-border);
}

.crop-modal-title-wrap {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.crop-modal-title {
  font-size: var(--text-xl);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.1;
}

.crop-modal-subtitle {
  font-size: var(--text-sm);
  color: var(--color-text-soft);
}

.crop-modal-body {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: var(--space-md);
  flex: 1;
  min-height: 0;
}

@media (max-width: 900px) {
  .crop-modal-body { grid-template-columns: 1fr; }
}

/* La scène de crop */
.crop-stage-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  min-height: 0;
}

.crop-stage {
  position: relative;
  flex: 1;
  background: var(--color-surface);
  border-radius: var(--radius-sm);
  overflow: hidden;
  cursor: grab;
  user-select: none;
  min-height: 400px;
  /* Checkerboard pour différencier la zone visible du crop */
  background-image:
    linear-gradient(45deg, var(--color-border) 25%, transparent 25%),
    linear-gradient(-45deg, var(--color-border) 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, var(--color-border) 75%),
    linear-gradient(-45deg, transparent 75%, var(--color-border) 75%);
  background-size: 16px 16px;
  background-position: 0 0, 0 8px, 8px -8px, -8px 0px;
}

.crop-stage.is-dragging { cursor: grabbing; }

#cropCanvas {
  position: absolute;
  display: block;
  /* Position contrôlée par JS */
  transform-origin: 0 0;
}

/* Le cadre cible — fixe au centre, par-dessus l'image */
.crop-frame {
  position: absolute;
  border: 2px solid var(--color-accent);
  box-shadow: 0 0 0 9999px rgba(0, 0, 0, 0.55);
  pointer-events: none;
  /* Position et dimensions calculées par JS */
}

.crop-frame-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, transparent calc(33.33% - 0.5px), rgba(255, 255, 255, 0.3) calc(33.33% - 0.5px), rgba(255, 255, 255, 0.3) calc(33.33% + 0.5px), transparent calc(33.33% + 0.5px)),
    linear-gradient(to right, transparent calc(66.66% - 0.5px), rgba(255, 255, 255, 0.3) calc(66.66% - 0.5px), rgba(255, 255, 255, 0.3) calc(66.66% + 0.5px), transparent calc(66.66% + 0.5px)),
    linear-gradient(to bottom, transparent calc(33.33% - 0.5px), rgba(255, 255, 255, 0.3) calc(33.33% - 0.5px), rgba(255, 255, 255, 0.3) calc(33.33% + 0.5px), transparent calc(33.33% + 0.5px)),
    linear-gradient(to bottom, transparent calc(66.66% - 0.5px), rgba(255, 255, 255, 0.3) calc(66.66% - 0.5px), rgba(255, 255, 255, 0.3) calc(66.66% + 0.5px), transparent calc(66.66% + 0.5px));
}

.crop-warning {
  padding: var(--space-sm) var(--space-md);
  background: color-mix(in srgb, var(--color-warning) 15%, transparent);
  color: var(--color-warning);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  line-height: 1.4;
}

/* Contrôles à droite */
.crop-controls {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  min-width: 0;
  overflow-y: auto;
}

.crop-info {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  padding: var(--space-sm);
  background: var(--color-surface);
  border-radius: var(--radius-sm);
}

.crop-info-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}

.crop-info-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-text-faint);
}

.crop-info-value {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--color-text);
  font-weight: 500;
}

.crop-control {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.crop-control label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-text-faint);
}

.crop-control input[type="range"] { width: 100%; }

.crop-control output {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--color-text);
  align-self: flex-end;
}

.crop-instructions {
  font-size: var(--text-sm);
  color: var(--color-text-soft);
  line-height: 1.5;
  padding: var(--space-sm);
  background: var(--color-bg);
  border-radius: var(--radius-sm);
  border-left: 2px solid var(--color-accent);
}

.crop-derived {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  padding-top: var(--space-sm);
  border-top: 1px solid var(--color-border);
}

.crop-derived-title {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-text-faint);
  margin-bottom: var(--space-xs);
}

.crop-derived-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
  max-height: 180px;
  overflow-y: auto;
}

.crop-derived-item {
  display: flex;
  justify-content: space-between;
  gap: var(--space-sm);
  font-size: var(--text-xs);
  padding: var(--space-xs) 0;
  border-bottom: 1px solid var(--color-border);
}

.crop-derived-item:last-child { border-bottom: none; }

.crop-derived-item-label { color: var(--color-text-soft); }

.crop-derived-item-size {
  font-family: var(--font-mono);
  color: var(--color-text-faint);
}

.crop-actions {
  display: flex;
  gap: var(--space-sm);
  margin-top: auto;
  padding-top: var(--space-sm);
  border-top: 1px solid var(--color-border);
}

.crop-actions .btn,
.crop-actions .btn-ghost {
  flex: 1;
}

.modal-close {
  font-size: 1.5rem;
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-soft);
  border-radius: var(--radius-sm);
  transition: background var(--t-fast), color var(--t-fast);
  background: transparent;
  border: none;
  cursor: pointer;
}

.modal-close:hover {
  background: var(--color-surface);
  color: var(--color-text);
}


/* ===========================================================
   TOAST
   =========================================================== */

.toast {
  position: fixed;
  bottom: var(--space-lg);
  left: 50%;
  transform: translateX(-50%) translateY(120%);
  background: var(--color-text);
  color: var(--color-bg);
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
  transition: transform var(--t-med);
  z-index: 300;
}

.toast.is-visible {
  transform: translateX(-50%) translateY(0);
}
