/* Too Spicy Rescue Tool — front-end styles. All rules scoped under .tsr. */
.tsr * { box-sizing: border-box; margin: 0; padding: 0; }
.tsr {
  --paper: #FBF3E6;
  --paper-2: #F4E7D2;
  --ink: #2A2018;
  --ink-soft: #6B5C4B;
  --line: #E2D2B8;
  --hot: #D43A26;
  --hot-deep: #A82817;
  --ember: #E8852B;
  --cool: #1C8C86;
  --cool-deep: #136661;
  --cool-soft: #E2F0EE;
  --shadow: 0 1px 2px rgba(42,32,24,.06), 0 8px 24px rgba(42,32,24,.08);
  font-family: 'Hanken Grotesk', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color: var(--ink);
  background: var(--paper);
  max-width: 740px;
  margin: 0 auto;
  padding: clamp(20px, 4vw, 34px);
  border-radius: 18px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
.tsr-seed { display: none !important; }
.tsr .tsr-noscript { color: var(--ink-soft); font-size: 14px; margin: 0; }

.tsr .head { margin-bottom: 26px; }
.tsr .kicker {
  font-size: 12px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  color: var(--hot); display: inline-flex; align-items: center; gap: 7px; margin-bottom: 10px;
}
.tsr .kicker::before { content: ""; width: 22px; height: 2px; background: var(--hot); display: inline-block; }
.tsr h1 {
  font-family: 'Fraunces', Georgia, 'Times New Roman', serif; font-weight: 600;
  font-size: clamp(28px, 5.5vw, 40px); line-height: 1.04; letter-spacing: -.01em;
  color: var(--ink); margin: 0;
}
.tsr h1 em { font-style: italic; color: var(--hot); }
.tsr .sub { color: var(--ink-soft); font-size: 15px; margin-top: 9px; max-width: 52ch; }

.tsr .step { margin-bottom: 22px; }
.tsr .step-label {
  font-family: 'Fraunces', Georgia, serif; font-size: 18px; font-weight: 600; margin-bottom: 11px;
  display: flex; align-items: baseline; gap: 9px; color: var(--ink);
}
.tsr .step-num {
  font-family: 'Hanken Grotesk', sans-serif; font-size: 12px; font-weight: 700;
  background: var(--ink); color: var(--paper); width: 22px; height: 22px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center; flex: none;
}
.tsr .hint { font-size: 13px; color: var(--ink-soft); font-weight: 400; }

.tsr .grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 8px; }
.tsr .opt {
  border: 1.5px solid var(--line); background: #fff; border-radius: 11px;
  padding: 11px 12px; cursor: pointer; font: inherit; font-size: 14px; font-weight: 500;
  color: var(--ink); text-align: left; display: flex; align-items: center; gap: 9px;
  transition: border-color .15s, background .15s, transform .08s; user-select: none;
  -webkit-appearance: none; appearance: none; line-height: 1.3;
}
.tsr .opt:hover { border-color: var(--ember); }
.tsr .opt:active { transform: scale(.98); }
.tsr .opt .em { font-size: 18px; line-height: 1; flex: none; }
.tsr .opt.on { border-color: var(--hot); background: #fff; box-shadow: inset 0 0 0 1px var(--hot); }
.tsr .opt.on.chip { border-color: var(--cool); box-shadow: inset 0 0 0 1px var(--cool); background: var(--cool-soft); }

.tsr .seg { display: flex; gap: 8px; flex-wrap: wrap; }
.tsr .seg .opt { flex: 1; min-width: 130px; flex-direction: column; align-items: flex-start; gap: 3px; }
.tsr .seg .opt .t { font-weight: 600; }
.tsr .seg .opt .d { font-size: 12px; color: var(--ink-soft); font-weight: 400; }
.tsr .seg .opt.on .d { color: var(--hot-deep); }

.tsr .chips { display: flex; flex-wrap: wrap; gap: 8px; }
.tsr .chips .opt { flex: 0 0 auto; }

.tsr .go {
  margin-top: 4px; width: 100%; border: none; cursor: pointer; font: inherit;
  font-weight: 700; font-size: 16px; color: #fff; padding: 15px; border-radius: 12px;
  background: linear-gradient(135deg, var(--hot) 0%, var(--hot-deep) 100%);
  box-shadow: var(--shadow); transition: transform .08s, filter .15s; letter-spacing: .01em;
  -webkit-appearance: none; appearance: none;
}
.tsr .go:hover { filter: brightness(1.05); }
.tsr .go:active { transform: scale(.99); }

.tsr .results { margin-top: 28px; display: none; }
.tsr .results.show { display: block; animation: tsr-rise .4s ease; }
@keyframes tsr-rise { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }

.tsr .gauge { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 18px 18px 16px; margin-bottom: 22px; box-shadow: var(--shadow); }
.tsr .gauge .g-top { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 12px; gap: 12px; }
.tsr .gauge .g-title { font-family: 'Fraunces', Georgia, serif; font-weight: 600; font-size: 16px; }
.tsr .gauge .g-note { font-size: 12px; color: var(--ink-soft); text-align: right; }
.tsr .bar { height: 14px; border-radius: 8px; background: var(--paper-2); position: relative; overflow: hidden; }
.tsr .bar .fill { position: absolute; inset: 0; width: 0; border-radius: 8px; transition: width .9s cubic-bezier(.4,0,.2,1); background: linear-gradient(90deg, var(--cool) 0%, var(--ember) 70%, var(--hot) 100%); }
.tsr .bar .marker { position: absolute; top: -4px; height: 22px; width: 2px; background: var(--ink); transition: left .9s cubic-bezier(.4,0,.2,1); }
.tsr .bar .marker::after { content: attr(data-l); position: absolute; top: 24px; left: 50%; transform: translateX(-50%); font-size: 10px; font-weight: 700; white-space: nowrap; color: var(--ink); }
.tsr .gauge .scale { display: flex; justify-content: space-between; font-size: 11px; color: var(--ink-soft); margin-top: 26px; gap: 8px; }
.tsr .gauge .scale span:nth-child(2) { text-align: center; }

.tsr .res-head { font-family: 'Fraunces', Georgia, serif; font-size: 13px; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; color: var(--ink-soft); margin: 22px 0 12px; display: flex; align-items: center; gap: 8px; }
.tsr .res-head::after { content: ""; flex: 1; height: 1px; background: var(--line); }

.tsr .fix { border: 1px solid var(--line); border-left: 4px solid var(--cool); background: #fff; border-radius: 12px; padding: 15px 17px; margin-bottom: 11px; box-shadow: var(--shadow); }
.tsr .fix.extra { border-left-color: var(--line); opacity: .92; }
.tsr .fix.split { border-left-color: var(--hot); background: linear-gradient(180deg,#fff,#FEF6F3); }
.tsr .fix .f-top { display: flex; align-items: center; gap: 10px; margin-bottom: 7px; flex-wrap: wrap; }
.tsr .fix .f-rank { font-family: 'Fraunces', Georgia, serif; font-weight: 700; font-size: 19px; color: var(--cool-deep); flex: none; }
.tsr .fix.split .f-rank { color: var(--hot-deep); }
.tsr .fix .f-name { font-family: 'Fraunces', Georgia, serif; font-weight: 600; font-size: 18px; }
.tsr .fix .badge { font-size: 10px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; padding: 3px 8px; border-radius: 20px; background: var(--cool-soft); color: var(--cool-deep); }
.tsr .fix.split .badge { background: #FBE3DD; color: var(--hot-deep); }
.tsr .fix .have { font-size: 12px; color: var(--ink-soft); margin-left: auto; }
.tsr .fix .have b { color: var(--ink); font-weight: 600; }
.tsr .fix .f-how { font-size: 14.5px; margin-bottom: 7px; }
.tsr .fix .f-why { font-size: 13px; color: var(--ink-soft); border-top: 1px dashed var(--line); padding-top: 7px; }
.tsr .fix .f-why b { color: var(--cool-deep); font-weight: 600; }

.tsr .ceiling { background: var(--paper-2); border-radius: 11px; padding: 13px 15px; font-size: 13.5px; color: var(--ink); margin-bottom: 16px; }
.tsr .ceiling b { color: var(--hot-deep); }
.tsr .reset { margin-top: 8px; background: none; border: none; color: var(--ink-soft); font: inherit; font-size: 13px; cursor: pointer; text-decoration: underline; padding: 6px 0; }
.tsr .empty { font-size: 14px; color: var(--ink-soft); padding: 10px 0; }
