/* ── SECTION COMMONS ── */
  .section { padding: 80px 5vw; }
  .section-label {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--gold);
    margin-bottom: 14px;
    display: block;
  }
  .section-title {
    font-family: var(--font-head);
    font-size: clamp(30px, 4vw, 46px);
    font-weight: 500;
    line-height: 1.18;
    color: var(--green-dark);
    margin-bottom: 20px;
  }
  .section-title em { font-style: italic; color: var(--gold); }
  .section-body {
    font-size: 15px;
    font-weight: 300;
    color: var(--text-mid);
    line-height: 1.85;
    max-width: 640px;
  }
  .divider {
    width: 52px;
    height: 2px;
    background: var(--gold);
    margin: 0 0 28px;
  }

  /* ── INTRO TWO-COL ── */
  .intro-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
    max-width: 1200px;
    margin: 0 auto;
  }
  @media (max-width: 820px) { .intro-grid { grid-template-columns: 1fr; gap: 36px; } }
  .intro-img-wrap {
    position: relative;
  }
  .intro-img-wrap img {
    width: 100%;
    aspect-ratio: 4/5;
    object-fit: cover;
    display: block;
  }
  .intro-badge {
    position: absolute;
    bottom: -22px;
    right: -22px;
    width: 110px;
    height: 110px;
    border-radius: 50%;
    background: var(--gold);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--white);
  }
  .intro-badge strong {
    font-family: var(--font-head);
    font-size: 28px;
    font-weight: 600;
    line-height: 1;
  }
  .intro-badge span {
    font-size: 9px;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-top: 4px;
    text-align: center;
    padding: 0 6px;
  }
  .sanskrit-note {
    margin-top: 28px;
    padding: 18px 22px;
    border-left: 3px solid var(--gold);
    background: var(--gold-pale);
    font-family: var(--font-head);
    font-style: italic;
    font-size: 17px;
    color: var(--text);
    line-height: 1.6;
  }
  .sanskrit-note cite {
    display: block;
    font-style: normal;
    font-family: var(--font-body);
    font-size: 12px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--gold);
    margin-top: 8px;
  }


  /* ── CLASSES SECTION ── */
  .classes-section { background: var(--white); }
  .classes-inner { max-width: 1200px; margin: 0 auto; }
  .classes-top {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    margin-bottom: 56px;
    align-items: start;
  }
  @media (max-width: 820px) { .classes-top { grid-template-columns: 1fr; gap: 24px; } }

  .session-flow {
    margin-top: 36px;
  }
  .session-step {
    display: flex;
    gap: 18px;
    align-items: flex-start;
    padding: 16px 0;
    border-bottom: 1px solid var(--border);
  }
  .session-step:last-child { border-bottom: none; }
  .step-num {
    width: 34px;
    height: 34px;
    min-width: 34px;
    border-radius: 50%;
    border: 1.5px solid var(--gold);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-head);
    font-size: 16px;
    color: var(--gold);
    font-weight: 600;
  }
  .step-text strong {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: var(--green-dark);
    margin-bottom: 3px;
  }
  .step-text span {
    font-size: 13.5px;
    font-weight: 300;
    color: var(--text-muted);
  }

  .level-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
  @media (max-width: 700px) { .level-cards { grid-template-columns: 1fr; } }
  .level-card {
    padding: 28px 22px;
    border: 1px solid var(--border);
    background: var(--cream);
    position: relative;
  }
  .level-card.featured {
    background: var(--green-dark);
    border-color: var(--green-dark);
  }
  .level-card.featured .level-name,
  .level-card.featured .level-desc { color: rgba(255,255,255,0.9); }
  .level-card.featured .level-icon { color: var(--gold-light); }
  .level-icon { font-size: 26px; margin-bottom: 14px; color: var(--gold); }
  .level-name {
    font-family: var(--font-head);
    font-size: 22px;
    font-weight: 600;
    color: var(--green-dark);
    margin-bottom: 10px;
  }
  .level-desc {
    font-size: 13.5px;
    font-weight: 300;
    color: var(--text-mid);
    line-height: 1.75;
  }

  .facilities-head h2 {
    font-size: 36px;
    font-weight: 600;
    color: #005b18;
    margin-bottom: 15px;
    line-height: 42px;
}


.yoga-ayurveda-section{
    padding:80px 0;
    background:#f8f5ef;
}

.yoga-ayurveda-section .container{
    max-width:1200px;
    margin:0 auto;
    padding:0 15px;
    display:flex;
    align-items:center;
    gap:60px;
}

.ya-image{
    flex:1;
}

.ya-image img{
    width:100%;
    border-radius:20px;
    display:block;
    box-shadow:0 15px 40px rgba(0,0,0,0.08);
}

.ya-content{
    flex:1;
}

.section-tag{
    display:inline-block;
    background:#dfeee4;
    color:#2e6b4c;
    padding:8px 18px;
    border-radius:30px;
    font-size:14px;
    font-weight:600;
    margin-bottom:20px;
}

.ya-content h2{
    font-size: 36px;
    font-weight: 600;
    color: #005b18;
    margin-bottom: 15px;
    line-height: 42px;
}

.ya-content p{
    /* font-size:16px;
    line-height:1.9;
    color:#666;
    margin-bottom:18px; */
}

.ya-features{
    display:flex;
    flex-wrap:wrap;
    gap:20px;
    margin-top:30px;
    margin-bottom:30px;
}

.feature-item{
    display:flex;
    align-items:center;
    gap:10px;
    background:#fff;
    padding:12px 20px;
    border-radius:50px;
    box-shadow:0 5px 20px rgba(0,0,0,0.05);
}

.feature-item i{
    color:#2e6b4c;
    font-size:18px;
}

.feature-item span{
    font-weight:600;
    color:#333;
}

.theme-btn{
    display:inline-block;
    padding:14px 35px;
    background:#2e6b4c;
    color:#fff;
    text-decoration:none;
    border-radius:50px;
    font-weight:600;
    transition:0.3s;
}

.theme-btn:hover{
    background:#1f5138;
}

/* Responsive */

@media(max-width:991px){

    .yoga-ayurveda-section .container{
        flex-direction:column;
    }

    .ya-content h2{
        font-size:34px;
    }
}

@media(max-width:767px){

    .yoga-ayurveda-section{
        padding:60px 0;
    }

    .ya-content h2{
        font-size:28px;
    }

    .ya-content p{
        font-size:15px;
        line-height:1.8;
    }

    .ya-features{
        flex-direction:column;
        gap:12px;
    }

    .feature-item{
        width:100%;
    }
}



.integrated-yoga-section{
    padding:90px 0;
    background:#fff;
}

.integrated-yoga-section .container{
    max-width:1200px;
    margin:auto;
    padding:0 15px;
}

.section-heading{
    text-align:center;
    max-width:800px;
    margin:0 auto 60px;
}

.section-heading span{
    color:#6c8b6f;
    font-weight:600;
    letter-spacing:1px;
    text-transform:uppercase;
}

.section-heading h2{
    font-size: 36px;
    font-weight: 600;
    color: #005b18;
    margin-bottom: 15px;
    line-height: 42px;
}

.section-heading p{
    /* color:#666;
    line-height:1.8; */
}

.healing-timeline{
    position:relative;
}

.healing-timeline:before{
    content:"";
    position:absolute;
    left:50%;
    top:0;
    width:2px;
    height:100%;
    background:#d9e5db;
    transform:translateX(-50%);
}

.timeline-item{
    width:50%;
    padding:20px 50px;
    position:relative;
}

.timeline-item:nth-child(odd){
    margin-left:auto;
}

.timeline-item.reverse{
    text-align:right;
}

.timeline-icon{
    width:70px;
    height:70px;
    background:#2c6b4f;
    color:#fff;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:24px;
    position:absolute;
    top:25px;
    left:-35px;
    z-index:2;
}

.timeline-item.reverse .timeline-icon{
    right:-35px;
    left:auto;
}

.timeline-content{
    background:#fff;
    padding:30px;
    border-radius:20px;
    box-shadow:0 10px 30px rgba(0,0,0,.05);
}

.timeline-content h3{
    color:#18392d;
    margin-bottom:12px;
}

.timeline-content p{
    /* color:#666;
    line-height:1.8; */
}

.doctor-note{
    margin-top:60px;
    background:#edf7ef;
    padding:25px 30px;
    border-radius:20px;
    display:flex;
    gap:20px;
    align-items:flex-start;
}

.doctor-note i{
    font-size:35px;
    color:#2c6b4f;
}

.doctor-note h4{
    margin-bottom:8px;
    color:#18392d;
}

.doctor-note p{
    /* margin:0;
    color:#666;
    line-height:1.8; */
}

@media(max-width:768px){

    .section-heading h2{
        font-size:30px;
    }

    .healing-timeline:before{
        left:20px;
    }

    .timeline-item,
    .timeline-item:nth-child(odd){
        width:100%;
        margin:0;
        padding:0 0 30px 60px;
        text-align:left;
    }

    .timeline-item.reverse{
        text-align:left;
    }

    .timeline-icon,
    .timeline-item.reverse .timeline-icon{
        left:-15px;
        right:auto;
    }

    .doctor-note{
        flex-direction:column;
    }
}


.why-book-retreat{
    padding:90px 0;
    background:#f8f7f2;
}

.why-book-retreat .container{
    max-width:1200px;
    margin:auto;
    padding:0 15px;
}

.section-title{
    text-align:center;
    max-width:800px;
    margin:0 auto 60px;
}

.section-title span{
    display:inline-block;
    color:#6a8b6d;
    font-weight:600;
    text-transform:uppercase;
    letter-spacing:1px;
    margin-bottom:10px;
}

.section-title h2{
    font-size: 36px;
    font-weight: 600;
    color: #005b18;
    margin-bottom: 15px;
    line-height: 42px;
}

.section-title p{
    color:#666;
    line-height:1.8;
}

.retreat-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:30px;
}

.retreat-card{
    background:#fff;
    padding:35px;
    border-radius:20px;
    box-shadow:0 10px 30px rgba(0,0,0,0.05);
    transition:.3s;
}

.retreat-card:hover{
    transform:translateY(-5px);
}

.card-icon{
    width:70px;
    height:70px;
    background:#eaf4ec;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    margin-bottom:20px;
}

.card-icon i{
    font-size:28px;
    color:#2d6b4f;
}

.retreat-card h3{
    font-size:22px;
    color:#18392d;
    margin-bottom:12px;
}

.retreat-card p{
    color:#666;
    line-height:1.8;
    margin:0;
}

.return-guests-box{
    margin-top:50px;
    background:#18392d;
    border-radius:25px;
    padding:40px;
    display:flex;
    align-items:center;
    gap:25px;
}

.return-icon{
    width:80px;
    height:80px;
    flex-shrink:0;
    background:#fff;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
}

.return-icon i{
    color:#18392d;
    font-size:32px;
}

.return-content h3{
    color:#fff;
    margin-bottom:10px;
}

.return-content p{
    color:rgba(255,255,255,.85);
    line-height:1.8;
    margin:0;
}

@media(max-width:991px){

    .retreat-grid{
        grid-template-columns:1fr;
    }

    .section-title h2{
        font-size:34px;
    }
}

@media(max-width:767px){

    .why-book-retreat{
        padding:60px 0;
    }

    .section-title h2{
        font-size:28px;
    }

    .return-guests-box{
        flex-direction:column;
        text-align:center;
        padding:30px 25px;
    }
}