:root {
  --yellow: #FFD60A;
  --yellow-shade: #F5C800;
  --pink: #FF3FA4;
  --pink-dark: #D81F84;
  --white: #FFFFFF;
  --ink: #1A1A1A;
  --ink-soft: #4A4A4A;
  --shadow: 0 6px 0 rgba(26, 26, 26, 0.18);
  --radius: 14px;
  --container: 1100px;
  --font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

* { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }

body {
  background: var(--yellow);
  color: var(--ink);
  font-family: var(--font);
  font-size: 18px;
  line-height: 1.55;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

a { color: var(--pink-dark); text-decoration: underline; text-decoration-thickness: 2px; text-underline-offset: 3px; }
a:hover { color: var(--ink); }

img { max-width: 100%; display: block; }

button { font: inherit; cursor: pointer; }

/* ---------- header / nav ---------- */

.site-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
  padding: 1.25rem 1.5rem;
  max-width: var(--container);
  margin: 0 auto;
  width: 100%;
}

.brand {
  font-family: "Impact", "Arial Black", sans-serif;
  font-size: clamp(2rem, 6vw, 3.25rem);
  letter-spacing: -1px;
  line-height: 1;
  text-decoration: none;
  display: inline-flex;
  gap: 0.4rem;
  text-transform: uppercase;
}

.brand-cozza, .brand-candy {
  color: var(--pink);
  -webkit-text-stroke: 2px var(--white);
  paint-order: stroke fill;
  text-shadow: 3px 3px 0 var(--ink);
}

.site-nav {
  display: flex;
  gap: 1.25rem;
  font-weight: 600;
}
.site-nav a {
  color: var(--ink);
  text-decoration: none;
  padding: 0.4rem 0.6rem;
  border-radius: 6px;
}
.site-nav a:hover {
  background: var(--white);
  color: var(--pink-dark);
}

/* ---------- main ---------- */

.site-main {
  flex: 1;
  max-width: var(--container);
  width: 100%;
  margin: 0 auto;
  padding: 1rem 1.5rem 3rem;
}

/* ---------- hero ---------- */

.hero {
  text-align: center;
  padding: 2.5rem 1rem 2rem;
}

.hero-title {
  font-family: "Impact", "Arial Black", sans-serif;
  font-size: clamp(2.5rem, 8vw, 5rem);
  line-height: 1;
  margin: 0 0 1rem;
  color: var(--pink);
  -webkit-text-stroke: 3px var(--white);
  paint-order: stroke fill;
  text-shadow: 4px 4px 0 var(--ink);
  text-transform: uppercase;
  letter-spacing: -1px;
}

.hero-tag {
  font-size: clamp(1.1rem, 2.5vw, 1.4rem);
  font-weight: 600;
  margin: 0 0 1.75rem;
  color: var(--ink);
}

.cta {
  display: inline-block;
  background: var(--pink);
  color: var(--white);
  padding: 0.85rem 1.5rem;
  font-weight: 700;
  font-size: 1.1rem;
  border-radius: var(--radius);
  text-decoration: none;
  border: 3px solid var(--ink);
  box-shadow: var(--shadow);
  transition: transform 0.05s ease, box-shadow 0.05s ease;
}
.cta:hover {
  background: var(--pink-dark);
  color: var(--white);
}
.cta:active {
  transform: translateY(3px);
  box-shadow: 0 3px 0 rgba(26, 26, 26, 0.18);
}

/* ---------- pages ---------- */

.page h1, .featured h2 {
  font-family: "Impact", "Arial Black", sans-serif;
  font-size: clamp(2rem, 5vw, 3rem);
  letter-spacing: -1px;
  margin: 1rem 0 0.5rem;
  color: var(--pink);
  -webkit-text-stroke: 2px var(--white);
  paint-order: stroke fill;
  text-shadow: 3px 3px 0 var(--ink);
  text-transform: uppercase;
}

.lede {
  max-width: 60ch;
  font-size: 1.1rem;
  margin: 0 0 1.75rem;
}

/* ---------- card grid ---------- */

.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1.25rem;
  margin: 1.25rem 0;
}

.card {
  background: var(--white);
  border: 3px solid var(--ink);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: transform 0.1s ease;
}
.card:hover { transform: translateY(-2px); }

.card-out { opacity: 0.6; filter: saturate(0.5); }

.card-image {
  aspect-ratio: 4 / 3;
  background: var(--yellow-shade) center/cover no-repeat;
  border-bottom: 3px solid var(--ink);
}

.card-body {
  padding: 1rem 1.1rem 1.1rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.card-body h3 {
  margin: 0;
  font-size: 1.25rem;
  color: var(--pink-dark);
}

.card-body p {
  margin: 0;
  color: var(--ink-soft);
}

.card-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: auto;
  padding-top: 0.75rem;
}

.price {
  font-weight: 800;
  font-size: 1.2rem;
  color: var(--ink);
}

.pill {
  font-size: 0.85rem;
  font-weight: 700;
  padding: 0.25rem 0.6rem;
  border-radius: 999px;
  border: 2px solid var(--ink);
}
.pill-in { background: var(--pink); color: var(--white); }
.pill-out { background: var(--white); color: var(--ink); }

.see-all {
  margin-top: 1.5rem;
  text-align: center;
  font-weight: 700;
}

/* ---------- about ---------- */

.about p { max-width: 64ch; margin: 0 0 1rem; }
.about .contact { margin-top: 1.5rem; font-weight: 700; }

/* ---------- admin ---------- */

.admin .stock-list {
  list-style: none;
  padding: 0;
  margin: 1rem 0 1.5rem;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 0.75rem;
}
.admin .stock-list li {
  background: var(--white);
  border: 3px solid var(--ink);
  border-radius: var(--radius);
  padding: 0.85rem 1rem;
}
.admin .stock-list label {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  cursor: pointer;
  font-weight: 600;
}
.admin .stock-list input[type="checkbox"] {
  width: 1.25rem;
  height: 1.25rem;
  accent-color: var(--pink);
}
.admin button {
  background: var(--pink);
  color: var(--white);
  border: 3px solid var(--ink);
  border-radius: var(--radius);
  padding: 0.85rem 1.5rem;
  font-weight: 700;
  font-size: 1.1rem;
  box-shadow: var(--shadow);
}
.admin .flash {
  background: var(--white);
  border: 3px solid var(--ink);
  border-radius: var(--radius);
  padding: 0.75rem 1rem;
  font-weight: 600;
  color: var(--pink-dark);
}

/* ---------- footer ---------- */

.site-footer {
  background: var(--pink);
  color: var(--white);
  border-top: 3px solid var(--ink);
  text-align: center;
  padding: 1.25rem 1rem;
  font-weight: 600;
}
.site-footer a {
  color: var(--white);
  text-decoration: underline;
}

/* ---------- 404 ---------- */

.notfound { text-align: center; padding: 3rem 1rem; }

@media (max-width: 480px) {
  .site-header { padding: 1rem; }
  .site-nav { gap: 0.5rem; }
  .site-main { padding: 0.5rem 1rem 2rem; }
}
