/* ============================================================
   WORKSHOPS — index grid + cards
   ============================================================ */
.ws-grid {
  display:grid; grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));
  gap:clamp(20px,2.2vw,32px);
}

.ws-card {
  display:flex; flex-direction:column; height:100%; color:var(--ink);
  background:var(--paper); border:1px solid var(--line); border-radius:22px; overflow:hidden;
  transition:transform 0.4s var(--ease), box-shadow 0.4s var(--ease), border-color 0.4s var(--ease);
}
.ws-card:hover { transform:translateY(-5px); box-shadow:0 26px 54px rgba(28,36,25,0.12); border-color:rgba(28,36,25,0.16); }

.ws-card-img { position:relative; aspect-ratio:16/10; overflow:hidden; background:#eef0ea; }
.ws-card-img img { width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.ws-card:hover .ws-card-img img { transform:scale(1.06); }
.ws-card-tag {
  position:absolute; top:14px; left:14px;
  padding:6px 14px; border-radius:var(--r-pill);
  font-size:11px; font-weight:600; letter-spacing:0.04em;
  background:rgba(255,255,255,0.92); color:var(--ink); backdrop-filter:blur(6px);
}

.ws-card-body { display:flex; flex-direction:column; flex:1; padding:clamp(22px,2vw,28px); }
.ws-host { font-size:11px; font-weight:600; letter-spacing:0.14em; text-transform:uppercase; color:var(--sage-deep); margin-bottom:10px; }
.ws-card-body h3 { font-size:1.3rem; font-weight:500; letter-spacing:-0.02em; color:var(--ink); margin:0 0 8px; }
.ws-card-body > p { font-size:14px; line-height:1.6; color:var(--ink-soft); margin:0 0 18px; flex:1; }

.ws-card-meta {
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding-top:16px; border-top:1px solid var(--line);
  font-size:13px; color:var(--ink-soft);
}
.ws-card-meta strong { color:var(--ink); font-weight:600; }
.ws-card-price { font-size:15px; font-weight:600; color:var(--sage-deep); }

/* ============================================================
   WORKSHOPS INDEX — structured emotional-health rebuild
   ============================================================ */
/* Positioning strip */
.wk-intro-grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,60px); align-items:end; }
@media(max-width:820px){ .wk-intro-grid{ grid-template-columns:1fr; gap:18px; } }
.wk-intro-lead h2 { margin-top:14px; font-size:clamp(1.9rem,3.6vw,3rem); font-weight:500; letter-spacing:-0.03em; line-height:1.08; color:var(--ink); }
.wk-intro-lead h2 em { font-family:var(--serif); font-style:italic; font-weight:400; color:var(--sage-deep); }
.wk-intro-body { font-size:clamp(1rem,1.4vw,1.12rem); line-height:1.75; color:var(--ink-soft); }
.wk-pillars { display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(14px,1.6vw,22px);
  margin-top:clamp(36px,5vh,56px); padding-top:clamp(28px,3.5vh,42px); border-top:1px solid var(--line); }
@media(max-width:760px){ .wk-pillars{ grid-template-columns:repeat(2,1fr); gap:22px 16px; } }
.wk-pillar b { display:block; font-size:1.05rem; font-weight:600; color:#1f3a2e; letter-spacing:-0.01em; }
.wk-pillar span { display:block; margin-top:7px; font-size:13px; line-height:1.5; color:var(--ink-soft); }

/* Section head (shared) */
.section-head { text-align:center; max-width:680px; margin:0 auto clamp(40px,5vh,60px); }
.section-head h2 { margin-top:14px; font-size:clamp(2rem,3.8vw,3rem); font-weight:500; letter-spacing:-0.03em; line-height:1.06; color:var(--ink); }
.section-head h2 em { font-family:var(--serif); font-style:italic; font-weight:400; color:var(--sage-deep); }

/* Workshop cards */
.wk-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.2vw,28px); }
@media(max-width:920px){ .wk-cards{ grid-template-columns:1fr; max-width:560px; margin:0 auto; } }
.wk-card { display:flex; flex-direction:column; background:#fff; border:1px solid var(--line);
  border-radius:22px; padding:clamp(26px,2.6vw,34px); transition:transform 0.4s var(--ease), box-shadow 0.4s var(--ease), border-color 0.4s; }
.wk-card:hover { transform:translateY(-5px); box-shadow:0 28px 58px rgba(28,36,25,0.12); border-color:rgba(31,58,46,0.2); }
.wk-card-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.wk-card-for { font-size:11px; font-weight:700; letter-spacing:0.14em; text-transform:uppercase; color:var(--sage-deep);
  background:rgba(138,170,124,0.14); border-radius:var(--r-pill); padding:6px 13px; }
.wk-card-no { font-family:var(--serif); font-style:italic; font-size:1.5rem; color:rgba(31,58,46,0.25); }
.wk-card h3 { font-size:1.32rem; font-weight:600; letter-spacing:-0.02em; line-height:1.2; color:var(--ink); margin-bottom:12px; }
.wk-card > p { font-size:14px; line-height:1.65; color:var(--ink-soft); margin-bottom:22px; }
.wk-card-k { font-size:11px; font-weight:700; letter-spacing:0.14em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:14px; display:block; }
.wk-outcomes { display:flex; flex-direction:column; gap:11px; flex:1; }
.wk-outcomes li { position:relative; padding-left:24px; font-size:14px; line-height:1.5; color:var(--ink); }
.wk-outcomes li::before { content:''; position:absolute; left:0; top:7px; width:8px; height:8px; border-radius:50%;
  background:var(--sage); box-shadow:0 0 0 4px rgba(138,170,124,0.18); }
.wk-card-foot { margin-top:24px; padding-top:18px; border-top:1px solid var(--line); }
.wk-card-meta { font-size:12px; font-weight:600; letter-spacing:0.04em; color:var(--ink-faint); }
.wk-availability { text-align:center; margin-top:clamp(32px,4vh,48px); font-size:14px; color:var(--ink-soft); }
.wk-availability strong { color:#1f3a2e; font-weight:600; }

/* For institutions */
.wk-inst-grid { display:grid; grid-template-columns:1.25fr 0.85fr; gap:clamp(32px,4vw,56px); align-items:center; }
@media(max-width:880px){ .wk-inst-grid{ grid-template-columns:1fr; gap:28px; } }
.wk-inst-text h2 { margin-top:14px; font-size:clamp(1.9rem,3.6vw,2.9rem); font-weight:500; letter-spacing:-0.03em; line-height:1.08; color:var(--ink); }
.wk-inst-text h2 em { font-family:var(--serif); font-style:italic; font-weight:400; color:var(--sage-deep); }
.wk-inst-text > p { margin-top:16px; font-size:15px; line-height:1.78; color:var(--ink-soft); max-width:520px; }
.wk-inst-points { display:flex; flex-direction:column; gap:10px; margin-top:22px; }
.wk-inst-points li { position:relative; padding-left:24px; font-size:14.5px; color:var(--ink); }
.wk-inst-points li::before { content:''; position:absolute; left:0; top:8px; width:8px; height:8px; border-radius:50%; background:var(--sage); box-shadow:0 0 0 4px rgba(138,170,124,0.18); }
.wk-inst-card { background:linear-gradient(160deg, #1f3a2e, #16291f); color:#fff; border-radius:24px; padding:clamp(28px,3vw,40px); }
.wk-inst-card-k { font-size:11px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; color:rgba(220,239,202,0.85); }
.wk-inst-card h3 { margin:12px 0 12px; font-size:1.5rem; font-weight:500; letter-spacing:-0.02em; color:#fff; }
.wk-inst-card > p { font-size:14px; line-height:1.65; color:rgba(255,255,255,0.78); margin-bottom:24px; }
.wk-inst-card .btn-primary { background:#fff; color:#1f3a2e; }
.wk-inst-card .btn-primary:hover { background:#f3f7f0; }
.wk-inst-card-sig { display:block; margin-top:16px; font-size:12px; color:rgba(255,255,255,0.6); letter-spacing:0.03em; }

/* ============================================================
   WORKSHOP DETAIL (view.php)
   ============================================================ */
.ws-hero {
  position:relative; isolation:isolate; overflow:hidden;
  padding:calc(var(--nav-h,66px) + clamp(72px,13vh,150px)) 0 clamp(52px,8vh,96px);
  color:#fff;
}
.ws-hero-img { position:absolute; inset:0; z-index:-2; }
.ws-hero-img img { width:100%; height:100%; object-fit:cover; }
.ws-hero-veil { position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(18,24,16,0.45) 0%, rgba(18,24,16,0.30) 40%, rgba(18,24,16,0.78) 100%); }
.ws-hero-content { position:relative; max-width:820px; }
.ws-hero .eyebrow { color:rgba(255,255,255,0.78); }
.ws-hero .eyebrow::before { background:rgba(255,255,255,0.78); }
.ws-back { display:inline-block; margin-bottom:22px; font-size:13px; color:rgba(255,255,255,0.75); transition:color 0.25s; }
.ws-back:hover { color:#fff; }
.ws-hero h1 { color:#fff; font-size:clamp(2.2rem,4.6vw,4rem); font-weight:500; letter-spacing:-0.03em; margin:14px 0 0; }
.ws-hero-sub { color:rgba(255,255,255,0.85); font-size:clamp(1.05rem,1.6vw,1.3rem); max-width:600px; margin:16px 0 0; }
.ws-hero-meta { display:flex; align-items:center; gap:14px; margin-top:24px; font-size:14px; color:rgba(255,255,255,0.82); }
.ws-hero-meta strong { color:#fff; font-weight:600; }
.ws-hero-meta .dot { width:4px; height:4px; border-radius:50%; background:rgba(255,255,255,0.5); }

.ws-detail-grid { display:grid; grid-template-columns:1.6fr 1fr; gap:clamp(32px,4vw,64px); align-items:start; }
@media(max-width:880px) { .ws-detail-grid { grid-template-columns:1fr; } }
.ws-prose { margin-top:18px; color:var(--ink-soft); line-height:1.85; font-size:16px; }
.ws-prose h2, .ws-prose h3 { color:var(--ink); margin:1.4em 0 0.5em; }
.ws-prose p { margin-bottom:1em; }

.ws-sessions {
  position:sticky; top:calc(var(--nav-h,66px) + 20px);
  background:var(--paper); border:1px solid var(--line); border-radius:22px;
  padding:clamp(22px,2vw,30px);
}
.ws-sessions h3 { font-size:1.15rem; font-weight:600; color:var(--ink); margin-bottom:18px; }
.ws-session {
  display:grid; grid-template-columns:auto 1fr auto; gap:14px; align-items:center;
  padding:16px 0; border-top:1px solid var(--line);
}
.ws-session:first-of-type { border-top:none; padding-top:0; }
.ws-session-when { text-align:center; }
.ws-session-day { font-family:var(--serif); font-size:1.25rem; color:var(--sage-deep); line-height:1; }
.ws-session-time { font-size:11px; color:var(--ink-faint); margin-top:3px; }
.ws-session-title { font-size:14px; font-weight:600; color:var(--ink); }
.ws-session-meta { font-size:12px; color:var(--ink-soft); margin-top:3px; }
.ws-session-meta .tight { color:#b4622f; font-weight:600; }

/* ============================================================
   ENROL MODAL
   ============================================================ */
.enroll-modal { position:fixed; inset:0; z-index:2000; display:flex; align-items:center; justify-content:center; padding:20px; }
.enroll-modal[hidden] { display:none; }
.enroll-backdrop { position:absolute; inset:0; background:rgba(18,24,16,0.5); backdrop-filter:blur(4px); border:none; }
.enroll-card {
  position:relative; width:100%; max-width:520px; max-height:90vh; overflow:auto;
  background:#fff; border-radius:24px; padding:clamp(28px,3vw,40px);
  box-shadow:0 40px 80px rgba(18,24,16,0.3);
}
.enroll-x { position:absolute; top:18px; right:20px; font-size:26px; line-height:1; color:var(--ink-faint); background:none; border:none; }
.enroll-x:hover { color:var(--ink); }
.enroll-eyebrow { font-size:11px; font-weight:600; letter-spacing:0.16em; color:var(--sage-deep); margin-bottom:8px; }
.enroll-head h3 { font-size:1.5rem; font-weight:500; color:var(--ink); letter-spacing:-0.02em; }
.enroll-event { display:flex; gap:8px; flex-wrap:wrap; margin-top:8px; font-size:13px; color:var(--ink-soft); }
.enroll-alert { margin:18px 0 0; padding:12px 16px; border-radius:12px; font-size:14px; background:rgba(180,98,47,0.10); color:#9a4a23; }
.enroll-alert.is-success { background:rgba(138,170,124,0.16); color:var(--sage-deep); }
.enroll-alert.is-info { background:rgba(28,36,25,0.06); color:var(--ink-soft); }
.enroll-form { margin-top:22px; }
.enroll-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media(max-width:520px) { .enroll-row { grid-template-columns:1fr; } }
.enroll-field { margin-bottom:14px; }
.enroll-field label { display:block; font-size:12.5px; font-weight:500; color:var(--ink-soft); margin-bottom:6px; }
.enroll-field input, .enroll-field textarea {
  width:100%; padding:12px 14px; font-family:var(--font); font-size:14.5px; color:var(--ink);
  background:var(--paper); border:1px solid var(--line); border-radius:12px; transition:border-color 0.25s;
}
.enroll-field input:focus, .enroll-field textarea:focus { outline:none; border-color:var(--sage); }
.enroll-submit {
  display:inline-flex; align-items:center; gap:10px; justify-content:center; width:100%;
  margin-top:6px; padding:14px 24px; border-radius:var(--r-pill);
  background:var(--ink); color:#fff; font-family:var(--font); font-size:15px; font-weight:600;
  transition:background 0.25s, transform 0.15s;
}
.enroll-submit:hover { background:#11160e; transform:translateY(-1px); }
.enroll-submit.is-loading { opacity:0.7; }
.enroll-foot { margin-top:14px; font-size:12px; color:var(--ink-faint); text-align:center; }
