/* Kukarma — page-specific styles: hero, detail, checkout, thank-you, highlights, reviews, about. */

/* -------- Home hero (Variant A: editorial, NO stats column) -------- */
.hero { padding-block: 64px 80px; }
.hero-eyebrow { display: flex; align-items: center; gap: 14px; margin-bottom: 28px; }
.hero-eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--terracotta); }
.hero h1 { max-width: 1100px; }
.hero h1 em { font-style: italic; color: var(--terracotta); }
.hero-sub { font-size: 18px; color: var(--ink-2); max-width: 520px; margin-top: 28px; text-wrap: pretty; }
.hero-ctas { margin-top: 36px; display: flex; gap: 14px; flex-wrap: wrap; }
.hero-facts { margin-top: 28px; font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.06em; color: var(--ink-3); }
.hero-facts span + span::before { content: "·"; margin: 0 10px; color: var(--line-2); }

/* -------- Dark "From the studio" section -------- */
.studio-dark { background: #2B221C; color: var(--cream); }
.studio-dark .container { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; padding-top: var(--space-section); padding-bottom: var(--space-section); }
.studio-dark .ph, .studio-dark .kukarma-img { aspect-ratio: 4/3; }
.studio-dark h2, .studio-dark p { color: var(--cream); }
.studio-dark p { color: color-mix(in oklch, var(--cream) 80%, transparent); font-size: 17px; margin: 20px 0 28px; }

/* -------- Instagram strip -------- */
.ig-strip-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px; }
.ig-strip-grid .ph { aspect-ratio: 1; }

/* -------- Featured testimonial -------- */
.featured-quote { text-align: center; max-width: 760px; margin: 0 auto; }
.featured-quote .review-stars { justify-content: center; color: var(--terracotta); letter-spacing: 2px; margin-bottom: 20px; }
.featured-quote blockquote { font-family: var(--font-display); font-size: clamp(28px, 4vw, 44px); line-height: 1.25; margin: 0 0 24px; text-wrap: balance; }
.featured-quote cite { font-style: normal; font-size: 14px; color: var(--ink-3); }

/* -------- Workshop detail -------- */
.detail { padding-block: 40px 96px; }
.detail-back { display: inline-flex; align-items: center; gap: 8px; margin-bottom: 32px; color: var(--ink-2); font-size: 13px; }
.detail-back:hover { color: var(--ink); }
.detail-hero { display: grid; grid-template-columns: 1.25fr 1fr; gap: 48px; align-items: start; margin-bottom: 72px; }
.detail-hero-media { aspect-ratio: 5/4; width: 100%; object-fit: cover; border-radius: var(--radius-md); }
.detail h1 { font-size: clamp(40px, 5vw, 64px); }
.detail-meta { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 20px; }
.detail-meta .chip { pointer-events: none; }
.detail-desc { font-size: 17px; color: var(--ink-2); text-wrap: pretty; margin: 20px 0 0; }
.detail-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 64px; }
.detail-section { margin-bottom: 56px; }
.detail-section h3 { margin-bottom: 20px; }

/* Stat tiles (2 only — class size + next session) */
.stat-tiles { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin: 32px 0; }
.stat-tile { border-top: 1px solid var(--ink); padding-top: 16px; }
.stat-tile .num { font-family: var(--font-display); font-size: 32px; line-height: 1; }
.stat-tile .lbl { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-2); margin-top: 10px; }

/* Schedule list */
.schedule-list { display: flex; flex-direction: column; }
.schedule-item { display: grid; grid-template-columns: 52px 1fr auto; gap: 20px; align-items: center; padding: 18px 0; border-top: 1px solid var(--line); }
.schedule-item:last-child { border-bottom: 1px solid var(--line); }
.schedule-num { font-family: var(--font-mono); font-size: 11px; color: var(--ink-3); letter-spacing: 0.16em; }
.schedule-title { font-family: var(--font-display); font-size: 20px; }
.schedule-sub { color: var(--ink-2); font-size: 13px; margin-top: 2px; }
.schedule-dur { font-family: var(--font-mono); font-size: 11px; color: var(--ink-3); letter-spacing: 0.1em; }

/* Provide / bring lists */
.lists-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }
.check-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.check-list li { display: grid; grid-template-columns: 20px 1fr; gap: 12px; align-items: start; font-size: 15px; color: var(--ink-2); }
.check-list li svg { color: var(--olive); margin-top: 3px; }

/* A few more views */
.views-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.views-grid .ph, .views-grid img { aspect-ratio: 4/3; border-radius: var(--radius-md); width: 100%; object-fit: cover; }

/* Booking sidebar (desktop) */
.booking-card { position: sticky; top: 96px; background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 28px; }
.booking-price { display: flex; align-items: baseline; gap: 10px; }
.booking-price .num { font-family: var(--font-display); font-size: 42px; }
.booking-price .per { font-size: 13px; color: var(--ink-3); }
.sessions { display: flex; flex-direction: column; gap: 8px; margin: 20px 0; }
.session { display: flex; justify-content: space-between; align-items: center; padding: 14px 16px; border: 1px solid var(--line); border-radius: 10px; transition: all .15s ease; cursor: pointer; }
.session:hover { border-color: var(--ink); }
.session.selected { border-color: var(--ink); background: var(--ink); color: var(--cream); }
.session.full { opacity: 0.5; cursor: not-allowed; }
.session-date { font-size: 14px; font-weight: 500; }
.session-time { font-size: 12px; opacity: 0.75; margin-top: 2px; }
.session-seats { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.14em; }
.qty { display: flex; justify-content: space-between; align-items: center; padding: 10px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); margin: 16px 0; }
.qty-btns { display: flex; align-items: center; gap: 8px; }
.qty-btn { width: 32px; height: 32px; border-radius: 50%; border: 1px solid var(--line-2); display: grid; place-items: center; }
.qty-btn:hover:not([disabled]) { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.qty-num { min-width: 24px; text-align: center; font-family: var(--font-display); font-size: 20px; }
.total-row { display: flex; justify-content: space-between; align-items: center; margin: 20px 0; }
.total-row .total { font-family: var(--font-display); font-size: 28px; }
.booking-note { font-size: 12px; color: var(--ink-3); margin-top: 14px; text-align: center; }

/* Waitlist inline form (sold-out) */
.waitlist-form { display: flex; flex-direction: column; gap: 10px; margin-top: 16px; }

/* -------- Thank-you -------- */
.thankyou { text-align: center; max-width: 560px; margin: 0 auto; padding-block: 80px; }
.success-check { width: 72px; height: 72px; border-radius: 50%; background: var(--terracotta); color: var(--cream); display: grid; place-items: center; margin: 0 auto 24px; }
.thankyou h1 { margin-bottom: 16px; }
.thankyou p { color: var(--ink-2); }
.booking-summary { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 24px; text-align: left; margin: 32px 0; }
.booking-summary .summary-row { display: flex; justify-content: space-between; padding: 8px 0; font-size: 14px; }
.booking-summary .summary-row.total { border-top: 1px solid var(--line); margin-top: 8px; padding-top: 12px; font-family: var(--font-display); font-size: 20px; }

/* -------- Highlights (uniform square grid, NOT masonry) -------- */
.ig-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.ig-grid .ph { aspect-ratio: 1; }

/* -------- Reviews -------- */
.reviews-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 24px; }
.review { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 28px; }
.review-stars { display: flex; color: var(--terracotta); font-size: 14px; letter-spacing: 2px; margin-bottom: 14px; }
.review-quote { font-family: var(--font-display); font-size: 18px; line-height: 1.35; text-wrap: pretty; margin-bottom: 20px; }
.review-author { display: flex; align-items: center; gap: 12px; }
.review-avatar { width: 40px; height: 40px; border-radius: 50%; display: grid; place-items: center; background: var(--cream-2); color: var(--ink); font-family: var(--font-display); font-size: 16px; }
.review-name { font-size: 14px; font-weight: 500; }
.review-workshop { font-size: 12px; color: var(--ink-3); }

/* -------- About -------- */
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
.about-media { aspect-ratio: 4/5; border-radius: var(--radius-md); width: 100%; object-fit: cover; }
.about-body p { color: var(--ink-2); font-size: 17px; margin: 0 0 18px; }
.about-ctas { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 28px; }

/* -------- Listing header + empty state -------- */
.listing-header { padding-block: 56px 40px; }
.listing-toolbar { display: flex; justify-content: space-between; align-items: center; gap: 24px; margin-bottom: 40px; flex-wrap: wrap; }
.search-box { display: flex; align-items: center; gap: 8px; border: 1px solid var(--line-2); border-radius: 999px; padding: 8px 16px; }
.search-box input { border: none; background: none; outline: none; width: 180px; }
.empty-state { text-align: center; padding: 80px 20px; max-width: 480px; margin: 0 auto; }
.empty-state p { color: var(--ink-2); margin-bottom: 24px; }
.empty-state form { display: flex; gap: 10px; max-width: 380px; margin: 0 auto; }
.empty-state input { flex: 1; padding: 12px 14px; border: 1px solid var(--line); border-radius: 999px; background: var(--paper); }

/* -------- Contact -------- */
.contact-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 64px; align-items: start; }
.contact-info p { color: var(--ink-2); font-size: 16px; line-height: 1.7; margin: 0 0 18px; }
.contact-info a { color: var(--terracotta); }
.contact-info .label { display: block; margin-bottom: 4px; }
.contact-form button { justify-content: center; }
.contact-ok { background: color-mix(in oklch, var(--olive) 16%, var(--cream)); border: 1px solid color-mix(in oklch, var(--olive) 40%, var(--cream)); border-radius: var(--radius-md); padding: 16px 20px; margin-bottom: 24px; color: var(--ink); font-size: 14px; }
.hp-field { position: absolute; left: -9999px; }

/* -------- Legal pages (Terms / Privacy) -------- */
.legal { max-width: 760px; margin: 0 auto; padding-bottom: 96px; }
.legal h2 { font-size: clamp(24px, 2.6vw, 34px); margin: 48px 0 16px; }
.legal h3 { font-size: 20px; margin: 28px 0 10px; }
.legal p, .legal li { color: var(--ink-2); font-size: 16px; line-height: 1.65; }
.legal ul { padding-left: 20px; }
.legal li { margin-bottom: 8px; }
.legal a { color: var(--terracotta); text-decoration: underline; text-underline-offset: 2px; }
.legal .updated { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-3); }
.legal-note {
  background: color-mix(in oklch, var(--ochre) 14%, var(--cream));
  border: 1px solid color-mix(in oklch, var(--ochre) 40%, var(--cream));
  border-radius: var(--radius-md); padding: 16px 20px; margin: 24px 0;
  font-size: 14px; color: var(--ink-2);
}

/* -------- Forms (shared) -------- */
.form-row { display: grid; gap: 6px; margin-bottom: 18px; }
.form-row.two { grid-template-columns: 1fr 1fr; gap: 14px; }
.form-row label { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-3); }
.form-row input, .form-row textarea, .form-row select { padding: 12px 14px; background: var(--cream); border: 1px solid var(--line); border-radius: 8px; font-size: 14px; outline: none; transition: border-color .15s ease; }
.form-row input:focus, .form-row textarea:focus, .form-row select:focus { border-color: var(--ink); }
.form-row .err { color: var(--terracotta); font-size: 12px; margin-top: 2px; }

/* -------- Responsive -------- */
/* Tablet & below (≤1024): two-column editorial blocks collapse to one column,
   and the desktop booking sidebar gives way to the mobile bar + sheet.
   This boundary is shared with booking-mobile.css and booking-mobile.js. */
@media (max-width: 1024px) {
  .detail-hero, .detail-grid, .about-grid, .studio-dark .container, .contact-grid { grid-template-columns: 1fr; }
  .reviews-grid { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
  .ig-grid { grid-template-columns: repeat(3, 1fr); }
  .ig-strip-grid { grid-template-columns: repeat(3, 1fr); }
  .lists-2col { grid-template-columns: 1fr; gap: 32px; }
  .booking-card { display: none; }
}
@media (max-width: 640px) {
  .reviews-grid, .views-grid { grid-template-columns: 1fr; }
  .ig-grid, .ig-strip-grid { grid-template-columns: repeat(2, 1fr); }
  .stat-tiles { grid-template-columns: 1fr; }
  .empty-state form { flex-direction: column; }
  /* Hero: tighten spacing, full-width CTAs. */
  .hero { padding-block: 36px 48px; }
  .hero-ctas .btn { flex: 1; justify-content: center; }
  .form-row.two { grid-template-columns: 1fr; }
}
