/* =============================================================
   Top Cut Calculator — Plugin Stylesheet v1.2.0
   Extracted from homepage.html and scoped to #tcc-app
   ============================================================= */

/* ── CSS variables scoped to the wrapper ─────────────────── */
#tcc-app {
  --blue:        #3B6FFF;
  --blue-light:  #6B9FFF;
  --blue-dark:   #1A3DBF;
  --yellow:      #F5C518;
  --green:       #00C48C;
  --bg:          #F8F9FC;
  --white:       #FFFFFF;
  --dark:        #0D1117;
  --ink:         #1A1F2E;
  --ink2:        #3D4460;
  --muted:       #8B91A8;
  --line:        #E4E7F0;
  --card-shadow: 0 2px 16px rgba(59,111,255,0.08), 0 1px 4px rgba(0,0,0,0.04);
  --card-shadow-hover: 0 8px 40px rgba(59,111,255,0.16), 0 2px 8px rgba(0,0,0,0.06);
}

/* ── Reset ───────────────────────────────────────────────── */
#tcc-app,
#tcc-app *,
#tcc-app *::before,
#tcc-app *::after {
  box-sizing: border-box !important;
}

#tcc-app {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
  -webkit-font-smoothing: antialiased !important;
  color: var(--ink) !important;
  line-height: 1.6 !important;
  max-width: 860px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  background: none !important;
  float: none !important;
  clear: both !important;
}

/* ── calc-box ─────────────────────────────────────────────── */
#tcc-app .calc-box {
  background: var(--white) !important;
  border: 1.5px solid var(--line) !important;
  border-radius: 20px !important;
  overflow: hidden !important;
  box-shadow: var(--card-shadow) !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  clear: both !important;
  display: block !important;
}

/* ── Blue header bar ──────────────────────────────────────── */
#tcc-app .calc-box-header {
  background: var(--blue) !important;
  padding: 20px 28px !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  border: none !important;
  border-radius: 0 !important;
  margin: 0 !important;
}

#tcc-app .calc-box-header .calculator-widget-title {
  font-size: 18px !important;
  font-weight: 800 !important;
  color: var(--white) !important;
  margin: 0 0 2px !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
  line-height: 1.2 !important;
  display: block !important;
}

#tcc-app .calc-box-header p {
  font-size: 13px !important;
  color: rgba(255,255,255,0.75) !important;
  margin: 0 !important;
  padding: 0 !important;
  background: none !important;
  border: none !important;
  line-height: 1.4 !important;
  display: block !important;
}

/* ── calc-body ────────────────────────────────────────────── */
#tcc-app .calc-body {
  padding: 28px !important;
  background: var(--white) !important;
  float: none !important;
  clear: both !important;
}

/* ── calc-inputs grid ─────────────────────────────────────── */
#tcc-app .calc-inputs {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 20px !important;
  margin-bottom: 24px !important;
  padding: 0 !important;
  background: none !important;
  border: none !important;
  float: none !important;
  clear: both !important;
}

@media (max-width: 600px) {
  #tcc-app .calc-inputs {
    grid-template-columns: 1fr !important;
  }
}

/* ── calc-field ───────────────────────────────────────────── */
#tcc-app .calc-field {
  display: flex !important;
  flex-direction: column !important;
  background: none !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  float: none !important;
}

#tcc-app .calc-field label {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 1.2px !important;
  text-transform: uppercase !important;
  color: var(--muted) !important;
  margin-bottom: 8px !important;
  padding: 0 !important;
  background: none !important;
  border: none !important;
  line-height: 1.4 !important;
  float: none !important;
  cursor: default !important;
}

#tcc-app .calc-field input {
  width: 100% !important;
  border: 1.5px solid var(--line) !important;
  border-radius: 10px !important;
  padding: 12px 16px !important;
  font-size: 17px !important;
  font-weight: 600 !important;
  color: var(--ink) !important;
  font-family: inherit !important;
  outline: none !important;
  transition: border-color 0.18s, box-shadow 0.18s !important;
  background: var(--bg) !important;
  -moz-appearance: textfield !important;
  display: block !important;
  margin: 0 !important;
  line-height: 1.4 !important;
  float: none !important;
  height: auto !important;
  box-shadow: none !important;
}

#tcc-app .calc-field input::-webkit-outer-spin-button,
#tcc-app .calc-field input::-webkit-inner-spin-button {
  -webkit-appearance: none !important;
  margin: 0 !important;
}

#tcc-app .calc-field input:focus {
  border-color: var(--blue) !important;
  box-shadow: 0 0 0 3px rgba(59,111,255,0.12) !important;
  background: var(--white) !important;
  outline: none !important;
}

#tcc-app .calc-field input::placeholder {
  color: var(--muted) !important;
  font-weight: 400 !important;
  font-size: 15px !important;
}

/* ── calc-hint ────────────────────────────────────────────── */
#tcc-app .calc-hint {
  font-size: 11px !important;
  color: var(--muted) !important;
  margin-top: 6px !important;
  padding: 0 !important;
  background: none !important;
  border: none !important;
  line-height: 1.4 !important;
  display: block !important;
}

/* ── calc-error ───────────────────────────────────────────── */
#tcc-app .calc-error {
  display: none !important;
  background: #FFF0F2 !important;
  border: 1px solid #FFD0D6 !important;
  border-radius: 10px !important;
  padding: 12px 16px !important;
  font-size: 14px !important;
  color: #B0182A !important;
  margin-bottom: 16px !important;
  line-height: 1.5 !important;
}

/* ── calc-run-btn ─────────────────────────────────────────── */
#tcc-app .calc-run-btn {
  width: 100% !important;
  background: var(--blue) !important;
  color: var(--white) !important;
  border: none !important;
  border-radius: 10px !important;
  padding: 15px !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  font-family: inherit !important;
  cursor: pointer !important;
  transition: background 0.18s, transform 0.15s, box-shadow 0.18s !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  box-shadow: 0 4px 14px rgba(59,111,255,0.3) !important;
  margin-bottom: 28px !important;
  line-height: 1.4 !important;
  text-align: center !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  letter-spacing: 0 !important;
  text-decoration: none !important;
  float: none !important;
  clear: both !important;
}

#tcc-app .calc-run-btn:hover {
  background: var(--blue-dark) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 20px rgba(59,111,255,0.4) !important;
  color: var(--white) !important;
  text-decoration: none !important;
}

#tcc-app .calc-run-btn:active {
  transform: translateY(0) !important;
  box-shadow: 0 2px 8px rgba(59,111,255,0.25) !important;
}

/* ── calc-results (hidden until .visible added by JS) ────── */
#tcc-app .calc-results {
  display: none !important;
}

#tcc-app .calc-results.visible {
  display: block !important;
}

/* ── results-summary stats row ───────────────────────────── */
#tcc-app .results-summary {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 14px !important;
  margin-bottom: 24px !important;
  padding: 0 !important;
  background: none !important;
  border: none !important;
  float: none !important;
  clear: both !important;
}

@media (max-width: 600px) {
  #tcc-app .results-summary {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

#tcc-app .res-stat {
  background: var(--bg) !important;
  border: 1px solid var(--line) !important;
  border-radius: 10px !important;
  padding: 14px !important;
  text-align: center !important;
  margin: 0 !important;
  float: none !important;
}

#tcc-app .res-stat-val {
  font-size: 24px !important;
  font-weight: 800 !important;
  color: var(--blue) !important;
  letter-spacing: -0.5px !important;
  line-height: 1.2 !important;
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  background: none !important;
  border: none !important;
}

#tcc-app .res-stat-lbl {
  font-size: 11px !important;
  color: var(--muted) !important;
  font-weight: 600 !important;
  margin-top: 3px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  display: block !important;
  padding: 0 !important;
  background: none !important;
  border: none !important;
}

/* ── results-table ────────────────────────────────────────── */
#tcc-app .results-table-wrap {
  overflow-x: auto !important;
  -webkit-overflow-scrolling: touch !important;
  margin-bottom: 0 !important;
}

#tcc-app .results-table {
  width: 100% !important;
  border-collapse: collapse !important;
  font-size: 14px !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
}

#tcc-app .results-table thead tr {
  background: var(--bg) !important;
  border-bottom: 2px solid var(--line) !important;
}

#tcc-app .results-table th {
  padding: 10px 14px !important;
  text-align: left !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  color: var(--muted) !important;
  background: var(--bg) !important;
  border: none !important;
  white-space: nowrap !important;
  vertical-align: middle !important;
}

#tcc-app .results-table td {
  padding: 11px 14px !important;
  border: none !important;
  border-bottom: 1px solid var(--line) !important;
  vertical-align: middle !important;
  background: transparent !important;
  color: var(--ink2) !important;
  font-size: 14px !important;
}

#tcc-app .results-table tr:last-child td {
  border-bottom: none !important;
}

#tcc-app .results-table tr.row-safe   { background: #F0FBF6 !important; }
#tcc-app .results-table tr.row-bubble { background: #FFFBEE !important; }
#tcc-app .results-table tr.row-elim  { background: var(--white) !important; }

#tcc-app .results-table .record-cell {
  font-weight: 700 !important;
  font-size: 15px !important;
  color: var(--ink) !important;
}

/* ── Badges ───────────────────────────────────────────────── */
#tcc-app .badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  padding: 4px 10px !important;
  border-radius: 6px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  white-space: nowrap !important;
}

#tcc-app .badge-safe   { background: #D4F5E9 !important; color: #007A52 !important; border: none !important; }
#tcc-app .badge-bubble { background: #FFF3CD !important; color: #92660A !important; border: none !important; }
#tcc-app .badge-elim   { background: #FFE8EB !important; color: #B0182A !important; border: none !important; }

/* ── Mini distribution bar ────────────────────────────────── */
#tcc-app .pct-bar-cell {
  min-width: 100px !important;
}

#tcc-app .mini-bar {
  height: 6px !important;
  background: var(--line) !important;
  border-radius: 3px !important;
  overflow: hidden !important;
}

#tcc-app .mini-bar-fill {
  height: 100% !important;
  border-radius: 3px !important;
  transition: width 0.6s cubic-bezier(.4,0,.2,1) !important;
}

#tcc-app .fill-safe   { background: var(--green)  !important; }
#tcc-app .fill-bubble { background: var(--yellow) !important; }
#tcc-app .fill-elim   { background: #E0E4EF       !important; }

/* ── calc-note ────────────────────────────────────────────── */
#tcc-app .calc-note {
  margin-top: 16px !important;
  padding: 12px 16px !important;
  background: rgba(59,111,255,0.05) !important;
  border: none !important;
  border-left: 3px solid var(--blue) !important;
  border-radius: 0 8px 8px 0 !important;
  font-size: 13px !important;
  color: var(--ink2) !important;
  line-height: 1.6 !important;
}

#tcc-app .calc-note strong { color: inherit !important; }

/* =============================================================
   Scroll hint — right-edge fade, ❯ arrow, and hint text
   ============================================================= */

/* Outer wrapper: clips the fade overlay and positions the arrow */
#tcc-app .tcc-table-outer {
  position: relative !important;
  overflow: hidden !important;   /* clips the gradient to the table card edges */
  margin-bottom: 0 !important;
}

/* Right-edge gradient fade — invisible until .tcc-has-overflow is added */
#tcc-app .tcc-scroll-fade {
  position: absolute !important;
  top: 0 !important;
  right: 0 !important;
  width: 80px !important;
  height: 100% !important;
  background: linear-gradient(
    to right,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,0.97) 100%
  ) !important;
  pointer-events: none !important;
  opacity: 0 !important;
  transition: opacity 0.3s ease !important;
  z-index: 2 !important;
  border-radius: 0 !important;
}

/* ❯ arrow — real element positioned by JS at row 2–3 level */
#tcc-app .tcc-scroll-arrow {
  position: absolute !important;
  right: 8px !important;
  top: 60px !important;         /* JS overrides this to the 2nd-3rd row midpoint */
  width: 38px !important;
  height: 38px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 30px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  color: #3B6FFF !important;
  pointer-events: none !important;
  opacity: 0 !important;
  transition: opacity 0.3s ease !important;
  z-index: 3 !important;
  user-select: none !important;
  -webkit-user-select: none !important;
}

/* Both fade and arrow become visible when overflow detected */
#tcc-app .tcc-table-outer.tcc-has-overflow .tcc-scroll-fade,
#tcc-app .tcc-table-outer.tcc-has-overflow .tcc-scroll-arrow {
  opacity: 1 !important;
}

/* Nudge animation fires 3× on first appearance */
#tcc-app .tcc-table-outer.tcc-has-overflow .tcc-scroll-arrow {
  animation: tcc-nudge 1.8s ease-in-out 0.4s 3 !important;
  -webkit-animation: tcc-nudge 1.8s ease-in-out 0.4s 3 !important;
}

@keyframes tcc-nudge {
  0%, 100% { transform: translateX(0); }
  50%       { transform: translateX(6px); }
}
@-webkit-keyframes tcc-nudge {
  0%, 100% { -webkit-transform: translateX(0); }
  50%       { -webkit-transform: translateX(6px); }
}

/* "scroll to see more →" text below the table */
#tcc-app .tcc-scroll-text {
  font-size: 11.5px !important;
  color: #8B91A8 !important;
  text-align: right !important;
  font-style: italic !important;
  margin: 0 !important;
  padding: 6px 14px 10px !important;
  background: none !important;
  border: none !important;
  max-height: 0 !important;
  overflow: hidden !important;
  opacity: 0 !important;
  transition: max-height 0.3s ease, opacity 0.3s ease !important;
}

#tcc-app .tcc-scroll-text.tcc-scroll-text-show {
  max-height: 36px !important;
  opacity: 1 !important;
}
