/* TNM Prijstool — Apollo (headings) + Mulish (body) | Gold: #AF9059 */

:root {
  --tnm-gold: #AF9059;
  --tnm-gold-grad: linear-gradient(143deg, rgb(221,193,142) 0%, rgb(179,148,95) 100%);
  --tnm-gold-bg: #f9f3ea;
  --tnm-cream: #faf7f2;
  --tnm-border: #e5ddd0;
  --tnm-text: #333;
  --tnm-muted: #666;
  --tnm-white: #fff;
  --tnm-comp-red: #c0392b;
  --tnm-dark: #1a1410;
}

/* ── Base ── */
#tnm-prijstool {
  font-family: 'Mulish', sans-serif !important;
  color: var(--tnm-text);
  max-width: 860px;
  margin: 0 auto;
  padding: 0 0 40px;
}
#tnm-prijstool *, #tnm-prijstool *::before, #tnm-prijstool *::after { box-sizing: border-box; }
#tnm-prijstool p  { margin: 0 !important; }
#tnm-prijstool h3 { font-family: "Apollo", serif !important; font-weight: 400; margin: 0 !important; line-height: 1.2; }

/* Kill theme SVG blowup */
#tnm-prijstool svg { display: none !important; width: 0 !important; height: 0 !important; }

/* ── Sections ── */
#tnm-prijstool .tnm-pt-section         { display: none !important; }
#tnm-prijstool .tnm-pt-section.active  { display: block !important; }

/* ── Steps ── */
#tnm-prijstool .tnm-pt-steps {
  display: flex !important; flex-direction: row !important; flex-wrap: nowrap !important;
  background: var(--tnm-white); border: 1px solid var(--tnm-border); border-radius: 50px;
  padding: 5px; margin-bottom: 24px; gap: 4px; list-style: none !important;
}
#tnm-prijstool .tnm-pt-step {
  flex: 1 1 0 !important; display: flex !important; flex-direction: row !important;
  align-items: center !important; justify-content: center !important; gap: 8px;
  padding: 9px 10px; border-radius: 50px; font-size: 12px; color: var(--tnm-muted);
  transition: all .3s; cursor: default; font-family: 'Mulish', sans-serif !important;
}
#tnm-prijstool .tnm-pt-step.active {
  background: var(--tnm-gold-grad) !important; color: #fff !important; font-weight: 600;
}
#tnm-prijstool .tnm-pt-step-num {
  width: 20px; height: 20px; border-radius: 50%; background: rgba(0,0,0,.08);
  display: flex !important; align-items: center !important; justify-content: center !important;
  font-size: 10px; font-weight: 700; flex-shrink: 0; line-height: 1;
}
#tnm-prijstool .tnm-pt-step.active .tnm-pt-step-num { background: rgba(255,255,255,.28); }
@media (max-width: 480px) { #tnm-prijstool .tnm-pt-step span { display: none !important; } }

/* ── Upload zone ── */
#tnm-prijstool .tnm-pt-upload-zone {
  background: var(--tnm-white); border: 2px dashed var(--tnm-border) !important;
  border-radius: 18px; padding: 48px 28px; text-align: center; cursor: pointer;
  transition: all .25s; margin-bottom: 16px;
}
#tnm-prijstool .tnm-pt-upload-zone:hover { border-color: var(--tnm-gold) !important; background: var(--tnm-gold-bg); }
#tnm-prijstool .tnm-pt-upload-icon {
  width: 64px !important; height: 64px !important; min-width: 64px !important; min-height: 64px !important;
  max-width: 64px !important; max-height: 64px !important; margin: 0 auto 16px !important;
  background: #f2ede4 !important; border-radius: 50% !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  font-size: 28px !important; line-height: 1 !important; color: #AF9059 !important;
  font-family: sans-serif !important; overflow: hidden !important;
}
#tnm-prijstool .tnm-pt-upload-zone h3 { font-size: 1.4rem; margin-bottom: 8px !important; }
#tnm-prijstool .tnm-pt-upload-zone p  { font-size: 13px; color: var(--tnm-muted); margin-bottom: 20px !important; }
#tnm-prijstool .tnm-pt-demo-links {
  margin-top: 16px; font-size: 12px; color: var(--tnm-muted);
  display: flex !important; align-items: center !important; justify-content: center !important; gap: 10px; flex-wrap: wrap;
}

/* ── Buttons ── */
#tnm-prijstool .tnm-pt-btn-gold,
#tnm-calib-popup .tnm-pt-btn-gold {
  display: inline-flex !important; align-items: center !important; gap: 8px;
  background: var(--tnm-gold-grad) !important; color: #fff !important; border: none !important;
  border-radius: 50px !important; padding: 13px 28px !important;
  font-family: 'Mulish', sans-serif !important; font-size: 14px !important; font-weight: 600 !important;
  cursor: pointer !important; transition: all .2s; text-decoration: none !important;
  box-shadow: none; letter-spacing: 0; text-transform: none !important; line-height: 1.2;
}
#tnm-prijstool .tnm-pt-btn-gold:hover,
#tnm-calib-popup .tnm-pt-btn-gold:hover { opacity: .88; transform: translateY(-1px); color: #fff !important; }
#tnm-prijstool .tnm-pt-btn-gold:disabled { opacity: .45 !important; cursor: default !important; transform: none !important; }

#tnm-prijstool .tnm-pt-btn-outline,
#tnm-calib-popup .tnm-pt-btn-outline {
  display: inline-flex !important; align-items: center !important; gap: 8px;
  background: transparent !important; color: var(--tnm-gold) !important;
  border: 1.5px solid var(--tnm-gold) !important; border-radius: 50px !important;
  padding: 11px 22px !important; font-family: 'Mulish', sans-serif !important;
  font-size: 14px !important; font-weight: 500 !important; cursor: pointer !important;
  transition: all .2s; text-decoration: none !important; text-transform: none !important; line-height: 1.2;
}
#tnm-prijstool .tnm-pt-btn-outline:hover,
#tnm-calib-popup .tnm-pt-btn-outline:hover { background: var(--tnm-gold-bg) !important; }

#tnm-prijstool .tnm-pt-demo-link {
  background: none !important; border: none !important; color: var(--tnm-gold) !important;
  font-size: 12px; cursor: pointer; text-decoration: underline;
  font-family: 'Mulish', sans-serif !important; padding: 0 !important;
}

/* ── Hint ── */
#tnm-prijstool .tnm-pt-hint {
  background: #f2ede4; border: 1px solid var(--tnm-border) !important; border-radius: 12px;
  padding: 13px 16px; font-size: 13px; color: var(--tnm-muted);
  display: flex !important; flex-direction: row !important; gap: 10px; line-height: 1.55; margin-bottom: 14px;
}
#tnm-prijstool .tnm-pt-hint strong { color: var(--tnm-text); }
#tnm-prijstool .tnm-pt-hint-icon {
  display: inline-flex !important; align-items: center !important; justify-content: center !important;
  flex-shrink: 0 !important; width: 18px !important; height: 18px !important;
  min-width: 18px !important; min-height: 18px !important;
  border-radius: 50% !important; border: 1.5px solid #AF9059 !important;
  color: #AF9059 !important; font-size: 11px !important; font-weight: 700 !important;
  font-style: normal !important; font-family: serif !important; line-height: 1 !important; margin-top: 1px;
}

/* ── Card ── */
#tnm-prijstool .tnm-pt-card {
  background: var(--tnm-white); border: 1px solid var(--tnm-border) !important;
  border-radius: 16px; overflow: hidden; margin-bottom: 14px;
}
#tnm-prijstool .tnm-pt-card-head {
  padding: 13px 18px; border-bottom: 1px solid var(--tnm-border) !important;
  display: flex !important; flex-direction: row !important; align-items: center !important;
  justify-content: space-between !important; flex-wrap: wrap; gap: 10px;
}
#tnm-prijstool .tnm-pt-card-head h3 { font-size: 1rem; }

/* ── Toolbar ── */
#tnm-prijstool .tnm-pt-toolbar {
  display: flex !important; flex-direction: row !important; align-items: center !important; gap: 8px; flex-wrap: wrap;
}
#tnm-prijstool .tnm-pt-tool-btn {
  padding: 7px 14px; border-radius: 50px; border: 1.5px solid var(--tnm-border) !important;
  background: var(--tnm-white) !important; font-size: 12px !important;
  font-family: 'Mulish', sans-serif !important; cursor: pointer; color: var(--tnm-muted) !important;
  transition: all .2s; display: flex !important; align-items: center !important; gap: 6px;
  white-space: nowrap; text-transform: none !important; letter-spacing: 0 !important; line-height: 1.2;
}
#tnm-prijstool .tnm-pt-tool-btn:hover { border-color: var(--tnm-gold) !important; color: var(--tnm-gold) !important; background: var(--tnm-white) !important; }
#tnm-prijstool .tnm-pt-tool-btn.active { background: var(--tnm-gold-grad) !important; border-color: transparent !important; color: #fff !important; }
#tnm-prijstool .tnm-pt-count-badge { margin-left: auto; font-size: 13px; color: var(--tnm-muted); white-space: nowrap; }
#tnm-prijstool .tnm-pt-count-badge strong { color: var(--tnm-text); }

/* ── Canvas ── */
#tnm-prijstool .tnm-pt-canvas-outer {
  position: relative; overflow: hidden; background: #f0ede8; line-height: 0;
  display: flex !important; align-items: flex-start !important; justify-content: center !important;
}
#tnm-prijstool .tnm-pt-canvas-outer canvas {
  display: block !important;
  max-width: 100% !important;
  height: auto !important;
  touch-action: none; user-select: none; -webkit-user-select: none;
}
/* Section-specific height caps */
#tnm-sec2 .tnm-pt-canvas-outer { max-height: 480px; overflow-y: auto !important; }
#tnm-sec3 .tnm-pt-canvas-outer { max-height: 520px; overflow: auto !important; }
#tnm-sec4 .tnm-pt-canvas-outer { max-height: 480px; overflow-y: auto !important; }

/* ── Calib status ── */
#tnm-prijstool .tnm-pt-calib-status { display: flex !important; align-items: center !important; gap: 10px; font-size: 13px; }
#tnm-prijstool .tnm-pt-dot { width: 10px; height: 10px; border-radius: 50%; background: #ccc; flex-shrink: 0; display: inline-block !important; }
#tnm-prijstool .tnm-pt-dot.ok { background: #4caf50; }
#tnm-prijstool .tnm-pt-dot.pending { background: #e8a020; animation: tnmPulse 1.2s infinite; }
@keyframes tnmPulse { 0%,100%{opacity:1} 50%{opacity:.35} }

/* ── Actions ── */
#tnm-prijstool .tnm-pt-actions { display: flex !important; flex-direction: row !important; gap: 10px; flex-wrap: wrap; margin-top: 12px; }

/* ── Results ── */
#tnm-prijstool .tnm-pt-results-grid { display: grid !important; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px; }
@media (max-width: 520px) { #tnm-prijstool .tnm-pt-results-grid { grid-template-columns: 1fr !important; } }
#tnm-prijstool .tnm-pt-rc { border-radius: 14px; padding: 20px; border: 1px solid var(--tnm-border) !important; background: var(--tnm-white); }
#tnm-prijstool .tnm-pt-rc.ours { border-color: var(--tnm-gold) !important; background: linear-gradient(135deg, #fff 0%, var(--tnm-gold-bg) 100%); }
#tnm-prijstool .tnm-pt-rc-eye { font-size: 10px; letter-spacing: 3px; text-transform: uppercase; margin-bottom: 5px; font-family: 'Mulish', sans-serif !important; }
#tnm-prijstool .tnm-pt-rc-eye.ours { color: var(--tnm-gold); }
#tnm-prijstool .tnm-pt-rc-eye.theirs { color: var(--tnm-muted); }
#tnm-prijstool .tnm-pt-rc-title { font-family: "Apollo", serif !important; font-size: 1.05rem; font-weight: 400; margin-bottom: 4px !important; }
#tnm-prijstool .tnm-pt-rc-desc { font-size: 12px; color: var(--tnm-muted); margin-bottom: 12px !important; line-height: 1.45; }
#tnm-prijstool .tnm-pt-rc-area { font-size: 12px; color: var(--tnm-muted); margin-bottom: 4px !important; }
#tnm-prijstool .tnm-pt-rc-price { font-family: "Apollo", serif !important; font-size: 2.4rem; font-weight: 400; line-height: 1; margin-bottom: 2px !important; }
#tnm-prijstool .tnm-pt-rc-price.ours { color: var(--tnm-gold); }
#tnm-prijstool .tnm-pt-rc-price.theirs { color: var(--tnm-comp-red); }
#tnm-prijstool .tnm-pt-rc-note { font-size: 11px; color: var(--tnm-muted); }

/* ── Savings bar ── */
#tnm-prijstool .tnm-pt-savings-bar {
  background: linear-gradient(135deg, #f9f3ea 0%, #f0e8d8 100%);
  border: 1.5px solid #d4b97a !important;
  border-radius: 14px; padding: 20px 24px;
  display: flex !important; flex-direction: row !important; align-items: center !important;
  justify-content: space-between !important; flex-wrap: wrap; gap: 12px; margin-bottom: 14px;
}
#tnm-prijstool .tnm-pt-savings-lbl {
  font-size: 10px; letter-spacing: 3px; text-transform: uppercase;
  color: #8a6a30; margin-bottom: 4px !important; font-family: 'Mulish', sans-serif !important;
}
#tnm-prijstool .tnm-pt-savings-val {
  font-family: "Apollo", serif !important; font-size: 2.2rem; font-weight: 400;
  color: var(--tnm-gold); line-height: 1;
}
#tnm-prijstool .tnm-pt-savings-tag {
  font-size: 13px; color: #7a5c28; max-width: 340px; line-height: 1.5;
}

/* ── View toggle ── */
#tnm-prijstool .tnm-pt-view-toggle { display: flex !important; flex-direction: row !important; gap: 6px; }

/* ── CTA box ── */
#tnm-prijstool .tnm-pt-cta-box { background: var(--tnm-white); border: 1px solid var(--tnm-border) !important; border-radius: 14px; padding: 26px; text-align: center; }
#tnm-prijstool .tnm-pt-cta-box h3 { font-size: 1.4rem; margin-bottom: 8px !important; }
#tnm-prijstool .tnm-pt-cta-box p { font-size: 13px; color: var(--tnm-muted); margin-bottom: 18px !important; line-height: 1.55; }
#tnm-prijstool .tnm-pt-cta-btns { display: flex !important; flex-direction: row !important; gap: 10px; justify-content: center !important; flex-wrap: wrap; }

/* ── Popup ── */
#tnm-calib-popup {
  display: none;
  position: fixed !important;
  top: 0 !important; left: 0 !important; right: 0 !important; bottom: 0 !important;
  background: rgba(0,0,0,.6) !important;
  z-index: 999999 !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 20px !important;
}
#tnm-calib-popup.open { display: flex !important; }
#tnm-calib-popup .tnm-pt-popup-box {
  background: #fff !important;
  border-radius: 18px !important;
  padding: 32px 28px !important;
  max-width: 380px !important;
  width: 100% !important;
  text-align: center !important;
  box-shadow: 0 24px 60px rgba(0,0,0,.3) !important;
  font-family: 'Mulish', sans-serif !important;
  color: #333 !important;
  position: relative !important;
  z-index: 1000000 !important;
}
#tnm-calib-popup .tnm-pt-popup-box h3 {
  font-family: "Apollo", serif !important;
  font-size: 1.5rem !important; font-weight: 400 !important;
  color: #333 !important; margin: 0 0 8px !important; line-height: 1.2 !important;
}
#tnm-calib-popup .tnm-pt-popup-box p {
  font-size: 13px !important; color: #666 !important;
  margin: 0 0 16px !important; line-height: 1.5 !important;
  font-family: 'Mulish', sans-serif !important;
}
#tnm-calib-popup canvas {
  display: block !important;
  width: 100% !important; max-width: 100% !important;
  height: 50px !important; min-height: 50px !important; max-height: 50px !important;
  margin-bottom: 18px !important;
  border-radius: 10px !important;
  background: #f2ede4 !important;
}
#tnm-calib-popup .tnm-pt-input-group {
  display: flex !important; flex-direction: row !important;
  gap: 10px !important; margin: 0 0 20px !important; align-items: center !important;
}
#tnm-calib-popup .tnm-pt-input-group input {
  flex: 1 !important; padding: 12px 16px !important;
  border: 1.5px solid #e5ddd0 !important; border-radius: 12px !important;
  font-family: 'Mulish', sans-serif !important; font-size: 20px !important;
  text-align: center !important; color: #333 !important; background: #faf7f2 !important;
  outline: none !important; -moz-appearance: textfield; box-shadow: none !important;
  width: auto !important;
}
#tnm-calib-popup .tnm-pt-input-group input:focus { border-color: #AF9059 !important; background: #fff !important; }
#tnm-calib-popup .tnm-pt-input-group input::-webkit-inner-spin-button { -webkit-appearance: none !important; }
#tnm-calib-popup .tnm-pt-input-group span { font-size: 14px !important; color: #666 !important; white-space: nowrap; }
#tnm-calib-popup .tnm-pt-actions { display: flex !important; flex-direction: row !important; gap: 10px !important; justify-content: center !important; flex-wrap: wrap; }

/* ── Divider hint ── */
#tnm-prijstool .tnm-pt-divider-hint {
  font-size: 11px !important; color: var(--tnm-muted) !important;
  margin: 2px 0 0 0 !important; font-style: italic;
}
/* Result canvas needs cursor for manual drag */
#tnm-prijstool #tnm-result-canvas { cursor: ew-resize !important; }

/* ── Zoom bar ── */
#tnm-zoom-bar {
  display: flex !important; flex-direction: row !important;
  align-items: center !important; gap: 8px;
  margin-left: auto; flex-wrap: nowrap;
}
#tnm-zoom-bar .tnm-zoom-label { font-size: 12px; color: var(--tnm-muted); white-space: nowrap; }
#tnm-zoom-bar .tnm-zoom-btn {
  width: 26px; height: 26px; border-radius: 50%;
  border: 1.5px solid var(--tnm-border) !important; background: #fff !important;
  color: var(--tnm-muted) !important; font-size: 16px; font-weight: 700;
  cursor: pointer; display: flex !important; align-items: center !important;
  justify-content: center !important; padding: 0 !important; line-height: 1;
  flex-shrink: 0;
}
#tnm-zoom-bar .tnm-zoom-btn:hover { border-color: var(--tnm-gold) !important; color: var(--tnm-gold) !important; }
#tnm-zoom-bar #tnm-zoom-slider {
  width: 80px; -webkit-appearance: none; appearance: none;
  height: 4px; background: var(--tnm-border); border-radius: 2px;
  outline: none; cursor: pointer; border: none !important;
  padding: 0 !important; box-shadow: none !important;
}
#tnm-zoom-bar #tnm-zoom-slider::-webkit-slider-thumb {
  -webkit-appearance: none; width: 16px; height: 16px;
  background: var(--tnm-gold); border-radius: 50%; cursor: pointer;
  box-shadow: 0 0 4px rgba(175,144,89,.4);
}
#tnm-zoom-bar .tnm-zoom-val { font-size: 11px; color: var(--tnm-muted); white-space: nowrap; min-width: 34px; }

