/* ============================================================
   AJAY'S ART — Design Override Layer v2
   ============================================================ */

:root {
  --r-sm: 8px;
  --r:    14px;
  --r-lg: 20px;
  --shadow:       0 2px 14px rgba(0,0,0,.07);
  --shadow-hover: 0 8px 30px rgba(0,0,0,.14);
}

/* ── Buttons ────────────────────────────────────────────── */
.btn {
  border-radius: var(--r-sm) !important;
  transition: transform .15s, box-shadow .2s, background .2s !important;
}
.btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-hover); }

/* ── Universal card radii ───────────────────────────────── */
.event-card,
.service-card,
.product-card,
.review,
.category-card,
.mini-product,
.summary,
.content-card,
.bundle,
.sidebar,
.notice,
.workshop-card,
.student-signup {
  border-radius: var(--r) !important;
  overflow: hidden;
}

/* ── Event / retreat cards — enhanced ───────────────────── */
.event-card {
  border-radius: var(--r-lg) !important;
  box-shadow: var(--shadow) !important;
  transition: transform .25s, box-shadow .25s !important;
  overflow: hidden !important;
}
.event-card:hover {
  transform: translateY(-5px) !important;
  box-shadow: var(--shadow-hover) !important;
}
.event-card img {
  height: 240px !important;
  width: 100% !important;
  object-fit: cover !important;
  display: block !important;
  border-radius: 0 !important;
}
.event-card .pad { padding: 22px 20px 20px !important; }
.event-card h3  { font-size: 22px !important; margin: 10px 0 6px !important; }
.event-tag {
  border-radius: 100px !important;
  padding: 4px 12px !important;
  font-size: 11px !important;
  display: inline-block !important;
}

/* ── Homepage retreat layout ────────────────────────────── */
.retreats-featured {
  display: grid !important;
  grid-template-columns: 1.5fr 1fr !important;
  gap: 20px !important;
  align-items: start !important;
}
.retreats-featured .event-card.main img { height: 300px !important; }
.retreats-stack {
  display: flex !important;
  flex-direction: column !important;
  gap: 20px !important;
}
.retreats-stack .event-card img  { height: 155px !important; }
.retreats-stack .event-card h3   { font-size: 18px !important; }
.retreats-stack .event-card .pad { padding: 14px 16px !important; }
@media(max-width:860px) {
  .retreats-featured { grid-template-columns: 1fr !important; }
  .retreats-stack .event-card img { height: 200px !important; }
}

/* ── Service cards ──────────────────────────────────────── */
.service-card {
  border-radius: var(--r) !important;
  box-shadow: var(--shadow) !important;
  overflow: hidden !important;
  transition: transform .2s, box-shadow .2s !important;
}
.service-card:hover { transform: translateY(-3px) !important; box-shadow: var(--shadow-hover) !important; }

/* ── Product cards ──────────────────────────────────────── */
.product-card {
  border-radius: var(--r) !important;
  box-shadow: var(--shadow) !important;
  overflow: hidden !important;
  transition: transform .2s, box-shadow .2s !important;
}
.product-card:hover { transform: translateY(-3px) !important; box-shadow: var(--shadow-hover) !important; }
.product-card img   { border-radius: 0 !important; }
.badge              { border-radius: 100px !important; }

/* ── Photo/gallery images ───────────────────────────────── */
.photo-grid img      { border-radius: var(--r) !important; overflow: hidden; }
.live-media-grid img { border-radius: var(--r) !important; }
.gallery-grid img    { border-radius: var(--r) !important; }

/* ── Inputs & forms ─────────────────────────────────────── */
input[type=text],
input[type=email],
input[type=tel],
input[type=search],
input[type=number],
textarea,
.select,
select {
  border-radius: var(--r-sm) !important;
}
.email-form input  { border-radius: var(--r-sm) 0 0 var(--r-sm) !important; }
.email-form button { border-radius: 0 var(--r-sm) var(--r-sm) 0 !important; }

/* ── Reviews carousel ───────────────────────────────────── */
.reviews-carousel-wrap { overflow: hidden; position: relative; margin-top: 32px; }
.reviews-carousel { display: flex; gap: 20px; transition: transform .45s cubic-bezier(.4,0,.2,1); }
.review-slide {
  min-width: calc(33.333% - 14px);
  flex-shrink: 0;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--r-lg) !important;
  padding: 28px 24px;
  box-shadow: var(--shadow);
}
.review-slide .stars  { color: #f5a623; font-size: 17px; margin-bottom: 14px; display: block; letter-spacing: 2px; }
.review-slide blockquote { font-size: 14px; line-height: 1.75; color: #3d3934; margin: 0 0 18px; font-style: italic; }
.review-slide .reviewer { font-weight: 700; font-size: 13px; }
.review-slide .reviewer-meta { font-size: 12px; color: var(--muted); margin-top: 2px; }
.review-slide .g-logo { font-size: 11px; color: #4285f4; font-weight: 900; margin-bottom: 10px; display: inline-block; background: #f1f3f4; padding: 2px 7px; border-radius: 4px; }
.carousel-nav { display: flex; gap: 10px; margin-top: 20px; align-items: center; }
.carousel-btn { width: 40px; height: 40px; border: 1px solid var(--line); border-radius: 50% !important; background: #fff; font-size: 18px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all .15s; }
.carousel-btn:hover { background: var(--ink); color: #fff; border-color: var(--ink); }
.carousel-dots { display: flex; gap: 6px; margin-left: 6px; }
.carousel-dot { width: 7px; height: 7px; border-radius: 50% !important; background: var(--line); cursor: pointer; transition: background .2s; border: none; padding: 0; }
.carousel-dot.active { background: var(--ink); }
@media(max-width:860px) { .review-slide { min-width: calc(80% - 10px); } }

/* ── Coming soon banner ─────────────────────────────────── */
.coming-soon-banner {
  background: linear-gradient(135deg,#1a3021,#2d4a2d) !important;
  color: #fff !important;
  border-radius: var(--r-lg) !important;
  padding: 80px 40px !important;
  text-align: center !important;
}
.coming-soon-banner .eyebrow { color: rgba(255,255,255,.55); margin-bottom: 16px; display: block; letter-spacing: .2em; }
.coming-soon-banner h2 { font-size: 52px; color: #fff; margin: 0 0 16px; }
.coming-soon-banner p  { font-size: 16px; color: rgba(255,255,255,.65); max-width: 420px; margin: 0 auto; line-height: 1.8; }

/* ── Workshop cards ─────────────────────────────────────── */
.workshop-card { background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg) !important; overflow: hidden !important; box-shadow: var(--shadow); transition: box-shadow .2s; }
.workshop-card:hover { box-shadow: var(--shadow-hover); }
.workshop-card img { height: 220px; width: 100%; object-fit: cover; display: block; border-radius: 0 !important; }
.workshop-card .wk-body { padding: 22px; }
.workshop-card h3 { font-size: 20px; margin: 0 0 6px; }
.workshop-card .wk-meta { font-size: 13px; color: var(--muted); margin-bottom: 14px; }
.wk-enquiry-form { display: none; border-top: 1px solid var(--line); padding: 20px 22px; background: #fbfaf7; }
.wk-enquiry-form.open { display: block; }
.wk-enquiry-form .fg { margin-bottom: 12px; }
.wk-enquiry-form label { display: block; font-size: 11px; text-transform: uppercase; letter-spacing: .1em; font-weight: 700; margin-bottom: 5px; color: #555; }
.wk-enquiry-form input, .wk-enquiry-form textarea { width: 100%; padding: 10px 12px; border: 1px solid var(--line); border-radius: var(--r-sm) !important; font-family: inherit; font-size: 13px; background: #fff; }
.wk-enquiry-form textarea { min-height: 70px; resize: vertical; }
.wk-notice { padding: 12px 14px; border-radius: var(--r-sm) !important; font-size: 13px; display: none; margin-top: 10px; }
.wk-notice.success { background: #e7f1ea; border: 1px solid #aacdb8; color: #1f5135; }
.wk-notice.error   { background: #fff1f0; border: 1px solid #f0bdb9; color: #7f1f1f; }
@media(max-width:860px) { .workshops-grid { grid-template-columns: 1fr !important; } }

/* ── Student signup ─────────────────────────────────────── */
.student-signup { background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg) !important; padding: 36px; box-shadow: var(--shadow); max-width: 640px; margin: 0 auto; overflow: visible !important; }
.student-signup h3 { font-size: 26px; margin: 0 0 6px; }
.student-signup > p { color: var(--muted); margin: 0 0 28px; font-size: 14px; }
.signup-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media(max-width:600px) { .signup-grid { grid-template-columns: 1fr; } }
.signup-field { display: flex; flex-direction: column; gap: 5px; }
.signup-field label { font-size: 11px; text-transform: uppercase; letter-spacing: .1em; font-weight: 700; color: #555; }
.signup-field input, .signup-field select { padding: 11px 13px; border: 1px solid var(--line); border-radius: var(--r-sm) !important; font-family: inherit; font-size: 14px; background: #fff; transition: border-color .2s; }
.signup-field input:focus, .signup-field select:focus { outline: none; border-color: var(--accent); }
.signup-full { grid-column: 1 / -1; }
.signup-notice { padding: 14px 16px; border-radius: var(--r-sm) !important; font-size: 14px; display: none; margin-top: 16px; }
.signup-notice.success { background: #e7f1ea; border: 1px solid #aacdb8; color: #1f5135; }
.signup-notice.error   { background: #fff1f0; border: 1px solid #f0bdb9; color: #7f1f1f; }

/* ── Cart & shop ────────────────────────────────────────── */
.cart-table, .summary { border-radius: var(--r) !important; }
.cart-item:first-child { border-radius: var(--r) var(--r) 0 0 !important; }
.qty button { border-radius: var(--r-sm) !important; }
.pagination a { border-radius: var(--r-sm) !important; }

/* ── Notice boxes ───────────────────────────────────────── */
.notice { border-radius: var(--r) !important; }

/* ── Category cards ─────────────────────────────────────── */
.category-card { border-radius: var(--r) !important; overflow: hidden !important; }
