/* Lightstack; Ohemaa — Inner page styles (About, Consultation, Testimonials)
   Each page's rules are scoped under a wrapper class so they layer cleanly
   on top of the global design system in style.css. */

/* Shared page slideshow hero bits */
.page-slideshow { position:absolute; inset:0; z-index:0; }
.page-slide { position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; transform:scale(1.06); transition:opacity 1.8s ease, transform 7s ease; }
.page-slide.active { opacity:1; transform:scale(1); }
.page-scrim { position:absolute; inset:0; z-index:1; pointer-events:none; background:linear-gradient(100deg, rgba(250,246,238,0.97) 0%, rgba(250,246,238,0.93) 40%, rgba(250,246,238,0.7) 62%, rgba(250,246,238,0.34) 100%); }

/* ============================================================
   ABOUT
   ============================================================ */
.about-page .about-hero { position:relative; overflow:hidden; background:var(--cream); }
.about-page .about-hero::before { content:''; position:absolute; top:-160px; right:-160px; width:520px; height:520px; background:radial-gradient(ellipse, rgba(95,111,66,0.1) 0%, transparent 70%); pointer-events:none; z-index:1; }
.about-page .about-hero-inner { position:relative; z-index:2; max-width:var(--max); margin:0 auto; padding:var(--pad); display:grid; grid-template-columns:1.05fr 0.95fr; gap:56px; align-items:center; }
.about-page .about-hero-text { padding:150px 0 90px; }
.about-page .about-hero-text h1 { font-family:var(--brand); font-size:clamp(2.4rem,4.2vw,4rem); font-weight:400; line-height:1.12; letter-spacing:0.03em; color:var(--forest); margin-bottom:26px; }
.about-page .about-hero-text h1 em { font-style:normal; color:var(--pink); display:block; }
.about-page .about-hero-sub { font-size:1.02rem; font-weight:300; line-height:1.85; color:var(--text-mid); max-width:460px; margin-bottom:40px; }
.about-page .about-hero-actions { display:flex; gap:12px; flex-wrap:wrap; }
.about-page .about-hero-figure { position:relative; padding:120px 0 60px; }
.about-page .about-hero-img { position:relative; z-index:2; aspect-ratio:4/5; overflow:hidden; border-radius:4px; box-shadow:0 36px 80px rgba(8,37,26,0.26); animation:heroRise 1.1s cubic-bezier(0.22,1,0.36,1) both; }
.about-page .about-hero-img img { width:100%; height:100%; object-fit:cover; object-position:center; }
.about-page .about-hero-ring { position:absolute; top:140px; right:-26px; bottom:48px; left:-26px; border:1px solid rgba(95,111,66,0.35); border-radius:6px; z-index:1; }
.about-page .about-hero-badge { position:absolute; bottom:24px; left:-16px; z-index:4; background:var(--gold); color:var(--forest); padding:16px 20px; border-radius:4px; box-shadow:0 16px 40px rgba(201,169,110,0.45); animation:float 4.5s ease-in-out infinite; }
.about-page .about-hero-badge strong { display:block; font-family:var(--display); font-size:1.5rem; font-weight:700; line-height:1; }
.about-page .about-hero-badge span { font-size:0.66rem; font-weight:500; letter-spacing:0.1em; text-transform:uppercase; }

.about-page .story { background:var(--white); padding:100px 0; }
.about-page .story-inner { max-width:var(--max); margin:0 auto; padding:var(--pad); display:grid; grid-template-columns:0.9fr 1.1fr; gap:80px; align-items:start; }
.about-page .story-img-col { position:sticky; top:100px; }
.about-page .story-portrait { aspect-ratio:3/4; overflow:hidden; border-radius:4px; position:relative; box-shadow:0 24px 60px rgba(8,37,26,0.15); }
.about-page .story-portrait img { width:100%; height:100%; object-fit:cover; object-position:center top; }
.about-page .story-badge { position:absolute; bottom:-16px; right:-16px; background:var(--forest); color:var(--lime); padding:18px 22px; border-radius:4px; font-size:0.7rem; letter-spacing:0.08em; line-height:1.7; text-transform:uppercase; max-width:160px; text-align:center; box-shadow:0 16px 40px rgba(0,0,0,0.25); }
.about-page .story-badge strong { display:block; font-family:var(--brand); font-size:1.4rem; color:var(--pink); margin-bottom:4px; line-height:1; }
.about-page .story-text .eyebrow { color:var(--sage); }
.about-page .story-body { font-size:0.97rem; font-weight:300; line-height:1.95; color:var(--text-mid); margin-bottom:22px; }
.about-page .story-emphasis { font-size:1.25rem; font-style:italic; font-weight:400; color:var(--sage); line-height:1.5; margin:30px 0; padding-left:20px; border-left:2px solid var(--gold); }
.about-page .story-quote { background:var(--lt-green); border-radius:4px; padding:32px 36px; margin:32px 0; position:relative; }
.about-page .story-quote-glyph { font-family:Georgia, serif; font-size:3.4rem; line-height:0.4; color:rgba(95,111,66,0.3); display:block; margin-bottom:14px; }
.about-page .story-quote p { font-size:1rem; font-style:italic; font-weight:400; line-height:1.75; color:var(--forest); }
.about-page .story-sig { font-family:var(--brand); font-size:1.1rem; color:var(--sage); letter-spacing:0.08em; margin-top:18px; }

.about-page .lineage { background:linear-gradient(135deg, var(--accent-dark) 0%, #0c2c1e 100%); padding:100px 0; position:relative; overflow:hidden; }
.about-page .lineage::before { content:''; position:absolute; top:0; right:0; width:50%; height:100%; background:radial-gradient(ellipse at 80% 30%, rgba(95,111,66,0.18) 0%, transparent 60%); pointer-events:none; }
.about-page .lineage-inner { position:relative; z-index:1; max-width:var(--max); margin:0 auto; padding:var(--pad); }
.about-page .lineage-header { text-align:center; margin-bottom:72px; }
.about-page .lineage-header .eyebrow { justify-content:center; color:var(--lime); }
.about-page .lineage-header h2.display { color:var(--white); }
.about-page .lineage-header h2.display .pink { color:var(--pink); }
.about-page .lineage-header p { color:rgba(255,255,255,0.55); font-size:0.95rem; font-weight:300; line-height:1.8; max-width:560px; margin:18px auto 0; }
.about-page .lineage-tree { display:grid; grid-template-columns:1fr auto 1fr; gap:0 44px; align-items:center; max-width:920px; margin:0 auto; }
.about-page .lineage-branch-title { font-family:var(--brand); font-size:0.92rem; letter-spacing:0.08em; color:var(--lime); margin-bottom:18px; display:flex; align-items:center; gap:12px; }
.about-page .lineage-branch-title::after { content:''; flex:1; height:1px; background:rgba(223,226,183,0.25); }
.about-page .lineage-branch.right .lineage-branch-title { flex-direction:row-reverse; }
.about-page .lineage-card { background:rgba(255,255,255,0.04); border:1px solid rgba(223,226,183,0.12); border-radius:4px; padding:26px 28px; margin-bottom:16px; transition:all 0.35s; }
.about-page .lineage-card:hover { background:rgba(255,255,255,0.08); border-color:rgba(223,226,183,0.3); transform:translateY(-3px); }
.about-page .lineage-card-name { font-family:var(--brand); font-size:0.95rem; color:var(--pink); letter-spacing:0.05em; margin-bottom:6px; }
.about-page .lineage-card-role { font-size:0.72rem; color:rgba(223,226,183,0.65); letter-spacing:0.08em; text-transform:uppercase; margin-bottom:12px; }
.about-page .lineage-card-desc { font-size:0.82rem; font-weight:300; color:rgba(255,255,255,0.55); line-height:1.7; }
.about-page .lineage-center { display:flex; flex-direction:column; align-items:center; }
.about-page .lineage-line { width:1px; height:42px; background:rgba(223,226,183,0.25); }
.about-page .lineage-orb { width:90px; height:90px; border-radius:50%; background:var(--sage); border:3px solid rgba(223,226,183,0.3); display:flex; align-items:center; justify-content:center; animation:float 4.5s ease-in-out infinite; box-shadow:0 12px 36px rgba(0,0,0,0.3); }
.about-page .lineage-orb-label { font-family:var(--brand); font-size:0.8rem; color:var(--lime); letter-spacing:0.14em; text-align:center; margin-top:14px; }

.about-page .approach { background:var(--lt-green); padding:100px 0; }
.about-page .approach-inner { max-width:var(--max); margin:0 auto; padding:var(--pad); }
.about-page .approach-header { text-align:center; margin-bottom:64px; }
.about-page .approach-header .eyebrow { justify-content:center; }
.about-page .approach-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.about-page .approach-card { background:var(--white); border:1px solid var(--border); border-radius:4px; padding:44px 34px 40px; min-height:340px; display:flex; flex-direction:column; position:relative; overflow:hidden; transition:opacity 0.7s ease, transform 0.7s ease, box-shadow 0.4s; }
.about-page .approach-card::after { content:''; position:absolute; left:0; bottom:0; height:3px; width:100%; background:linear-gradient(90deg, var(--sage), var(--pink)); transform:scaleX(0); transform-origin:left; transition:transform 0.45s ease; }
.about-page .approach-card.visible:hover { transform:translateY(-6px); box-shadow:0 22px 50px rgba(8,37,26,0.1); }
.about-page .approach-card.visible:hover::after { transform:scaleX(1); }
.about-page .approach-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:22px; }
.about-page .approach-num { font-family:var(--display); font-size:2.8rem; font-weight:700; color:rgba(8,37,26,0.1); line-height:1; transition:color 0.4s; }
.about-page .approach-card.visible:hover .approach-num { color:rgba(95,111,66,0.32); }
.about-page .approach-icon-wrap { width:54px; height:54px; border-radius:50%; background:var(--lt-green); display:flex; align-items:center; justify-content:center; transition:all 0.4s; }
.about-page .approach-card.visible:hover .approach-icon-wrap { background:var(--sage); transform:rotate(-6deg) scale(1.05); }
.about-page .approach-icon { width:28px; height:28px; transition:all 0.4s; }
.about-page .approach-title { font-family:var(--brand); font-size:1.05rem; font-weight:400; letter-spacing:0.04em; color:var(--forest); margin-bottom:12px; line-height:1.3; }
.about-page .approach-desc { font-size:0.85rem; font-weight:300; line-height:1.8; color:var(--text-mid); margin-top:auto; }

.about-page .philosophy { background:var(--white); padding:100px 0; }
.about-page .philosophy-inner { max-width:var(--max); margin:0 auto; padding:var(--pad); display:grid; grid-template-columns:1.1fr 0.9fr; gap:80px; align-items:center; }
.about-page .philosophy-text .eyebrow { color:var(--sage); }
.about-page .philosophy-text h2.display { margin-bottom:24px; }
.about-page .philosophy-intro { font-size:0.97rem; font-weight:300; line-height:1.9; color:var(--text-mid); margin-bottom:30px; }
.about-page .philosophy-list { list-style:none; }
.about-page .philosophy-list li { display:flex; gap:16px; padding:18px 0; border-top:1px solid var(--border); }
.about-page .philosophy-list li:last-child { border-bottom:1px solid var(--border); }
.about-page .philosophy-check { width:26px; height:26px; border-radius:50%; background:var(--lt-green); display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:2px; }
.about-page .philosophy-li-title { font-family:var(--brand); font-size:0.95rem; color:var(--forest); letter-spacing:0.03em; margin-bottom:4px; }
.about-page .philosophy-li-desc { font-size:0.83rem; font-weight:300; line-height:1.7; color:var(--text-mid); }
.about-page .philosophy-img { position:relative; }
.about-page .philosophy-img-frame { aspect-ratio:4/5; overflow:hidden; border-radius:4px; box-shadow:0 24px 60px rgba(8,37,26,0.15); }
.about-page .philosophy-img-frame img { width:100%; height:100%; object-fit:cover; }
.about-page .philosophy-img-tag { position:absolute; top:-16px; left:-16px; background:var(--sage); color:var(--lime); padding:16px 20px; border-radius:4px; font-size:0.7rem; letter-spacing:0.1em; line-height:1.6; text-transform:uppercase; text-align:center; box-shadow:0 12px 32px rgba(0,0,0,0.18); }
.about-page .philosophy-img-tag strong { display:block; font-family:var(--brand); font-size:1.3rem; color:var(--white); margin-bottom:2px; }

.about-page .about-stats { background:var(--cream); padding:80px 0; }
.about-page .about-stats .stats-inner { background:rgba(95,111,66,0.15); border:1px solid rgba(95,111,66,0.15); }
.about-page .about-stats .stat-item { background:var(--cream); }
.about-page .about-stats .stat-item:hover { background:#f1ece0; }

.about-page .gallery { background:var(--off-white); padding:90px 0; }
.about-page .gallery-inner { max-width:var(--max); margin:0 auto; padding:var(--pad); }
.about-page .gallery-head { margin-bottom:44px; }
.about-page .gallery-grid { display:grid; grid-template-columns:1.4fr 1fr 1fr; grid-template-rows:240px 240px; gap:16px; }
.about-page .gallery-item { border-radius:4px; overflow:hidden; position:relative; }
.about-page .gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform 0.7s cubic-bezier(0.22,1,0.36,1); }
.about-page .gallery-item:hover img { transform:scale(1.06); }
.about-page .gallery-item.tall { grid-row:span 2; }

.about-page .cta-section::before { background-size:cover; background-position:center; }

@media (max-width:1024px) {
  .about-page .about-hero-inner { grid-template-columns:1fr; gap:40px; }
  .about-page .about-hero-text { padding:150px 0 10px; }
  .about-page .about-hero-figure { padding:0 0 60px; max-width:440px; }
  .about-page .about-hero-ring { top:0; }
  .about-page .story-inner { grid-template-columns:1fr; gap:48px; }
  .about-page .story-img-col { position:static; max-width:420px; }
  .about-page .approach-grid { grid-template-columns:repeat(2,1fr); }
  .about-page .philosophy-inner { grid-template-columns:1fr; gap:48px; }
}
@media (max-width:900px) {
  .about-page .lineage-tree { grid-template-columns:1fr; gap:8px; }
  .about-page .lineage-center { flex-direction:row; gap:0; margin:16px 0; }
  .about-page .lineage-center .lineage-line { width:42px; height:1px; }
  .about-page .lineage-branch.right .lineage-branch-title { flex-direction:row; }
  .about-page .gallery-grid { grid-template-columns:1fr 1fr; grid-template-rows:auto; }
  .about-page .gallery-item.tall { grid-row:auto; }
  .about-page .story, .about-page .lineage, .about-page .approach, .about-page .philosophy, .about-page .gallery { padding:64px 0; }
}
@media (max-width:600px) {
  .about-page .approach-grid { grid-template-columns:1fr; }
  .about-page .gallery-grid { grid-template-columns:1fr; }
}

/* ============================================================
   CONSULTATION
   ============================================================ */
.consult-page .consult-hero { position:relative; overflow:hidden; background:var(--cream); }
.consult-page .consult-hero::before { content:''; position:absolute; top:-160px; right:-160px; width:520px; height:520px; background:radial-gradient(ellipse, rgba(95,111,66,0.1) 0%, transparent 70%); pointer-events:none; }
.consult-page .consult-hero-inner { position:relative; z-index:2; max-width:var(--max); margin:0 auto; padding:var(--pad); display:grid; grid-template-columns:1.05fr 0.95fr; gap:56px; align-items:center; }
.consult-page .consult-hero-text { padding:150px 0 90px; }
.consult-page .consult-hero-text h1 { font-family:var(--brand); font-size:clamp(2.3rem,4vw,3.8rem); font-weight:400; line-height:1.14; letter-spacing:0.03em; color:var(--forest); margin-bottom:26px; }
.consult-page .consult-hero-text h1 em { font-style:normal; color:var(--pink); display:block; }
.consult-page .consult-hero-sub { font-size:1.02rem; font-weight:300; line-height:1.85; color:var(--text-mid); max-width:470px; margin-bottom:40px; }
.consult-page .consult-hero-actions { display:flex; gap:12px; flex-wrap:wrap; }
.consult-page .consult-hero-figure { position:relative; padding:120px 0 70px; }
.consult-page .consult-hero-img { position:relative; z-index:2; aspect-ratio:4/5; overflow:hidden; border-radius:4px; box-shadow:0 36px 80px rgba(8,37,26,0.26); animation:heroRise 1.1s cubic-bezier(0.22,1,0.36,1) both; }
.consult-page .consult-hero-img img { width:100%; height:100%; object-fit:cover; object-position:center; }
.consult-page .consult-hero-ring { position:absolute; top:140px; right:-26px; bottom:48px; left:-26px; border:1px solid rgba(95,111,66,0.35); border-radius:6px; z-index:1; }
.consult-page .consult-hero-badge { position:absolute; bottom:24px; left:-16px; z-index:4; background:var(--gold); color:var(--forest); padding:16px 20px; border-radius:4px; box-shadow:0 16px 40px rgba(201,169,110,0.45); animation:float 4.5s ease-in-out infinite; }
.consult-page .consult-hero-badge strong { display:block; font-family:var(--display); font-size:1.5rem; font-weight:700; line-height:1; }
.consult-page .consult-hero-badge span { font-size:0.66rem; font-weight:500; letter-spacing:0.1em; text-transform:uppercase; }

.consult-page .cprocess { background:var(--white); padding:96px 0; }
.consult-page .cprocess-inner { max-width:var(--max); margin:0 auto; padding:var(--pad); }
.consult-page .cprocess-head { text-align:center; margin-bottom:64px; }
.consult-page .cprocess-head .eyebrow { justify-content:center; }
.consult-page .cprocess-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.consult-page .cprocess-card { background:var(--off-white); border:1px solid var(--border); border-radius:4px; padding:38px 30px 42px; min-height:280px; position:relative; overflow:hidden; transition:opacity 0.7s ease, transform 0.7s ease, box-shadow 0.4s; }
.consult-page .cprocess-card::after { content:''; position:absolute; left:0; bottom:0; height:3px; width:100%; background:var(--sage); transform:scaleX(0); transform-origin:left; transition:transform 0.45s ease; }
.consult-page .cprocess-card.visible:hover { transform:translateY(-5px); box-shadow:0 22px 50px rgba(8,37,26,0.1); }
.consult-page .cprocess-card.visible:hover::after { transform:scaleX(1); }
.consult-page .cprocess-num { font-family:var(--display); font-size:2.6rem; font-weight:700; color:rgba(8,37,26,0.1); line-height:1; margin-bottom:18px; }
.consult-page .cprocess-title { font-family:var(--brand); font-size:1rem; font-weight:400; letter-spacing:0.04em; color:var(--forest); margin-bottom:12px; }
.consult-page .cprocess-desc { font-size:0.83rem; font-weight:300; line-height:1.75; color:var(--text-mid); }

.consult-page .booking { background:var(--lt-green); padding:96px 0; }
.consult-page .booking-inner { max-width:var(--max); margin:0 auto; padding:var(--pad); display:grid; grid-template-columns:1.4fr 0.85fr; gap:48px; align-items:start; }
.consult-page .booking-form-wrap { background:var(--white); border:1px solid var(--border); border-radius:4px; padding:48px; }
.consult-page .booking-form-wrap .eyebrow { color:var(--sage); }
.consult-page .booking-form-wrap h2 { font-family:var(--brand); font-size:1.7rem; font-weight:400; letter-spacing:0.03em; color:var(--forest); margin-bottom:10px; }
.consult-page .booking-form-wrap > p { font-size:0.9rem; font-weight:300; line-height:1.7; color:var(--text-mid); margin-bottom:32px; }
.consult-page .form-row { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.consult-page .form-field { margin-bottom:18px; }
.consult-page .form-field.full { grid-column:1 / -1; }
.consult-page .form-field label { display:block; font-size:0.72rem; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; color:var(--forest); margin-bottom:8px; }
.consult-page .form-field input, .consult-page .form-field select, .consult-page .form-field textarea { width:100%; padding:13px 16px; border:1.5px solid var(--border); border-radius:3px; font-family:var(--body); font-size:0.88rem; color:var(--text); background:var(--near-wh); outline:none; transition:border-color 0.25s; }
.consult-page .form-field input:focus, .consult-page .form-field select:focus, .consult-page .form-field textarea:focus { border-color:var(--sage); }
.consult-page .form-field textarea { resize:vertical; min-height:110px; }
.consult-page .form-note { font-size:0.76rem; font-weight:300; color:var(--text-lt); margin-top:16px; line-height:1.6; }
.consult-page .booking-submit { width:100%; justify-content:center; margin-top:8px; }
.consult-page .booking-side { display:flex; flex-direction:column; gap:20px; }
.consult-page .side-card { background:var(--forest); color:var(--white); border-radius:4px; padding:36px 32px; }
.consult-page .side-card h3 { font-family:var(--brand); font-size:1.15rem; font-weight:400; letter-spacing:0.04em; color:var(--lime); margin-bottom:22px; }
.consult-page .side-list { list-style:none; }
.consult-page .side-list li { display:flex; gap:12px; align-items:flex-start; font-size:0.86rem; font-weight:300; line-height:1.6; color:rgba(255,255,255,0.78); margin-bottom:16px; }
.consult-page .side-list li:last-child { margin-bottom:0; }
.consult-page .side-list li svg { flex-shrink:0; margin-top:2px; }
.consult-page .side-card-wa { background:#0d3324; }
.consult-page .side-card-wa p { font-size:0.88rem; font-weight:300; line-height:1.7; color:rgba(255,255,255,0.7); margin-bottom:22px; }
.consult-page .side-contact { display:flex; flex-direction:column; gap:14px; }
.consult-page .side-contact a { display:flex; align-items:center; gap:12px; font-size:0.85rem; color:rgba(255,255,255,0.85); transition:color 0.2s; }
.consult-page .side-contact a:hover { color:var(--lime); }
.consult-page .side-contact .ic { width:34px; height:34px; border-radius:50%; background:rgba(223,226,183,0.12); display:flex; align-items:center; justify-content:center; flex-shrink:0; }

.consult-page .expect-section { background:var(--white); padding:96px 0; }
.consult-page .expect-inner { max-width:var(--max); margin:0 auto; padding:var(--pad); }
.consult-page .expect-head { text-align:center; margin-bottom:56px; }
.consult-page .expect-head .eyebrow { justify-content:center; }
.consult-page .expect-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.consult-page .expect-card { padding:0 8px; text-align:center; }
.consult-page .expect-icon-wrap { width:64px; height:64px; border-radius:50%; background:var(--lt-green); display:flex; align-items:center; justify-content:center; margin:0 auto 22px; transition:all 0.4s; }
.consult-page .expect-card:hover .expect-icon-wrap { background:var(--sage); transform:scale(1.06); }
.consult-page .expect-icon { width:30px; height:30px; transition:all 0.4s; }
.consult-page .expect-title { font-family:var(--brand); font-size:1.05rem; font-weight:400; letter-spacing:0.04em; color:var(--forest); margin-bottom:12px; }
.consult-page .expect-desc { font-size:0.85rem; font-weight:300; line-height:1.8; color:var(--text-mid); }

.consult-page .faq-section { background:var(--off-white); }
.consult-page .cta-section::before { background-size:cover; background-position:center; }

@media (max-width:1024px) {
  .consult-page .consult-hero-inner { grid-template-columns:1fr; gap:40px; }
  .consult-page .consult-hero-text { padding:150px 0 10px; }
  .consult-page .consult-hero-figure { padding:0 0 70px; max-width:440px; }
  .consult-page .consult-hero-ring { top:0; }
  .consult-page .cprocess-grid { grid-template-columns:repeat(2,1fr); }
  .consult-page .booking-inner { grid-template-columns:1fr; }
  .consult-page .expect-grid { grid-template-columns:1fr; max-width:480px; margin:0 auto; }
}
@media (max-width:900px) {
  .consult-page .booking-form-wrap { padding:32px 24px; }
  .consult-page .cprocess, .consult-page .booking, .consult-page .expect-section { padding:64px 0; }
}
@media (max-width:600px) {
  .consult-page .cprocess-grid { grid-template-columns:1fr; }
  .consult-page .form-row { grid-template-columns:1fr; }
}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testi-page { --wa:#25D366; --wa-bg:#E5DDD5; --wa-head:#075E54; --wa-bubble-in:#FFFFFF; --wa-bubble-out:#DCF8C6; }
.testi-page .testi-hero { background:var(--cream); position:relative; overflow:hidden; padding:150px 0 70px; }
.testi-page .testi-hero::before { content:''; position:absolute; top:-160px; right:-120px; width:480px; height:480px; background:radial-gradient(ellipse, rgba(95,111,66,0.1) 0%, transparent 70%); pointer-events:none; z-index:1; }
.testi-page .page-scrim { background:linear-gradient(180deg, rgba(250,246,238,0.95) 0%, rgba(250,246,238,0.9) 50%, rgba(250,246,238,0.95) 100%); }
.testi-page .testi-hero-inner { position:relative; z-index:2; max-width:var(--max); margin:0 auto; padding:var(--pad); text-align:center; }
.testi-page .testi-hero .eyebrow { justify-content:center; }
.testi-page .testi-hero h1 { font-family:var(--brand); font-size:clamp(2.4rem,4.4vw,4rem); font-weight:400; line-height:1.12; letter-spacing:0.03em; color:var(--forest); margin-bottom:22px; }
.testi-page .testi-hero h1 em { font-style:normal; color:var(--pink); }
.testi-page .testi-hero p { font-size:1.02rem; font-weight:300; line-height:1.85; color:var(--text-mid); max-width:560px; margin:0 auto 18px; }
.testi-page .testi-hero .note { font-size:0.8rem; color:var(--text-lt); letter-spacing:0.04em; }

.testi-page .testi-statbar { background:var(--lime); }
.testi-page .testi-statbar-inner { max-width:var(--max); margin:0 auto; padding:28px 48px; display:flex; justify-content:center; gap:64px; flex-wrap:wrap; }
.testi-page .testi-stat { text-align:center; }
.testi-page .testi-stat-num { font-family:var(--display); font-size:1.9rem; font-weight:700; color:var(--forest); line-height:1; }
.testi-page .testi-stat-num span { color:var(--sage); }
.testi-page .testi-stat-label { font-size:0.7rem; font-weight:500; letter-spacing:0.1em; text-transform:uppercase; color:rgba(8,37,26,0.6); margin-top:4px; }

.testi-page .gallery-section { background:var(--white); padding:80px 0 100px; }
.testi-page .gallery-inner { max-width:var(--max); margin:0 auto; padding:var(--pad); }
.testi-page .gallery-intro { text-align:center; margin-bottom:48px; }
.testi-page .gallery-intro .eyebrow { justify-content:center; }
.testi-page .masonry { columns:3; column-gap:22px; }
.testi-page .shot { break-inside:avoid; margin-bottom:22px; border-radius:14px; overflow:hidden; box-shadow:0 8px 30px rgba(8,37,26,0.10); border:1px solid var(--border); cursor:zoom-in; transition:transform 0.35s, box-shadow 0.35s; background:var(--white); }
.testi-page .shot:hover { transform:translateY(-4px); box-shadow:0 18px 44px rgba(8,37,26,0.14); }
.testi-page .shot img { width:100%; display:block; }

/* WhatsApp (light) — generic avatar, names hidden */
.testi-page .wa-head { background:var(--wa-head); color:#fff; display:flex; align-items:center; gap:10px; padding:11px 14px; }
.testi-page .wa-back { font-size:1.2rem; opacity:0.85; }
.testi-page .wa-avatar { width:36px; height:36px; border-radius:50%; background:#6b7b8a; display:flex; align-items:center; justify-content:center; color:#fff; flex-shrink:0; }
.testi-page .wa-avatar svg, .testi-page .ig-ava svg { width:22px; height:22px; }
.testi-page .wa-contact { line-height:1.25; }
.testi-page .wa-contact .n { font-size:0.88rem; font-weight:600; color:#fff; }
.testi-page .wa-contact .s { font-size:0.66rem; color:rgba(255,255,255,0.7); }
.testi-page .wa-head .wa-ic { margin-left:auto; display:flex; gap:16px; color:rgba(255,255,255,0.8); }
.testi-page .wa-body { background:var(--wa-bg); padding:16px 12px; display:flex; flex-direction:column; gap:7px; background-image:radial-gradient(rgba(0,0,0,0.02) 1px, transparent 1px); background-size:14px 14px; }
.testi-page .wa-bubble { max-width:85%; padding:7px 10px 5px; border-radius:9px; font-size:0.82rem; line-height:1.5; color:#111; position:relative; box-shadow:0 1px 1px rgba(0,0,0,0.10); }
.testi-page .wa-bubble .t { display:block; font-size:0.58rem; color:rgba(0,0,0,0.45); text-align:right; margin-top:3px; }
.testi-page .wa-in { background:var(--wa-bubble-in); align-self:flex-start; border-top-left-radius:2px; }
.testi-page .wa-out { background:var(--wa-bubble-out); align-self:flex-end; border-top-right-radius:2px; }
.testi-page .wa-out .tick { color:#34B7F1; }

/* Instagram DM */
.testi-page .ig-head { display:flex; align-items:center; gap:10px; padding:10px 14px; border-bottom:1px solid #efefef; background:#fff; }
.testi-page .ig-back { color:#262626; font-size:1.3rem; line-height:1; }
.testi-page .ig-ava { width:34px; height:34px; border-radius:50%; padding:2px; background:linear-gradient(45deg,#feda75,#fa7e1e,#d62976,#962fbf); flex-shrink:0; }
.testi-page .ig-ava div { width:100%; height:100%; border-radius:50%; background:var(--sage); display:flex; align-items:center; justify-content:center; color:#fff; border:2px solid #fff; }
.testi-page .ig-who { line-height:1.2; }
.testi-page .ig-who .n { font-size:0.86rem; font-weight:600; color:#262626; }
.testi-page .ig-who .s { font-size:0.64rem; color:#8e8e8e; }
.testi-page .ig-head .ig-ic { margin-left:auto; display:flex; gap:16px; color:#262626; }
.testi-page .ig-body { background:#fff; padding:14px 12px 12px; display:flex; flex-direction:column; gap:5px; }
.testi-page .ig-bubble { max-width:82%; padding:9px 14px; font-size:0.82rem; line-height:1.45; border-radius:20px; }
.testi-page .ig-in { background:#efefef; color:#262626; align-self:flex-start; border-bottom-left-radius:5px; }
.testi-page .ig-out { background:linear-gradient(135deg,#5b51d8,#962fbf 55%,#d62976); color:#fff; align-self:flex-end; border-bottom-right-radius:5px; }
.testi-page .ig-inputbar { display:flex; align-items:center; gap:10px; margin-top:10px; border:1px solid #dbdbdb; border-radius:22px; padding:9px 14px; }
.testi-page .ig-inputbar .ph { font-size:0.78rem; color:#8e8e8e; }
.testi-page .ig-inputbar .ig-ic2 { margin-left:auto; display:flex; gap:12px; color:#262626; }

.testi-page .shot-result { display:block; margin:12px 12px 14px; width:max-content; font-size:0.66rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; padding:5px 12px; border-radius:100px; background:var(--lt-green); color:var(--sage); }
.testi-page .gallery-cta { text-align:center; margin-top:46px; }
.testi-page .privacy-note { text-align:center; margin-top:22px; font-size:0.82rem; color:var(--text-lt); font-weight:300; line-height:1.7; }
.btn-ig { background:linear-gradient(135deg,#5b51d8,#962fbf 45%,#d62976 75%,#fa7e1e); color:#fff; }
.btn-ig:hover { filter:brightness(1.06); transform:translateY(-2px); }

.testi-lightbox { position:fixed; inset:0; z-index:500; background:rgba(8,20,14,0.82); backdrop-filter:blur(4px); display:none; align-items:center; justify-content:center; padding:40px 20px; }
.testi-lightbox.open { display:flex; animation:lbFade 0.3s ease; }
@keyframes lbFade { from { opacity:0; } to { opacity:1; } }
.testi-lightbox-inner { width:100%; max-width:440px; max-height:90vh; overflow:auto; border-radius:12px; box-shadow:0 30px 80px rgba(0,0,0,0.5); animation:lbZoom 0.3s cubic-bezier(0.22,1,0.36,1); }
@keyframes lbZoom { from { transform:scale(0.9); opacity:0; } to { transform:scale(1); opacity:1; } }
.testi-lightbox-inner .shot { margin:0; cursor:default; box-shadow:none; border:none; }
.testi-lightbox-inner .shot:hover { transform:none; }
.lb-close { position:fixed; top:22px; right:26px; width:42px; height:42px; border-radius:50%; background:rgba(255,255,255,0.12); border:1px solid rgba(255,255,255,0.25); color:#fff; font-size:1.4rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background 0.25s; z-index:501; }
.lb-close:hover { background:rgba(255,255,255,0.25); }

.testi-page .cta-section::before { background-size:cover; background-position:center; }

@media (max-width:1024px) { .testi-page .masonry { columns:2; } }
@media (max-width:900px) {
  .testi-page .testi-statbar-inner { gap:36px; }
  .testi-page .testi-hero { padding:130px 0 56px; }
  .testi-page .gallery-section { padding:56px 0; }
}
@media (max-width:600px) { .testi-page .masonry { columns:1; } }

/* ============================================================
   CONDITIONS LANDING (archive-condition.php)
   ============================================================ */
.conditions-page .cond-hero { position:relative; overflow:hidden; background:var(--cream); }
.conditions-page .cond-hero::before { content:''; position:absolute; top:-160px; left:-160px; width:520px; height:520px; background:radial-gradient(ellipse, rgba(95,111,66,0.1) 0%, transparent 70%); pointer-events:none; z-index:1; }
.conditions-page .cond-hero-inner { position:relative; z-index:2; max-width:var(--max); margin:0 auto; padding:var(--pad); display:grid; grid-template-columns:1.05fr 0.95fr; gap:56px; align-items:center; }
.conditions-page .cond-hero-text { padding:150px 0 90px; }
.conditions-page .cond-hero-text h1 { font-family:var(--brand); font-size:clamp(2.3rem,4vw,3.8rem); font-weight:400; line-height:1.14; letter-spacing:0.03em; color:var(--forest); margin-bottom:26px; }
.conditions-page .cond-hero-text h1 em { font-style:normal; color:var(--pink); display:block; }
.conditions-page .cond-hero-sub { font-size:1.02rem; font-weight:300; line-height:1.85; color:var(--text-mid); max-width:470px; margin-bottom:40px; }
.conditions-page .cond-hero-actions { display:flex; gap:12px; flex-wrap:wrap; }
.conditions-page .cond-hero-figure { position:relative; padding:120px 0 60px; }
.conditions-page .cond-hero-img { position:relative; z-index:2; aspect-ratio:4/5; overflow:hidden; border-radius:4px; box-shadow:0 36px 80px rgba(8,37,26,0.26); animation:heroRise 1.1s cubic-bezier(0.22,1,0.36,1) both; }
.conditions-page .cond-hero-img img { width:100%; height:100%; object-fit:cover; object-position:center; }
.conditions-page .cond-hero-ring { position:absolute; top:140px; right:-26px; bottom:48px; left:-26px; border:1px solid rgba(95,111,66,0.35); border-radius:6px; z-index:1; }
.conditions-page .cond-hero-badge { position:absolute; bottom:24px; left:-16px; z-index:4; background:var(--gold); color:var(--forest); padding:16px 20px; border-radius:4px; box-shadow:0 16px 40px rgba(201,169,110,0.45); animation:float 4.5s ease-in-out infinite; }
.conditions-page .cond-hero-badge strong { display:block; font-family:var(--display); font-size:1.5rem; font-weight:700; line-height:1; }
.conditions-page .cond-hero-badge span { font-size:0.66rem; font-weight:500; letter-spacing:0.1em; text-transform:uppercase; }

.conditions-page .cond-intro { background:var(--white); padding:96px 0 0; }
.conditions-page .cond-intro-inner { max-width:var(--max); margin:0 auto; padding:var(--pad); display:grid; grid-template-columns:1fr 1.5fr; gap:80px; align-items:end; }
.conditions-page .cond-intro-left h2.display { max-width:420px; }
.conditions-page .cond-intro-right p { font-size:1rem; font-weight:300; line-height:1.9; color:var(--text-mid); max-width:560px; margin-bottom:24px; }

.conditions-page .cond-grid-section { background:var(--white); padding:64px 0 100px; }
.conditions-page .cond-grid-inner { max-width:var(--max); margin:0 auto; padding:var(--pad); }
.conditions-page .cond-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.conditions-page .cond-card { background:var(--white); border:1px solid var(--border); border-radius:4px; padding:40px 32px 36px; min-height:330px; display:flex; flex-direction:column; position:relative; overflow:hidden; transition:opacity 0.7s ease, transform 0.7s ease, box-shadow 0.4s; }
.conditions-page .cond-card::after { content:''; position:absolute; left:0; bottom:0; height:3px; width:100%; background:linear-gradient(90deg, var(--sage), var(--pink)); transform:scaleX(0); transform-origin:left; transition:transform 0.45s ease; }
.conditions-page .cond-card.visible:hover { transform:translateY(-6px); box-shadow:0 22px 50px rgba(8,37,26,0.1); }
.conditions-page .cond-card.visible:hover::after { transform:scaleX(1); }
.conditions-page .cond-icon-wrap { width:60px; height:60px; border-radius:50%; background:var(--lt-green); display:flex; align-items:center; justify-content:center; margin-bottom:22px; transition:all 0.4s; }
.conditions-page .cond-card.visible:hover .cond-icon-wrap { background:var(--sage); transform:rotate(-6deg) scale(1.05); }
.conditions-page .cond-card.visible:hover .cond-icon path, .conditions-page .cond-card.visible:hover .cond-icon circle, .conditions-page .cond-card.visible:hover .cond-icon ellipse { stroke:var(--lime); }
.conditions-page .cond-icon { width:30px; height:30px; transition:all 0.4s; }
.conditions-page .cond-name { font-family:var(--brand); font-size:1.1rem; font-weight:400; letter-spacing:0.04em; color:var(--forest); margin-bottom:12px; }
.conditions-page .cond-desc { font-size:0.84rem; font-weight:300; line-height:1.8; color:var(--text-mid); margin-bottom:18px; }
.conditions-page .cond-link { margin-top:auto; font-size:0.72rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; color:var(--sage); display:inline-flex; align-items:center; gap:6px; transition:gap 0.25s; }
.conditions-page .cond-link:hover { gap:10px; }

.conditions-page .cond-features { background:var(--lt-green); padding:100px 0; }
.conditions-page .cond-features-inner { max-width:var(--max); margin:0 auto; padding:var(--pad); }
.conditions-page .cond-features-head { text-align:center; margin-bottom:72px; }
.conditions-page .cond-features-head .eyebrow { justify-content:center; }
.conditions-page .feature-row { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; margin-bottom:72px; }
.conditions-page .feature-row:last-child { margin-bottom:0; }
.conditions-page .feature-row.flip .feature-img { order:2; }
.conditions-page .feature-img { position:relative; }
.conditions-page .feature-img-frame { aspect-ratio:5/4; overflow:hidden; border-radius:4px; box-shadow:0 24px 60px rgba(8,37,26,0.14); }
.conditions-page .feature-img-frame img { width:100%; height:100%; object-fit:cover; transition:transform 0.7s cubic-bezier(0.22,1,0.36,1); }
.conditions-page .feature-img:hover img { transform:scale(1.05); }
.conditions-page .feature-tag { position:absolute; top:-14px; left:-14px; background:var(--pink); color:var(--forest); padding:8px 16px; border-radius:3px; font-size:0.68rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; }
.conditions-page .feature-row.flip .feature-tag { left:auto; right:-14px; }
.conditions-page .feature-text .eyebrow { color:var(--sage); }
.conditions-page .feature-text h3 { font-family:var(--brand); font-size:clamp(1.5rem,2.4vw,2.1rem); font-weight:400; letter-spacing:0.03em; color:var(--forest); line-height:1.2; margin-bottom:18px; }
.conditions-page .feature-text p { font-size:0.92rem; font-weight:300; line-height:1.9; color:var(--text-mid); margin-bottom:16px; }
.conditions-page .feature-points { list-style:none; margin-top:20px; }
.conditions-page .feature-points li { display:flex; gap:12px; align-items:flex-start; font-size:0.86rem; font-weight:300; line-height:1.6; color:var(--text-mid); margin-bottom:12px; }
.conditions-page .feature-points li svg { flex-shrink:0; margin-top:3px; }

.conditions-page .cond-midcta { background:linear-gradient(135deg, var(--accent-dark) 0%, #0c2c1e 100%); padding:80px 0; position:relative; overflow:hidden; }
.conditions-page .cond-midcta::before { content:''; position:absolute; top:-120px; right:-80px; width:400px; height:400px; background:radial-gradient(ellipse, rgba(95,111,66,0.25) 0%, transparent 65%); pointer-events:none; }
.conditions-page .cond-midcta-inner { position:relative; z-index:1; max-width:760px; margin:0 auto; padding:var(--pad); text-align:center; }
.conditions-page .cond-midcta .eyebrow { justify-content:center; color:var(--lime); }
.conditions-page .cond-midcta h2 { font-family:var(--brand); font-size:clamp(1.8rem,3vw,2.6rem); font-weight:400; letter-spacing:0.03em; color:var(--white); line-height:1.2; margin-bottom:18px; }
.conditions-page .cond-midcta h2 .pink { color:var(--pink); }
.conditions-page .cond-midcta p { font-size:0.97rem; font-weight:300; line-height:1.8; color:rgba(255,255,255,0.6); margin-bottom:36px; }
.conditions-page .cond-midcta-actions { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

.conditions-page .stats-strip { background:var(--cream); }
.conditions-page .stats-strip .stat-item { background:var(--cream); }
.conditions-page .stats-strip .stat-item:hover { background:#f1ece0; }
.conditions-page .cta-section::before { background-size:cover; background-position:center; }

@media (max-width:1024px) {
  .conditions-page .cond-hero-inner { grid-template-columns:1fr; gap:40px; }
  .conditions-page .cond-hero-text { padding:150px 0 10px; }
  .conditions-page .cond-hero-figure { padding:0 0 60px; max-width:440px; }
  .conditions-page .cond-hero-ring { top:0; }
  .conditions-page .cond-intro-inner { grid-template-columns:1fr; gap:32px; }
  .conditions-page .cond-grid { grid-template-columns:repeat(2,1fr); }
  .conditions-page .feature-row { grid-template-columns:1fr; gap:32px; }
  .conditions-page .feature-row.flip .feature-img { order:0; }
}
@media (max-width:600px) { .conditions-page .cond-grid { grid-template-columns:1fr; } }

/* ============================================================
   BLOG INDEX (home.php)
   ============================================================ */
.blog-page .blog-hero { background:var(--cream); position:relative; overflow:hidden; padding:150px 0 80px; }
.blog-page .blog-hero::before { content:''; position:absolute; top:-160px; right:-120px; width:480px; height:480px; background:radial-gradient(ellipse, rgba(95,111,66,0.1) 0%, transparent 70%); pointer-events:none; }
.blog-page .blog-hero-inner { position:relative; z-index:2; max-width:var(--max); margin:0 auto; padding:var(--pad); text-align:center; }
.blog-page .blog-hero .eyebrow { justify-content:center; }
.blog-page .blog-hero h1 { font-family:var(--brand); font-size:clamp(2.4rem,4.4vw,4rem); font-weight:400; line-height:1.12; letter-spacing:0.03em; color:var(--forest); margin-bottom:22px; }
.blog-page .blog-hero h1 em { font-style:normal; color:var(--pink); }
.blog-page .blog-hero p { font-size:1.02rem; font-weight:300; line-height:1.85; color:var(--text-mid); max-width:540px; margin:0 auto; }

.blog-page .featured-section { background:var(--white); padding:72px 0 40px; }
.blog-page .featured-inner { max-width:var(--max); margin:0 auto; padding:var(--pad); }
.blog-page .featured-card { display:grid; grid-template-columns:1.2fr 1fr; gap:0; border:1px solid var(--border); border-radius:4px; overflow:hidden; transition:box-shadow 0.4s; }
.blog-page .featured-card:hover { box-shadow:0 24px 60px rgba(8,37,26,0.12); }
.blog-page .featured-img { position:relative; overflow:hidden; min-height:380px; }
.blog-page .featured-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.7s cubic-bezier(0.22,1,0.36,1); }
.blog-page .featured-card:hover .featured-img img { transform:scale(1.05); }
.blog-page .featured-flag { position:absolute; top:18px; left:18px; font-size:0.66rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; background:var(--pink); color:var(--forest); padding:6px 14px; }
.blog-page .featured-body { padding:52px 48px; display:flex; flex-direction:column; justify-content:center; background:var(--lt-green); }
.blog-page .featured-meta { display:flex; gap:14px; align-items:center; margin-bottom:18px; }
.blog-page .featured-cat { font-size:0.66rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--sage); }
.blog-page .featured-date { font-size:0.7rem; letter-spacing:0.08em; color:var(--text-lt); text-transform:uppercase; }
.blog-page .featured-title { font-family:var(--brand); font-size:clamp(1.6rem,2.6vw,2.2rem); font-weight:400; letter-spacing:0.02em; color:var(--forest); line-height:1.25; margin-bottom:18px; }
.blog-page .featured-excerpt { font-size:0.92rem; font-weight:300; line-height:1.85; color:var(--text-mid); margin-bottom:28px; }
.blog-page .read-link { font-size:0.74rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; color:var(--forest); display:inline-flex; align-items:center; gap:8px; transition:gap 0.25s; }
.blog-page .featured-card:hover .read-link { gap:12px; }

.blog-page .blog-section { background:var(--white); padding:48px 0 100px; }
.blog-page .blog-inner { max-width:var(--max); margin:0 auto; padding:var(--pad); }
.blog-page .blog-filters { display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-bottom:52px; }
.blog-page .blog-filter { font-family:var(--body); font-size:0.74rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; padding:10px 22px; border:1.5px solid var(--border); background:var(--white); color:var(--text-mid); border-radius:3px; cursor:pointer; transition:all 0.25s; }
.blog-page .blog-filter:hover { border-color:var(--sage); color:var(--sage); }
.blog-page .blog-filter.active { background:var(--forest); border-color:var(--forest); color:var(--white); }
.blog-page .blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.blog-page .blog-card.hide { display:none; }
.blog-page .blog-loadmore-wrap { text-align:center; margin-top:56px; }
.blog-page .blog-loadmore { cursor:pointer; }
.blog-page .blog-card { background:var(--white); border:1px solid var(--border); border-radius:4px; overflow:hidden; display:flex; flex-direction:column; transition:box-shadow 0.4s, transform 0.4s, opacity 0.6s; }
.blog-page .blog-card.visible:hover { box-shadow:0 20px 50px rgba(8,37,26,0.1); transform:translateY(-5px); }
.blog-page .blog-card.hide { display:none; }
.blog-page .blog-img { height:220px; overflow:hidden; position:relative; }
.blog-page .blog-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.7s cubic-bezier(0.22,1,0.36,1); }
.blog-page .blog-card.visible:hover .blog-img img { transform:scale(1.06); }
.blog-page .blog-cat { position:absolute; bottom:14px; left:14px; font-size:0.64rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; background:var(--sage); color:var(--white); padding:5px 12px; }
.blog-page .blog-body { padding:26px 24px; display:flex; flex-direction:column; flex:1; }
.blog-page .blog-date { font-size:0.68rem; letter-spacing:0.1em; color:var(--text-lt); text-transform:uppercase; margin-bottom:12px; }
.blog-page .blog-title { font-family:var(--brand); font-size:1.08rem; font-weight:400; letter-spacing:0.02em; color:var(--forest); line-height:1.4; margin-bottom:12px; }
.blog-page .blog-title a { color:inherit; }
.blog-page .blog-excerpt { font-size:0.83rem; font-weight:300; line-height:1.7; color:var(--text-mid); margin-bottom:22px; }
.blog-page .blog-read { margin-top:auto; font-size:0.72rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; color:var(--sage); display:inline-flex; align-items:center; gap:6px; transition:gap 0.25s; }
.blog-page .blog-read:hover { gap:10px; }

.blog-page .news-section { background:linear-gradient(135deg, var(--accent-dark) 0%, #0c2c1e 100%); padding:88px 0; position:relative; overflow:hidden; }
.blog-page .news-section::before { content:''; position:absolute; top:-120px; left:-80px; width:420px; height:420px; background:radial-gradient(ellipse, rgba(95,111,66,0.22) 0%, transparent 65%); pointer-events:none; }
.blog-page .news-inner { position:relative; z-index:1; max-width:600px; margin:0 auto; padding:var(--pad); text-align:center; }
.blog-page .news-inner .eyebrow { justify-content:center; color:var(--lime); }
.blog-page .news-inner h2 { font-family:var(--brand); font-size:clamp(1.8rem,3vw,2.6rem); font-weight:400; letter-spacing:0.03em; color:var(--white); line-height:1.2; margin-bottom:16px; }
.blog-page .news-inner h2 .pink { color:var(--pink); }
.blog-page .news-inner p { font-size:0.95rem; font-weight:300; line-height:1.75; color:rgba(255,255,255,0.6); margin-bottom:36px; }
.blog-page .news-form { display:flex; gap:0; max-width:460px; margin:0 auto; }
.blog-page .news-input { flex:1; padding:14px 20px; border:1.5px solid rgba(223,226,183,0.3); border-right:none; background:rgba(255,255,255,0.05); color:var(--white); font-family:var(--body); font-size:0.85rem; outline:none; border-radius:3px 0 0 3px; }
.blog-page .news-input::placeholder { color:rgba(255,255,255,0.4); }
.blog-page .news-btn { background:var(--pink); color:var(--forest); border:none; padding:14px 24px; font-family:var(--body); font-size:0.76rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; cursor:pointer; border-radius:0 3px 3px 0; flex-shrink:0; }
.blog-page .news-btn:hover { background:var(--lime); }

.blog-page .cta-section { background:var(--cream); padding:96px 0; }
.blog-page .cta-inner { max-width:720px; margin:0 auto; padding:var(--pad); text-align:center; }
.blog-page .cta-inner .eyebrow { justify-content:center; }
.blog-page .cta-inner h2.display { font-size:clamp(2.2rem,4vw,3.2rem); margin-bottom:20px; color:var(--forest); }
.blog-page .cta-inner p { font-size:1rem; font-weight:300; color:var(--text-mid); line-height:1.75; margin-bottom:40px; }
.blog-page .cta-actions { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

@media (max-width:1024px) { .blog-page .blog-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:900px) {
  .blog-page .featured-card { grid-template-columns:1fr; }
  .blog-page .featured-img { min-height:260px; }
  .blog-page .featured-body { padding:40px 28px; }
  .blog-page .blog-hero { padding:130px 0 56px; }
}
@media (max-width:600px) {
  .blog-page .blog-grid { grid-template-columns:1fr; }
  .blog-page .news-form { flex-direction:column; }
  .blog-page .news-input { border-right:1.5px solid rgba(223,226,183,0.3); border-radius:3px; margin-bottom:10px; }
  .blog-page .news-btn { border-radius:3px; }
}

/* ============================================================
   SINGLE POST (single.php)
   ============================================================ */
.post-page .post-hero { background:var(--cream); padding-top:120px; position:relative; overflow:hidden; }
.post-page .post-hero::before { content:''; position:absolute; top:-160px; right:-160px; width:520px; height:520px; background:radial-gradient(ellipse, rgba(95,111,66,0.1) 0%, transparent 70%); pointer-events:none; }
.post-page .post-hero-inner { position:relative; z-index:2; max-width:820px; margin:0 auto; padding:48px 48px 40px; text-align:center; }
.post-page .post-breadcrumb { display:flex; gap:8px; align-items:center; justify-content:center; margin-bottom:28px; flex-wrap:wrap; }
.post-page .post-breadcrumb a, .post-page .post-breadcrumb span { font-size:0.72rem; letter-spacing:0.06em; color:var(--text-lt); }
.post-page .post-breadcrumb a:hover { color:var(--sage); }
.post-page .post-breadcrumb .sep { color:var(--border); }
.post-page .post-flag { display:inline-block; font-size:0.66rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; background:var(--sage); color:var(--white); padding:6px 14px; border-radius:3px; margin-bottom:20px; }
.post-page .post-hero h1 { font-family:var(--brand); font-size:clamp(1.9rem,3.4vw,2.9rem); font-weight:400; line-height:1.2; letter-spacing:0.02em; color:var(--forest); margin-bottom:22px; }
.post-page .post-meta { display:flex; gap:18px; align-items:center; justify-content:center; flex-wrap:wrap; }
.post-page .post-meta .author { display:flex; align-items:center; gap:10px; }
.post-page .post-meta .av { width:34px; height:34px; border-radius:50%; background:var(--sage); color:var(--lime); display:flex; align-items:center; justify-content:center; font-family:var(--display); font-size:0.78rem; font-weight:600; }
.post-page .post-meta .who { font-size:0.8rem; font-weight:500; color:var(--forest); }
.post-page .post-meta .dot { width:3px; height:3px; border-radius:50%; background:var(--border); }
.post-page .post-meta .date, .post-page .post-meta .rt { font-size:0.78rem; color:var(--text-lt); }
.post-page .post-feature-img { max-width:980px; margin:0 auto; padding:0 48px; }
.post-page .post-feature-img .fr { aspect-ratio:16/8; overflow:hidden; border-radius:6px; box-shadow:0 30px 70px rgba(8,37,26,0.18); }
.post-page .post-feature-img img { width:100%; height:100%; object-fit:cover; }

.post-page .post-body { background:var(--white); padding:64px 0 90px; }
.post-page .post-body-inner { max-width:720px; margin:0 auto; padding:var(--pad); }
.post-page .post-body-inner p { font-size:1.04rem; font-weight:300; line-height:1.95; color:var(--text-mid); margin-bottom:26px; }
.post-page .post-body-inner > p:first-child strong, .post-page .post-body-inner .lead { font-weight:400; }
.post-page .post-body-inner h2 { font-family:var(--brand); font-size:1.6rem; font-weight:400; letter-spacing:0.02em; color:var(--forest); margin:42px 0 18px; }
.post-page .post-body-inner h3 { font-family:var(--brand); font-size:1.3rem; font-weight:400; color:var(--forest); margin:32px 0 14px; }
.post-page .post-body-inner blockquote { border-left:3px solid var(--pink); background:var(--lt-green); border-radius:0 4px 4px 0; padding:24px 28px; margin:32px 0; font-size:1.08rem; font-style:italic; line-height:1.6; color:var(--forest); }
.post-page .post-body-inner blockquote p { font-size:1.08rem; color:var(--forest); margin:0; }
.post-page .post-body-inner ul { list-style:none; margin:0 0 26px; }
.post-page .post-body-inner ul li { display:flex; gap:12px; align-items:flex-start; font-size:1rem; font-weight:300; line-height:1.7; color:var(--text-mid); margin-bottom:14px; }
.post-page .post-body-inner ul li::before { content:''; width:8px; height:8px; border-radius:50%; background:var(--sage); flex-shrink:0; margin-top:9px; }
.post-page .post-body-inner img { border-radius:4px; margin:24px 0; }
.post-page .post-body-inner a { color:var(--sage); border-bottom:1px solid var(--sage); }
.post-page .post-share { max-width:720px; margin:40px auto 0; padding:var(--pad); display:flex; align-items:center; gap:16px; }
.post-page .post-share-line { border-top:1px solid var(--border); padding-top:28px; }
.post-page .post-share span { font-size:0.72rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-lt); }
.post-page .post-share a { width:38px; height:38px; border-radius:50%; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--sage); transition:all 0.25s; }
.post-page .post-share a:hover { background:var(--sage); color:#fff; border-color:var(--sage); }

.post-page .post-author { background:var(--off-white); padding:48px 0; }
.post-page .post-author-inner { max-width:720px; margin:0 auto; padding:var(--pad); display:flex; gap:24px; align-items:center; }
.post-page .post-author-av { width:80px; height:80px; border-radius:50%; overflow:hidden; flex-shrink:0; background:var(--lime); }
.post-page .post-author-av img { width:100%; height:100%; object-fit:cover; }
.post-page .post-author-info h4 { font-family:var(--brand); font-size:1.2rem; font-weight:400; color:var(--forest); margin-bottom:6px; letter-spacing:0.03em; }
.post-page .post-author-info p { font-size:0.88rem; font-weight:300; line-height:1.7; color:var(--text-mid); }

.post-page .related { background:var(--white); padding:80px 0; }
.post-page .related-inner { max-width:var(--max); margin:0 auto; padding:var(--pad); }
.post-page .related-head { text-align:center; margin-bottom:48px; }
.post-page .related-head .eyebrow { justify-content:center; }
.post-page .related-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.post-page .rel-card { background:var(--white); border:1px solid var(--border); border-radius:4px; overflow:hidden; transition:box-shadow 0.4s, transform 0.4s; display:flex; flex-direction:column; }
.post-page .rel-card:hover { box-shadow:0 18px 44px rgba(8,37,26,0.1); transform:translateY(-4px); }
.post-page .rel-img { height:170px; overflow:hidden; position:relative; }
.post-page .rel-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.6s; }
.post-page .rel-card:hover .rel-img img { transform:scale(1.06); }
.post-page .rel-cat { position:absolute; bottom:12px; left:12px; font-size:0.62rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; background:var(--sage); color:#fff; padding:4px 11px; }
.post-page .rel-body { padding:22px; display:flex; flex-direction:column; flex:1; }
.post-page .rel-date { font-size:0.68rem; letter-spacing:0.08em; color:var(--text-lt); text-transform:uppercase; margin-bottom:10px; }
.post-page .rel-name { font-family:var(--brand); font-size:1rem; font-weight:400; letter-spacing:0.02em; color:var(--forest); line-height:1.4; margin-bottom:14px; }
.post-page .rel-name a { color:inherit; }
.post-page .rel-link { margin-top:auto; font-size:0.72rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; color:var(--sage); }
.post-page .cta-section::before { background-size:cover; background-position:center; }

@media (max-width:900px) {
  .post-page .related-grid { grid-template-columns:1fr; }
  .post-page .post-author-inner { flex-direction:column; text-align:center; }
}

/* ============================================================
   SHOP (WooCommerce archive override)
   ============================================================ */
.shop-page .shop-hero { position:relative; overflow:hidden; background:var(--cream); }
.shop-page .shop-hero::before { content:''; position:absolute; top:-160px; right:-160px; width:520px; height:520px; background:radial-gradient(ellipse, rgba(95,111,66,0.1) 0%, transparent 70%); pointer-events:none; }
.shop-page .shop-hero-inner { position:relative; z-index:2; max-width:var(--max); margin:0 auto; padding:var(--pad); display:grid; grid-template-columns:1.05fr 0.95fr; gap:56px; align-items:center; }
.shop-page .shop-hero-text { padding:150px 0 90px; }
.shop-page .shop-hero-text h1 { font-family:var(--brand); font-size:clamp(2.3rem,4vw,3.8rem); font-weight:400; line-height:1.14; letter-spacing:0.03em; color:var(--forest); margin-bottom:26px; }
.shop-page .shop-hero-text h1 em { font-style:normal; color:var(--pink); display:block; }
.shop-page .shop-hero-sub { font-size:1.02rem; font-weight:300; line-height:1.85; color:var(--text-mid); max-width:470px; margin-bottom:40px; }
.shop-page .shop-hero-actions { display:flex; gap:12px; flex-wrap:wrap; }
.shop-page .shop-hero-figure { position:relative; padding:120px 0 70px; }
.shop-page .shop-hero-img { position:relative; z-index:2; aspect-ratio:4/5; overflow:hidden; border-radius:4px; box-shadow:0 36px 80px rgba(8,37,26,0.26); animation:heroRise 1.1s cubic-bezier(0.22,1,0.36,1) both; }
.shop-page .shop-hero-img img { width:100%; height:100%; object-fit:cover; object-position:center; }
.shop-page .shop-hero-ring { position:absolute; top:140px; right:-26px; bottom:48px; left:-26px; border:1px solid rgba(95,111,66,0.35); border-radius:6px; z-index:1; }
.shop-page .shop-hero-badge { position:absolute; bottom:24px; left:-16px; z-index:4; background:var(--gold); color:var(--forest); padding:16px 20px; border-radius:4px; box-shadow:0 16px 40px rgba(201,169,110,0.45); animation:float 4.5s ease-in-out infinite; }
.shop-page .shop-hero-badge strong { display:block; font-family:var(--display); font-size:1.5rem; font-weight:700; line-height:1; }
.shop-page .shop-hero-badge span { font-size:0.66rem; font-weight:500; letter-spacing:0.1em; text-transform:uppercase; }

.shop-page .shop-section { background:var(--white); padding:96px 0; }
.shop-page .shop-inner { max-width:var(--max); margin:0 auto; padding:var(--pad); }
.shop-page .shop-head { text-align:center; margin-bottom:40px; }
.shop-page .shop-head .eyebrow { justify-content:center; }
.shop-page .shop-filters { display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-bottom:52px; }
.shop-page .shop-filter { font-family:var(--body); font-size:0.74rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; padding:10px 22px; border:1.5px solid var(--border); background:var(--white); color:var(--text-mid); border-radius:3px; cursor:pointer; transition:all 0.25s; }
.shop-page .shop-filter:hover { border-color:var(--sage); color:var(--sage); }
.shop-page .shop-filter.active { background:var(--forest); border-color:var(--forest); color:var(--white); }
.shop-page .product-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.shop-page .product-card { background:var(--white); overflow:hidden; border:1px solid rgba(8,37,26,0.06); border-radius:4px; transition:box-shadow 0.4s, transform 0.4s, opacity 0.6s; display:flex; flex-direction:column; }
.shop-page .product-card.visible:hover { box-shadow:0 24px 56px rgba(8,37,26,0.14); transform:translateY(-6px); }
.shop-page .product-card.hide { display:none; }
.shop-page .product-img { aspect-ratio:4/5; overflow:hidden; position:relative; display:block; }
.shop-page .product-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.7s cubic-bezier(0.22,1,0.36,1); }
.shop-page .product-card.visible:hover .product-img img { transform:scale(1.07); }
.shop-page .product-img::after { content:''; position:absolute; inset:0; background:linear-gradient(180deg, transparent 55%, rgba(8,37,26,0.28) 100%); opacity:0.7; transition:opacity 0.4s; }
.shop-page .product-tag-pill { position:absolute; top:16px; left:16px; z-index:2; font-size:0.64rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; padding:6px 13px; background:var(--forest); color:var(--lime); }
.shop-page .product-tag-pill.best { background:var(--pink); color:var(--forest); }
.shop-page .product-body { padding:26px 24px; display:flex; flex-direction:column; flex:1; }
.shop-page .product-cat { font-size:0.64rem; font-weight:600; letter-spacing:0.14em; text-transform:uppercase; color:var(--sage); margin-bottom:10px; }
.shop-page .product-name { font-family:var(--brand); font-size:1.1rem; font-weight:400; letter-spacing:0.04em; color:var(--forest); margin-bottom:10px; line-height:1.3; }
.shop-page .product-name a { color:inherit; }
.shop-page .product-desc { font-size:0.82rem; font-weight:300; line-height:1.7; color:var(--text-mid); margin-bottom:22px; }
.shop-page .product-footer { display:flex; align-items:center; justify-content:space-between; margin-top:auto; }
.shop-page .product-price { font-size:0.82rem; font-weight:500; color:var(--text); }
.shop-page .product-btn { display:inline-flex; align-items:center; gap:6px; background:var(--forest); color:var(--lime); padding:9px 18px; font-size:0.7rem; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; border-radius:2px; transition:background 0.25s; }
.shop-page .product-btn:hover { background:var(--sage); }
.shop-page .product-book-cover { width:100%; height:100%; background:linear-gradient(150deg, #123A28, #5F6F42 55%, #FB8BA7); display:flex; align-items:flex-end; justify-content:center; padding:32px; }
.shop-page .product-book-cover-inner { text-align:center; color:var(--white); }
.shop-page .product-book-cover-inner .t { font-family:var(--brand); font-size:1.5rem; font-weight:400; letter-spacing:0.08em; line-height:1.25; margin-bottom:10px; }
.shop-page .product-book-cover-inner .a { font-size:0.65rem; letter-spacing:0.2em; opacity:0.75; text-transform:uppercase; }

.shop-page .order-section { background:var(--lt-green); padding:96px 0; }
.shop-page .order-inner { max-width:var(--max); margin:0 auto; padding:var(--pad); }
.shop-page .order-head { text-align:center; margin-bottom:64px; }
.shop-page .order-head .eyebrow { justify-content:center; }
.shop-page .order-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.shop-page .order-step { background:var(--white); border:1px solid var(--border); border-radius:4px; padding:44px 34px; min-height:240px; position:relative; overflow:hidden; }
.shop-page .order-step::after { content:''; position:absolute; left:0; bottom:0; height:3px; width:100%; background:var(--sage); transform:scaleX(0); transform-origin:left; transition:transform 0.45s ease; }
.shop-page .order-step:hover::after { transform:scaleX(1); }
.shop-page .order-num { font-family:var(--display); font-size:2.8rem; font-weight:700; color:rgba(8,37,26,0.1); line-height:1; margin-bottom:18px; }
.shop-page .order-title { font-family:var(--brand); font-size:1.05rem; font-weight:400; letter-spacing:0.04em; color:var(--forest); margin-bottom:12px; }
.shop-page .order-desc { font-size:0.85rem; font-weight:300; line-height:1.8; color:var(--text-mid); }
.shop-page .stats-strip { background:var(--cream); }
.shop-page .stats-strip .stat-item { background:var(--cream); }
.shop-page .cta-section::before { background-size:cover; background-position:center; }

@media (max-width:1024px) {
  .shop-page .shop-hero-inner { grid-template-columns:1fr; gap:40px; }
  .shop-page .shop-hero-text { padding:150px 0 10px; }
  .shop-page .shop-hero-figure { padding:0 0 60px; max-width:440px; }
  .shop-page .shop-hero-ring { top:0; }
  .shop-page .order-grid { grid-template-columns:1fr; max-width:480px; margin:0 auto; }
}
@media (max-width:600px) { .shop-page .product-grid { grid-template-columns:1fr; } }

/* ============================================================
   SINGLE PRODUCT (WooCommerce single override)
   ============================================================ */
.product-page .breadcrumb { background:var(--white); border-bottom:1px solid var(--border); }
.product-page .breadcrumb-inner { max-width:var(--max); margin:0 auto; padding:26px 48px; display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.product-page .breadcrumb a, .product-page .breadcrumb span { font-size:0.74rem; letter-spacing:0.06em; color:var(--text-lt); }
.product-page .breadcrumb a:hover { color:var(--sage); }
.product-page .breadcrumb .sep { color:var(--border); }
.product-page .breadcrumb .current { color:var(--forest); font-weight:500; }
.product-page .product-main { background:var(--cream); padding:40px 0 90px; }
.product-page .product-main-inner { max-width:var(--max); margin:0 auto; padding:var(--pad); display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; }
.product-page .gallery { position:sticky; top:100px; }
.product-page .gallery-main { aspect-ratio:4/5; overflow:hidden; border-radius:4px; box-shadow:0 24px 60px rgba(8,37,26,0.16); background:var(--lt-green); }
.product-page .gallery-main img { width:100%; height:100%; object-fit:cover; }
.product-page .gallery-thumbs { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-top:14px; }
.product-page .gallery-thumb { aspect-ratio:1; overflow:hidden; border-radius:3px; cursor:pointer; border:2px solid transparent; transition:border-color 0.25s; }
.product-page .gallery-thumb.active { border-color:var(--sage); }
.product-page .gallery-thumb img { width:100%; height:100%; object-fit:cover; }
.product-page .product-info { padding-top:8px; }
.product-page .product-info .pcat { font-size:0.68rem; font-weight:600; letter-spacing:0.14em; text-transform:uppercase; color:var(--sage); margin-bottom:14px; }
.product-page .product-info h1 { font-family:var(--brand); font-size:clamp(1.9rem,3vw,2.6rem); font-weight:400; letter-spacing:0.03em; color:var(--forest); line-height:1.2; margin-bottom:16px; }
.product-page .product-rating { display:flex; align-items:center; gap:12px; margin-bottom:24px; }
.product-page .product-rating .stars { color:var(--gold); letter-spacing:2px; font-size:0.95rem; }
.product-page .product-rating .count { font-size:0.78rem; color:var(--text-lt); }
.product-page .product-price-row { display:flex; align-items:baseline; gap:12px; padding-bottom:24px; margin-bottom:24px; border-bottom:1px solid var(--border); }
.product-page .product-price-main { font-family:var(--display); font-size:1.5rem; font-weight:600; color:var(--forest); }
.product-page .product-price-note { font-size:0.8rem; color:var(--text-lt); }
.product-page .product-lead { font-size:0.95rem; font-weight:300; line-height:1.85; color:var(--text-mid); margin-bottom:28px; }
.product-page .product-benefits { list-style:none; margin-bottom:32px; }
.product-page .product-benefits li { display:flex; gap:12px; align-items:flex-start; font-size:0.88rem; font-weight:300; line-height:1.6; color:var(--text-mid); margin-bottom:14px; }
.product-page .product-benefits li svg { flex-shrink:0; margin-top:3px; }
.product-page .product-actions { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:28px; }
.product-page .tab-list { list-style:none; }
.product-page .tab-list li { display:flex; gap:14px; align-items:flex-start; padding:16px 0; border-bottom:1px solid var(--border); }
.product-page .tab-list li:last-child { border-bottom:none; }
.product-page .tab-list .ic { width:30px; height:30px; border-radius:50%; background:var(--lt-green); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--sage); }
.product-page .tab-list .ti { font-family:var(--brand); font-size:0.95rem; color:var(--forest); letter-spacing:0.03em; margin-bottom:4px; }
.product-page .tab-list .td { font-size:0.85rem; font-weight:300; line-height:1.7; color:var(--text-mid); }
.product-page .product-meta-row { display:flex; gap:24px; flex-wrap:wrap; padding-top:24px; border-top:1px solid var(--border); }
.product-page .product-meta-item { display:flex; gap:10px; align-items:center; font-size:0.8rem; color:var(--text-mid); }
.product-page .product-meta-item svg { flex-shrink:0; color:var(--sage); }
.product-page .details-section { background:var(--white); padding:90px 0; }
.product-page .details-inner { max-width:920px; margin:0 auto; padding:var(--pad); }
.product-page .tab-nav { display:flex; gap:6px; flex-wrap:wrap; border-bottom:1px solid var(--border); margin-bottom:40px; }
.product-page .tab-btn { font-family:var(--body); font-size:0.78rem; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; padding:14px 24px; background:transparent; border:none; border-bottom:2px solid transparent; color:var(--text-lt); cursor:pointer; transition:all 0.25s; margin-bottom:-1px; }
.product-page .tab-btn:hover { color:var(--sage); }
.product-page .tab-btn.active { color:var(--forest); border-bottom-color:var(--sage); }
.product-page .tab-panel { display:none; }
.product-page .tab-panel.active { display:block; animation:fadeTab 0.4s ease; }
@keyframes fadeTab { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }
.product-page .tab-panel h3 { font-family:var(--brand); font-size:1.4rem; font-weight:400; letter-spacing:0.03em; color:var(--forest); margin-bottom:18px; }
.product-page .tab-panel p { font-size:0.94rem; font-weight:300; line-height:1.9; color:var(--text-mid); margin-bottom:18px; }
.product-page .related-section { background:var(--lt-green); padding:90px 0; }
.product-page .related-inner { max-width:var(--max); margin:0 auto; padding:var(--pad); }
.product-page .related-head { text-align:center; margin-bottom:52px; }
.product-page .related-head .eyebrow { justify-content:center; }
.product-page .related-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.product-page .rel-card { background:var(--white); overflow:hidden; border:1px solid rgba(8,37,26,0.06); border-radius:4px; transition:box-shadow 0.4s, transform 0.4s; display:flex; flex-direction:column; }
.product-page .rel-card:hover { box-shadow:0 22px 50px rgba(8,37,26,0.12); transform:translateY(-5px); }
.product-page .rel-img { aspect-ratio:4/5; overflow:hidden; display:block; }
.product-page .rel-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.7s cubic-bezier(0.22,1,0.36,1); }
.product-page .rel-card:hover .rel-img img { transform:scale(1.06); }
.product-page .rel-body { padding:24px; display:flex; flex-direction:column; flex:1; }
.product-page .rel-cat { font-size:0.64rem; font-weight:600; letter-spacing:0.14em; text-transform:uppercase; color:var(--sage); margin-bottom:8px; }
.product-page .rel-name { font-family:var(--brand); font-size:1.05rem; font-weight:400; letter-spacing:0.03em; color:var(--forest); margin-bottom:16px; line-height:1.3; }
.product-page .rel-name a { color:inherit; }
.product-page .rel-footer { display:flex; align-items:center; justify-content:space-between; margin-top:auto; }
.product-page .rel-price { font-size:0.8rem; color:var(--text-mid); }
.product-page .rel-btn { font-size:0.7rem; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; color:var(--sage); }
.product-page .cta-section::before { background-size:cover; background-position:center; }

@media (max-width:900px) {
  .product-page .product-main-inner { grid-template-columns:1fr; gap:36px; }
  .product-page .gallery { position:static; }
  .product-page .related-grid { grid-template-columns:1fr; }
}

/* ============================================================
   WOOCOMMERCE — Add-to-Cart, Cart & Checkout (brand styling)
   ============================================================ */
/* Buttons */
.woocommerce .button, .woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce #respond input#submit, .product-page .single_add_to_cart_button {
  background:var(--forest); color:#fff; border:none; border-radius:3px; font-family:var(--body);
  font-size:0.8rem; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; padding:14px 26px;
  cursor:pointer; transition:background 0.25s; line-height:1.2; display:inline-flex; align-items:center; justify-content:center;
}
.woocommerce .button:hover, .woocommerce a.button:hover, .woocommerce button.button:hover,
.woocommerce input.button:hover, .product-page .single_add_to_cart_button:hover { background:var(--sage); color:#fff; }
.woocommerce .button.alt, .woocommerce #place_order, .woocommerce .checkout-button, .woocommerce .wc-proceed-to-checkout .button {
  background:var(--pink); color:var(--forest);
}
.woocommerce .button.alt:hover, .woocommerce #place_order:hover, .woocommerce .checkout-button:hover { background:#ff9db8; color:var(--forest); }

/* Single-product buy area */
.product-page .product-buy { width:100%; }
.product-page form.cart { display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin:0 0 4px; }
.product-page form.cart .quantity { display:inline-flex; }
.product-page .quantity input.qty { width:74px; padding:12px 8px; border:1.5px solid var(--border); border-radius:3px; font-family:var(--body); font-size:0.95rem; text-align:center; color:var(--forest); }
.product-page .single_add_to_cart_button { flex:1; min-width:180px; }
.product-page table.variations { width:100%; margin:0 0 16px; border-collapse:collapse; }
.product-page table.variations th, .product-page table.variations td { padding:6px 0; text-align:left; }
.product-page table.variations th { font-size:0.74rem; font-weight:600; letter-spacing:0.06em; text-transform:uppercase; color:var(--text-mid); width:120px; }
.product-page table.variations select { width:100%; padding:12px 14px; border:1.5px solid var(--border); border-radius:4px; font-family:var(--body); font-size:0.92rem; color:var(--forest); background:#fff; }
.product-page .woocommerce-variation-price { margin:0 0 14px; font-family:var(--display); font-size:1.4rem; color:var(--forest); }
.product-page .reset_variations { font-size:0.78rem; color:var(--sage); }

/* Notices */
.woocommerce-message, .woocommerce-info, .woocommerce-error, .woocommerce-noreviews {
  border-top:3px solid var(--sage); background:var(--lt-green); color:var(--forest); font-family:var(--body);
  border-radius:0 4px 4px 0; list-style:none;
}
.woocommerce-message .button, .woocommerce-info .button, .woocommerce-error .button { background:var(--forest); }
.woocommerce-error { border-top-color:#c0392b; background:#fdecea; }

/* Cart + Checkout shared spacing */
.woocommerce-cart .page-shell, .woocommerce-checkout .page-shell, .woocommerce-account .page-shell { padding-top:120px; }
.woocommerce-cart .entry-title, .woocommerce-checkout .entry-title, .woocommerce-account .entry-title { font-family:var(--brand); font-weight:400; color:var(--forest); letter-spacing:0.03em; }

/* Tables */
.woocommerce table.shop_table { border:1px solid var(--border); border-radius:6px; border-collapse:separate; }
.woocommerce table.shop_table th { font-family:var(--body); font-size:0.72rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; color:var(--forest); }
.woocommerce table.cart img { width:72px; border-radius:4px; }
.woocommerce a.remove { color:var(--pink) !important; border:1px solid var(--border); border-radius:50%; }
.woocommerce a.remove:hover { background:var(--pink) !important; color:#fff !important; }
.woocommerce-cart table.cart td.actions .coupon .input-text { width:200px; }

/* Totals / order review headings */
.woocommerce .cart_totals h2, .woocommerce-checkout h3, .woocommerce-checkout #order_review_heading, .woocommerce-column__title {
  font-family:var(--brand); font-weight:400; color:var(--forest); letter-spacing:0.02em;
}

/* Form fields */
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea, .woocommerce form .form-row select,
.woocommerce-checkout input.input-text, .woocommerce-checkout textarea, .woocommerce .coupon input.input-text,
.select2-container .select2-selection--single { border:1.5px solid var(--border) !important; border-radius:4px !important; }
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea, .woocommerce-checkout input.input-text, .woocommerce-checkout textarea {
  padding:12px 14px; font-family:var(--body); font-size:0.95rem; color:var(--forest);
}
.woocommerce form .form-row label { font-size:0.78rem; font-weight:600; color:var(--text-mid); }
.woocommerce-checkout #payment { background:var(--cream); border-radius:8px; }
.woocommerce-checkout #payment ul.payment_methods { border-bottom:1px solid var(--border); }
.woocommerce-checkout #payment div.payment_box { background:#fff; border:1px solid var(--border); }
.woocommerce-Price-amount { font-family:var(--display); color:var(--forest); }
.product-page .product-price-main .woocommerce-Price-amount { font-size:inherit; }
