/* ===== FIX PROPRE — PANNEAU DE CONTRÔLES ÉQUILIBRÉ ===== */

.atelier-sheet .controls {
  display: grid !important;
  grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
  column-gap: 10px !important;
  row-gap: 8px !important;
  align-items: end !important;
  overflow: visible !important;
}

/* Ligne 1 : structure + dimensions */
.atelier-sheet .controls > div:nth-child(1) {
  grid-column: 1 / span 4 !important;
  min-width: 0 !important;
}

.atelier-sheet .controls > div:nth-child(2) {
  grid-column: 5 / span 2 !important;
  min-width: 0 !important;
}

.atelier-sheet .controls > div:nth-child(3) {
  grid-column: 7 / span 2 !important;
  min-width: 0 !important;
}

.atelier-sheet .controls > div:nth-child(4) {
  grid-column: 9 / span 2 !important;
  min-width: 0 !important;
}

/* Ligne 2 : focus + boutons */
.atelier-sheet .controls > div:nth-child(5) {
  grid-column: 1 / span 2 !important;
  min-width: 0 !important;
}

.atelier-sheet #resetBtn {
  grid-column: 3 / span 2 !important;
}

.atelier-sheet #anchorBtn {
  grid-column: 5 / span 3 !important;
}

.atelier-sheet #anchorEditBtn {
  grid-column: 8 / span 3 !important;
}

/* Ligne 3 : note */
.atelier-sheet .controls .note {
  grid-column: 1 / -1 !important;
  padding-top: 2px !important;
}

/* Hauteur homogène des champs */
.atelier-sheet .controls select,
.atelier-sheet .controls input,
.atelier-sheet #resetBtn,
.atelier-sheet #anchorBtn,
.atelier-sheet #anchorEditBtn {
  height: 30px !important;
  min-height: 30px !important;
  padding: 4px 9px !important;
  font-size: 11px !important;
  line-height: 1 !important;
  box-sizing: border-box !important;
}

/* Champs */
.atelier-sheet .controls select,
.atelier-sheet .controls input {
  width: 100% !important;
  min-width: 0 !important;
  border-radius: 9px !important;
}

/* Boutons */
.atelier-sheet #resetBtn,
.atelier-sheet #anchorBtn,
.atelier-sheet #anchorEditBtn {
  width: 100% !important;
  white-space: nowrap !important;
  border-radius: 999px !important;
}

/* Responsive */
@media (max-width: 900px) {
  .atelier-sheet .controls {
    grid-template-columns: 1fr !important;
  }

  .atelier-sheet .controls > div,
  .atelier-sheet #resetBtn,
  .atelier-sheet #anchorBtn,
  .atelier-sheet #anchorEditBtn,
  .atelier-sheet .controls .note {
    grid-column: 1 / -1 !important;
  }
}

#domeV4Viewer + .tabs {
  margin-top: 24px;
}

@media (max-width: 600px) {
  .controls {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 14px;
  }

  .controls > div {
    width: 100%;
  }

  .controls label {
    display: block;
    margin-bottom: 5px;
    letter-spacing: 0.08em;
    white-space: normal;
  }

  .controls select,
  .controls input,
  .controls button,
  .controls #resetBtn,
  .controls #anchorBtn,
  .controls #anchorEditBtn {
    width: 100%;
    max-width: none;
  }

  .controls .note {
    font-size: 0.82rem;
    line-height: 1.45;
    margin-top: 4px;
  }

  .sheet-header {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .title-box {
    text-align: left;
  }
}

@media (max-width: 600px) {
  .grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .segment-card {
    min-width: 0;
    padding: 18px 12px 22px;
    overflow: visible;
  }

  .piece-zone {
    min-height: 190px;
    transform: scale(0.82);
    transform-origin: center top;
    margin-bottom: -24px;
  }

  .segment-title,
  .segment-card h3 {
    font-size: 1.1rem;
  }

  .segment-card .cut-length,
  .segment-card .length-main {
    font-size: 1rem;
    line-height: 1.15;
    white-space: normal;
  }

  .segment-card .small,
  .segment-card .note,
  .segment-card p {
    font-size: 0.82rem;
    line-height: 1.35;
  }
}


@media (max-width: 600px) {
  .piece-zone {
    transform: scale(0.66);
    transform-origin: center top;
    margin-bottom: -46px;
  }

  .piece-zone .label,
  .piece-zone .measure,
  .piece-zone .angle,
  .piece-zone .cut-length,
  .piece-zone .length-main,
  .piece-zone .warning,
  .piece-zone .drill {
    font-size: 0.78rem !important;
    line-height: 1.05 !important;
  }

  .piece-zone .cut-length,
  .piece-zone .length-main {
    font-size: 0.9rem !important;
  }

  .segment-card {
    padding-top: 18px;
    padding-bottom: 18px;
  }
}

@media (max-width: 600px) {
  .segment-card {
    padding: 18px 10px 26px;
  }

  .piece-zone {
    position: relative;
    transform: scale(0.68);
    transform-origin: center top;
    margin-bottom: -58px;
  }

  /* On masque les textes secondaires qui saturent le visuel mobile */
  .piece-zone [class*="warning"],
  .piece-zone [class*="drill"],
  .piece-zone [class*="pre"],
  .piece-zone [class*="percage"] {
    display: none !important;
  }

  /* On réduit tous les textes posés sur le dessin */
  .piece-zone * {
    font-size: 11px !important;
    line-height: 1 !important;
  }

  /* Longueur rouge principale */
  .piece-zone [class*="longueur"],
  .piece-zone [class*="length"],
  .piece-zone [class*="cut"] {
    font-size: 13px !important;
    line-height: 1.05 !important;
  }
}

@media (max-width: 600px) {
  .atelier-sheet {
    padding: 0 18px;
  }

  .panel {
    padding: 18px;
  }
}

@media (max-width: 600px) {
  .panel.controls {
    display: grid !important;
    grid-template-columns: 1fr !important;
    padding: 18px !important;
  }

  .panel.controls > * {
    grid-column: 1 / -1 !important;
    width: 100% !important;
  }

  .panel.controls .note {
    max-width: none !important;
    width: 100% !important;
    font-size: 0.9rem !important;
    line-height: 1.5 !important;
    margin-top: 10px !important;
  }

  .panel.controls button,
  .panel.controls select,
  .panel.controls input {
    width: 100% !important;
    box-sizing: border-box !important;
  }
}

.segment-card .total-length {
  margin-top: -12px;
}

@media (max-width: 600px) {
  .piece-zone + * {
    margin-top: -34px !important;
    transform: translateY(-34px);
  }

  .segment-card {
    overflow: visible !important;
  }
}

@media (max-width: 600px) {
  .piece-zone {
    --total-y: 75% !important;
  }
}

@media (max-width: 600px) {
  .piece-zone {
    --angle-tl-y: 28% !important;
    --angle-tr-y: 28% !important;
  }
}

.panel.controls {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.panel.controls .note {
  grid-column: 1 / -1;
  max-width: 600px;
}

/* ===== FIX MOBILE — PANNEAU PARAMÈTRES + NOTE ===== */

@media (max-width: 640px) {
  .atelier-sheet .controls {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
    padding: 14px 18px 18px !important;
  }

  .atelier-sheet .controls > div:nth-child(1),
  .atelier-sheet .controls > div:nth-child(5),
  .atelier-sheet #resetBtn,
  .atelier-sheet #anchorBtn,
  .atelier-sheet #anchorEditBtn,
  .atelier-sheet .controls .note {
    grid-column: 1 / -1 !important;
    max-width: none !important;
    width: 100% !important;
  }

  .atelier-sheet .controls > div:nth-child(2),
  .atelier-sheet .controls > div:nth-child(3),
  .atelier-sheet .controls > div:nth-child(4) {
    grid-column: auto !important;
    min-width: 0 !important;
  }

  .atelier-sheet .controls .note {
    padding: 14px 4px 4px !important;
    font-size: 14px !important;
    line-height: 1.55 !important;
    text-align: left !important;
  }

  .atelier-sheet label {
    font-size: 8px !important;
    letter-spacing: 0.12em !important;
    line-height: 1.15 !important;
  }

  .atelier-sheet select,
  .atelier-sheet input {
    min-width: 0 !important;
    width: 100% !important;
    font-size: 12px !important;
    padding: 8px 9px !important;
  }
}

/* ===== FIX MOBILE — MODE FOCUS ===== */

@media (max-width: 640px) {
  #focusView:not(.hidden) {
    display: block !important;
  }

  #focusCard {
    width: 100% !important;
    margin-bottom: 24px !important;
  }

  #focusCard .segment-card.atelier-card {
    padding: 18px 14px 34px !important;
    min-height: auto !important;
    height: auto !important;
  }

  #focusCard .atelier-row {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }

  #focusCard .side-label {
    display: block !important;
    font-size: 20px !important;
    margin-bottom: 4px !important;
  }

  #focusCard .piece-zone {
    width: 100% !important;
    max-width: none !important;
    aspect-ratio: 849 / 243 !important;
    height: auto !important;
    margin: 0 auto !important;
    transform: none !important;
    overflow: visible !important;
  }

  #focusCard .cut-label {
    font-size: 13px !important;
  }

  #focusCard .angle-label {
    font-size: 12px !important;
  }

  #focusCard .neighbor {
    font-size: 15px !important;
  }

  #focusCard .total-note {
    font-size: 10px !important;
    line-height: 1.15 !important;
  }

  #focusView .detail-table {
    margin-top: 0 !important;
  }
}

/* ===== HARMONISATION V4 AVEC LA V3 ===== */

.dome-viewer-panel {
  margin: 28px 0 34px;
  padding: clamp(16px, 2.5vw, 26px);
  border-radius: 28px;
  overflow: hidden;
}

.dome-viewer-header {
  max-width: 860px;
  margin-bottom: 18px;
}

.dome-viewer-header h2 {
  margin: 0 0 8px;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(24px, 3vw, 38px);
  line-height: 1.05;
  color: var(--ink);
}

.dome-viewer-note {
  margin: 0 !important;
  max-width: 760px;
  color: var(--muted) !important;
  font-size: 15px !important;
  line-height: 1.55 !important;
}

.dome-v4-iframe {
  margin-top: 18px;
  background: #fffdf8 !important;
  border: 1px solid rgba(127, 90, 56, .18) !important;
  border-radius: 22px !important;
  box-shadow: 0 14px 34px rgba(61, 43, 26, .12);
}

#freq {
  font-weight: 700 !important;
}

/* ===== SEGMENT FOCUS INTÉGRÉ AUX TABS ===== */

.tabs {
  align-items: center !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
}

.seg-select-inline {
  width: auto !important;
  min-width: 140px !important;
  max-width: 180px !important;
  height: 30px !important;
  padding: 5px 28px 5px 10px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(127, 90, 56, 0.28) !important;
  background: #fffaf1 !important;
  color: var(--ink) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  margin-left: 4px !important;
}

.seg-select-inline:hover {
  background: #f4efe6 !important;
}

@media (max-width: 640px) {
  .seg-select-inline {
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
  }
}

/* ===== GRISAGE UNIQUEMENT DU SELECT ===== */

.view-global #segSelect,
.view-global .seg-select-inline {
  opacity: 0.45;
  filter: grayscale(100%);
  pointer-events: none;
  transition: all 0.2s ease;
}

.view-focus #segSelect,
.view-focus .seg-select-inline {
  opacity: 1;
  filter: none;
  pointer-events: auto;
}

/* ===== LAYOUT PROPRE ET ÉQUILIBRÉ ===== */

.atelier-sheet .controls {
  display: grid;
  grid-template-columns: 2.5fr 1fr 1fr 1fr auto;
  gap: 12px;
  align-items: end;
}

/* Bouton à droite */
.atelier-sheet #resetBtn {
  grid-column: 5;
  grid-row: 1;
  justify-self: end;
  min-width: 130px;
}

.info-field {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.info-field label {
  font-size: 11px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #777;
  margin-bottom: 4px;
}

.info-field div {
  height: 32px;
  display: flex;
  align-items: center;
  padding: 0 10px;
  border-radius: 8px;
  background: #f4efe6;
  font-weight: 600;
}

.stats-row {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	gap: 10px;
	margin-top: 10px;
	width: 100%;
}

.info-field.stat {
	min-width: 0;
}

.info-field.stat div {
	width: 100%;
	justify-content: flex-start;
	white-space: nowrap;
}

.height-info {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding-bottom: 8px;
	margin-left: 65px;
	color: #7a7168;
}

.height-label {
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-bottom: 3px;
}

#domeHeight {
	font-size: 15px;
	font-weight: 600;
}

.viewer-activate-btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  margin: 18px auto 0;
  padding: 12px 18px;
  border-radius: 999px;
  border: 1px solid rgba(127, 90, 56, .35);
  background: #fffdf8;
  color: var(--ink);
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(61, 43, 26, .12);
}

.viewer-activate-btn:hover {
  background: #f7efe3;
}

/* --- FIX iOS impression : bouton manuel de secours dans la fenêtre PDF --- */
body.print-document .print-manual-button {
  position: sticky !important;
  top: 10px !important;
  z-index: 9999 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 10px 0 10px 18px !important;
  padding: 10px 16px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(127, 90, 56, 0.28) !important;
  background: #2f2922 !important;
  color: #fffaf1 !important;
  font: 700 13px/1.1 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  cursor: pointer !important;
}

@media print {
  body.print-document .print-manual-button {
    display: none !important;
  }
}

/* ===== IOS PRINT HELP ===== */
.ios-print-help {
  max-width: 980px;
  margin: 8px auto 14px;
  padding: 10px 14px;
  border: 1px solid rgba(127, 90, 56, 0.18);
  border-radius: 14px;
  background: #fffaf1;
  color: #2f2922;
  font-size: 14px;
  line-height: 1.35;
}

@media print {
  .ios-print-help {
    display: none !important;
  }
}


/* ===== FIX iOS PRINT PREVIEW — LOT 2B =====
   Sur Safari iOS, l’aperçu d’impression peut capturer l’état écran plutôt que
   respecter correctement @media print. On masque donc le bouton dès le clic
   et on compacte la fiche en mode iOS pour limiter le passage sur 2 pages. */

body.print-document.is-printing .print-manual-button {
  display: none !important;
}

body.ios-print-document main {
  max-width: none !important;
  padding: 6mm 5mm !important;
  margin: 0 !important;
}

body.ios-print-document .print-summary {
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
}

body.ios-print-document .print-summary-header {
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  gap: 3mm !important;
  margin: 0 0 2mm !important;
}

body.ios-print-document .print-summary .eyebrow {
  font-size: 6pt !important;
  margin: 0 0 .5mm !important;
}

body.ios-print-document .print-summary h2 {
  font-size: 12pt !important;
  line-height: 1.05 !important;
  margin: 0 !important;
}

body.ios-print-document .print-summary-note {
  display: none !important;
}

body.ios-print-document .print-summary-brand {
  font-size: 7pt !important;
  line-height: 1.1 !important;
  text-align: right !important;
}

body.ios-print-document .print-meta-grid {
  display: grid !important;
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  gap: 1.5mm !important;
  margin: 0 0 2mm !important;
}

body.ios-print-document .print-meta-grid div {
  padding: 1mm 1.2mm !important;
  min-height: 0 !important;
}

body.ios-print-document .print-meta-grid span {
  font-size: 5.4pt !important;
  line-height: 1 !important;
  margin-bottom: .5mm !important;
}

body.ios-print-document .print-meta-grid strong {
  font-size: 6.6pt !important;
  line-height: 1.05 !important;
}

body.ios-print-document .print-visual-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 2mm !important;
  margin: 0 !important;
}

body.ios-print-document .print-visual-grid .segment-card.atelier-card {
  padding: 1.2mm !important;
  min-height: 0 !important;
  break-inside: avoid !important;
  page-break-inside: avoid !important;
  overflow: hidden !important;
}

body.ios-print-document .print-visual-grid .atelier-row {
  grid-template-columns: 8mm minmax(0, 1fr) !important;
  gap: 1.2mm !important;
}

body.ios-print-document .print-visual-grid .side-label {
  font-size: 6.8pt !important;
  line-height: 1.05 !important;
  padding: 0 !important;
}

body.ios-print-document .print-visual-grid .piece-zone {
  aspect-ratio: 849 / 243 !important;
  overflow: visible !important;
}

body.ios-print-document .print-visual-grid .anchor-label,
body.ios-print-document .print-visual-grid .angle-label,
body.ios-print-document .print-visual-grid .prehole,
body.ios-print-document .print-visual-grid .cut-label {
  font-size: 5pt !important;
  line-height: 1 !important;
}

body.ios-print-document .print-visual-grid .total-note {
  font-size: 4.8pt !important;
  line-height: 1 !important;
}

body.ios-print-document .print-technical-details,
body.ios-print-document .print-footnote {
  display: none !important;
}

@media print {
  body.print-document.is-printing .print-manual-button,
  body.print-document .print-manual-button,
  .ios-print-help {
    display: none !important;
  }
}

@media print {
  body.ios-print-document .print-summary {
    transform: scale(0.8);
    transform-origin: top left;
    width: 125%;
  }
}

/* ===== FIX iPHONE — afficher perçage + angles bas en mode ancres ===== */

@media (max-width: 600px) {
  body.show-anchors .piece-zone .prehole,
  body.anchor-edit .piece-zone .prehole {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }

  body.show-anchors .piece-zone .angle-label.bl,
  body.show-anchors .piece-zone .angle-label.br,
  body.anchor-edit .piece-zone .angle-label.bl,
  body.anchor-edit .piece-zone .angle-label.br {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }
}

/* ===== FIX iPHONE LANDSCAPE — boutons admin du panneau contrôles ===== */

@media (max-width: 900px) and (orientation: landscape) {
  .atelier-sheet #anchorBtn,
  .atelier-sheet #anchorEditBtn {
    grid-column: 1 / -1 !important;
    width: 100% !important;
    justify-self: stretch !important;
    min-width: 0 !important;
  }

  .atelier-sheet #printSummaryBtn {
    grid-column: 1 / -1 !important;
    width: 100% !important;
    justify-self: stretch !important;
  }
}

/* ===== FIX iPHONE LANDSCAPE — panneau réglage ancres compact ===== */

@media (max-width: 900px) and (orientation: landscape) {
  .anchor-tools {
    right: 10px !important;
    bottom: 10px !important;
    width: min(360px, 46vw) !important;
    max-height: 72vh !important;
    overflow: auto !important;
    padding: 10px !important;
  }

  .anchor-tools h3 {
    font-size: 13px !important;
    margin-bottom: 5px !important;
  }

  .anchor-tools p {
    font-size: 11px !important;
    line-height: 1.25 !important;
    margin-bottom: 7px !important;
  }

  .anchor-tools textarea {
    min-height: 86px !important;
    max-height: 28vh !important;
    font-size: 10px !important;
  }

  .anchor-tools .tool-row {
    gap: 6px !important;
    margin-top: 8px !important;
  }

  .anchor-tools button {
    padding: 8px 10px !important;
    font-size: 11px !important;
  }
}

/* ===== FIX — Metrics panneau haut : hauteur + surface ===== */

.stats-row {
  grid-column: 1 / -1 !important;

  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;

  gap: 12px 14px !important;
  margin-top: 10px !important;
  width: 100% !important;
}

.info-field.stat {
  min-width: 0 !important;
}

.info-field.stat label {
  font-size: 9px !important;
  letter-spacing: 0.12em !important;
  line-height: 1.15 !important;
  white-space: nowrap !important;
}

.info-field.stat div {
  width: 100% !important;
  min-width: 0 !important;
  min-height: 34px !important;

  display: flex !important;
  align-items: center !important;

  padding: 0 10px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}

.height-info {
  margin-left: 0 !important;
  padding-bottom: 0 !important;
}

.height-label,
.info-field label {
  white-space: nowrap !important;
}

#floorArea {
  min-width: 90px !important;
}

.atelier-sheet #printSummaryBtn {
  justify-self: stretch !important;
}

/* ===== FIX — Barre outils sous le panneau métriques ===== */

.tabs {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 6px !important;
}

.atelier-sheet .tabs #printSummaryBtn,
.atelier-sheet .tabs #anchorBtn,
.atelier-sheet .tabs #anchorEditBtn {
  width: auto !important;
  min-width: max-content !important;
  flex: 0 0 auto !important;
  grid-column: auto !important;
  justify-self: auto !important;
  white-space: nowrap !important;
  height: 30px !important;
  padding: 5px 12px !important;
  font-size: 12px !important;
  border-radius: 999px !important;
}

.atelier-sheet .tabs #printSummaryBtn {
  margin-left: auto !important;
}

@media (max-width: 760px) {
  .atelier-sheet .tabs #printSummaryBtn,
  .atelier-sheet .tabs #anchorBtn,
  .atelier-sheet .tabs #anchorEditBtn,
  .atelier-sheet .tabs .seg-select-inline {
    width: 100% !important;
    margin-left: 0 !important;
  }
}

/* ===== FINAL — Barre navigation + outils atelier ===== */

.atelier-sheet .tabs-main,
.atelier-sheet .tabs-tools {
  align-items: center !important;
}

.atelier-sheet .tabs-main .tab,
.atelier-sheet .tabs-tools .tab,
.atelier-sheet .tabs-tools #anchorEditBtn,
.atelier-sheet .tabs-main .seg-select-inline {
  height: 32px !important;
  min-height: 32px !important;
  padding: 6px 14px !important;
  border-radius: 999px !important;
  font-size: 12px !important;
  line-height: 1 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-sizing: border-box !important;
}

/* Select segment : même hauteur et même présence que les boutons */
.atelier-sheet .tabs-main .seg-select-inline {
  min-width: 150px !important;
  padding-right: 30px !important;
  background: #fffaf1 !important;
  border: 1px solid rgba(127, 90, 56, 0.25) !important;
  font-weight: 600 !important;
}

/* Bouton principal */
.atelier-sheet #printSummaryBtn {
  height: 38px !important;
  min-height: 38px !important;
  padding: 8px 18px !important;
  font-weight: 800 !important;
  letter-spacing: 0.02em !important;
  background: #efe5d7 !important;
  border-color: rgba(127, 90, 56, 0.42) !important;
}

/* Ligne admin alignée sous le bouton impression */
.atelier-sheet .tabs-tools {
  justify-content: flex-end !important;
}

/* ===== FIX — cacher outils admin hors mode admin ===== */

body:not(.admin-mode) #anchorBtn,
body:not(.admin-mode) #anchorEditBtn {
  display: none !important;
}

/* ===== FIX — homogénéiser métriques ===== */

#domeHeight,
#floorArea {
  font-size: 16px !important;
  font-weight: 700 !important;
  line-height: 1.1 !important;
}

/* ===== FIX FINAL — même typo Hauteur / Surface ===== */

.atelier-sheet .info-field.stat #domeHeight,
.atelier-sheet .info-field.stat #floorArea {
  font-family: "Helvetica Neue", Arial, sans-serif !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  font-style: normal !important;
  line-height: 1 !important;
  color: var(--ink) !important;
  letter-spacing: 0 !important;
}

.atelier-sheet .info-field.stat > div {
  display: flex !important;
  align-items: center !important;
  min-height: 32px !important;
}

/* ===== FIX — champs numériques panneau haut ===== */

.atelier-sheet .controls input[type="number"],
.atelier-sheet .controls select {
  font-size: 15px !important;
  font-weight: 600 !important;
  color: var(--ink) !important;
}

/* ===== AJOUT — Metrics Lmax + poids triangle max ===== */
.atelier-sheet .stats-row {
  grid-column: 1 / -1 !important;

  display: grid !important;
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;

  gap: 10px !important;
  margin-top: 8px !important;
  align-items: start !important;
}

.atelier-sheet .stats-row {
  grid-column: 1 / -1 !important;

  display: grid !important;
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;

  gap: 10px !important;
  margin-top: 8px !important;
  align-items: start !important;
}

.info-field.stat {
  min-width: 0;
}

.atelier-sheet .controls .stats-row {
  flex-wrap: wrap !important;
  row-gap: 10px !important;
}

#maxSegmentLength,
#maxTriangleWeight {
  min-width: 92px !important;
}

@media (max-width: 640px) {
  .atelier-sheet .controls .stats-row {
    grid-template-columns: 1fr 1fr !important;
  }
}

/* ===== STATS PARAMÈTRES — UNE LIGNE DESKTOP ===== */

.atelier-sheet .stats-row {
  grid-column: 1 / -1 !important;
  display: grid !important;
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  gap: 10px !important;
  margin-top: 6px !important;
}

.atelier-sheet .info-field.stat {
  min-width: 0 !important;
}

.atelier-sheet .info-field.stat label {
  font-size: 8.5px !important;
  letter-spacing: 0.09em !important;
  white-space: nowrap !important;
}

.atelier-sheet .info-field.stat > div {
  min-height: 30px;
  display: flex;
  align-items: center;
  font-weight: 800;
  white-space: nowrap;
}

/* ===== FIX FINAL — STATS SUR UNE LIGNE ===== */

.atelier-sheet .controls .stats-row {
  grid-column: 1 / -1 !important;
  display: grid !important;
  grid-template-columns:
  0.8fr
  0.8fr
  1fr
  1.2fr
  1.2fr
  1.6fr !important;
  gap: 10px !important;
  width: 100% !important;
}

.atelier-sheet .stats-row label {
  white-space: nowrap !important;
  font-size: 8px !important;
  letter-spacing: 0.08em !important;
}

.atelier-sheet .controls .stats-row .info-field {
  min-width: 0 !important;
}

.atelier-sheet .controls .stats-row .info-field div {
  width: 100% !important;
}

/* ===== FIX FINAL — STATS LISIBLES SUR UNE LIGNE ===== */

.atelier-sheet .controls .stats-row {
  grid-column: 1 / -1 !important;
  display: grid !important;
  grid-template-columns: 0.7fr 0.7fr 0.9fr 1.25fr 1fr 1.8fr !important;
  gap: 12px !important;
  width: 100% !important;
  margin-top: 10px !important;
}

.atelier-sheet .controls .stats-row .info-field {
  min-width: 0 !important;
}

.atelier-sheet .controls .stats-row .info-field label {
  font-size: 7px !important;
  letter-spacing: 0.06em !important;
  white-space: normal !important;
  line-height: 1.05 !important;
  min-height: 14px !important;
}

.atelier-sheet .controls .stats-row .info-field div {
  width: 100% !important;
  min-width: 0 !important;
  height: 30px !important;
  padding: 0 8px !important;
  font-size: 12px !important;
  white-space: nowrap !important;
}

/* ===== PATCH ULTIME — STATS SUR TOUTE LA LARGEUR ===== */

.atelier-sheet .panel.controls > .stats-row {
  grid-column: 1 / 13 !important;
  width: 100% !important;
  max-width: none !important;

  display: grid !important;
  grid-template-columns: 0.75fr 0.75fr 0.9fr 1.25fr 1fr 1.8fr !important;
  gap: 12px !important;
  margin-top: 10px !important;
}

.atelier-sheet .panel.controls > .stats-row .info-field {
  width: 100% !important;
  min-width: 0 !important;
}

.atelier-sheet .panel.controls > .stats-row .info-field label {
  font-size: 7px !important;
  letter-spacing: 0.05em !important;
  line-height: 1.05 !important;
  white-space: normal !important;
}

.atelier-sheet .panel.controls > .stats-row .info-field div {
  width: 100% !important;
  min-width: 0 !important;
  height: 30px !important;
  font-size: 12px !important;
  padding: 0 8px !important;
}

/* ===== STATS — 2 LIGNES LISIBLES ===== */

.atelier-sheet .panel.controls > .stats-row {
  grid-column: 1 / 13 !important;
  width: 100% !important;

  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;

  gap: 12px 14px !important;
  margin-top: 12px !important;
}

.atelier-sheet .panel.controls > .stats-row .info-field label {
  font-size: 9px !important;
  letter-spacing: 0.12em !important;
  line-height: 1.15 !important;
  white-space: nowrap !important;
}

.atelier-sheet .panel.controls > .stats-row .info-field div {
  min-height: 34px !important;
  height: 34px !important;
  font-size: 13px !important;
  padding: 0 10px !important;
}

/* ===== FIX iPHONE PORTRAIT — panneau paramètres compact lisible ===== */

@media (max-width: 640px) {
  .atelier-sheet .panel.controls {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 14px !important;
    padding: 18px !important;
  }

  .atelier-sheet .panel.controls > div:nth-child(1) {
    grid-column: 1 / -1 !important;
  }

  .atelier-sheet .panel.controls > div:nth-child(2),
  .atelier-sheet .panel.controls > div:nth-child(3),
  .atelier-sheet .panel.controls > div:nth-child(4) {
    grid-column: span 1 !important;
  }

  .atelier-sheet .panel.controls label {
    display: block !important;
    min-height: 28px !important;
    margin-bottom: 6px !important;
    font-size: 9px !important;
    line-height: 1.15 !important;
    letter-spacing: 0.08em !important;
    white-space: normal !important;
  }

  .atelier-sheet .panel.controls select,
  .atelier-sheet .panel.controls input {
    width: 100% !important;
    height: 42px !important;
    min-height: 42px !important;
    font-size: 16px !important;
    line-height: 1.2 !important;
  }

  .atelier-sheet .panel.controls > .stats-row {
    grid-column: 1 / -1 !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 14px !important;
    margin-top: 4px !important;
  }

  .atelier-sheet .panel.controls > .stats-row .info-field label {
    min-height: 24px !important;
    font-size: 9px !important;
    line-height: 1.15 !important;
  }

  .atelier-sheet .panel.controls > .stats-row .info-field div {
    height: 42px !important;
    min-height: 42px !important;
    font-size: 16px !important;
  }
}
