:root {
  --cds-olive: #6f7759;
  --cds-matcha: #95a07a;
  --cds-oat: #f3eee6;
  --cds-cream: #f8f4ee;
  --cds-taupe: #c5af97;
  --cds-espresso: #8c7866;
  --cds-ink: #2f3428;
}

.cds-public-recipe-book {
  display: grid;
  gap: clamp(1rem, 2vw, 1.5rem);
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  margin: clamp(2rem, 4vw, 4rem) auto;
}

.cds-public-card {
  background:
    linear-gradient(145deg, rgba(248,244,238,0.86), rgba(243,238,230,0.68)),
    radial-gradient(circle at top left, rgba(255,255,255,0.55), transparent 18rem);
  border: 1px solid rgba(140,120,102,0.22);
  border-radius: 28px;
  box-shadow: 0 24px 70px rgba(47,52,40,0.10);
  overflow: hidden;
  padding: 1rem;
}

.cds-public-image {
  align-items: center;
  aspect-ratio: 4 / 3;
  background: rgba(248,244,238,.85);
  border-radius: 22px;
  display: flex;
  justify-content: center;
  overflow: hidden;
}

.cds-public-image img { height: 100%; object-fit: cover; width: 100%; }
.cds-public-image-placeholder span { color: var(--cds-olive); font-family: Georgia, serif; font-size: 4rem; }
.cds-public-kicker { color: var(--cds-espresso); font-size: .72rem; font-weight: 900; letter-spacing: .14em; margin: 1rem 0 .35rem; text-transform: uppercase; }
.cds-public-card h3 { color: var(--cds-olive); font-family: Georgia, serif; font-size: clamp(1.5rem, 3vw, 2.2rem); margin: 0 0 .5rem; }
.cds-public-empty { background: rgba(248,244,238,.8); border: 1px solid rgba(140,120,102,.22); border-radius: 22px; padding: 1.25rem; }


/* v1.0.1 — public contrast polish. */
.cds-public-recipe-book,
.cds-public-card,
.cds-public-card p,
.cds-public-empty {
  color: var(--cds-ink);
}

.cds-public-card p {
  color: rgba(47, 52, 40, 0.84);
}

.cds-public-card h3 {
  color: #566246;
}

.cds-public-kicker {
  color: #604f42;
}


/* v1.2.0 — public drink tasting panel. */
.cds-tasting-panel {
  color: var(--cds-ink);
  margin: clamp(1.5rem, 4vw, 3rem) auto;
}

.cds-tasting-intro {
  background:
    linear-gradient(145deg, rgba(248,244,238,.92), rgba(243,238,230,.72)),
    radial-gradient(circle at 92% 0%, rgba(149,160,122,.18), transparent 18rem);
  border: 1px solid rgba(140,120,102,.22);
  border-radius: 30px;
  box-shadow: 0 24px 70px rgba(47,52,40,.10);
  margin: 0 0 1.25rem;
  padding: clamp(1.2rem, 3vw, 2rem);
}

.cds-tasting-intro h2 {
  color: #566246;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(2rem, 4vw, 3.4rem);
  font-weight: 500;
  letter-spacing: .025em;
  line-height: 1.03;
  margin: .2rem 0 .7rem;
}

.cds-tasting-grid {
  display: grid;
  gap: clamp(1rem, 2.2vw, 1.5rem);
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.cds-tasting-card {
  background:
    linear-gradient(145deg, rgba(248,244,238,.88), rgba(243,238,230,.68)),
    radial-gradient(circle at top left, rgba(255,255,255,.52), transparent 18rem);
  border: 1px solid rgba(140,120,102,.22);
  border-radius: 30px;
  box-shadow: 0 24px 70px rgba(47,52,40,.10);
  overflow: hidden;
  padding: 1rem;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.cds-tasting-card:hover {
  border-color: rgba(111,119,89,.34);
  box-shadow: 0 30px 90px rgba(47,52,40,.14);
  transform: translateY(-3px);
}

.cds-tasting-card-body {
  padding: .25rem .2rem .4rem;
}

.cds-rating-summary {
  align-items: center;
  background: rgba(255,255,255,.42);
  border: 1px solid rgba(140,120,102,.20);
  border-radius: 18px;
  display: flex;
  gap: .85rem;
  justify-content: space-between;
  margin: 1rem 0;
  padding: .85rem 1rem;
}

.cds-rating-summary strong {
  color: #566246;
  font-family: Georgia, serif;
  font-size: 1.35rem;
  font-weight: 500;
}

.cds-rating-summary span {
  color: rgba(47,52,40,.72);
  font-size: .9rem;
}

.cds-rating-details {
  border-top: 1px solid rgba(140,120,102,.18);
  padding-top: .85rem;
}

.cds-rating-details summary {
  align-items: center;
  background: linear-gradient(135deg, #6f7759, #566246);
  border-radius: 999px;
  box-shadow: 0 14px 34px rgba(47,52,40,.16);
  color: #fffaf3;
  cursor: pointer;
  display: inline-flex;
  font-size: .78rem;
  font-weight: 900;
  gap: .4rem;
  letter-spacing: .12em;
  list-style: none;
  padding: .78rem 1.05rem;
  text-transform: uppercase;
  transition: transform .2s ease, box-shadow .2s ease;
}

.cds-rating-details summary:hover {
  box-shadow: 0 18px 44px rgba(47,52,40,.2);
  transform: translateY(-1px);
}

.cds-rating-details summary::-webkit-details-marker {
  display: none;
}

.cds-public-rating-form {
  display: grid;
  gap: .95rem;
  margin-top: 1rem;
}

.cds-public-rating-form label,
.cds-public-rating-form fieldset {
  background: rgba(255,255,255,.36);
  border: 1px solid rgba(140,120,102,.20);
  border-radius: 18px;
  color: var(--cds-ink);
  display: grid;
  font-size: .92rem;
  gap: .45rem;
  margin: 0;
  padding: .85rem;
}

.cds-public-rating-form input[type="text"],
.cds-public-rating-form select,
.cds-public-rating-form textarea {
  background: rgba(248,244,238,.96);
  border: 1px solid rgba(140,120,102,.28);
  border-radius: 14px;
  color: var(--cds-ink);
  font: inherit;
  padding: .78rem .85rem;
  width: 100%;
}

.cds-public-rating-form input:focus,
.cds-public-rating-form select:focus,
.cds-public-rating-form textarea:focus {
  border-color: rgba(111,119,89,.62);
  box-shadow: 0 0 0 4px rgba(111,119,89,.12);
  outline: none;
}

.cds-star-field legend {
  color: #604f42;
  font-size: .76rem;
  font-weight: 900;
  letter-spacing: .12em;
  margin-bottom: .4rem;
  text-transform: uppercase;
}

.cds-star-field legend span {
  color: #6f7759;
  font-size: .68rem;
}

.cds-star-options {
  display: flex;
  flex-direction: row-reverse;
  flex-wrap: wrap;
  gap: .45rem;
  justify-content: flex-end;
}

.cds-star-options label {
  background: transparent;
  border: 0;
  display: inline-flex;
  padding: 0;
}

.cds-star-options input {
  inline-size: 1px;
  opacity: 0;
  position: absolute;
}

.cds-star-options span {
  background: rgba(248,244,238,.85);
  border: 1px solid rgba(111,119,89,.24);
  border-radius: 999px;
  color: #6f7759;
  cursor: pointer;
  display: inline-flex;
  font-size: .85rem;
  font-weight: 900;
  letter-spacing: .04em;
  padding: .45rem .66rem;
  transition: transform .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease;
}

.cds-star-options input:checked + span,
.cds-star-options label:hover span {
  background: linear-gradient(135deg, #95a07a, #c5af97);
  box-shadow: 0 10px 24px rgba(47,52,40,.14);
  color: #fffaf3;
  transform: translateY(-1px);
}

.cds-public-consent {
  align-items: start;
  display: flex !important;
  grid-template-columns: none !important;
}

.cds-public-consent input {
  accent-color: #6f7759;
  height: 1.1rem;
  margin-top: .15rem;
  width: 1.1rem;
}

.cds-consent-help {
  color: #604f42;
  font-size: .9rem;
  margin: -.45rem 0 0;
}

.cds-public-submit {
  background: linear-gradient(135deg, #6f7759, #566246);
  border: 0;
  border-radius: 999px;
  box-shadow: 0 16px 38px rgba(47,52,40,.18);
  color: #fffaf3;
  cursor: pointer;
  font-size: .8rem;
  font-weight: 900;
  letter-spacing: .13em;
  overflow: hidden;
  padding: .95rem 1.2rem;
  position: relative;
  text-transform: uppercase;
  transition: transform .2s ease, box-shadow .2s ease;
}

.cds-public-submit:hover {
  box-shadow: 0 20px 48px rgba(47,52,40,.22);
  transform: translateY(-2px);
}

.cds-public-submit::after {
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.36), transparent);
  content: "";
  inset: 0;
  position: absolute;
  transform: translateX(-120%);
  transition: transform .55s ease;
}

.cds-public-submit:hover::after {
  transform: translateX(120%);
}

.cds-hp {
  display: none !important;
}

.cds-public-notice {
  border-radius: 20px;
  font-weight: 800;
  margin: 0 0 1rem;
  padding: .95rem 1.1rem;
}

.cds-public-notice-success {
  background: rgba(149,160,122,.18);
  border: 1px solid rgba(111,119,89,.28);
  color: #566246;
}

.cds-public-notice-error {
  background: rgba(201,124,124,.14);
  border: 1px solid rgba(201,124,124,.28);
  color: #7b4545;
}

@media (max-width: 680px) {
  .cds-tasting-grid {
    grid-template-columns: 1fr;
  }

  .cds-star-options {
    justify-content: flex-start;
  }

  .cds-rating-summary {
    align-items: flex-start;
    flex-direction: column;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cds-tasting-card,
  .cds-rating-details summary,
  .cds-public-submit,
  .cds-public-submit::after {
    transition: none !important;
  }
}


/* v1.2.1 — smaller mobile-first tasting layout and latte-art placeholders. */
.cds-public-recipe-book {
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.cds-public-card {
  border-radius: 24px;
  padding: .9rem;
}

.cds-public-card h3 {
  font-size: clamp(1.2rem, 2.5vw, 1.75rem);
  line-height: 1.08;
}

.cds-public-image-placeholder {
  background:
    radial-gradient(circle at 30% 22%, rgba(255,255,255,.92), rgba(243,238,230,.78)),
    linear-gradient(145deg, rgba(248,244,238,.86), rgba(243,238,230,.7));
}

.cds-public-image-placeholder img {
  border-radius: 999px;
  box-shadow: 0 12px 28px rgba(47,52,40,.12);
  height: 68%;
  object-fit: cover;
  width: 68%;
}

.cds-tasting-intro {
  border-radius: 24px;
  padding: clamp(1rem, 2.4vw, 1.5rem);
}

.cds-tasting-intro h2 {
  font-size: clamp(1.6rem, 3.2vw, 2.7rem);
  line-height: 0.98;
  max-width: 12ch;
}

.cds-tasting-intro p {
  font-size: .98rem;
  max-width: 54ch;
}

.cds-tasting-grid {
  gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
}

.cds-tasting-card {
  border-radius: 24px;
  padding: .85rem;
}

.cds-tasting-card .cds-public-image {
  aspect-ratio: 1 / 1;
  border-radius: 20px;
}

.cds-tasting-card h3 {
  color: #566246;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.3rem, 2.2vw, 1.8rem);
  line-height: 1.02;
  margin: 0 0 .45rem;
}

.cds-tasting-card p {
  font-size: .95rem;
}

.cds-rating-summary {
  border-radius: 16px;
  margin: .85rem 0;
  padding: .75rem .9rem;
}

.cds-rating-summary strong {
  font-size: 1.15rem;
}

@media (max-width: 900px) {
  .cds-tasting-intro h2 {
    max-width: none;
  }
}

@media (max-width: 680px) {
  .cds-tasting-panel {
    margin: 1rem auto;
  }

  .cds-tasting-intro {
    border-radius: 22px;
    margin-bottom: 1rem;
    padding: 1rem;
  }

  .cds-tasting-intro h2 {
    font-size: clamp(1.45rem, 8vw, 2rem);
    line-height: 1.02;
    margin-bottom: .55rem;
  }

  .cds-tasting-intro p {
    font-size: .94rem;
  }

  .cds-tasting-grid {
    gap: .9rem;
    grid-template-columns: 1fr;
  }

  .cds-tasting-card {
    border-radius: 22px;
    padding: .8rem;
  }

  .cds-tasting-card .cds-public-image {
    aspect-ratio: 4 / 3;
  }

  .cds-tasting-card h3,
  .cds-public-card h3 {
    font-size: 1.3rem;
    line-height: 1.06;
  }

  .cds-rating-summary {
    align-items: flex-start;
    flex-direction: column;
    gap: .25rem;
  }

  .cds-rating-details summary,
  .cds-public-submit {
    width: 100%;
    justify-content: center;
  }

  .cds-public-rating-form label,
  .cds-public-rating-form fieldset {
    border-radius: 16px;
    font-size: .9rem;
    padding: .8rem;
  }

  .cds-star-options {
    gap: .35rem;
    justify-content: flex-start;
  }

  .cds-star-options span {
    font-size: .78rem;
    padding: .4rem .54rem;
  }
}
