/* StuffBlaster — pastel, bubbly, made for home shoppers hunting the best price. */

:root {
  --pink: #ffb3d1; --pink-2: #ff8fb8;
  --blue: #a8d8ff; --blue-2: #7ec4ff;
  --yellow: #ffe9a8; --green: #b8e6c8; --green-2: #8fd9ab;
  --purple: #d8c2ff; --purple-2: #bfa3ff;
  --ink: #4a4458; --ink-soft: #7c7490;
  --logo-stroke: #c6c1d4;
  --bg: #fff7fb; --card: #ffffff;
  --radius: 26px; --shadow: 0 10px 30px rgba(180, 140, 200, 0.18);
}
* { box-sizing: border-box; }
body {
  margin: 0; font-family: "Quicksand", system-ui, sans-serif; color: var(--ink);
  background:
    radial-gradient(1200px 500px at 10% -10%, var(--purple) 0%, transparent 55%),
    radial-gradient(1000px 460px at 100% 0%, var(--blue) 0%, transparent 50%),
    radial-gradient(900px 500px at 50% 120%, var(--pink) 0%, transparent 55%),
    var(--bg);
  min-height: 100vh;
}

.topbar { text-align: center; padding: 34px 16px 6px; }
.logo {
  position: relative;
  display: inline-block;
  font-family: "Fredoka", sans-serif; font-weight: 700; font-size: 2.6rem;
  line-height: 1; text-decoration: none; letter-spacing: -0.5px;
  /* continuous pink -> purple gradient across the whole wordmark (the front layer) */
  background: linear-gradient(95deg, var(--pink-2) 0%, var(--pink-2) 18%, var(--purple-2) 90%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
/* Outline lives on a stroked copy BEHIND the gradient text, so only the outer half of
   the stroke shows. The gradient fill covers every interior stroke — including the t/f
   crossbar intersections — instead of the stroke cutting straight through them. */
.logo::before {
  content: attr(data-text);
  position: absolute; left: 0; top: 0; z-index: -1;
  font: inherit; line-height: 1; letter-spacing: -0.5px;
  -webkit-text-fill-color: transparent;
  -webkit-text-stroke: 1.4px var(--logo-stroke);
}
.tagline { margin: 4px 0 0; color: var(--ink-soft); font-weight: 500; }

.wrap { max-width: 760px; margin: 0 auto; padding: 8px 18px 40px; }

/* search */
.search { display: flex; gap: 10px; margin: 22px 0 14px; }
.search-input {
  flex: 1; font-family: "Quicksand", sans-serif; font-size: 1.05rem; color: var(--ink);
  background: #fff; border: 3px solid var(--purple); border-radius: 999px;
  padding: 14px 22px; box-shadow: var(--shadow); outline: none;
}
.search-input:focus { border-color: var(--pink-2); }
.search-btn {
  font-family: "Fredoka", sans-serif; font-weight: 600; font-size: 1.05rem; color: #fff;
  background: var(--purple-2); border: none; border-radius: 999px; padding: 0 24px;
  cursor: pointer; box-shadow: var(--shadow); transition: transform .12s ease, background .12s ease;
}
.search-btn:hover { transform: translateY(-2px); background: var(--pink-2); }

.chips { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin: 6px 0 18px; }
.chip {
  font-family: "Fredoka", sans-serif; font-weight: 500; color: var(--ink); background: #fff;
  border: 2px solid var(--purple); padding: 6px 16px; border-radius: 999px; cursor: pointer;
  box-shadow: var(--shadow); transition: transform .12s ease, background .12s ease;
}
.chip:hover { transform: translateY(-2px) scale(1.04); background: var(--purple); }

.status { text-align: center; color: var(--ink-soft); font-weight: 500; margin: 6px 0 18px; }

/* result cards */
.results { display: flex; flex-direction: column; gap: 14px; }
.card { background: var(--card); border-radius: var(--radius); box-shadow: var(--shadow); padding: 18px 20px; border-left: 8px solid var(--blue); }
.card[style*="--c: 0"] { border-left-color: var(--pink); }
.card[style*="--c: 1"] { border-left-color: var(--blue); }
.card[style*="--c: 2"] { border-left-color: var(--yellow); }
.card[style*="--c: 3"] { border-left-color: var(--green); }
.card[style*="--c: 4"] { border-left-color: var(--purple); }

.card-top { display: flex; justify-content: space-between; align-items: flex-start; }
.brand { font-family: "Fredoka", sans-serif; font-weight: 600; font-size: 1.2rem; }
.ptitle { color: var(--ink-soft); font-size: .9rem; margin-top: 2px; }
.badge-generic, .badge-name { font-size: .65rem; font-weight: 700; padding: 3px 9px; border-radius: 999px; text-transform: uppercase; letter-spacing: .04em; vertical-align: middle; }
.badge-generic { background: var(--green); color: #2f6b48; }
.badge-name { background: var(--blue); color: #2b5e86; }

.best-line { display: flex; align-items: baseline; gap: 12px; margin-top: 12px; flex-wrap: wrap; }
.best { font-family: "Fredoka", sans-serif; font-weight: 700; font-size: 1.7rem; color: var(--green-2); }
.unit { color: var(--ink-soft); font-size: .9rem; }
.buy {
  margin-left: auto; font-family: "Fredoka", sans-serif; font-weight: 600; text-decoration: none;
  background: var(--pink-2); color: #fff; padding: 8px 20px; border-radius: 999px;
  transition: transform .12s ease, background .12s ease;
}
.buy:hover { transform: scale(1.06); background: var(--purple-2); }

.more { margin-top: 12px; }
.more-btn { font-family: "Quicksand", sans-serif; font-weight: 600; color: var(--purple-2); background: none; border: none; cursor: pointer; padding: 4px 0; }
.retailers { display: none; flex-direction: column; gap: 8px; margin-top: 10px; }
.retailers.open { display: flex; }
.retailer {
  display: grid; grid-template-columns: 30px 1fr auto; align-items: center; gap: 12px;
  text-decoration: none; color: var(--ink); background: #fff; border: 2px solid var(--blue);
  border-radius: 14px; padding: 10px 16px; transition: transform .1s ease;
}
.retailer:hover { transform: translateX(3px); }
.retailer.win { border-color: var(--green-2); background: #f3fbf6; }
.r-rank { font-family: "Fredoka", sans-serif; font-weight: 700; color: var(--purple-2); text-align: center; }
.r-name { font-weight: 600; }
.r-name em { color: var(--ink-soft); font-weight: 500; font-size: .85rem; }
.r-price { font-family: "Fredoka", sans-serif; font-weight: 700; color: var(--green-2); }
.r-price small { color: var(--ink-soft); font-weight: 500; }

.foot { text-align: center; color: var(--ink-soft); font-size: .85rem; padding: 30px 18px 50px; max-width: 640px; margin: 0 auto; }
.foot a { color: var(--purple-2); font-weight: 600; }
.disclosure { line-height: 1.5; }

@media (max-width: 520px) {
  .logo { font-size: 2.1rem; }
  .search { flex-direction: column; }
  .search-btn { padding: 12px; }
}
