/* Page-specific viewer styling (Figma replica) */

#tools-tool-page #tools-viewer-modal {
  /* Map design-token vars used by the provided CSS */
  --color-primary: var(--primary, #fb5650);
  --white: #fff;
  --input-border: #f6e9e9;
  --black-darker: #0f1b34;
  --black-dark: #31343f;
  --gray-darker: #616579;
  --sidebar-section-border: #4d5162;
  --border-gray: #f0f1f6;
  --white-text-light: #f2f3f7;
  --checkbox-default-border: #e6e7ec;
}

/* Ensure `hidden` attribute always hides (our design styles use flex) */
#tools-tool-page #tools-viewer-modal [hidden] {
  display: none !important;
}

/* Disable toolbars until STL is uploaded */
#tools-tool-page #tools-viewer-modal .left-side-tooltip.is-disabled,
#tools-tool-page #tools-viewer-modal .right-side-tooltip.is-disabled {
  opacity: 0.45;
  pointer-events: none;
}


/* Container */
#tools-tool-page #tools-viewer-modal .tools-viewer-modal-dialog {
  background: transparent;
  border-radius: 12px;
  box-shadow: none;
  width: 100%;
  height: auto;
  overflow: visible;
}

#tools-tool-page #tools-viewer-modal .stl-viewer-modal {
  background: var(--white);
  border-radius: 12px;
  overflow: hidden;
  width: min(70vw, 100%);
  height: 92vh;
  max-height: 96vh;
  min-height: 0;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
}

/* Header */
#tools-tool-page #tools-viewer-modal .stl-viewer-modal .header {
  background: var(--input-border);
  display: flex;
  height: 68px;
  padding: 16px;
  justify-content: space-between;
  align-items: center;
}

#tools-tool-page #tools-viewer-modal .stl-viewer-modal .header>span {
  color: var(--black-darker);
  font-family: "SF-Pro-Bold-Text";
  font-size: 24px;
  line-height: 125%;
}

#tools-tool-page #tools-viewer-modal #modal-close-icon.back-button {
  border-radius: 1000px;
  border: 1px solid var(--color-primary);
  display: inline-flex;
  padding: 8px 12px;
  justify-content: center;
  align-items: center;
  gap: 6px;
  background: transparent;
}

#tools-tool-page #tools-viewer-modal #modal-close-icon.back-button .close-badge {
  display: none;
}

#tools-tool-page #tools-viewer-modal #modal-close-icon.back-button::before {
  content: "×";
  width: 16px;
  height: 16px;
  border: 1px solid var(--color-primary);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  font-family: "SF-Pro-Semi-Bold-Text";
  font-size: 12px;
  line-height: 1;
}

#tools-tool-page #tools-viewer-modal #modal-close-icon.back-button span {
  color: var(--color-primary);
  font-family: "SF-Pro-Semi-Bold-Text";
  font-size: 16px;
  line-height: 125%;
}

/* Modal body */
#tools-tool-page #tools-viewer-modal .inside-modal {
  display: flex;
  align-items: stretch;
  background: var(--white);
  flex: 1 1 auto;
  min-height: 0;
}

#tools-tool-page #tools-viewer-modal .inside-content {
  position: relative;
  display: flex;
  gap: 24px;
  padding: 10px;
  flex-direction: column;
  width: 100%;
  min-height: 0;
  flex: 1 1 auto;
}

#tools-tool-page #tools-viewer-modal .left-right-tooltip-contianer {
  position: relative;
  display: flex;
  align-items: flex-start;
  z-index: 60;
}

/* Shared button reset (keep IDs/JS behavior intact) */
#tools-tool-page #tools-viewer-modal .icon-btn {
  border: none;
  background: transparent;
  cursor: pointer;
  width: auto;
  height: auto;
  border-radius: 0;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

#tools-tool-page #tools-viewer-modal .icon-btn img {
  width: 24px;
  height: 24px;
  object-fit: contain;
}

#tools-tool-page #tools-viewer-modal .chevron-icon {
  width: 9px;
  height: 9px;
  flex: 0 0 9px;
}

#tools-tool-page #tools-viewer-modal #tools-measure-toggle-btn img:first-child {
  width: 24px;
  height: 20px;
}

/* Left toolbar */
#tools-tool-page #tools-viewer-modal .left-side-tooltip {
  border-radius: 4px;
  background: var(--white);
  box-shadow: 0 2px 4px 0 rgba(39, 40, 51, 0.2);
  display: flex;
  padding: 8px;
  align-items: flex-start;
  width: fit-content;
  position: static;
  z-index: 65;
}

#tools-tool-page #tools-viewer-modal .left-side-tooltip> :not(:last-child) {
  border-right: 2px solid var(--checkbox-default-border);
  padding-right: 8px;
  margin-right: 8px;
}

#tools-tool-page #tools-viewer-modal .eye-div,
#tools-tool-page #tools-viewer-modal .bounding-length {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

#tools-tool-page #tools-viewer-modal .eye-toggle,
#tools-tool-page #tools-viewer-modal #tools-measure-toggle-btn {
  gap: 4px;
  min-width: 0;
}

/* Dropdowns */
#tools-tool-page #tools-viewer-modal .eye-dropdown,
#tools-tool-page #tools-viewer-modal .bounding-dropdown {
  z-index: 99;
  position: absolute;
  top: 44px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  list-style: none;
  margin: 0;
  padding: 10px;
  padding-bottom: 8px;
  border-radius: 4px;
  background: var(--white);
  box-shadow: 0px 8px 16px 0px rgba(39, 40, 51, 0.16);
}

#tools-tool-page #tools-viewer-modal .eye-dropdown {
  left: -24px;
  width: 140px;
}

#tools-tool-page #tools-viewer-modal .eye-dropdown::before {
  content: "";
  position: absolute;
  left: 20%;
  top: -8px;
  transform: translateY(-50%);
  width: 8px;
  height: 8px;
  border: 8px solid transparent;
  border-bottom-color: var(--white);
}

#tools-tool-page #tools-viewer-modal .eye-dropdown li {
  width: 100%;
}

#tools-tool-page #tools-viewer-modal .eye-item {
  width: 100%;
  border: none;
  background: transparent;
  cursor: pointer;
  display: flex;
  gap: 8px;
  align-items: center;
  padding: 4px 2px;
  text-align: left;
}

#tools-tool-page #tools-viewer-modal .eye-item span {
  color: var(--sidebar-section-border);
  font-family: "SF-Pro-Regular-Text";
  font-size: 12px;
  line-height: 125%;
}

#tools-tool-page #tools-viewer-modal .eye-item img {
  width: 16px;
  height: 16px;
}

#tools-tool-page #tools-viewer-modal .bounding-dropdown {
  right: 0;
  width: 166px;
}

#tools-tool-page #tools-viewer-modal .bounding-dropdown::before {
  content: "";
  position: absolute;
  right: 7%;
  top: -8px;
  transform: translateY(-50%);
  width: 8px;
  height: 8px;
  border: 8px solid transparent;
  border-bottom-color: var(--white);
}

#tools-tool-page #tools-viewer-modal .bounding-item {
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: 8px;
}

#tools-tool-page #tools-viewer-modal .bounding-item .content {
  width: 100%;
  cursor: pointer;
  border: none;
  background: transparent;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 2px 0;
  text-align: left;
}

#tools-tool-page #tools-viewer-modal .bounding-item .content,
#tools-tool-page #tools-viewer-modal .bounding-item .content span {
  color: var(--sidebar-section-border);
  font-family: "SF-Pro-Regular-Text";
  font-size: 12px;
  line-height: 125%;
}

#tools-tool-page #tools-viewer-modal .bounding-img {
  width: 24px;
  height: 20px;
}

/* Right toolbar */
#tools-tool-page #tools-viewer-modal .right-side-tooltip {
  border-radius: 12px;
  background: var(--white);
  box-shadow: 0 2px 4px 0 rgba(39, 40, 51, 0.2);
  position: absolute;
  right: 16px;
  top: 8px;
  display: flex;
  height: 48px;
  padding: 10px;
  justify-content: center;
  align-items: flex-start;
  gap: 16px;
  z-index: 65;
}

#tools-tool-page #tools-viewer-modal .right-side-tooltip> :not(:last-child) {
  border-right: 2px solid var(--checkbox-default-border);
  padding-right: 12px;
}

/* Viewer area */
#tools-tool-page #tools-viewer-modal .stl-image-viewer {
  display: flex;
  flex-direction: column;
  width: 95%;
  flex: 1 1 auto;
  min-height: 0;
  margin-top: 18px;
}

#tools-tool-page #tools-viewer-modal #renderer-container.canvas-host {
  width: 100%;
  flex: 1 1 auto;
  height: auto;
  min-height: 320px;
  border-radius: 16px;
  overflow: hidden;
  background: #020919;
}

#tools-tool-page #tools-viewer-modal #tools-replace-file-btn {
  z-index: 70;
  width: 113px;
  height: 40px;
  display: flex;
  align-self: flex-end;
  align-items: center;
  position: relative;
  top: -59px;
  right: 19px;
}

#tools-tool-page #tools-viewer-modal #renderer-container canvas {
  border-radius: 16px;
  display: block;
  width: 100%;
  height: 100%;
}

/* Panels */
#tools-tool-page #tools-viewer-modal .analysis-panel {
  z-index: 99;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  position: absolute;
  top: 73px;
  gap: 8px;
  border-radius: 12px;
  background: var(--white);
  box-shadow: 0px 8px 16px 0px rgba(39, 40, 51, 0.16);
  border: none;
  padding: 16px 12px;
}

#tools-tool-page #tools-viewer-modal .analysis-panel::before {
  content: "";
  position: absolute;
  top: -8px;
  transform: translateY(-50%);
  width: 8px;
  height: 8px;
  border: 8px solid transparent;
  border-bottom-color: var(--white);
}

#tools-tool-page #tools-viewer-modal #tools-panel-part.analysis-panel {
  right: 114px;

  width: 350px;
}

#tools-tool-page #tools-viewer-modal #tools-panel-part.analysis-panel::before {
  right: 7%;
}

#tools-tool-page #tools-viewer-modal #tools-panel-analysis.analysis-panel {
  right: 66px;
  width: 350px;
  padding: 16px 0;
}

#tools-tool-page #tools-viewer-modal #tools-panel-analysis.analysis-panel::before {
  right: 7%;
}

#tools-tool-page #tools-viewer-modal #tools-panel-thickness.analysis-panel {
  right: 23px;
  width: 300px;
}

#tools-tool-page #tools-viewer-modal #tools-panel-thickness.analysis-panel::before {
  right: 7%;
}

#tools-tool-page #tools-viewer-modal[data-default-tool="stl-error-analysis"] .analysis-panel::before,
#tools-tool-page #tools-viewer-modal[data-default-tool="wall-thickness-analysis"] .analysis-panel::before {
  content: "";
  position: absolute;
  right: 7%;
  top: -8px;
  transform: translateY(-50%);
  width: 8px;
  height: 8px;
  border: 8px solid transparent;
  border-bottom-color: var(--white);
  background: transparent;
}

#tools-tool-page #tools-viewer-modal .cube-header,
#tools-tool-page #tools-viewer-modal .mesh-header,
#tools-tool-page #tools-viewer-modal .thickness-header {
  width: 100%;
  text-align: center;
  font-size: 18px;
}

#tools-tool-page #tools-viewer-modal .cube-header span,
#tools-tool-page #tools-viewer-modal .mesh-header span,
#tools-tool-page #tools-viewer-modal .thickness-header span {
  color: var(--black-dark);
  font-family: "SF-Pro-Semi-Bold-Text";
  font-weight: 600;
  line-height: 125%;
}

#tools-tool-page #tools-viewer-modal .part-details {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
  width: 100%;
}

#tools-tool-page #tools-viewer-modal .info-div,
#tools-tool-page #tools-viewer-modal .info,
#tools-tool-page #tools-viewer-modal .information {
  width: 100%;
  align-self: stretch;
  box-sizing: border-box;
}

#tools-tool-page #tools-viewer-modal .part-name-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}

#tools-tool-page #tools-viewer-modal .part-name-row span {
  color: var(--gray-darker);
  font-family: "SF-Pro-Semi-Bold-Text";
  font-size: 16px;
  line-height: 125%;
}

#tools-tool-page #tools-viewer-modal .file-name-pill {
  border-radius: 4px;
  background: var(--border-gray);
  display: inline-flex;
  padding: 4px 8px;
  align-items: center;
  max-width: 60%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--gray-darker);
  font-family: "SF-Pro-Semi-Bold-Text";
  font-size: 14px;
}

#tools-tool-page #tools-viewer-modal .info .heading {
  border-radius: 4px;
  border: 1px solid var(--border-gray);
  background: var(--white-text-light);
  display: flex;
  width: 100%;
  box-sizing: border-box;
  padding: 0 8px;
  align-items: flex-start;
}

#tools-tool-page #tools-viewer-modal .info .heading span {
  color: var(--black-dark);
  font-family: "SF-Pro-Regular-Text";
  font-size: 16px;
  line-height: 125%;
}

#tools-tool-page #tools-viewer-modal .information {
  display: flex;
  padding: 0 8px;
  flex-direction: column;
  gap: 8px;
}

#tools-tool-page #tools-viewer-modal .information .contents {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

#tools-tool-page #tools-viewer-modal .information .contents .left {
  color: var(--gray-darker);
  font-family: "SF-Pro-Regular-Text";
  font-size: 16px;
  line-height: 125%;
}

#tools-tool-page #tools-viewer-modal .information .contents .right {
  border-radius: 4px;
  background: var(--border-gray);
  display: flex;
  width: fit-content;
  height: 20px;
  padding: 10px 4px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

#tools-tool-page #tools-viewer-modal .information .contents .right span {
  color: var(--gray-darker);
  text-align: center;
  font-family: "SF-Pro-Semi-Bold-Text";
  font-size: 14px;
  line-height: 125%;
  background: transparent;
  padding: 0;
}

#tools-tool-page #tools-viewer-modal .analysis-div {
  padding: 0 12px 8px;
  width: 100%;
}

#tools-tool-page #tools-viewer-modal .analysis-content {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

#tools-tool-page #tools-viewer-modal .analysis-content .left-side {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
}

#tools-tool-page #tools-viewer-modal .analysis-content .left-side span {
  color: var(--gray-darker);
  font-family: "SF-Pro-Regular-Text";
  font-size: 16px;
  line-height: 125%;
}

#tools-tool-page #tools-viewer-modal .analysis-content .right-side {
  border-radius: 4px;
  background: var(--white-text-light);
  display: flex;
  width: fit-content;
  height: 20px;
  padding: 10px 4px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

#tools-tool-page #tools-viewer-modal .analysis-content .right-side span {
  color: var(--gray-darker);
  text-align: center;
  font-family: "SF-Pro-Semi-Bold-Text";
  font-size: 14px;
  line-height: 125%;
  background: transparent;
  padding: 0;
}

#tools-tool-page #tools-viewer-modal .status-dot {
  width: 20px;
  height: 20px;
  border-radius: 999px;
  background: #2b9749;
  color: #fff !important;
  font-size: 13px !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

#tools-tool-page #tools-viewer-modal #tools-panel-thickness .btn-div {
  margin-top: 6px;
  display: flex;
  width: 100%;
  justify-content: flex-end;
}

#tools-tool-page #tools-viewer-modal #tools-panel-thickness #tools-thickness-calculate {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 5px 10px;
  width: fit-content;
  border: none;
  border-radius: 12px;
  background: var(--color-primary);
  color: var(--white);
  cursor: pointer;
  font-family: "SF-Pro-Semi-Bold-Text";
  font-size: 14px;
}

#tools-tool-page #tools-viewer-modal #tools-wall-thickness-threshold {
  width: 100%;
  border: 1px solid var(--border-gray);
  border-radius: 10px;
  background: var(--white-text-light);
  padding: 6px 12px;
  font-family: "SF-Pro-Regular-Text";
  font-size: 16px;
  color: var(--black-dark);
}

/* Fullscreen */
#tools-tool-page #tools-viewer-modal .fullscreen-active {
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100vh;
  z-index: 9999;
  background: #0b0f17;
  display: flex;
  flex-direction: column;
}

#tools-tool-page #tools-viewer-modal .fullscreen-active .stl-image-viewer {
  position: relative;
  flex: 1 1 auto;
  display: flex;
}

#tools-tool-page #tools-viewer-modal .fullscreen-active #renderer-container.canvas-host {
  height: 88vh !important;
  min-height: 0;
}

/* Tooltip */
#tools-tool-page #tools-viewer-modal [data-tooltip] {
  position: relative;
}

#tools-tool-page #tools-viewer-modal [data-tooltip]::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  padding: 6px 8px;
  border-radius: 4px;
  background: rgba(20, 24, 32, 0.92);
  color: #e7eefc;
  white-space: nowrap;
  font-size: 12px;
  line-height: 1;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.15s ease;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.35);
  z-index: 999;
}

#tools-tool-page #tools-viewer-modal [data-tooltip]:hover::after {
  opacity: 1;
}
