/* Boccaccio Global Styles — v1.0 */
/* Palette */
:root {
  --bocc-white: #FFFFFF;
  --bocc-lgrey: #E6E6E1;
  --bocc-lbeige: #E6DCD3;
  --bocc-lgreige: #D4C5B8;
  --bocc-greige: #A6907C;
  --bocc-cappuccino: #795E44;
  --bocc-coffee: #3A2B1E;
  --bocc-wgrey: #4D4945;
  --bocc-black: #000000;
}

/* Typography defaults */
body {
  font-family: "Jost", -apple-system, sans-serif;
  font-weight: 300;
  color: var(--bocc-wgrey);
  line-height: 1.7;
}

h1, h2, h3, h4, h5, h6,
.wp-block-heading {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight: 300;
  letter-spacing: 0.04em;
  color: var(--bocc-coffee);
}

h1 { font-size: clamp(2rem, 4vw, 3rem); }
h2 { font-size: clamp(1.6rem, 3vw, 2.4rem); }
h3 { font-size: clamp(1.2rem, 2vw, 1.7rem); }

/* Links */
a { color: var(--bocc-cappuccino); text-decoration: none; }
a:hover { color: var(--bocc-coffee); }

/* Buttons - Boccaccio style */
.wp-block-button__link,
.wp-element-button {
  font-family: "Jost", sans-serif;
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-size: 0.78rem;
  background: var(--bocc-cappuccino);
  color: var(--bocc-white);
  border-radius: 0;
  padding: 0.9em 2.2em;
  transition: background 0.3s;
}
.wp-block-button__link:hover,
.wp-element-button:hover {
  background: var(--bocc-coffee);
  color: var(--bocc-white);
}

/* Outline button variant */
.wp-block-button.is-style-outline .wp-block-button__link {
  background: transparent;
  color: var(--bocc-cappuccino);
  border: 1px solid var(--bocc-greige);
}
.wp-block-button.is-style-outline .wp-block-button__link:hover {
  background: var(--bocc-cappuccino);
  color: var(--bocc-white);
}

/* Cover block overlay */
.wp-block-cover {
  min-height: 70vh;
}

/* Separator */
.wp-block-separator {
  border-color: var(--bocc-lgreige);
  opacity: 0.5;
}

/* Navigation */
.wp-block-navigation a {
  font-family: "Jost", sans-serif;
  font-weight: 400;
  font-size: 0.82rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--bocc-wgrey);
}
.wp-block-navigation a:hover {
  color: var(--bocc-cappuccino);
}

/* Smooth scroll */
html { scroll-behavior: smooth; }

/* Image treatments */
.wp-block-image img {
  border-radius: 0;
}

/* Blockquote */
blockquote, .wp-block-quote {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-style: italic;
  font-size: 1.2rem;
  border-left: 2px solid var(--bocc-greige);
  padding-left: 1.5rem;
  color: var(--bocc-cappuccino);
}

/* ============================================
   Gästebuch & Reviews — v2.0
   ============================================ */

/* Section wrapper */
.bocc-gastebuch-section {
  background: var(--bocc-lgrey);
  padding: 64px 24px;
}
.bocc-gastebuch-inner {
  max-width: 780px;
  margin: 0 auto;
}

/* Header */
.bocc-gastebuch-header {
  text-align: center;
  margin-bottom: 40px;
}
.bocc-gastebuch-header .bocc-label {
  font-family: "Jost", sans-serif;
  font-weight: 400;
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bocc-greige);
  margin-bottom: 8px;
}
.bocc-gastebuch-header h2 {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight: 300;
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  color: var(--bocc-coffee);
  margin: 0;
}

/* Review cards */
.bocc-reviews-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 8px;
}
.bocc-review-card {
  background: var(--bocc-white);
  padding: 20px 24px;
  border-left: 3px solid var(--bocc-lgreige);
  transition: border-color 0.3s;
}
.bocc-review-card:hover {
  border-left-color: var(--bocc-cappuccino);
}
.bocc-review-stars {
  margin-bottom: 8px;
  letter-spacing: 2px;
}
.bocc-star {
  color: var(--bocc-lgreige);
  font-size: 0.9rem;
}
.bocc-star.bocc-star-filled {
  color: var(--bocc-cappuccino);
}
.bocc-review-text {
  font-family: "Jost", sans-serif;
  font-weight: 300;
  font-size: 0.92rem;
  line-height: 1.6;
  color: var(--bocc-wgrey);
  margin: 0 0 8px;
}
.bocc-review-author {
  font-family: "Jost", sans-serif;
  font-size: 0.78rem;
  color: var(--bocc-greige);
  margin: 0;
}
.bocc-review-author strong {
  color: var(--bocc-cappuccino);
  font-weight: 500;
}

/* Hidden reviews (toggle) */
.bocc-review-hidden {
  display: none;
}
.bocc-review-hidden.bocc-review-show {
  display: block;
}

/* Toggle button */
.bocc-btn-outline {
  font-family: "Jost", sans-serif;
  font-weight: 400;
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  background: transparent;
  color: var(--bocc-cappuccino);
  border: 1px solid var(--bocc-greige);
  padding: 0.7em 2em;
  cursor: pointer;
  transition: all 0.3s;
}
.bocc-btn-outline:hover {
  background: var(--bocc-cappuccino);
  color: var(--bocc-white);
  border-color: var(--bocc-cappuccino);
}

/* Boccaccio primary button */
.bocc-btn {
  font-family: "Jost", sans-serif;
  font-weight: 400;
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  background: var(--bocc-cappuccino);
  color: var(--bocc-white);
  border: none;
  padding: 0.9em 2.5em;
  cursor: pointer;
  transition: background 0.3s;
}
.bocc-btn:hover {
  background: var(--bocc-coffee);
}
.bocc-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Form */
.bocc-gastebuch-form-wrap {
  background: var(--bocc-white);
  padding: 32px;
  margin-top: 32px;
  border-top: 3px solid var(--bocc-lgreige);
}
.bocc-gastebuch-form-wrap h3 {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight: 300;
  font-size: 1.3rem;
  color: var(--bocc-coffee);
}
.bocc-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 16px;
}
@media (max-width: 600px) {
  .bocc-form-row { grid-template-columns: 1fr; }
}
.bocc-form-field {
  margin-bottom: 16px;
}
.bocc-form-field label {
  display: block;
  font-family: "Jost", sans-serif;
  font-weight: 400;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--bocc-greige);
  margin-bottom: 6px;
}
.bocc-form-field input[type="text"],
.bocc-form-field textarea {
  width: 100%;
  font-family: "Jost", sans-serif;
  font-weight: 300;
  font-size: 0.92rem;
  color: var(--bocc-wgrey);
  background: var(--bocc-lgrey);
  border: 1px solid var(--bocc-lgreige);
  padding: 10px 14px;
  transition: border-color 0.3s;
  box-sizing: border-box;
}
.bocc-form-field input[type="text"]:focus,
.bocc-form-field textarea:focus {
  outline: none;
  border-color: var(--bocc-cappuccino);
}
.bocc-form-field textarea {
  resize: vertical;
  min-height: 80px;
}
.bocc-char-count {
  display: block;
  text-align: right;
  font-size: 0.72rem;
  color: var(--bocc-greige);
  margin-top: 4px;
}

/* Star picker */
.bocc-star-input {
  display: flex;
  gap: 4px;
}
.bocc-star-pick {
  font-size: 1.6rem;
  color: var(--bocc-lgreige);
  cursor: pointer;
  transition: color 0.2s, transform 0.2s;
  user-select: none;
}
.bocc-star-pick.bocc-star-active,
.bocc-star-pick.bocc-star-hover {
  color: var(--bocc-cappuccino);
}
.bocc-star-pick:hover {
  transform: scale(1.15);
}

/* Form messages */
.bocc-form-message {
  text-align: center;
  padding: 12px 16px;
  margin-top: 16px;
  font-family: "Jost", sans-serif;
  font-size: 0.88rem;
}
.bocc-form-success {
  background: rgba(74,92,46,0.08);
  color: #4A5C2E;
  border: 1px solid rgba(74,92,46,0.2);
}
.bocc-form-error {
  background: rgba(196,98,45,0.08);
  color: #C4622D;
  border: 1px solid rgba(196,98,45,0.2);
}

/* Platform Ratings bar — harmonized */
.bocc-platforms-section {
  background: var(--bocc-coffee);
  padding: 40px 24px;
}
.bocc-platforms-inner {
  max-width: 780px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
@media (max-width: 600px) {
  .bocc-platforms-inner { grid-template-columns: 1fr; }
}
.bocc-platform {
  text-align: center;
  padding: 24px 16px;
  border-right: 1px solid rgba(255,255,255,0.06);
}
.bocc-platform:last-child { border-right: none; }
@media (max-width: 600px) {
  .bocc-platform {
    border-right: none;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    padding: 20px 16px;
  }
  .bocc-platform:last-child { border-bottom: none; }
}
.bocc-platform-score {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight: 300;
  font-size: 2rem;
  color: var(--bocc-lbeige);
  margin: 0;
  line-height: 1;
}
.bocc-platform-name {
  font-family: "Jost", sans-serif;
  font-weight: 300;
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--bocc-greige);
  margin: 8px 0 0;
}
.bocc-platform a {
  text-decoration: none;
  color: inherit;
  transition: opacity 0.3s;
}
.bocc-platform a:hover {
  opacity: 0.7;
}

/* Helper classes */
.bocc-serif {
  font-family: "Cormorant Garamond", Georgia, serif;
}
.bocc-sans {
  font-family: "Jost", sans-serif;
}

/* =========================================================
   GÄSTEBUCH — Card chiara premium v7
   Sfondo light beige, testo scuro, separazione netta
   ========================================================= */

.bocc-gastebuch-section {
  background: var(--bocc-lbeige, #E6DCD3);
  padding: 40px 20px 40px;
  position: relative;
  z-index: 2;
  border-radius: 14px;
  max-width: 1060px;
  margin: 16px auto 0;
  box-shadow: 0 6px 30px rgba(0,0,0,.12);
}
.bocc-gb-inner {
  max-width: 680px;
  margin: 0 auto;
  text-align: center;
}
.bocc-gb-title {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight: 300;
  font-size: clamp(1.6rem, 3.5vw, 2.2rem);
  color: var(--bocc-coffee, #3A2B1E);
  margin: 0 0 .2rem;
  line-height: 1.1;
}
.bocc-gb-subtitle {
  font-family: "Jost", sans-serif;
  font-weight: 300;
  font-size: .78rem;
  color: var(--bocc-warmgrey, #4D4945);
  margin: 0 0 1.4rem;
  letter-spacing: .06em;
}

/* Summary */
.bocc-gb-summary {
  display: inline-flex;
  align-items: center;
  gap: .8rem;
  margin: 0 auto 1.2rem;
  padding: .5rem 1.2rem;
  background: var(--bocc-white, #FFFFFF);
  border-radius: 999px;
  box-shadow: 0 2px 8px rgba(58,43,30,.06);
}
.bocc-gb-summary-score {
  display: flex;
  align-items: baseline;
  gap: .3rem;
}
.bocc-gb-summary-num {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight: 600;
  font-size: 1.4rem;
  color: var(--bocc-coffee, #3A2B1E);
}
.bocc-gb-summary-stars { color: #B8893A; font-size: .85rem; }
.bocc-gb-summary-count {
  font-family: "Jost", sans-serif;
  font-weight: 300;
  font-size: .58rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--bocc-greige, #A6907C);
}

/* Review container */
.bocc-gb-compact {
  background: var(--bocc-white, #FFFFFF);
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: .8rem;
  text-align: left;
  box-shadow: 0 2px 10px rgba(58,43,30,.05);
}
.bocc-gb-row {
  display: grid;
  grid-template-columns: 4.8rem 1fr auto;
  grid-template-rows: auto auto;
  gap: 0 .6rem;
  padding: .7rem 1rem;
  border-bottom: 1px solid var(--bocc-lbeige, #E6DCD3);
  align-items: center;
}
.bocc-gb-row:last-child { border-bottom: none; }
.bocc-gb-row-stars {
  grid-row: 1 / 3;
  color: #B8893A;
  font-size: .68rem;
  letter-spacing: .03em;
  align-self: center;
}
.bocc-gb-row-author {
  font-family: "Jost", sans-serif;
  font-weight: 500;
  font-size: .6rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--bocc-cappuccino, #795E44);
}
.bocc-gb-row-date {
  font-family: "Jost", sans-serif;
  font-size: .5rem;
  color: var(--bocc-greige, #A6907C);
  letter-spacing: .08em;
  text-align: right;
}
.bocc-gb-row-text {
  grid-column: 2 / 4;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight: 300;
  font-style: italic;
  font-size: .8rem;
  line-height: 1.4;
  color: var(--bocc-warmgrey, #4D4945);
  margin: 0;
}
.bocc-gb-hidden { display: none; }

/* Toggle */
.bocc-gb-toggle {
  display: block;
  margin: .3rem auto 1rem;
  background: none;
  border: none;
  color: var(--bocc-cappuccino, #795E44);
  font-family: "Jost", sans-serif;
  font-weight: 400;
  font-size: .58rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  cursor: pointer;
  padding: .3rem .8rem;
}
.bocc-gb-toggle:hover { color: var(--bocc-coffee, #3A2B1E); }

/* Write button */
.bocc-gb-write-btn {
  display: inline-block;
  margin: 0 auto .6rem;
  background: var(--bocc-cappuccino, #795E44);
  border: none;
  border-radius: 999px;
  color: var(--bocc-white, #FFFFFF);
  font-family: "Jost", sans-serif;
  font-weight: 400;
  font-size: .6rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  padding: .65rem 1.6rem;
  cursor: pointer;
  transition: background .25s;
  box-shadow: 0 4px 12px rgba(121,94,68,.15);
}
.bocc-gb-write-btn:hover { background: var(--bocc-coffee, #3A2B1E); }

/* Form */
.bocc-gb-form-wrap {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height .4s, opacity .3s, margin .3s, padding .3s;
}
.bocc-gb-form-wrap.bocc-gb-open {
  max-height: 550px;
  opacity: 1;
  margin-top: .6rem;
  background: var(--bocc-white, #FFFFFF);
  border-radius: 14px;
  padding: 1.4rem;
  text-align: left;
  box-shadow: 0 2px 10px rgba(58,43,30,.05);
}
.bocc-gb-form-title {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight: 300;
  font-size: 1.2rem;
  color: var(--bocc-coffee, #3A2B1E);
  margin: 0 0 1rem;
}
.bocc-gb-field { margin-bottom: .9rem; }
.bocc-gb-field label {
  display: block;
  font-family: "Jost", sans-serif;
  font-weight: 400;
  font-size: .56rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--bocc-warmgrey, #4D4945);
  margin-bottom: .35rem;
}
.bocc-gb-field input[type="text"],
.bocc-gb-field textarea {
  width: 100%;
  background: var(--bocc-lgrey, #E6E6E1);
  border: 1px solid transparent;
  border-radius: 12px;
  color: var(--bocc-coffee, #3A2B1E);
  font-family: "Jost", sans-serif;
  font-weight: 300;
  font-size: .85rem;
  padding: .7rem .9rem;
  outline: none;
  transition: border-color .25s;
  box-sizing: border-box;
}
.bocc-gb-field input::placeholder,
.bocc-gb-field textarea::placeholder { color: var(--bocc-greige, #A6907C); }
.bocc-gb-field input:focus,
.bocc-gb-field textarea:focus { border-color: var(--bocc-cappuccino, #795E44); }
.bocc-gb-field textarea { min-height: 70px; resize: vertical; }
.bocc-gb-charcount {
  font-family: "Jost", sans-serif;
  font-size: .55rem;
  color: var(--bocc-greige, #A6907C);
  text-align: right;
  margin-top: .15rem;
}
.bocc-gb-star-input { display: flex; gap: .2rem; }
.bocc-gb-star-input span {
  font-size: 1.2rem;
  cursor: pointer;
  color: rgba(166,144,124,.3);
  transition: color .2s, transform .15s;
  user-select: none;
}
.bocc-gb-star-input span:hover,
.bocc-gb-star-input span.active { color: #B8893A; transform: scale(1.1); }
.bocc-gb-submit {
  background: var(--bocc-cappuccino, #795E44);
  border: none;
  border-radius: 999px;
  color: var(--bocc-white, #FFFFFF);
  font-family: "Jost", sans-serif;
  font-weight: 400;
  font-size: .6rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  padding: .65rem 1.6rem;
  cursor: pointer;
  transition: background .25s;
}
.bocc-gb-submit:hover { background: var(--bocc-coffee, #3A2B1E); }
.bocc-gb-submit:disabled { opacity: .45; cursor: not-allowed; }
.bocc-gb-feedback {
  font-family: "Jost", sans-serif;
  font-size: .75rem;
  padding: .6rem .8rem;
  border-radius: 8px;
  margin-top: .6rem;
}
.bocc-gb-feedback--success { background: rgba(74,92,46,.1); color: #4A5C2E; border: 1px solid rgba(74,92,46,.2); }
.bocc-gb-feedback--error { background: rgba(196,98,45,.1); color: #C4622D; border: 1px solid rgba(196,98,45,.2); }

/* Mobile */
@media (max-width: 640px) {
  .bocc-gastebuch-section { padding: 28px 14px 28px; margin: 12px 8px 0; border-radius: 12px; }
  .bocc-gb-title { font-size: 1.5rem; }
  .bocc-gb-row { grid-template-columns: 4rem 1fr auto; padding: .6rem .8rem; gap: 0 .4rem; }
  .bocc-gb-row-stars { font-size: .62rem; }
  .bocc-gb-row-text { font-size: .76rem; }
  .bocc-gb-summary { gap: .5rem; padding: .4rem 1rem; }
  .bocc-gb-summary-num { font-size: 1.2rem; }
  .bocc-gb-form-wrap.bocc-gb-open { padding: 1.1rem; border-radius: 10px; }
}
