* { box-sizing: border-box; }

::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-thumb { background: #f0b9d3; border-radius: 99px; }

body {
  margin: 0;
  background: #fff0f6;
  font-family: 'Quicksand', sans-serif;
  color: #4a2338;
}

.site-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 22px 36px;
  max-width: 900px;
  margin: 0 auto;
}

.logo {
  font-family: 'Pacifico', cursive;
  font-size: 28px;
  color: #e02f80;
}

.site-header nav {
  display: flex;
  gap: 20px;
  font-family: 'Fredoka', sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: #a8557d;
}

.site-header nav a {
  color: inherit;
  text-decoration: none;
}

.site-header nav a.custom-link,
.site-header nav a:hover {
  color: #ff4d97;
}

main {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 24px 80px;
}

.hero h1 {
  font-family: 'Fredoka', sans-serif;
  font-weight: 700;
  font-size: 42px;
  line-height: 1.1;
  color: #4a2338;
  margin: 8px 0 6px;
}

.hero p {
  font-size: 16px;
  color: #a86b86;
  font-weight: 600;
  margin: 0 0 32px;
}

.grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 20px;
  margin-bottom: 36px;
}

.card {
  cursor: pointer;
  background: #fff;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid #ffd6e8;
  box-shadow: 0 8px 18px -10px rgba(224, 47, 128, 0.4);
  transition: all .18s;
}

.card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 30px -12px rgba(224, 47, 128, 0.55);
}

.card-image {
  position: relative;
  height: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: repeating-linear-gradient(45deg, #ffc2dd, #ffc2dd 11px, #ffd9ea 11px, #ffd9ea 22px);
}

.card-coming-soon {
  position: relative;
  cursor: default;
}

.card-coming-soon:hover {
  transform: none;
  box-shadow: 0 8px 18px -10px rgba(224, 47, 128, 0.4);
}

.card-coming-soon .card-image {
  background: repeating-linear-gradient(45deg, #ffd6e8, #ffd6e8 11px, #ffe9f2 11px, #ffe9f2 22px);
}

.coming-soon-body {
  padding: 18px 15px 20px;
  text-align: center;
}

.coming-soon-text {
  font-family: 'Fredoka', sans-serif;
  font-weight: 700;
  font-size: 15px;
  color: #c74e8a;
}

.tape-ribbon {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 135%;
  transform: translate(-50%, -50%) rotate(-8deg);
  background: repeating-linear-gradient(45deg, #ffd400, #ffd400 14px, #1a1a1a 14px, #1a1a1a 28px);
  border-top: 2px solid #1a1a1a;
  border-bottom: 2px solid #1a1a1a;
  text-align: center;
  padding: 9px 0;
  box-shadow: 0 6px 14px -4px rgba(0, 0, 0, 0.45);
}

.tape-ribbon span {
  display: inline-block;
  background: #ffd400;
  color: #1a1a1a;
  font-family: 'Fredoka', sans-serif;
  font-weight: 800;
  font-size: 13px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 3px;
}

.card-image span {
  font-family: 'Courier New', monospace;
  font-size: 10px;
  letter-spacing: 1px;
  color: #c74e8a;
  background: rgba(255, 255, 255, .7);
  padding: 3px 8px;
  border-radius: 99px;
}

.card-body {
  padding: 14px 15px 16px;
}

.card-name {
  font-family: 'Fredoka', sans-serif;
  font-weight: 600;
  font-size: 15px;
  color: #4a2338;
  line-height: 1.15;
}

.card-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 8px;
}

.card-cat {
  font-size: 11px;
  font-weight: 700;
  color: #c88;
  text-transform: uppercase;
  letter-spacing: .5px;
}

.card-price {
  font-family: 'Fredoka', sans-serif;
  font-weight: 700;
  font-size: 14px;
  color: #ff4d97;
}

.cta-banner {
  display: block;
  margin: 0 0 40px;
  padding: 28px 24px;
  border-radius: 22px;
  background: linear-gradient(135deg, #ff7ab5, #ff4d97);
  text-align: center;
  text-decoration: none;
}

.cta-title {
  font-family: 'Fredoka', sans-serif;
  font-weight: 700;
  font-size: 20px;
  color: #fff;
}

.cta-sub {
  font-size: 14px;
  color: #ffe0ee;
  font-weight: 600;
  margin-top: 6px;
}

.about {
  padding: 8px 0 20px;
}

.about h2 {
  font-family: 'Fredoka', sans-serif;
  color: #4a2338;
}

.about-content {
  display: flex;
  align-items: center;
  gap: 28px;
  flex-wrap: wrap;
}

.about-photo {
  width: 180px;
  height: 180px;
  object-fit: cover;
  border-radius: 50%;
  border: 4px solid #ffd6e8;
  box-shadow: 0 10px 24px -10px rgba(224, 47, 128, 0.45);
  flex-shrink: 0;
}

.about p {
  color: #7a5266;
  line-height: 1.6;
  font-size: 15px;
  flex: 1;
  min-width: 240px;
}

.tipjar {
  padding: 8px 0 30px;
}

.tipjar h2 {
  font-family: 'Fredoka', sans-serif;
  color: #4a2338;
}

.tipjar p {
  color: #7a5266;
  line-height: 1.6;
  font-size: 15px;
  max-width: 520px;
}

.tip-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 18px;
}

.tip-btn {
  border: none;
  background: #ffe1ee;
  color: #d9629a;
  font-family: 'Fredoka', sans-serif;
  font-weight: 700;
  font-size: 15px;
  padding: 12px 24px;
  border-radius: 999px;
  cursor: pointer;
  transition: all .15s;
}

.tip-btn:hover {
  background: linear-gradient(135deg, #ff7ab5, #ff4d97);
  color: #fff;
}

.tip-btn-custom {
  background: #fff;
  border: 2px solid #ffb4d5;
  color: #ff4d97;
}

/* Detail view */
#detail-view {
  padding-top: 8px;
}

.back-btn {
  border: none;
  background: #ffe1ee;
  color: #d9629a;
  font-family: 'Fredoka', sans-serif;
  font-weight: 600;
  font-size: 13px;
  padding: 9px 17px;
  border-radius: 999px;
  cursor: pointer;
  margin-bottom: 20px;
}

.detail-image {
  position: relative;
  height: 280px;
  border-radius: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: repeating-linear-gradient(45deg, #ffc2dd, #ffc2dd 14px, #ffd9ea 14px, #ffd9ea 28px);
}

.detail-image span {
  font-family: 'Courier New', monospace;
  font-size: 13px;
  letter-spacing: 1px;
  color: #c74e8a;
  background: rgba(255, 255, 255, .75);
  padding: 6px 14px;
  border-radius: 99px;
}

.detail-cat {
  font-size: 12px;
  font-weight: 700;
  color: #c88;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-top: 20px;
}

.detail-name {
  font-family: 'Fredoka', sans-serif;
  font-weight: 700;
  font-size: 32px;
  color: #4a2338;
  line-height: 1.1;
  margin: 4px 0 0;
}

.detail-price {
  font-family: 'Fredoka', sans-serif;
  font-weight: 700;
  font-size: 24px;
  color: #ff4d97;
  margin-top: 10px;
}

.detail-desc {
  font-size: 15.5px;
  line-height: 1.65;
  color: #7a5266;
  margin: 16px 0 0;
  max-width: 560px;
}

.made-with-label {
  font-family: 'Fredoka', sans-serif;
  font-weight: 600;
  font-size: 14px;
  color: #4a2338;
  margin: 22px 0 12px;
}

.ingredients {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
}

.ingredients span {
  background: #ffe1ee;
  color: #c74e8a;
  font-weight: 600;
  font-size: 12.5px;
  padding: 7px 14px;
  border-radius: 999px;
}

.order-btn {
  margin-top: 26px;
  width: 100%;
  max-width: 360px;
  display: block;
  border: none;
  background: linear-gradient(135deg, #ff7ab5, #ff4d97);
  color: #fff;
  font-family: 'Fredoka', sans-serif;
  font-weight: 700;
  font-size: 17px;
  padding: 16px;
  border-radius: 999px;
  cursor: pointer;
  box-shadow: 0 12px 24px -8px rgba(224, 47, 128, .6);
}

