:root {
    --PrimaryColor: #217fff;
    --PrimaryColorRGBA: 33, 127, 255;
    --SecondaryColor: #1e1d28;
    --SecondaryColorRGBA: 33, 32, 40;
    --BodyColor: #1E1D28;
    --BodyColorRGBA: 30, 29, 40;
    --TitleColor: #1E1D28;
    --WhiteColor: #FFFFFF;
    --WhiteColorRGBA: 255, 255, 255;
    --BlackColor: #000000;
    --BlackColorRGBA: 0, 0, 0;
    --YellowColor: #ffa117;
    --YellowColorRGBA: 255, 161, 23;
    --RedColor: #ff4230;
    --RedColorRGBA: 255, 66, 48;
    --OrangeColor: #FF5438;
    --PurpleColor: #9374FC;
    --GreenColor: #009875;
    --ParrotColor: #8EC64E;
    --CyanColor: #07E5E5;
    --bgColor: #f0f3f7;
    --bgColorRGBA: 240, 243, 247;
    --FooterbgColor: #0E0D1F
}

h1 {
    font-size: 60px
}

h2 {
    font-size: 45px
}

html {
    height: 100%;
    width: 100%
}

* {
    outline: 0 !important
}

body {
    font-family: Montserrat, sans-serif;
    font-size: 18px;
    font-weight: 400;
    line-height: 150%;
    background: #fcfcfc;
    color: var(--BodyColor);
    font-style: normal;
    letter-spacing: .16px;
    word-spacing: 0;
    text-transform: inherit;
    margin: 0;
    padding: 0;
    overflow-x: hidden
}

@media (max-width:991.98px) {
    body {
        font-size: 16px
    }
}

@media (max-width:575.98px) {
    body {
        font-size: 14px
    }
}

img {
    max-width: 100%;
    width: auto
}

strong {
    font-weight: 600
}

a {
    text-decoration: none;
    font-family: Montserrat, sans-serif;
    color: var(--PrimaryColor)
}

@media (min-width:1200px) {
    a {
        -webkit-transition: all .3s ease-in-out;
        -o-transition: all .3s ease-in-out;
        transition: all .3s ease-in-out
    }
}

a:focus {
    outline: 0
}

.h1,
.h2,
h1,
h2 {
    font-weight: 700;
    font-family: Montserrat, sans-serif;
    line-height: 110%;
    font-style: normal;
    word-spacing: 0;
    text-transform: inherit;
    margin: 0;
    padding: 0;
    color: var(--BodyColor)
}

.h1,
h1 {
    font-size: 60px
}

@media (max-width:1400px) {

    .h1,
    h1 {
        font-size: 54px
    }
}

@media (max-width:1199.98px) {

    .h1,
    h1 {
        font-size: 47px
    }
}

@media (max-width:991.98px) {

    .h1,
    h1 {
        font-size: 33px
    }
}

.h2,
h2 {
    font-size: 45px
}

@media (max-width:1400px) {

    .h2,
    h2 {
        font-size: 54px
    }
}

@media (max-width:1199.98px) {

    .h2,
    h2 {
        font-size: 40px
    }
}

@media (max-width:991.98px) {

    .h2,
    h2 {
        font-size: 28px
    }
}

.fade {
    -webkit-transition: opacity .3s ease-in-out;
    -o-transition: opacity .3s ease-in-out;
    transition: opacity .3s ease-in-out
}

@media (min-width:1200px) {

    .container {
        max-width: 1050px
    }
}

@media (min-width:1400px) {

    .container {
        max-width: 1280px
    }
}

@media (min-width:1650px) {

    .container {
        max-width: 1590px
    }
}

@media (max-width:575.98px) {

    .container {
        padding-left: 20px;
        padding-right: 20px
    }
}

.fade:not(.show) {
    display: none !important
}

[class*=col]:has(.choices.is-open) {
    position: relative;
    z-index: 10
}

.btn {
    position: relative;
    padding: 14px 30px;
    font-size: 18px;
    font-weight: 600;
    font-family: Montserrat, sans-serif;
    line-height: 115%;
    letter-spacing: .36px;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    border-radius: 35px;
    border: none;
    -webkit-box-shadow: none;
    box-shadow: none;
    text-decoration: none;
    overflow: hidden;
    z-index: 1;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

@media (min-width:1200px) {
    .btn:not(.dropdown-toggle)::before {
        content: "";
        position: absolute;
        inset: 0;
        height: 100%;
        -webkit-transform-origin: left center;
        -ms-transform-origin: left center;
        transform-origin: left center;
        -webkit-transform: scaleX(0);
        -ms-transform: scaleX(0);
        transform: scaleX(0);
        border-radius: 50px;
        z-index: -1;
        -webkit-transition: all .3s ease-in-out;
        -o-transition: all .3s ease-in-out;
        transition: all .3s ease-in-out
    }
}

@media (max-width:991.98px) {
    .btn {
        padding: 12px 28px
    }
}

@media (max-width:575.98px) {
    .btn {
        font-size: 14px;
        padding: 6px 20px
    }
}


.btn:active,
.btn:focus,
.btn:hover,
.btn:not([disabled]):not(.disabled):active {
    -webkit-box-shadow: none;
    box-shadow: none
}

@media (min-width:1200px) {


    .btn:active::before,
    .btn:focus::before,
    .btn:hover::before,
    .btn:not([disabled]):not(.disabled):active::before {
        -webkit-transform: scaleX(1);
        -ms-transform: scaleX(1);
        transform: scaleX(1)
    }
}

.btn.btn-primary {
    color: var(--WhiteColor);
    background: var(--PrimaryColor)
}

.btn.btn-primary::before {
    background: rgba(var(--BlackColorRGBA), .1)
}

@-webkit-keyframes spin {
    0% {
        -webkit-transform: rotate(0);
        transform: rotate(0)
    }

    100% {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg)
    }
}

@keyframes spin {
    0% {
        -webkit-transform: rotate(0);
        transform: rotate(0)
    }

    100% {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg)
    }
}

.home-banner-container {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    position: relative;
    background:white;
}

@media (min-width:1200px) {
    .home-banner-container .container {
        max-width: calc(100% - 20px - 20px)
    }
}

@media (min-width:1400px) {
    .home-banner-container .container {
        max-width: calc(100% - 40px - 40px)
    }
}

@media (min-width:1680px) {
    .home-banner-container .container {
        max-width: calc(100% - 77px - 77px)
    }
}

.home-banner-container .slides {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    gap: 16px
}

@media (max-width:1199.98px) {
    .home-banner-container .slides {
        gap: 7px
    }
}

@media (max-width:575.98px) {
    .home-banner-container .slides {
        gap: 4px
    }
}

.home-banner-container .slide {
    -webkit-box-flex: .125;
    -ms-flex: .125;
    flex: .125;
    min-height: 755px;
    background-color: var(--WhiteColor);
    -webkit-transition: flex-grow .3s ease, -webkit-box-flex .3s ease;
    transition: flex-grow .3s ease, -webkit-box-flex .3s ease;
    -o-transition: flex-grow .3s ease;
    transition: flex-grow .3s ease;
    transition: flex-grow .3s ease, -webkit-box-flex .3s ease, -ms-flex-positive .3s ease;
    color: var(--WhiteColor);
    position: relative;
    padding: 28px 40px;
    overflow: hidden;
    border-radius: 12px;
    -webkit-box-shadow: inset 0 0 8px 0 var(--WhiteColor);
    box-shadow: inset 0 0 8px 0 var(--WhiteColor)
}

@media (max-width:1750px) {
    .home-banner-container .slide {
        min-height: 580px
    }
}

@media (max-width:1199.98px) {
    .home-banner-container .slide {
        min-height: 580px
    }
}

@media (max-width:1399.98px) {
    .home-banner-container .slide {
        padding: 30px 30px 80px 30px;
        min-height: 540px
    }
}

@media (max-width:575.98px) {
    .home-banner-container .slide {
        min-height: 400px;
        padding: 19px 23px 69px 24px;
        -webkit-box-shadow: none;
        box-shadow: none
    }
}

.home-banner-container .slide .cms ul li {
    padding-left: 15px;
    line-height: 110%
}

.home-banner-container .slide .cms ul li a {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
    -webkit-transition: all .5s ease-in-out;
    -o-transition: all .5s ease-in-out;
    transition: all .5s ease-in-out
}

.home-banner-container .slide .cms ul li::before {
    top: 6px;
    width: 6px;
    height: 6px
}

@media (max-width:1199.98px) {
    .home-banner-container .slide .cms ul li::before {
        top: 4px
    }
}

.home-banner-container .slide .cms ul li:hover a {
    -webkit-transform: translateX(10px);
    -ms-transform: translateX(10px);
    transform: translateX(10px)
}

.home-banner-container .slide.active {
    -webkit-box-flex: 3;
    -ms-flex-positive: 3;
    flex-grow: 3;
    -webkit-box-shadow: none;
    box-shadow: none
}

@media (min-width:1600px) {
    .home-banner-container .slide.active {
        padding: 30px 60px 48px 70px
    }
}

@media (max-width:767.98px) {
    .home-banner-container .slide.active .slide-tag {
        text-align: end
    }
}

@media (max-width:575.98px) {
    .home-banner-container .slide.active .slide-tag {
        font-size: 10px;
        padding-right: 15px;
        color: #fcfcfc
    }
}

@media (max-width:374.98px) {
    .home-banner-container .slide.active .slide-tag {
        line-height: 100%
    }
}

.home-banner-container .slide:not(.active) {
    cursor: pointer
}

@media (max-width:575.98px) {
    .home-banner-container .slide:not(.active) {
        padding: 15px;
        border-radius: 7px
    }
}

.home-banner-container .slide:not(.active) .slide-tag {
    -webkit-writing-mode: vertical-lr;
    -ms-writing-mode: tb-lr;
    writing-mode: vertical-lr;
    -webkit-transform: rotate(180deg);
    -ms-transform: rotate(180deg);
    transform: rotate(180deg);
    text-align: center;
    margin: auto;
    padding: .75rem .55rem 1.6rem;
    border-radius: .75rem;
    line-height: 1.2;
    background: rgba(0, 0, 0, .38);
    border: 1px solid rgba(255, 255, 255, .14)
}

.home-banner-container .slide.slide-hero-slide:not(.active) .slide-tag {
    background: rgba(0, 0, 0, .38)
}

@media (max-width:575.98px) {
    .home-banner-container .slide:not(.active) .slide-tag {
        padding-bottom: 25px
    }
}

@media (max-width:575.98px) {
    .home-banner-container .slide:not(.active) .slide-tag {
        padding-left: 0;
        font-size: 10px;
        letter-spacing: .14em;
        font-weight: 700;
        color: rgba(255, 255, 255, .95);
        text-shadow: 0 2px 10px rgba(0, 0, 0, .6);
        margin-left: -17px;
    }
}

.home-banner-container .slide:not(.active) .slide-tag::after {
    left: 0;
    right: 0;
    top: auto;
    bottom: .55rem
}

/* @media (max-width:575.98px) {
    .home-banner-container .slide:not(.active) .slide-tag::after {
        top: 5px
    }
} */

.home-banner-container .slide:not(.active) .content {
    display: none
}

.home-banner-container .slide.slide-hero-slide {
    background-color: #523528;
    background-image: -webkit-linear-gradient(top, rgba(100, 115, 67, .14) 0, rgba(82, 53, 40, .38) 100%);
    background-image: linear-gradient(180deg, rgba(100, 115, 67, .14) 0, rgba(82, 53, 40, .38) 100%);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover
}

.home-banner-container .slide.slide-hero-slide.active {
    background-color: #523528;
    background-image: -webkit-linear-gradient(115deg, rgba(100, 115, 67, .16) 0, rgba(82, 53, 40, .42) 50%, rgba(82, 53, 40, .34) 100%);
    background-image: linear-gradient(115deg, rgba(100, 115, 67, .16) 0, rgba(82, 53, 40, .42) 50%, rgba(82, 53, 40, .34) 100%);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover
    
}

.home-banner-container .slide.slide-hero-slide:nth-child(1)::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background-image: url(../images/banner/img17.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    opacity: .55;
    z-index: 0;
    pointer-events: none
}

.home-banner-container .slide.slide-hero-slide:nth-child(2)::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background-image: url(../images/banner/img18.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    opacity: .55;
    z-index: 0;
    pointer-events: none
}

.home-banner-container .slide.slide-hero-slide:nth-child(3)::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background-image: url(../images/banner/img19.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    opacity: .55;
    z-index: 0;
    pointer-events: none
}

.home-banner-container .slide.slide-hero-slide .slide-tag {
    position: relative;
    z-index: 1
}

.home-banner-container .slide.slide-hero-slide .slider-controls,
.home-banner-container .slide.slide-hero-slide .plus-btn {
    z-index: 2
}

.home-banner-container .slide.slide-hero-slide.active .slide-tag::after {
    background-color: #647343;
    -webkit-box-shadow: 0 0 0 2px rgba(82, 53, 40, .2);
    box-shadow: 0 0 0 2px rgba(82, 53, 40, .2)
}

.home-banner-container .slide.slide-hero-slide .slide-tag::after {
    background-color: rgba(255, 255, 255, .92);
    -webkit-box-shadow: 0 0 0 1px rgba(82, 53, 40, .25), 0 10px 22px rgba(0, 0, 0, .25);
    box-shadow: 0 0 0 1px rgba(82, 53, 40, .25), 0 10px 22px rgba(0, 0, 0, .25)
}

.home-banner-container .slide.slide-hero-slide.active .slide-tag {
    display: none
}

.home-banner-container .slide.slide-hero-slide:not(.active) .slide-tag {
    color: #f7f5f0;
    font-weight: 600;
    letter-spacing: .08em;
    text-shadow: 0 2px 10px rgba(0, 0, 0, .55), 0 1px 1px rgba(0, 0, 0, .35)
}

.home-banner-container .slide.slide-hero-slide .slide-hero-title {
    position: absolute;
    inset: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    gap: .5rem;
    padding: 88px 20px 120px;
    pointer-events: none;
    z-index: 1;
    opacity: 0;
    -webkit-transform: translateY(12px);
    -ms-transform: translateY(12px);
    transform: translateY(12px);
    -webkit-transition: opacity .5s ease, -webkit-transform .5s ease;
    transition: opacity .5s ease, transform .5s ease;
    overflow: visible
}

.home-banner-container .slide.slide-hero-slide.active .slide-hero-title {
    opacity: 1;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0)
}

.home-banner-container .slide.slide-hero-slide .slide-hero-title__text {
    margin: 0;
    font-family: "Cormorant Garamond", Gantari, Georgia, serif;
    font-size: clamp(2.6rem, 9.2vw, 5.75rem);
    font-weight: 600;
    font-style: normal;
    line-height: 1.02;
    letter-spacing: .02em;
    text-transform: uppercase;
    text-align: center;
    display: inline-block;
    padding: .28em .42em .3em;
    border-radius: 18px;
    color: rgba(18, 18, 18, .92);
    -webkit-text-fill-color: rgba(18, 18, 18, .92);
    background: rgba(255, 255, 255, .78);
    -webkit-backdrop-filter: blur(7px);
    backdrop-filter: blur(7px);
    -webkit-box-shadow: 0 18px 42px rgba(0, 0, 0, .22);
    box-shadow: 0 18px 42px rgba(0, 0, 0, .22);
    text-shadow: none
}

.home-banner-container .slide.slide-hero-slide .slide-hero-title__text::after {
    display: none
}

.home-banner-container .slide.slide-hero-slide .slide-hero-title__sub {
    display: inline-block;
    position: relative;
    z-index: 2;
    margin: .35rem 0 0;
    padding: 0 14px;
    max-width: min(100%, 22rem);
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    font-family: Montserrat, Gantari, sans-serif;
    font-size: clamp(.72rem, 2.1vw, .9rem);
    font-weight: 700;
    line-height: 1.45;
    letter-spacing: .18em;
    text-transform: uppercase;
    text-align: center;
    color: rgba(18, 18, 18, .88);
    -webkit-text-fill-color: rgba(18, 18, 18, .88);
    background: rgba(255, 255, 255, .76);
    border-radius: 999px;
    padding: .25rem .85rem;
    border: none;
    visibility: visible;
    opacity: 1;
    -webkit-font-smoothing: antialiased;
    -webkit-backdrop-filter: blur(6px);
    backdrop-filter: blur(6px);
    -webkit-box-shadow: 0 14px 30px rgba(0, 0, 0, .18);
    box-shadow: 0 14px 30px rgba(0, 0, 0, .18);
    text-shadow: none
}

.home-banner-container .slide.slide-hero-slide .slide-hero-readmore {
    pointer-events: auto;
    position: relative;
    z-index: 2;
    margin: 1.15rem 0 0;
    -webkit-align-self: center;
    -ms-flex-item-align: center;
    align-self: center;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: .7rem 1.9rem;
    font-family: Montserrat, Gantari, sans-serif;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .18em;
    text-transform: uppercase;
    text-decoration: none;
    text-align: center;
    color: #523528;
    border: 2px solid #647343;
    border-radius: 999px;
    cursor: pointer;
    background-color: rgba(255, 255, 255, .88);
    -webkit-box-shadow: 0 1px 0 rgba(255, 255, 255, .95) inset, 0 4px 20px rgba(255, 255, 255, .45), 0 2px 10px rgba(82, 53, 40, .12);
    box-shadow: 0 1px 0 rgba(255, 255, 255, .95) inset, 0 4px 20px rgba(255, 255, 255, .45), 0 2px 10px rgba(82, 53, 40, .12);
    -webkit-transition: color .2s ease, background-color .2s ease, border-color .2s ease, -webkit-box-shadow .2s ease;
    transition: color .2s ease, background-color .2s ease, border-color .2s ease, box-shadow .2s ease
}

.home-banner-container .slide.slide-hero-slide .slide-hero-readmore:hover {
    color: #fff;
    text-decoration: none;
    background-color: #647343;
    border-color: #523528;
    -webkit-box-shadow: 0 2px 0 rgba(255, 255, 255, .22) inset, 0 6px 22px rgba(82, 53, 40, .28), 0 0 0 1px rgba(255, 255, 255, .35);
    box-shadow: 0 2px 0 rgba(255, 255, 255, .22) inset, 0 6px 22px rgba(82, 53, 40, .28), 0 0 0 1px rgba(255, 255, 255, .35)
}

.home-banner-container .slide.slide-hero-slide .slide-hero-readmore:focus-visible {
    color: #fff;
    text-decoration: none;
    background-color: #647343;
    border-color: #523528;
    outline: 2px solid #fff;
    outline-offset: 3px;
    -webkit-box-shadow: 0 2px 0 rgba(255, 255, 255, .22) inset, 0 6px 22px rgba(82, 53, 40, .28);
    box-shadow: 0 2px 0 rgba(255, 255, 255, .22) inset, 0 6px 22px rgba(82, 53, 40, .28)
}

.home-banner-container .slide.slide-hero-slide .slide-hero-readmore:active {
    color: #fff;
    background-color: #523528;
    border-color: #3d281c;
    -webkit-box-shadow: 0 2px 6px rgba(0, 0, 0, .2) inset, 0 2px 10px rgba(82, 53, 40, .2);
    box-shadow: 0 2px 6px rgba(0, 0, 0, .2) inset, 0 2px 10px rgba(82, 53, 40, .2)
}

@media (max-width:575.98px) {
    .home-banner-container .slide.slide-hero-slide .slide-hero-title {
        padding: 72px 18px 96px;
        gap: .25rem
    }

    .home-banner-container .slide.slide-hero-slide .slide-hero-title__text {
        font-size:30px;  
    }

    .home-banner-container .slide.slide-hero-slide .slide-hero-title__sub {
        letter-spacing: .1em;
        font-size: .68rem;
        max-width: 95%;
        padding: 0 10px
    }

    .home-banner-container .slide.slide-hero-slide .slide-hero-readmore {
        margin-top: .85rem;
        padding: 6px;
        font-size: .62rem;
        letter-spacing: .14em
    }
}

.home-banner-container .slider-controls {
    display: none;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    width: 100px;
    position: absolute;
    right: 60px
}

@media (max-width:1679.98px) {
    .home-banner-container .slider-controls {
        right: 40px
    }
}

@media (max-width:1199.98px) {
    .home-banner-container .slider-controls {
        right: 30px
    }
}

@media (max-width:575.98px) {
    .home-banner-container .slider-controls {
        width: auto;
        right: 20px;
        left: 10px;
        margin: auto;
        -webkit-box-pack: end;
        -ms-flex-pack: end;
        justify-content: end
    }
}

.home-banner-container .slider-controls .next {
    text-align: right;
    margin-left: 10px
}

.home-banner-container .slider-controls .next,
.home-banner-container .slider-controls .prev {
    background: rgba(var(--WhiteColorRGBA), .4);
    border: 0;
    padding-top: 3px;
    cursor: pointer;
    -webkit-transition: background .3s ease;
    -o-transition: background .3s ease;
    transition: background .3s ease;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    font-size: 30px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
}

@media (max-width:575.98px) {

    .home-banner-container .slider-controls .next,
    .home-banner-container .slider-controls .prev {
        padding: 5px;
        gap: 7px;
        width: 30px;
        height: 30px
    }
}

.home-banner-container .slider-controls .next:hover,
.home-banner-container .slider-controls .prev:hover {
    background-color: var(--WhiteColor) !important
}

@media (max-width:575.98px) {

    .home-banner-container .slider-controls .next:hover,
    .home-banner-container .slider-controls .prev:hover {
        background-color: transparent
    }
}

.home-banner-container .slider-controls .n-icon {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
}

.home-banner-container .slider-controls span {
    font-size: 45px;
    color: #fff;
    text-transform: uppercase;
    line-height: 0%;
    padding: 0 0 10px 0;
}

.home-banner-container .slide.active .slider-controls {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

.home-banner-container .plus-btn,
.home-banner-container .slider-controls {
    bottom: 48px
}

@media (max-width:1199.98px) {

    .home-banner-container .plus-btn,
    .home-banner-container .slider-controls {
        bottom: 28px
    }
}

@media (max-width:575.98px) {

    .home-banner-container .plus-btn,
    .home-banner-container .slider-controls {
        bottom: 20px
    }
}

.home-banner-container .plus-btn {
    background: rgba(var(--WhiteColorRGBA), .4);
    border: 0;
    padding: 10px;
    cursor: pointer;
    -webkit-transition: background .3s ease;
    -o-transition: background .3s ease;
    transition: background .3s ease;
    position: absolute;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    font-size: 30px;
    margin: auto;
    right: 0;
    left: 0;
    line-height: 0;
    color: var(--BodyColor)
}

.home-banner-container .plus-btn:hover {
    background-color: var(--WhiteColor)
}

@media (max-width:575.98px) {
    .home-banner-container .plus-btn {
        display: none;
        width: 16px;
        height: 16px;
        padding: 0;
        color: rgb(var(--WhiteColorRGBA), .5);
        font-size: 14px;
        color: #000
    }
}

.home-banner-container .slide.active .plus-btn {
    display: none
}

.home-banner-container .slide:not(.active) .plus-btn {
    display: block
}

.home-banner-container .slide-tag {
    color: var(--WhiteColor);
    text-transform: uppercase;
    position: relative;
    text-align: end;
    padding-right: 30px;
    margin-bottom: 20px;
    line-height: 1.05;
    font-size: 16px;
    display: inline-block;
    padding: .32rem 2.05rem .32rem .75rem;
    border-radius: .65rem;
    border: 1px solid rgba(255, 255, 255, .14);
    background: rgba(0, 0, 0, .32);
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px);
    letter-spacing: .16em;
    font-weight: 700;
    text-shadow: 0 2px 12px rgba(0, 0, 0, .6)
}

.home-banner-container .slide-tag::after {
    position: absolute;
    content: "";
    bottom: 0;
    top: 0;
    margin: auto;
    right: .7rem;
    width: 12px;
    height: 12px;
    background-color: var(--WhiteColor);
    border-radius: 50%;
    box-shadow: 0 0 0 2px rgba(0, 0, 0, .18), 0 10px 22px rgba(0, 0, 0, .25)
}

@media (max-width:575.98px) {
    .home-banner-container .slide-tag::after {
        width: 8px;
        height: 8px
    }
}

@media (min-width:1200px) {
    .home-banner-container .content {
        width: 85%
    }
}

.home-banner-container .content .title {
    font-weight: 700;
    color: var(--WhiteColor);
    margin-bottom: 15px;
    line-height: 105%;
    letter-spacing: -1.68px;
    font-size: 84px
}

@media (max-width:1750px) {
    .home-banner-container .content .title {
        font-size: 70px
    }
}

@media (max-width:1550px) {
    .home-banner-container .content .title {
        font-size: 56px
    }
}

@media (max-width:1366px) {
    .home-banner-container .content .title {
        font-size: 50px
    }
}

@media (max-width:1199.98px) {
    .home-banner-container .content .title {
        font-size: 47px
    }
}

@media (max-width:991.98px) {
    .home-banner-container .content .title {
        font-size: 33px;
        margin-bottom: 21px
    }
}

@media (max-width:767.98px) {
    .home-banner-container .content .title {
        font-size: 25px
    }
}

.home-banner-container .content .title span {
    color: var(--PrimaryColor)
}

.home-banner-container .content .detail {
    color: var(--WhiteColor);
    line-height: 1.5;
    font-weight: 300;
    margin-bottom: 34px
}

@media (max-width:1750px) {
    .home-banner-container .content .detail {
        margin-bottom: 25px
    }
}

@media (min-width:1600px) {
    .home-banner-container .content .detail {
        max-width: 85%;
        font-size: 20px
    }
}

@media (max-width:991.98px) {
    .home-banner-container .content .detail {
        margin-bottom: 25px
    }
}

@media (max-width:575.98px) {
    .home-banner-container .content .detail {
        font-size: 14px
    }
}

@media (min-width:1200px) {
    .home-banner-container .content .btn.btn-primary {
        padding: 18px 54px !important
    }
}

.home-banner-container .content .services-box {
    background: rgba(var(--WhiteColorRGBA), .1);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    border-radius: 16px;
    margin-top: 56px;
    padding: 15px 25px
}

@media (max-width:1750px) {
    .home-banner-container .content .services-box {
        margin-top: 30px
    }
}

@media (min-width:1600px) {
    .home-banner-container .content .services-box {
        max-width: 72.1%
    }
}

.home-banner-container .content .services-box .heading {
    color: var(--WhiteColor);
    font-size: 18px;
    font-weight: 500;
    letter-spacing: 0
}

.home-banner-container .content .services-box ul li {
    color: var(--WhiteColor);
    font-size: 16px
}

.home-banner-container .content .services-box ul li a {
    font-weight: 300
}

@media (max-width:1199.98px) {
    .home-banner-container .content .services-box ul li {
        font-size: 14px
    }
}

@media (max-width:991.98px) {
    .home-banner-container .content .services-box ul li {
        font-size: 12px
    }
}

.home-banner-container .content .services-box ul li::before {
    -webkit-transition: all .5s ease-in-out;
    -o-transition: all .5s ease-in-out;
    transition: all .5s ease-in-out;
    -webkit-box-shadow: 0 0 0 0 rgba(33, 127, 255, .3);
    box-shadow: 0 0 0 0 rgba(33, 127, 255, .3)
}

.home-banner-container .content .services-box ul li:hover::before {
    -webkit-box-shadow: 0 0 0 5px rgba(var(--PrimaryColorRGBA), .3);
    box-shadow: 0 0 0 5px rgba(var(--PrimaryColorRGBA), .3)
}

.home-banner-container .content .services-box a {
    text-decoration: none;
    color: var(--WhiteColor)
}

@media (max-width:767.98px) {
    .home-banner-container .content .services-box .cms {
        --bs-gutter-x: 0.5rem;
        --bs-gutter-y: 0.5rem
    }
}

@media (max-width:575.98px) {
    .home-banner-container .content .services-box .cms li {
        font-size: 14px
    }

    .home-banner-container .content .services-box .cms li::before {
        top: 6px
    }
}

.home-banner-container .content .services-box .cms li+li {
    margin-top: 10px
}

@media (max-width:575.98px) {
    .home-banner-container .content .services-box .cms li+li {
        margin-top: 7px
    }
}

@-webkit-keyframes leftright {

    0%,
    100% {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }

    20%,
    80% {
        -webkit-transform: translateX(1px);
        transform: translateX(1px)
    }

    50% {
        -webkit-transform: translateX(-1px);
        transform: translateX(-1px)
    }
}

@keyframes leftright {

    0%,
    100% {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }

    20%,
    80% {
        -webkit-transform: translateX(1px);
        transform: translateX(1px)
    }

    50% {
        -webkit-transform: translateX(-1px);
        transform: translateX(-1px)
    }
}

@-webkit-keyframes rotatedYimage {
    0% {
        -webkit-transform: rotateY(0);
        transform: rotateY(0)
    }

    100% {
        -webkit-transform: rotateY(360deg);
        transform: rotateY(360deg)
    }
}

@keyframes rotatedYimage {
    0% {
        -webkit-transform: rotateY(0);
        transform: rotateY(0)
    }

    100% {
        -webkit-transform: rotateY(360deg);
        transform: rotateY(360deg)
    }
}

@-webkit-keyframes zooming {

    0%,
    100% {
        -webkit-transform: scale(1);
        transform: scale(1)
    }

    20%,
    80% {
        -webkit-transform: scale(1.3);
        transform: scale(1.3)
    }

    50% {
        -webkit-transform: scale(.8);
        transform: scale(.8)
    }
}

@keyframes zooming {

    0%,
    100% {
        -webkit-transform: scale(1);
        transform: scale(1)
    }

    20%,
    80% {
        -webkit-transform: scale(1.05);
        transform: scale(1.05)
    }

    50% {
        -webkit-transform: scale(.9);
        transform: scale(.9)
    }
}

.cms:after {
    display: block;
    clear: both;
    content: ""
}


.cms p a,
.cms ul a {
    display: inline;
    font-weight: 400
}

.cms+.cms,
.cms~.cms {
    margin-top: 25px
}

.cms a {
    color: var(--PrimaryColor);
    position: relative;
    z-index: 1;
    line-height: inherit;
    word-break: break-word;
    display: inline-block
}


.cms a:active,
.cms a:focus,
.cms a:not([disabled]):not(.disabled):active,
.cms a:visited {
    color: var(--PrimaryColor)
}

.cms a:hover {
    color: #1e1d28
}


.cms ul li {
    font-weight: 400;
    line-height: 150%;
    color: var(--BodyColor);
    letter-spacing: 0
}

.cms p {
    margin-bottom: 0
}


.cms a+a,
.cms a+p,
.cms a+ul,
.cms p+a,
.cms p+p,
.cms p+ul,
.cms ul+a,
.cms ul+p,
.cms ul+ul {
    margin-top: 20px
}


.cms a+.h1,
.cms a+.h2,
.cms a+h1,
.cms a+h2,
.cms p+.h1,
.cms p+.h2,
.cms p+h1,
.cms p+h2,
.cms ul+.h1,
.cms ul+.h2,
.cms ul+h1,
.cms ul+h2 {
    margin-top: 25px
}

.cms .h1+.h1,
.cms .h1+.h2,
.cms .h1+h1,
.cms .h1+h2,
.cms .h2+.h1,
.cms .h2+.h2,
.cms .h2+h1,
.cms .h2+h2,
.cms h1+.h1,
.cms h1+.h2,
.cms h1+h1,
.cms h1+h2,
.cms h2+.h1,
.cms h2+.h2,
.cms h2+h1,
.cms h2+h2 {
    margin-top: 30px
}

.cms .h1 a,
.cms .h1+p,
.cms .h1+ul,
.cms .h2 a,
.cms .h2+p,
.cms .h2+ul,
.cms h1 a,
.cms h1+p,
.cms h1+ul,
.cms h2 a,
.cms h2+p,
.cms h2+ul {
    margin-top: 25px
}

.cms img+p {
    margin-top: 25px
}


.cms ul {
    position: relative;
    margin: 0;
    padding: 0;
    list-style: none
}


.cms ul li {
    list-style: none;
    position: relative;
    padding-left: 25px;
    display: table
}


.cms ul li::before {
    content: "";
    position: absolute;
    top: 8px;
    left: 0;
    width: 10px;
    height: 10px;
    background-color: var(--PrimaryColor);
    z-index: 0;
    border-radius: 50%
}


.cms ul li ul,
.cms ul li+li {
    margin-top: 10px
}


.cms ul li ul {
    margin-left: 15px
}


.cms ul+.h1,
.cms ul+.h2,
.cms ul+h1,
.cms ul+h2 {
    margin-top: 25px
}


.cms ul+p {
    margin-top: 25px
}

.cms ul {
    list-style-type: circle
}

/* Logo + header — #647343 (olive) + #523528 (umber), opacity for depth */
.header-main .logo a {
    display: inline-block;
    line-height: 0
}



.header-main .logo img {
    -webkit-transition: opacity .4s ease, -webkit-filter .4s ease;
    transition: opacity .4s ease, filter .4s ease
}

#wrapper:has(.home-banner-container .slide.slide-hero-slide.active) .header-main .bottom-part {
    /* background: -webkit-linear-gradient(top, rgba(100, 115, 67, .12) 0, rgba(82, 53, 40, .06) 45%, #fff 100%);
    background: linear-gradient(180deg, rgba(100, 115, 67, .12) 0, rgba(82, 53, 40, .06) 45%, #fff 100%); */
    border-bottom: none !important;
}

#wrapper:has(.home-banner-container .slide.slide-hero-slide.active) .header-main .logo img {
    opacity: 1;
    /* -webkit-filter: drop-shadow(0 2px 12px rgba(100, 115, 67, .35)) drop-shadow(0 5px 22px rgba(82, 53, 40, .16));
    filter: drop-shadow(0 2px 12px rgba(100, 115, 67, .35)) drop-shadow(0 5px 22px rgba(82, 53, 40, .16)) */
}

/* —— Crafts showcase (full section below hero) —— */
.crafts-showcase {
    position: relative;
    padding: clamp(3rem, 6vw, 5.5rem) 0 clamp(3.5rem, 7vw, 6rem);
    background: #f7f5f1;
    overflow: hidden
}

.crafts-showcase__bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(ellipse 70% 50% at 100% 0%, rgba(100, 115, 67, .14) 0%, transparent 55%),
        radial-gradient(ellipse 55% 45% at 0% 100%, rgba(82, 53, 40, .1) 0%, transparent 50%);
    opacity: 1
}

.crafts-showcase__container {
    position: relative;
    z-index: 1
}

.crafts-showcase__intro {
    margin-bottom: clamp(1.75rem, 4vw, 2.75rem);
    padding-bottom: clamp(1.75rem, 3vw, 2.5rem);
    border-bottom: 1px solid rgba(82, 53, 40, .14)
}

.crafts-showcase__eyebrow {
    font-family: Montserrat, sans-serif;
    font-size: .7rem;
    font-weight: 600;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: #647343;
    margin: 0 0 .85rem
}

.crafts-showcase__title {
    font-family: "Cormorant Garamond", Georgia, serif;
    font-weight: 600;
    font-size: clamp(2.15rem, 4.2vw, 3.25rem);
    line-height: 1.12;
    color: #1e1d28;
    margin: 0 0 1rem;
    max-width: 14ch
}

.crafts-showcase__lead {
    margin: 0;
    max-width: 36rem;
    font-size: clamp(.95rem, 1.2vw, 1.05rem);
    line-height: 1.7;
    color: rgba(30, 29, 40, .82)
}

.crafts-showcase__viewport {
    overflow: visible;
    width: 100%
}

.crafts-showcase__track {
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(1rem, 2vw, 1.25rem)
}

@media (min-width: 768px) {
    .crafts-showcase__track {
        grid-template-columns: repeat(3, minmax(0, 1fr))
    }
}

.crafts-showcase__card {
    width: 100%;
    min-width: 0;
    border-radius: 14px;
    overflow: hidden;
    background: #fff;
    box-shadow:
        0 12px 40px rgba(82, 53, 40, .1),
        0 0 0 1px rgba(82, 53, 40, .06);
    display: flex;
    flex-direction: column;
    -webkit-transition: box-shadow .35s ease, -webkit-transform .35s ease;
    transition: box-shadow .35s ease, transform .35s ease
}

.crafts-showcase__card:hover {
    box-shadow:
        0 20px 50px rgba(82, 53, 40, .14),
        0 0 0 1px rgba(100, 115, 67, .12);
    -webkit-transform: translateY(-4px);
    transform: translateY(-4px)
}

.crafts-showcase__card-visual {
    position: relative;
    overflow: hidden;
    min-height: clamp(168px, 22vw, 220px);
    aspect-ratio: 16 / 10;
    background-color: var(--card-fallback, #4a4038)
}

.crafts-showcase__card-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    z-index: 0
}

.crafts-showcase__card-visual::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background-image: linear-gradient(180deg, transparent 35%, rgba(30, 29, 40, .18) 100%),
        url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E")
}

.crafts-showcase__card-body {
    padding: 1.35rem 1.4rem 1.5rem;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    flex: 1
}

.crafts-showcase__card-kicker {
    font-size: .65rem;
    font-weight: 600;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: #647343;
    margin-bottom: .4rem
}

.crafts-showcase__card-title {
    font-family: "Cormorant Garamond", Georgia, serif;
    font-weight: 600;
    font-size: 1.75rem;
    line-height: 1.15;
    margin: 0 0 .65rem;
    color: #1e1d28
}

.crafts-showcase__card-text {
    margin: 0 0 1.1rem;
    font-size: .9rem;
    line-height: 1.6;
    color: rgba(30, 29, 40, .76);
    flex: 1
}

.crafts-showcase__card-cta {
    font-size: .78rem;
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #523528;
    border-bottom: 1px solid rgba(82, 53, 40, .35);
    padding-bottom: 2px;
    -webkit-transition: color .2s ease, border-color .2s ease;
    transition: color .2s ease, border-color .2s ease
}

.crafts-showcase__card-cta:hover {
    color: #647343;
    border-bottom-color: #647343
}

@media (prefers-reduced-motion: reduce) {
    .crafts-showcase__card:hover {
        -webkit-transform: none;
        transform: none
    }
}

/* —— How we teach: centered vertical timeline, alternating copy / image —— */
.teach-pedagogy {
    position: relative;
    padding: clamp(3rem, 8vw, 5.5rem) 0 clamp(3.5rem, 9vw, 6rem);
    overflow: hidden;
    color: #e6e9ee
}

/* .teach-pedagogy__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    background:
        radial-gradient(ellipse 70% 50% at 50% 0%, #563A2D 0%, transparent 55%),
        radial-gradient(ellipse 60% 45% at 100% 60%, #563A2D 0%, transparent 50%),
        linear-gradient(180deg, #563A2D 0%, #563A2D 40%, #563A2D 100%)
} */
.teach-pedagogy__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    background:
        radial-gradient(ellipse 70% 50% at 50% 0%, #647343 0%, transparent 55%),
        radial-gradient(ellipse 60% 45% at 100% 60%, #647343 0%, transparent 50%),
        linear-gradient(180deg, #647343 0%, #647343 40%, #647343 100%)
}
.teach-pedagogy__bg::after {
    content: "";
    position: absolute;
    inset: 0;
    opacity: .35;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.06'/%3E%3C/svg%3E");
    pointer-events: none
}

.teach-pedagogy__inner {
    position: relative;
    z-index: 1
}

.teach-pedagogy__figure-badge {
    margin: 0.75rem
}

.teach-pedagogy__card-body-inner {
    padding: 1rem 1.125rem
}

.teach-pedagogy--studio .teach-pedagogy__card-body-inner {
    min-height: 100%;
    color: #f2f4f8
}

.teach-pedagogy--studio .teach-pedagogy__card-body-inner .teach-title {
    color: #fff
}

.teach-pedagogy--studio .teach-pedagogy__card-body-inner .teach-copy {
    color: rgba(242, 244, 248, 0.88)
}

@media (min-width: 62rem) {
    .teach-pedagogy__card-body-inner {
        padding: 1.125rem 1.375rem
    }
}

.teach-pedagogy__title-gap {
    margin-bottom: 0.5rem
}

.teach-pedagogy__head {
    text-align: center;
    margin: 0 auto clamp(2rem, 4.5vw, 3rem);
    max-width: 44rem
}

.teach-pedagogy__head-text {
    position: relative;
    padding-bottom: clamp(1.15rem, 2.5vw, 1.6rem)
}

.teach-pedagogy__head-text::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    width: min(100px, 24vw);
    height: 1px;
    background: -webkit-linear-gradient(90deg, transparent, rgba(196, 168, 124, .8), transparent);
    background: linear-gradient(90deg, transparent, rgba(196, 168, 124, .8), transparent)
}

.teach-pedagogy__eyebrow {
    margin: 0 0 .5rem;
    font-size: .7rem;
    font-weight: 600;
    letter-spacing: .28em;
    text-transform: uppercase;
    color: rgba(196, 168, 124, .95)
}

.teach-pedagogy__title {
    margin: 0;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-weight: 600;
    font-size: clamp(2rem, 4.5vw, 3rem);
    line-height: 1.12;
    letter-spacing: .08em;
    color: #f2f4f8;
    text-transform: uppercase
}

.teach-pedagogy__list {
    list-style: none;
    margin: 0 auto;
    padding: 0;
    max-width: 56rem;
    position: relative
}

.teach-pedagogy__node {
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-areas:
        "marker copy"
        "visual visual";
    -webkit-column-gap: 1rem;
    column-gap: 1rem;
    row-gap: 1rem;
    align-items: start;
    padding: clamp(1.35rem, 2.5vw, 1.85rem) 0;
    border-bottom: 1px solid rgba(230, 233, 238, .06)
}

.teach-pedagogy__node:first-child {
    padding-top: 0
}

.teach-pedagogy__node:last-child {
    border-bottom: 0;
    padding-bottom: 0
}

.teach-pedagogy__marker {
    grid-area: marker;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding-top: .2rem
}

.teach-pedagogy__dot {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.65rem;
    height: 2.65rem;
    border-radius: 50%;
    border: 2px solid rgba(196, 168, 124, .55);
    background: rgba(10, 14, 20, .92);
    box-shadow: 0 0 0 4px rgba(10, 14, 20, .9), 0 6px 20px rgba(0, 0, 0, .35)
}

.teach-pedagogy__index {
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: .88rem;
    font-weight: 600;
    letter-spacing: .06em;
    color: rgba(220, 200, 160, .95)
}

.teach-pedagogy__copy {
    grid-area: copy;
    min-width: 0
}

.teach-pedagogy__item-title {
    margin: 0 0 .45rem;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-weight: 600;
    font-size: clamp(1.3rem, 2.4vw, 1.65rem);
    line-height: 1.2;
    color: #f2eee6
}

.teach-pedagogy__text {
    margin: 0;
    font-size: .9rem;
    line-height: 1.68;
    color: rgba(208, 214, 222, .86);
    max-width: 40rem
}

.teach-pedagogy__visual {
    grid-area: visual;
    margin: 0;
    padding: 0;
    position: relative;
    overflow: hidden;
    border-radius: 10px;
    aspect-ratio: 16 / 9;
    min-height: 150px;
    background: rgba(0, 0, 0, .25);
    box-shadow: 0 16px 40px rgba(0, 0, 0, .3)
}

.teach-pedagogy__visual img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    -webkit-transition: -webkit-transform .55s cubic-bezier(.25, .46, .45, .94);
    transition: transform .55s cubic-bezier(.25, .46, .45, .94)
}

.teach-pedagogy__node:hover .teach-pedagogy__visual img {
    -webkit-transform: scale(1.035);
    transform: scale(1.035)
}

@media (min-width: 768px) {
    .teach-pedagogy__list::before {
        content: "";
        position: absolute;
        left: 50%;
        top: 0;
        bottom: 0;
        width: 1px;
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
        background: -webkit-linear-gradient(180deg, transparent 0%, rgba(196, 168, 124, .2) 6%, rgba(196, 168, 124, .38) 50%, rgba(196, 168, 124, .2) 94%, transparent 100%);
        background: linear-gradient(180deg, transparent 0%, rgba(196, 168, 124, .2) 6%, rgba(196, 168, 124, .38) 50%, rgba(196, 168, 124, .2) 94%, transparent 100%);
        z-index: 0;
        pointer-events: none
    }

    .teach-pedagogy__node {
        grid-template-columns: minmax(0, 1fr) 56px minmax(0, 1fr);
        grid-template-areas: "copy rail visual";
        -webkit-column-gap: clamp(1rem, 2.5vw, 1.75rem);
        column-gap: clamp(1rem, 2.5vw, 1.75rem);
        row-gap: 0;
        align-items: center;
        padding: clamp(1.75rem, 3vw, 2.35rem) 0;
        border-bottom: none
    }

    .teach-pedagogy__node + .teach-pedagogy__node {
        border-top: 1px solid rgba(230, 233, 238, .05)
    }

    .teach-pedagogy__node:first-child {
        padding-top: .25rem
    }

    .teach-pedagogy__marker {
        grid-area: rail;
        grid-row: 1;
        padding-top: 0;
        position: relative;
        z-index: 1;
        align-self: center
    }

    .teach-pedagogy__node:not(.teach-pedagogy__node--swap) .teach-pedagogy__copy {
        text-align: right
    }

    .teach-pedagogy__node:not(.teach-pedagogy__node--swap) .teach-pedagogy__text {
        margin-left: auto
    }

    .teach-pedagogy__node--swap {
        grid-template-areas: "visual rail copy"
    }

    .teach-pedagogy__node--swap .teach-pedagogy__copy {
        text-align: left
    }

    .teach-pedagogy__node--swap .teach-pedagogy__text {
        margin-left: 0;
        margin-right: auto
    }

    .teach-pedagogy__visual {
        aspect-ratio: 4 / 3;
        min-height: 0;
        max-height: 220px
    }

    .teach-pedagogy__node--swap .teach-pedagogy__visual {
        justify-self: end;
        width: 100%;
        max-width: 320px
    }

    .teach-pedagogy__node:not(.teach-pedagogy__node--swap) .teach-pedagogy__visual {
        justify-self: start;
        width: 100%;
        max-width: 320px
    }
}

@media (prefers-reduced-motion: reduce) {
    .teach-pedagogy__visual img {
        -webkit-transition: none;
        transition: none
    }

    .teach-pedagogy__node:hover .teach-pedagogy__visual img {
        -webkit-transform: none;
        transform: none
    }
}

/* —— How we teach: compact studio grid —— */
.teach-pedagogy--studio {
    padding: clamp(2.5rem, 5vw, 4rem) 0 clamp(2.75rem, 6vw, 4.5rem)
}

/* Heading + grid align to same .container width as rest of site */
.teach-pedagogy--studio .teach-pedagogy__head.teach-pedagogy__head--studio {
    margin-bottom: clamp(1.5rem, 3.5vw, 2.25rem)
}

.teach-pedagogy--studio .teach-pedagogy__lede {
    max-width: 44rem
}

.teach-pedagogy__lede {
    margin: 1rem 0 0;
    font-family: Montserrat, sans-serif;
    font-size: clamp(.82rem, 1.35vw, .95rem);
    font-weight: 500;
    line-height: 1.65;
    letter-spacing: .02em;
    max-width: 32rem;
    margin-left: auto;
    margin-right: auto
}

/* How we teach: keep CSS minimal, let Bootstrap do layout */
.teach-pedagogy__row {
    max-width: 72rem;
    margin-left: auto;
    margin-right: auto
}

/* Studio grid: use full width of parent .container (not extra 72rem cap) */
.teach-pedagogy--studio .teach-pedagogy__row {
    max-width: none;
    width: 100%;
    margin-left: 0;
    margin-right: 0
}

/* card-row: allow inner columns to size from content (avoid clipping text with overflow:hidden) */
.teach-pedagogy--studio .teach-pedagogy__card-row {
    min-height: auto
}

.teach-pedagogy--studio .teach-pedagogy__studio-card {
    min-height: auto
}

.teach-pedagogy--studio .teach-pedagogy__card-figure {
    min-height: clamp(11rem, 20vw, 15rem);
    padding: 0.5rem 0.75rem
}

.teach-pedagogy--studio .teach-illustration {
    max-width: 100%;
    width: 100%;
    height: auto;
    max-height: clamp(9rem, 18vw, 15rem);
    object-fit: contain
}

@media (min-width: 48rem) {
    .teach-pedagogy--studio .teach-illustration {
        max-height: clamp(10rem, 16vw, 16rem)
    }
}

.teach-pedagogy--studio .teach-title {
    font-size: 34px;
    line-height: 1.28
}

.teach-pedagogy--studio .teach-copy {
    font-size: 16px;
    line-height: 1.6
}

.teach-badge {
    width: 2.05rem;
    height: 2.05rem;
    font-family: Montserrat, sans-serif;
    font-size: .58rem;
    font-weight: 700;
    letter-spacing: .04em;
    line-height: 1;
    color: #2a241b;
    background: #d4c4a8;
    -webkit-box-shadow: 0 0.1875rem 0.625rem rgba(0, 0, 0, .12);
    box-shadow: 0 0.1875rem 0.625rem rgba(0, 0, 0, .12)
}

.teach-illustration {
    /* width: 88%; */
    max-width: 15rem;
    height: auto;
    /* max-height: 92%; */
    -o-object-fit: contain;
    object-fit: contain;
    -o-object-position: center;
    object-position: center
}

.teach-title {
    font-family: "Cormorant Garamond", Georgia, serif;
    font-weight: 600;
    letter-spacing: .02em
}

.teach-copy {
    font-family: Montserrat, sans-serif;
    letter-spacing: .015em;
    line-height: 1.58
}

/* —— Why thoughtful making: circular portrait + quote column (Bootstrap: container, row, justify-content-center, col-12, h2, mb-3) —— */
@media (min-width: 992px) {
    .why-making .row>.col-lg-9 {
        flex: 0 0 auto;
        width: 75%
    }
}

@media (min-width: 1200px) {
    .why-making .row>.col-xl-8 {
        flex: 0 0 auto;
        width: 66.66666667%
    }
}

.why-making {
    position: relative;
    padding: clamp(2.75rem, 6vw, 4.25rem) 0;
    background:
        radial-gradient(ellipse 70% 50% at 20% 20%, rgba(100, 115, 67, .09) 0%, transparent 55%),
        radial-gradient(ellipse 60% 45% at 85% 80%, rgba(139, 120, 95, .1) 0%, transparent 50%),
        linear-gradient(165deg, #fdfcfa 0%, #f3efe6 48%, #ebe5da 100%);
    border-top: 1px solid rgba(30, 29, 40, .06);
    overflow: hidden
}

.why-making::before {
    content: "\201C";
    position: absolute;
    left: clamp(4%, 8vw, 12%);
    top: clamp(8%, 12vh, 18%);
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: clamp(5rem, 18vw, 11rem);
    line-height: 1;
    color: rgba(100, 115, 67, .07);
    pointer-events: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none
}

.why-making__layout {
    position: relative;
    z-index: 1;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -webkit-align-items: center;
    align-items: center;
    gap: clamp(1.5rem, 4vw, 2.25rem)
}

@media (min-width: 992px) {
    .why-making__layout {
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -webkit-flex-direction: row;
        flex-direction: row;
        -webkit-box-align: start;
        -webkit-align-items: flex-start;
        align-items: flex-start;
        gap: clamp(2rem, 5vw, 3.5rem);
        -webkit-box-pack: center;
        -webkit-justify-content: center;
        justify-content: center
    }
}

.why-making__orb {
    margin: 0;
    -webkit-flex-shrink: 0;
    flex-shrink: 0;
    width: min(13.5rem, 52vw);
    height: min(13.5rem, 52vw);
    border-radius: 50%;
    overflow: hidden;
    background: #3a4038;
    box-shadow:
        0 14px 40px rgba(30, 29, 40, .16),
        0 0 0 5px #fff,
        0 0 0 6px rgba(100, 115, 67, .28)
}

@media (min-width: 992px) {
    .why-making__orb {
        width: 14.5rem;
        height: 14.5rem
    }
}

.why-making__orb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 28%;
    display: block
}

.why-making__text {
    -webkit-box-flex: 1;
    -webkit-flex: 1;
    flex: 1;
    min-width: 0;
    text-align: center
}

@media (min-width: 992px) {
    .why-making__text {
        text-align: left;
        padding-top: .35rem
    }
}

.why-making__kicker {
    margin: 0 0 .55rem;
    font-size: .68rem;
    font-weight: 600;
    letter-spacing: .26em;
    text-transform: uppercase;
    color: #647343
}

.why-making__title {
    font-family: "Cormorant Garamond", Georgia, serif;
    font-weight: 600;
    font-size: clamp(1.7rem, 3.8vw, 2.5rem);
    line-height: 1.2;
    color: #1e1d28
}

.why-making__quote {
    margin-top: .25rem;
    padding: 1rem 0 0 1.15rem;
    border-left: 3px solid #647343;
    text-align: left
}

@media (max-width: 991.98px) {
    .why-making__quote {
        max-width: 32rem;
        margin-left: auto;
        margin-right: auto
    }
}

.why-making__body {
    margin: 0;
    font-size: .95rem;
    line-height: 1.8;
    color: rgba(30, 29, 40, .76)
}

/* —— Classes section (home): 3-col grid — intro | 01–02 top | 03–05 bottom —— */
.workshops-atlas {
    position: relative;
    padding: clamp(2.75rem, 6vw, 4.75rem) 0 clamp(3rem, 7vw, 5rem);
    overflow: hidden;
    background: linear-gradient(112deg, #4b533a 0%, #464c3a 42%, #3f382f 72%, #352c24 100%);
    border-top: 1px solid rgba(255, 255, 255, .1)
}

.workshops-atlas__bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(ellipse 90% 75% at 12% 88%, rgba(255, 255, 255, 0.06) 0%, transparent 52%),
        radial-gradient(ellipse 55% 45% at 88% 18%, rgba(210, 180, 140, 0.09) 0%, transparent 58%)
}

.workshops-atlas__inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.15rem
}

.workshops-atlas__intro {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    max-width: 22rem;
    margin: 0;
    padding: 0;
    text-align: left
}

.workshops-atlas__intro-branch {
    display: block;
    width: min(11.5rem, 78%);
    height: auto;
    margin-top: auto;
    padding-top: 1.25rem;
    opacity: 0.38;
    pointer-events: none
}

.workshops-atlas__eyebrow {
    margin: 0 0 0.75rem;
    font-family: Montserrat, sans-serif;
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.92)
}

.workshops-atlas__head-text {
    position: relative;
    margin-bottom: 1rem
}

.workshops-atlas__title {
    margin: 0 0 0.85rem;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-weight: 600;
    font-size: clamp(1.85rem, 4vw, 2.85rem);
    line-height: 1.14;
    letter-spacing: 0.01em;
    text-transform: none;
    color: #fff
}

.workshops-atlas__title-rule {
    display: block;
    width: 100%;
    height: 1px;
    background: rgba(255, 255, 255, 0.5)
}

.workshops-atlas__lede {
    margin: 0;
    max-width: 19rem;
    font-family: Montserrat, sans-serif;
    font-size: clamp(0.8125rem, 1.15vw, 0.9rem);
    font-weight: 400;
    line-height: 1.68;
    letter-spacing: 0.01em;
    color: rgba(255, 255, 255, 0.78)
}

.workshops-atlas__grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.15rem
}

.workshops-atlas__item {
    margin: 0;
    padding: 0;
    min-width: 0
}

.workshops-atlas__card {
    position: relative;
    display: block;
    height: 100%;
    min-height: 13.5rem;
    overflow: hidden;
    border-radius: 1.65rem;
    background: #f5f1e8;
    border: 1px solid rgba(255, 255, 255, 0.5);
    box-shadow: 0 0.75rem 2rem rgba(20, 18, 14, 0.18)
}

.workshops-atlas__card::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background: linear-gradient(90deg,
            #f5f1e8 0%,
            rgba(245, 241, 232, 0.97) 36%,
            rgba(245, 241, 232, 0.78) 48%,
            rgba(245, 241, 232, 0.3) 60%,
            transparent 82%)
}

.workshops-atlas__card-bg {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    /* left: 38%; */
    z-index: 0;
    width: auto;
    height: 100%;
    object-fit: cover;
    object-position: center right;
    display: block
}

.workshops-atlas__index {
    position: absolute;
    top: 0.65rem;
    right: 0.85rem;
    z-index: 3;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: clamp(2.5rem, 5vw, 3.75rem);
    font-weight: 600;
    font-style: italic;
    line-height: 1;
    color: rgba(100, 115, 67, 0.12);
    pointer-events: none
}

.workshops-atlas__icon {
    position: absolute;
    top: 1.1rem;
    left: 1.15rem;
    z-index: 4;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.4rem;
    height: 2.4rem;
    border-radius: 50%;
    background: #647343;
    color: #fff;
    box-shadow: 0 0.2rem 0.6rem rgba(82, 53, 40, 0.18)
}

.workshops-atlas__icon svg {
    width: 1.15rem;
    height: 1.15rem
}

.workshops-atlas__copy {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    min-height: 13.5rem;
    max-width: min(100%, 22rem);
    padding: 3.35rem 1.15rem 1.25rem 1.35rem
}

.workshops-atlas__name {
    margin: 0 0 0.2rem;
    padding-right: 2.5rem;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-weight: 600;
    font-size: clamp(1.2rem, 2vw, 1.90rem);
    line-height: 1.2;
    color: #1e1d28
}

.workshops-atlas__ages {
    display: block;
    margin-bottom: 0.55rem;
    font-family: Montserrat, sans-serif;
    font-size: 0.62rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: rgba(30, 29, 40, 0.48)
}

.workshops-atlas__desc {
    margin: 0 0 0.85rem;
    max-width: 28rem;
    font-family: Montserrat, sans-serif;
    font-size: 0.8125rem;
    line-height: 1.62;
    color: rgba(30, 29, 40, 0.68)
}

.workshops-atlas__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    list-style: none;
    margin: 0 0 1rem;
    padding: 0
}

.workshops-atlas__meta li {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.3rem 0.65rem;
    border-radius: 999rem;
    font-family: Montserrat, sans-serif;
    font-size: 0.58rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(30, 29, 40, 0.65);
    background: rgba(100, 115, 67, 0.1);
    border: 1px solid rgba(100, 115, 67, 0.14)
}

.workshops-atlas__meta-icon {
    font-size: 0.5rem;
    opacity: 0.55
}

.workshops-atlas__btn {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    margin-top: auto;
    padding: 0.55rem 1.1rem;
    border-radius: 999rem;
    font-family: Montserrat, sans-serif;
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    text-decoration: none;
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease
}

.workshops-atlas__btn--fill {
    color: #fff;
    background: #647343;
    border: 1px solid #647343;
    box-shadow: 0 0.35rem 1rem rgba(100, 115, 67, 0.35)
}

.workshops-atlas__btn--fill:hover {
    color: #fff;
    background: #556535;
    border-color: #556535
}

.workshops-atlas__btn--outline {
    color: #1e1d28;
    background: transparent;
    border: 1px solid rgba(30, 29, 40, 0.28)
}

.workshops-atlas__btn--outline:hover {
    color: #1e1d28;
    background: rgba(255, 255, 255, 0.5);
    border-color: rgba(30, 29, 40, 0.4)
}

.workshops-atlas__footer {
    margin-top: clamp(1.5rem, 3vw, 2.25rem);
    text-align: center
}

.workshops-atlas__footer-leaf {
    display: block;
    width: 1.25rem;
    height: 1.25rem;
    margin: 0 auto 0.65rem;
    color: rgba(220, 210, 190, 0.75)
}

.workshops-atlas__footer-leaf svg {
    width: 100%;
    height: 100%
}

.workshops-atlas__footer-text {
    margin: 0;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: clamp(1rem, 1.8vw, 1.2rem);
    font-style: italic;
    font-weight: 500;
    line-height: 1.5;
    color: rgba(248, 246, 241, 0.88)
}

/* Desktop: 3 equal columns — row1 intro|01|02, row2 03|04|05 */
@media (min-width: 48rem) {
    .workshops-atlas .workshops-atlas__inner.container {
        max-width: min(96vw, 1380px)
    }

    .workshops-atlas__inner {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        grid-template-rows: auto auto auto;
        gap: 1.2rem 1.35rem;
        align-items: stretch
    }

    .workshops-atlas__intro {
        grid-column: 1;
        grid-row: 1;
        align-self: stretch;
        justify-content: flex-end;
        max-width: none;
        min-height: 14.5rem
    }

    .workshops-atlas__lede {
        max-width: 100%
    }

    .workshops-atlas__intro-branch {
        width: min(12rem, 90%);
        padding-top: 1.5rem
    }

    .workshops-atlas__grid {
        display: contents
    }

    .workshops-atlas__item--top:nth-child(1) {
        grid-column: 2;
        grid-row: 1
    }

    .workshops-atlas__item--top:nth-child(2) {
        grid-column: 3;
        grid-row: 1
    }

    .workshops-atlas__item--bottom:nth-child(3) {
        grid-column: 1;
        grid-row: 2
    }

    .workshops-atlas__item--bottom:nth-child(4) {
        grid-column: 2;
        grid-row: 2
    }

    .workshops-atlas__item--bottom:nth-child(5) {
        grid-column: 3;
        grid-row: 2
    }

    .workshops-atlas__footer {
        grid-column: 1 / -1;
        grid-row: 3;
        margin-top: clamp(1.25rem, 2.5vw, 2rem)
    }

    .workshops-atlas__item--top .workshops-atlas__card,
    .workshops-atlas__item--top .workshops-atlas__copy {
        min-height: 14.5rem
    }

    .workshops-atlas__item--bottom .workshops-atlas__card,
    .workshops-atlas__item--bottom .workshops-atlas__copy {
        min-height: 14.5rem
    }

    .workshops-atlas__copy {
        max-width: 100%;
        padding: 3.35rem 0.75rem 1.15rem 1.35rem
    }

    .workshops-atlas__desc {
        font-size: 0.78rem;
        line-height: 1.58
    }

    /* .workshops-atlas__card-bg {
        left: 40%
    } */
}

@media (min-width: 62rem) {
    .workshops-atlas .workshops-atlas__inner.container {
        max-width: min(94vw, 1520px)
    }

    .workshops-atlas__inner {
        gap: 1.3rem 1.5rem
    }

    .workshops-atlas__intro {
        min-height: 15.5rem
    }

    .workshops-atlas__item--top .workshops-atlas__card,
    .workshops-atlas__item--top .workshops-atlas__copy,
    .workshops-atlas__item--bottom .workshops-atlas__card,
    .workshops-atlas__item--bottom .workshops-atlas__copy {
        min-height: 15.25rem
    }

    .workshops-atlas__title {
        font-size: clamp(2rem, 2.5vw, 2.9rem)
    }

    .workshops-atlas__desc {
        font-size: 15px;
        font-weight: 500;
        width: 53%;
    }
}

@media (max-width: 47.98rem) {
    .workshops-atlas__card-bg {
        left: 32%
    }
}

@media (prefers-reduced-motion: reduce) {
    .workshops-atlas__btn {
        transition: none
    }
}

/* —— Mission: wide hero crop + overlapping sheet (not side-by-side columns) —— */
.mission-atlas {
    background: -webkit-linear-gradient(180deg, #f7f8f5 0%, #e9ede6 100%);
    background: linear-gradient(180deg, #f7f8f5 0%, #e9ede6 100%);
    border-top: 1px solid rgba(100, 115, 67, .22)
}

.mission-atlas__hero {
    position: relative;
    margin: 0;
    overflow: hidden;
    width: 100%;
    height: clamp(11rem, 32vw, 20rem);
    border-radius: clamp(.5rem, 2vw, .85rem);
    -webkit-box-shadow: 0 18px 48px rgba(30, 29, 40, .12);
    box-shadow: 0 18px 48px rgba(30, 29, 40, .12)
}

@media (min-width: 768px) {
    .mission-atlas__hero {
        height: clamp(13rem, 26vw, 22rem)
    }
}

.mission-atlas__hero img {
    display: block;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center
}

.mission-atlas__pull {
    position: relative;
    z-index: 1;
    margin-top: clamp(-2.75rem, -6vw, -1.75rem)
}

.mission-atlas__sheet {
    margin: 0 auto;
    padding: clamp(1.35rem, 4vw, 2.25rem) clamp(1.15rem, 3vw, 2rem) clamp(1.5rem, 4vw, 2.35rem);
    background: #fff;
    border: 1px solid rgba(100, 115, 67, .14);
    border-radius: clamp(.35rem, 1.2vw, .5rem);
    -webkit-box-shadow: 0 20px 50px rgba(30, 29, 40, .08);
    box-shadow: 0 20px 50px rgba(30, 29, 40, .08)
}

.mission-atlas__eyebrow {
    margin: 0;
    font-family: Montserrat, sans-serif;
    font-size: .68rem;
    font-weight: 600;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: #647343
}

.mission-atlas__title {
    margin: 0;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-weight: 600;
    font-size: clamp(1.75rem, 4vw, 2.65rem);
    line-height: 1.15;
    letter-spacing: .02em;
    color: #1e1d28
}

.mission-atlas__divider {
    width: 4.5rem;
    height: 3px;
    background: -webkit-linear-gradient(90deg, #647343, #523528);
    background: linear-gradient(90deg, #647343, #523528);
    border-radius: 1px
}

.mission-atlas__body {
    margin: 0;
    font-size: clamp(.94rem, 1.35vw, 1.02rem);
    line-height: 1.78;
    color: rgba(30, 29, 40, .78)
}

.mission-atlas__tagline {
    margin: 1.5rem 0 0;
    padding-top: 1.15rem;
    border-top: 1px solid rgba(100, 115, 67, .18);
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: clamp(1.08rem, 2vw, 1.38rem);
    font-style: italic;
    font-weight: 500;
    line-height: 1.35;
    color: #523528
}

/* —— 2026 Look ahead —— */
.look-ahead-2026:not(.look-ahead-2026--ref) {
    position: relative;
    padding-top: clamp(2.5rem, 5vw, 4rem);
    padding-bottom: clamp(2.5rem, 5vw, 4rem);
    background: -webkit-radial-gradient(ellipse 120% 80% at 50% 0%, rgba(100, 115, 67, .06) 0%, transparent 55%), #f4f3ef;
    background: radial-gradient(ellipse 120% 80% at 50% 0%, rgba(100, 115, 67, .06) 0%, transparent 55%), #f4f3ef;
    border-top: 1px solid rgba(82, 53, 40, .09)
}

.look-ahead-2026:not(.look-ahead-2026--ref)::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: -webkit-linear-gradient(90deg, #647343 0%, #5a6b45 40%, #523528 100%);
    background: linear-gradient(90deg, #647343 0%, #5a6b45 40%, #523528 100%);
    opacity: .92
}

/* Ref: Look ahead section */
.look-ahead-2026--ref {
    --la-tile-sm: 6.35rem;
    --la-tile-row: 5.65rem;
    --la-strip-gap: .55rem;
    margin: 0;
    padding: 0;
    border-top: 1px solid rgba(82, 53, 40, .08);
    background: #f9f7f2
}

.look-ahead-2026--ref::before {
    display: none
}

.look-ahead-2026__top {
    margin: 0 auto;
    padding: 0 .5rem;
    max-width: 40rem
}

.look-ahead-2026__eyebrow {
    margin: 0 0 .3rem;
    font-family: Montserrat, sans-serif;
    font-size: .68rem;
    font-weight: 600;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: #647343
}

.look-ahead-2026__title {
    margin: 0;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-weight: 600;
    font-size: clamp(1.95rem, 4.5vw, 2.55rem);
    line-height: 1.12;
    letter-spacing: .015em;
    color: #1e1d28
}

.look-ahead-2026__rule {
    width: 3.5rem;
    height: 2px;
    margin: .9rem auto 0;
    background: -webkit-linear-gradient(90deg, #647343, rgba(82, 53, 40, .65));
    background: linear-gradient(90deg, #647343, rgba(82, 53, 40, .65));
    border-radius: 1px
}

.look-ahead-2026__strip {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: var(--la-tile-sm, 6.35rem) var(--la-tile-sm, 6.35rem);
    grid-template-columns: repeat(2, minmax(0, var(--la-tile-sm, 6.35rem)));
    gap: var(--la-strip-gap, .55rem);
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    max-width: 100%;
    margin: clamp(1.35rem, 3vw, 1.85rem) auto clamp(1.5rem, 3.5vw, 2rem);
    padding: 0 .5rem;
    justify-items: stretch
}

@media (min-width: 520px) {
    .look-ahead-2026__strip {
        -ms-grid-columns: var(--la-tile-row, 5.65rem) var(--la-tile-row, 5.65rem) var(--la-tile-row, 5.65rem) var(--la-tile-row, 5.65rem);
        grid-template-columns: repeat(4, minmax(0, var(--la-tile-row, 5.65rem)))
    }
}

.look-ahead-2026__tile {
    position: relative;
    overflow: hidden;
    margin: 0;
    width: 100%;
    aspect-ratio: 1 / 1;
    background: rgba(255, 255, 255, .55);
    border-radius: .4rem;
    border: 1px solid rgba(82, 53, 40, .07);
    -webkit-box-shadow: 0 2px 10px rgba(30, 29, 40, .04);
    box-shadow: 0 2px 10px rgba(30, 29, 40, .04)
}

.look-ahead-2026__tile > img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    display: block;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center
}

.look-ahead-2026__tile--focus > img {
    -o-object-position: 28% center;
    object-position: 28% center
}

.look-ahead-2026__panel {
    max-width: 32rem;
    margin: 0 auto;
    padding: clamp(1.25rem, 3vw, 1.65rem) clamp(1.1rem, 2.5vw, 1.5rem) clamp(1.35rem, 3vw, 1.75rem);
    text-align: center;
    background: #fff;
    border: 1px solid rgba(100, 115, 67, .12);
    border-radius: .5rem;
    -webkit-box-shadow: 0 10px 32px rgba(30, 29, 40, .06);
    box-shadow: 0 10px 32px rgba(30, 29, 40, .06)
}

.look-ahead-2026--ref .look-ahead-2026__intro {
    margin: 0 auto;
    max-width: 28rem;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: clamp(1.02rem, 1.45vw, 1.12rem);
    font-weight: 500;
    line-height: 1.72;
    color: rgba(30, 29, 40, .8)
}

.look-ahead-2026__ref-list {
    margin-left: auto;
    margin-right: auto;
    max-width: 24rem;
    padding: 0;
    text-align: left
}

.look-ahead-2026__ref-list li {
    position: relative;
    margin: 0 0 .55rem;
    padding-left: 1.05rem;
    font-family: Montserrat, sans-serif;
    font-size: clamp(.8rem, 1.05vw, .88rem);
    font-weight: 500;
    line-height: 1.55;
    letter-spacing: .015em;
    color: #4d5c38
}

.look-ahead-2026__ref-list li:last-child {
    margin-bottom: 0
}

.look-ahead-2026__ref-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: .55rem;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: #647343
}

.look-ahead-2026__actions {
    text-align: center
}

.look-ahead-2026--ref .look-ahead-2026__btn {
    min-height: 2.75rem;
    padding: .65rem 1.75rem;
    font-family: Montserrat, sans-serif;
    font-size: .58rem;
    font-weight: 600;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: #fff !important;
    border: none;
    border-radius: 999px;
    background: #647343;
    -webkit-box-shadow: 0 4px 14px rgba(100, 115, 67, .25);
    box-shadow: 0 4px 14px rgba(100, 115, 67, .25);
    -webkit-transition: background .2s ease, -webkit-transform .2s ease, box-shadow .2s ease;
    transition: background .2s ease, transform .2s ease, box-shadow .2s ease
}

.look-ahead-2026--ref .look-ahead-2026__btn:hover {
    color: #fff !important;
    background: #566738;
    -webkit-transform: translateY(-1px);
    transform: translateY(-1px);
    -webkit-box-shadow: 0 6px 20px rgba(100, 115, 67, .32);
    box-shadow: 0 6px 20px rgba(100, 115, 67, .32);
    -webkit-filter: none;
    filter: none
}

.look-ahead-2026--ref .look-ahead-2026__btn:focus-visible {
    outline: 2px solid #647343;
    outline-offset: 3px
}

@media (prefers-reduced-motion: reduce) {
    .look-ahead-2026--ref .look-ahead-2026__btn {
        -webkit-transition: none;
        transition: none
    }

    .look-ahead-2026--ref .look-ahead-2026__btn:hover {
        -webkit-transform: none;
        transform: none
    }
}

/* Split layout: copy + CTA | image grid (lg+) */
.look-ahead-2026--split .look-ahead-2026__top {
    max-width: none
}

.look-ahead-2026--split .look-ahead-2026__rule--split {
    margin-right: auto
}

.look-ahead-2026--split .look-ahead-2026__panel--split {
    max-width: none;
    margin-left: 0;
    margin-right: 0
}

.look-ahead-2026--split .look-ahead-2026__intro {
    max-width: none
}

.look-ahead-2026--split .look-ahead-2026__ref-list {
    max-width: none
}

/* Medium image grid: 2×2, scales with column (avoids tiny 4-across strip) */
.look-ahead-2026--split .look-ahead-2026__strip--split {
    display: grid;
    -ms-grid-columns: 1fr 1fr;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(.55rem, 2vw, .85rem);
    width: 100%;
    max-width: min(22rem, 100%);
    margin-left: auto;
    margin-right: auto;
    padding: 0;
    justify-items: stretch
}

@media (min-width: 520px) {
    .look-ahead-2026--split .look-ahead-2026__strip--split {
        -ms-grid-columns: 1fr 1fr;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        max-width: min(26rem, 100%)
    }
}

@media (min-width: 992px) {
    .look-ahead-2026--split .look-ahead-2026__strip--split {
        max-width: min(34rem, 100%);
        margin: 0;
        margin-left: auto
    }

    .look-ahead-2026--split .look-ahead-2026__actions {
        text-align: left
    }
}

/* Look ahead — reference mockup layout */
.look-ahead-2026--mockup {
    background: #f9f7f2
}

.look-ahead-2026--mockup .look-ahead-2026__top {
    max-width: none;
    margin-bottom: 0;
    padding: 0
}

.look-ahead-2026--mockup .look-ahead-2026__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    margin-bottom: 0.6rem;
    font-size: 0.75rem;
    letter-spacing: 0.12em;
    color: #647343
}

.look-ahead-2026__eyebrow-year {
    letter-spacing: 0.32em
}

.look-ahead-2026__eyebrow-leaf {
    display: inline-flex;
    width: 0.8rem;
    height: 0.8rem;
    color: #647343
}

.look-ahead-2026__eyebrow-leaf svg {
    width: 100%;
    height: 100%
}

.look-ahead-2026--mockup .look-ahead-2026__title {
    margin-bottom: 0;
    font-size: clamp(2.25rem, 4.8vw, 3.25rem);
    line-height: 1.06;
    color: #1e1d28
}

.look-ahead-2026__title-accent {
    background: linear-gradient(120deg, #4a5538 0%, #7a8460 50%, #647343 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent
}

.look-ahead-2026--mockup .look-ahead-2026__title-rule {
    display: block;
    width: 100%;
    height: 1px;
    margin-top: 0.85rem;
    background: rgba(30, 29, 40, 0.32)
}

.look-ahead-2026--mockup .look-ahead-2026__intro--above {
    margin: 1rem 0 1.25rem;
    max-width: 100%;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: clamp(1.05rem, 1.35vw, 1.2rem);
    font-weight: 500;
    line-height: 1.7;
    color: rgba(30, 29, 40, 0.8)
}

.look-ahead-2026--mockup .look-ahead-2026__panel {
    max-width: none;
    margin: 0;
    padding: 0;
    text-align: left;
    border-radius: 1.5rem;
    border: 1px solid rgba(100, 115, 67, 0.1);
    box-shadow: 0 12px 36px rgba(30, 29, 40, 0.07);
    overflow: hidden
}

.look-ahead-2026__features {
    padding: 0
}

.look-ahead-2026__feature {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    padding: 0.95rem 1.35rem;
    border-bottom: 1px solid rgba(82, 53, 40, 0.09)
}

.look-ahead-2026__feature:last-child {
    border-bottom: none
}

.look-ahead-2026__feat-icon {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 3.25rem;
    height: 3.25rem;
    border-radius: 50%;
    background: rgba(100, 115, 67, 0.11);
    color: #647343
}

.look-ahead-2026__feat-icon img {
    width: 2.25rem;
    height: 2.25rem;
    object-fit: contain;
    display: block
}

.look-ahead-2026__feat-text {
    font-family: Montserrat, sans-serif;
    font-size: clamp(0.9rem, 1.15vw, 1rem);
    font-weight: 500;
    line-height: 1.55;
    color: rgba(30, 29, 40, 0.76)
}

.look-ahead-2026--mockup .look-ahead-2026__actions {
    padding: 1rem 1.35rem 1.35rem;
    text-align: center
}

.look-ahead-2026--mockup .look-ahead-2026__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    width: 100%;
    min-height: 3rem;
    padding: 0.75rem 1.5rem;
    font-size: 0.68rem;
    letter-spacing: 0.2em;
    border-radius: 999px;
    background: #647343;
    box-shadow: 0 6px 18px rgba(100, 115, 67, 0.28)
}

.look-ahead-2026__btn-arrow {
    font-size: 1rem;
    line-height: 1
}

.look-ahead-2026__mosaic {
    position: relative;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: repeat(2, minmax(11rem, 1fr));
    gap: clamp(0.75rem, 1.5vw, 1rem);
    width: 100%;
    margin: 0
}

.look-ahead-2026--mockup .look-ahead-2026__tile {
    aspect-ratio: 4 / 3;
    min-height: 11rem;
    margin: 0;
    border-radius: 1.5rem;
    border: none;
    box-shadow: 0 10px 28px rgba(30, 29, 40, 0.1)
}

.look-ahead-2026__tile--tl {
    grid-column: 1;
    grid-row: 1
}

.look-ahead-2026__tile--tr {
    grid-column: 2;
    grid-row: 1
}

.look-ahead-2026__tile--bl {
    grid-column: 1;
    grid-row: 2
}

.look-ahead-2026__tile--br {
    grid-column: 2;
    grid-row: 2
}

.look-ahead-2026__tile--tl > img {
    object-position: 40% center
}

.look-ahead-2026__badge {
    position: absolute;
    z-index: 3;
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    max-width: calc(100% - 1.5rem);
    margin: 0;
    padding: 0.45rem 1rem 0.45rem 0.45rem;
    border-radius: 999rem;
    font-family: Montserrat, sans-serif;
    font-size: 0.55rem;
    font-weight: 500;
    font-style: normal;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #fff;
    background: linear-gradient(90deg, #6b7c52 0%, #4a5836 100%);
    box-shadow: 0 4px 14px rgba(30, 29, 40, 0.18)
}

.look-ahead-2026__tile--tl .look-ahead-2026__badge {
    left: 0.85rem;
    bottom: 0.85rem;
    top: auto;
    transform: none
}

.look-ahead-2026__badge-icon {
    display: inline-flex;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
    width: 2.65rem;
    height: 2.65rem;
    border-radius: 50%;
    background: #fff
}

.look-ahead-2026__badge-icon img {
    position: static;
    left: auto;
    top: auto;
    width: 2.2rem;
    height: 2.2rem;
    max-width: none;
    object-fit: contain;
    object-position: center;
    display: block
}

.look-ahead-2026__badge-text {
    display: flex;
    flex-direction: column;
    gap: 0.05rem;
    line-height: 1.2;
    font-weight: 500
}

.look-ahead-2026__badge-line {
    display: block;
    font-weight: 500
}

.look-ahead-2026__highlights {
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    width: 100%;
    max-width: 100%;
    margin-top: clamp(1rem, 2vw, 1.25rem);
    padding: 0.35rem 0;
    background: #f2ede4;
    border-radius: 999rem
}


.look-ahead-2026__highlight {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 1rem 1.35rem
}

.look-ahead-2026__highlight + .look-ahead-2026__highlight {
    border-top: 1px solid rgba(82, 53, 40, 0.12)
}

.look-ahead-2026__highlight-icon {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 3.25rem;
    height: 3.25rem;
    border-radius: 50%;
    background: #fff
}

.look-ahead-2026__highlight-icon img {
    width: 2.25rem;
    height: 2.25rem;
    object-fit: contain;
    display: block
}

.look-ahead-2026__highlight-title {
    margin: 0 0 0.15rem;
    font-family: Montserrat, sans-serif;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #647343
}

.look-ahead-2026__highlight-desc {
    margin: 0;
    font-family: Montserrat, sans-serif;
    font-size: 0.9rem;
    font-weight: 500;
    line-height: 1.5;
    color: rgba(30, 29, 40, 0.65)
}

@media (min-width: 48rem) {
    .look-ahead-2026__mosaic {
        grid-template-columns: 1.1fr 0.9fr;
        grid-template-rows: minmax(12rem, 1fr) minmax(12rem, 1fr);
        min-height: clamp(24rem, 50vw, 32rem)
    }

    .look-ahead-2026--mockup .look-ahead-2026__tile {
        aspect-ratio: unset;
        height: 100%;
        min-height: 12rem
    }

    .look-ahead-2026__tile--tr {
        min-height: 14rem
    }

    .look-ahead-2026__highlights {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        padding: 0.5rem clamp(2.25rem, 5vw, 3.25rem) 0.5rem 0
    }

    .look-ahead-2026__highlight {
        padding: 0.85rem 1.5rem
    }

    .look-ahead-2026__highlight + .look-ahead-2026__highlight {
        border-top: none;
        border-left: 1px solid rgba(82, 53, 40, 0.14)
    }

}

@media (min-width: 992px) {
    .look-ahead-2026__mosaic {
        min-height: clamp(28rem, 40vw, 36rem);
        gap: 1rem
    }

    .look-ahead-2026--mockup .look-ahead-2026__tile {
        min-height: 13.5rem
    }

    .look-ahead-2026__tile--tr {
        min-height: 16rem
    }

    .look-ahead-2026--mockup .look-ahead-2026__title {
        font-size: clamp(2.35rem, 3.2vw, 3.2rem)
    }
}

@media (min-width: 1200px) {
    .look-ahead-2026__mosaic {
        min-height: 38rem
    }

    .look-ahead-2026--mockup .look-ahead-2026__tile {
        min-height: 15rem
    }

    .look-ahead-2026__tile--tr {
        min-height: 18rem
    }
}

/* Look ahead — mobile */
@media (max-width: 575.98px) {
    .look-ahead-2026--mockup .look-ahead-2026__eyebrow {
        font-size: 0.72rem
    }

    .look-ahead-2026--mockup .look-ahead-2026__title {
        font-size: clamp(2rem, 8vw, 2.35rem)
    }

    .look-ahead-2026--mockup .look-ahead-2026__intro--above {
        margin: 0.75rem 0 1rem;
        font-size: 1.1rem;
        line-height: 1.65
    }

    .look-ahead-2026--mockup .look-ahead-2026__panel {
        border-radius: 1.15rem
    }

    .look-ahead-2026__feature {
        gap: 0.85rem;
        padding: 1rem 1.15rem
    }

    .look-ahead-2026__feat-icon {
        width: 3.25rem;
        height: 3.25rem
    }

    .look-ahead-2026__feat-icon img {
        width: 2.25rem;
        height: 2.25rem
    }

    .look-ahead-2026__feat-text {
        font-size: 0.9375rem;
        line-height: 1.55;
        text-align: left
    }

    .look-ahead-2026--mockup .look-ahead-2026__actions {
        padding: 0.85rem 1rem 1.1rem
    }

    .look-ahead-2026--mockup .look-ahead-2026__btn {
        min-height: 2.85rem;
        font-size: 0.7rem;
        letter-spacing: 0.18em
    }

    .look-ahead-2026__mosaic {
        grid-template-rows: repeat(2, minmax(8.5rem, 1fr));
        gap: 0.6rem
    }

    .look-ahead-2026--mockup .look-ahead-2026__tile {
        min-height: 8.5rem;
        border-radius: 1rem
    }

    .look-ahead-2026__badge {
        gap: 0.45rem;
        max-width: calc(100% - 0.85rem);
        padding: 0.4rem 0.85rem 0.4rem 0.4rem;
        font-size: 0.52rem;
        letter-spacing: 0.09em
    }

    .look-ahead-2026__tile--tl .look-ahead-2026__badge {
        left: 0.5rem;
        bottom: 0.5rem
    }

    .look-ahead-2026__badge-icon {
        width: 1.75rem;
        height: 1.75rem
    }

    .look-ahead-2026__badge-icon img {
        width: 1rem;
        height: 1rem
    }

    .look-ahead-2026__highlights {
        margin-top: 0.85rem;
        border-radius: 1.15rem
    }

    .look-ahead-2026__highlight {
        gap: 0.6rem;
        padding: 0.85rem 1rem
    }

    .look-ahead-2026__highlight-icon {
        width: 3.25rem;
        height: 3.25rem
    }

    .look-ahead-2026__highlight-icon img {
        width: 2.25rem;
        height: 2.25rem
    }

    .look-ahead-2026__highlight-title {
        font-size: 0.7rem;
        letter-spacing: 0.11em
    }

    .look-ahead-2026__highlight-desc {
        font-size: 0.875rem;
        line-height: 1.5
    }
}

/* Look ahead — tablet */
@media (min-width: 576px) and (max-width: 991.98px) {
    .look-ahead-2026--mockup .look-ahead-2026__panel {
        max-width: 36rem;
        margin-left: auto;
        margin-right: auto
    }

    .look-ahead-2026__mosaic {
        grid-template-rows: repeat(2, minmax(10rem, 1fr));
        min-height: clamp(18rem, 48vw, 26rem)
    }

    .look-ahead-2026--mockup .look-ahead-2026__tile {
        min-height: 10rem;
        border-radius: 1.25rem
    }

    .look-ahead-2026__highlights {
        border-radius: 1.35rem
    }

    .look-ahead-2026__badge {
        font-size: 0.46rem
    }

    .look-ahead-2026__badge-icon {
        width: 2rem;
        height: 2rem
    }

    .look-ahead-2026__badge-icon img {
        width: 1.1rem;
        height: 1.1rem
    }
}

@media (min-width: 576px) and (max-width: 767.98px) {
    .look-ahead-2026__highlights {
        border-radius: 999rem
    }
}

@media (min-width: 768px) and (max-width: 991.98px) {
    .look-ahead-2026__highlights {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        border-radius: 999rem;
        padding: 0.5rem clamp(1.75rem, 4vw, 2.5rem) 0.5rem 0
    }

    .look-ahead-2026__highlight + .look-ahead-2026__highlight {
        border-top: none;
        border-left: 1px solid rgba(82, 53, 40, 0.14)
    }

    .look-ahead-2026__highlight {
        padding: 0.75rem 1rem
    }
}

/* Embroidery css start */
:root {
    --embroidery-olive: #647343;
    --embroidery-olive-2: #566738;
    --embroidery-ink: #0f172a;
    --embroidery-cream: #f6f3ea;
    --embroidery-paper: #fbfaf6;
    --embroidery-line: rgba(15, 23, 42, .12);
}

.embroidery-section {
    background: var(--embroidery-paper);
}

.embroidery-section--alt {
    background: linear-gradient(180deg, rgba(100, 115, 67, .08), rgba(100, 115, 67, .04) 55%, rgba(251, 250, 246, 1));
}

.embroidery-eyebrow {
    letter-spacing: .22em;
    font-weight: 600;
    color: var(--embroidery-olive);
}

.embroidery-h2 {
    font-family: "Cormorant Garamond", serif;
    letter-spacing: .02em;
    color: var(--embroidery-ink);
}

.embroidery-link {
    color: var(--embroidery-olive);
    text-decoration: none;
    font-weight: 600;
}

.embroidery-link:hover {
    color: var(--embroidery-olive-2);
    text-decoration: underline;
}

/* Hero */
.embroidery-hero {
    color: #fff;
    background: radial-gradient(1200px 600px at 18% 8%, rgba(255, 255, 255, .18), rgba(255, 255, 255, 0) 55%),
        radial-gradient(900px 550px at 92% 14%, rgba(100, 115, 67, .42), rgba(100, 115, 67, 0) 62%),
        linear-gradient(135deg, #0b1220, #0b1a14 35%, #1a2513);
}

.embroidery-hero__bg {
    position: absolute;
    inset: 0;
    background-image: url("../images/Embroidery.png");
    background-size: cover;
    background-position: center;
    opacity: .16;
    filter: saturate(1.05) contrast(1.05);
    transform: scale(1.02);
}

.embroidery-hero__breadcrumb .breadcrumb-item a {
    color: rgba(255, 255, 255, .86);
    text-decoration: none;
}

.embroidery-hero__breadcrumb .breadcrumb-item a:hover {
    color: #fff;
    text-decoration: underline;
}

.embroidery-hero__breadcrumb .breadcrumb-item.active {
    color: rgba(255, 255, 255, .70);
}

.embroidery-hero__kicker {
    letter-spacing: .22em;
    font-weight: 600;
    color: rgba(255, 255, 255, .88);
}

.embroidery-hero__title {
    font-family: "Cormorant Garamond", serif;
    letter-spacing: .04em;
}

.embroidery-hero__sub {
    color: rgba(255, 255, 255, .88);
    max-width: 42rem;
}

.embroidery-hero__statgrid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .85rem;
}

.embroidery-hero__stat {
    border: 1px solid rgba(255, 255, 255, .18);
    background: rgba(15, 23, 42, .28);
    backdrop-filter: blur(8px);
    border-radius: 1rem;
    padding: 1rem;
}

.embroidery-hero__stat-value {
    font-weight: 700;
    letter-spacing: .02em;
}

.embroidery-hero__stat-label {
    margin-top: .25rem;
    font-size: .85rem;
    color: rgba(255, 255, 255, .76);
}

/* Buttons */
.embroidery-btn {
    border-radius: 999px;
    font-family: Montserrat, sans-serif;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.embroidery-btn.btn-primary {
    border: none;
    background: var(--embroidery-olive);
    box-shadow: 0 12px 28px rgba(100, 115, 67, .22);
}

.embroidery-btn.btn-primary:hover {
    background: var(--embroidery-olive-2);
    transform: translateY(-1px);
}

.embroidery-btn--outline {
    border-color: rgba(100, 115, 67, .45) !important;
    color: var(--embroidery-olive) !important;
}

.embroidery-btn--outline:hover {
    border-color: var(--embroidery-olive) !important;
    background: rgba(100, 115, 67, .08) !important;
}

.embroidery-btn--ghost {
    border-color: rgba(255, 255, 255, .55) !important;
}

.embroidery-btn--ghost:hover {
    border-color: rgba(255, 255, 255, .85) !important;
    background: rgba(255, 255, 255, .10) !important;
}

.embroidery-btn--light {
    color: #0b1220 !important;
    background: rgba(255, 255, 255, .92) !important;
    border: 1px solid rgba(255, 255, 255, .45) !important;
}

/* About media */
.embroidery-media {
    border-radius: 1.25rem;
    background: radial-gradient(800px 380px at 18% 18%, rgba(100, 115, 67, .14), rgba(100, 115, 67, 0) 55%),
        linear-gradient(180deg, rgba(15, 23, 42, .06), rgba(15, 23, 42, .00));
    border: 1px solid var(--embroidery-line);
    padding: .85rem;
}

.embroidery-media__img {
    border-radius: 1rem;
}

/* About side image sizing (used in About section) */
.embroidery-media--fixed {
    padding: 0;
    overflow: hidden;
    border-radius: 1.25rem;
    height: clamp(200px, 42vw, 420px);
    max-width: 34rem;
    margin-left: auto;
    margin-right: auto;
}

@media (min-width: 768px) {
    .embroidery-media--fixed {
        height: clamp(260px, 24vw, 440px);
    }
}

@media (min-width: 992px) {
    .embroidery-media--fixed {
        height: clamp(300px, 22vw, 480px);
    }
}

.embroidery-media--fixed .embroidery-media__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    border-radius: inherit;
}

.embroidery-feature {
    border: 1px solid var(--embroidery-line);
    background: rgba(255, 255, 255, .72);
}

/* About (text-first) */
.embroidery-about-copy {
    max-width: 62rem;
}

.embroidery-about-block {
    border: 1px solid var(--embroidery-line);
    background: rgba(255, 255, 255, .72);
    border-radius: 1.25rem;
    padding: 1rem 1.05rem;
}

.embroidery-about-list {
    padding-left: 1.15rem;
    margin-bottom: 0;
    color: rgba(15, 23, 42, .72);
}

.embroidery-about-list li {
    margin-bottom: .4rem;
}

.embroidery-learn-closing {
    border-top: 1px solid var(--embroidery-line);
}

.embroidery-learn-closing p {
    color: rgba(15, 23, 42, .82);
    font-size: 1.0625rem;
    line-height: 1.7;
    font-style: italic;
    max-width: 48rem;
}

/* Full-width image after content */
.embroidery-wide {
    border-radius: 1.25rem;
    overflow: hidden;
    border: 1px solid rgba(15, 23, 42, .10);
    background: rgba(255, 255, 255, .72);
    box-shadow: 0 18px 45px rgba(15, 23, 42, .06);
    max-width: 60rem;
    margin-left: auto;
    margin-right: auto;
}

.embroidery-wide img {
    width: 100%;
    height: clamp(200px, 26vw, 420px);
    object-fit: cover;
    object-position: center;
    display: block;
}

/* Cards / lists */
.embroidery-card {
    border-radius: 1.25rem;
    background: rgba(255, 255, 255, .84);
    transition: transform .2s ease, box-shadow .2s ease;
}

.embroidery-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 40px rgba(15, 23, 42, .10) !important;
}

/* Classes cards */
.embroidery-class {
    overflow: hidden;
    box-shadow: 0 18px 45px rgba(15, 23, 42, .08) !important;
}

.embroidery-class__media {
    position: relative;
    height: 180px;
    background: rgba(100, 115, 67, .08);
}

.embroidery-class__media::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(15, 23, 42, 0) 55%, rgba(15, 23, 42, .18));
    opacity: 1;
    pointer-events: none;
}

@media (min-width: 768px) {
    .embroidery-class__media {
        height: 190px;
    }
}

@media (min-width: 992px) {
    .embroidery-class__media {
        height: 200px;
    }
}

.embroidery-class__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    transform: scale(1.02);
    transition: transform .35s ease;
    filter: saturate(1.05) contrast(1.03);
}

.embroidery-class:hover .embroidery-class__media img {
    transform: scale(1.07);
}

.embroidery-class__info {
    display: flex;
    flex-wrap: wrap;
    gap: .55rem;
}

.embroidery-class__pill {
    display: inline-flex;
    align-items: baseline;
    gap: .45rem;
    padding: .55rem .7rem;
    border-radius: 999px;
    border: 1px solid rgba(15, 23, 42, .10);
    background: rgba(255, 255, 255, .72);
    color: rgba(15, 23, 42, .76);
    font-weight: 700;
    font-size: .9rem;
}

.embroidery-class__pill-k {
    font-size: .66rem;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: rgba(15, 23, 42, .54);
    font-weight: 900;
}

/* New compact meta row for classes */
.embroidery-class__meta2 {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}

.embroidery-class__chip {
    display: inline-flex;
    align-items: center;
    padding: .4rem .65rem;
    border-radius: 999px;
    border: 1px solid rgba(15, 23, 42, .10);
    background: rgba(255, 255, 255, .70);
    color: rgba(15, 23, 42, .70);
    font-weight: 700;
    font-size: .88rem;
}

/* Legacy meta layout no longer used by cards */
.embroidery-class__meta,
.embroidery-class__meta-row,
.embroidery-class__meta-label,
.embroidery-class__meta-value {
    display: none;
}

.embroidery-badge {
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: rgba(15, 23, 42, .78);
}

.embroidery-list li {
    position: relative;
    padding-left: 1.05rem;
    margin-bottom: .35rem;
    color: rgba(15, 23, 42, .72);
}

.embroidery-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: .52rem;
    width: 6px;
    height: 6px;
    border-radius: 999px;
    background: var(--embroidery-olive);
    opacity: .9;
}

/* Events */
.embroidery-cta {
    border: 1px solid rgba(255, 255, 255, .20);
    background: linear-gradient(135deg, rgba(100, 115, 67, .22), rgba(100, 115, 67, .10) 55%, rgba(15, 23, 42, .02));
}

/* Events cards (replaces list-group rows) */
.embroidery-event-card {
    border-radius: 1.25rem;
    background: rgba(255, 255, 255, .84);
}

/* Events: featured + mini stack */
.embroidery-event-feature,
.embroidery-event-mini {
    border-radius: 1.25rem;
    background: rgba(255, 255, 255, .84);
}

.embroidery-event-feature__media {
    height: 100%;
    min-height: 240px;
    background: rgba(100, 115, 67, .08);
}

.embroidery-event-feature__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

.embroidery-events-note {
    border-radius: 1.25rem;
    border: 1px solid rgba(15, 23, 42, .10);
    background: linear-gradient(135deg, rgba(100, 115, 67, .18), rgba(100, 115, 67, .06) 55%, rgba(255, 255, 255, .72));
    padding: 1.25rem;
}

/* Events section background + grid cards */
.embroidery-events-section {
    background:
        radial-gradient(900px 420px at 12% 18%, rgba(100, 115, 67, .14), rgba(100, 115, 67, 0) 60%),
        radial-gradient(860px 420px at 92% 24%, rgba(15, 23, 42, .06), rgba(15, 23, 42, 0) 62%),
        linear-gradient(180deg, rgba(251, 250, 246, 1), rgba(246, 243, 234, 1));
}

.embroidery-event-grid {
    border-radius: 1.25rem;
    overflow: hidden;
    background: rgba(255, 255, 255, .84);
}

.embroidery-event-grid__media {
    height: 180px;
    background: rgba(100, 115, 67, .08);
}

@media (min-width: 992px) {
    .embroidery-event-grid__media {
        height: 190px;
    }
}

.embroidery-event-grid__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

.embroidery-events-banner {
    border: 1px solid rgba(15, 23, 42, .10);
    background: rgba(255, 255, 255, .72);
}

.embroidery-date {
    width: 3.2rem;
    min-width: 3.2rem;
    border-radius: 1rem;
    border: 1px solid rgba(100, 115, 67, .20);
    background: rgba(100, 115, 67, .08);
    text-align: center;
    padding: .55rem .25rem;
}

.embroidery-date__day {
    font-weight: 800;
    font-size: 1.1rem;
    line-height: 1;
    color: var(--embroidery-olive);
}

.embroidery-date__mon {
    margin-top: .2rem;
    font-size: .72rem;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: rgba(15, 23, 42, .62);
}

/* Past events */
.embroidery-past {
    border: 1px solid var(--embroidery-line);
    background: rgba(255, 255, 255, .72);
}

.embroidery-dot {
    width: .85rem;
    height: .85rem;
    margin-top: .2rem;
    border-radius: 999px;
    background: var(--embroidery-olive);
    box-shadow: 0 0 0 6px rgba(100, 115, 67, .14);
}

/* Accordion */
.embroidery-accordion .accordion-button {
    font-weight: 700;
    color: var(--embroidery-ink);
    background: rgba(255, 255, 255, .85);
}

.embroidery-accordion .accordion-button:not(.collapsed) {
    color: var(--embroidery-ink);
    background: rgba(100, 115, 67, .10);
    box-shadow: none;
}

.embroidery-accordion .accordion-button:focus {
    box-shadow: 0 0 0 .25rem rgba(100, 115, 67, .22);
}

.embroidery-accordion .accordion-body {
    background: rgba(255, 255, 255, .78);
}

/* Footer */
.embroidery-footer {
    background: rgba(251, 250, 246, 1);
}

.embroidery-footer__link {
    color: rgba(15, 23, 42, .72);
    text-decoration: none;
    font-weight: 600;
}

.embroidery-footer__link:hover {
    color: var(--embroidery-olive);
    text-decoration: underline;
}

/* Site footer — mockup (olive, 4 columns) */
.site-footer {
    background: #6b704d;
    color: rgba(255, 255, 255, 0.92);
    padding: clamp(2.5rem, 5vw, 3.5rem) 0 clamp(1.75rem, 3vw, 2.25rem)
}

.site-footer__logo-link {
    display: inline-block;
    margin-bottom: 1.15rem
}

.site-footer__logo {
    display: block;
    width: min(100%, 13.75rem);
    height: auto;
    filter: brightness(0) invert(1);
    opacity: 0.98
}

.site-footer__about {
    margin: 0 0 1.35rem;
    max-width: 22rem;
    font-family: Montserrat, sans-serif;
    font-size: clamp(0.8rem, 1vw, 0.875rem);
    font-weight: 400;
    line-height: 1.65;
    color: rgba(255, 255, 255, 0.82)
}

.site-footer__social {
    display: flex;
    align-items: center;
    gap: 0.65rem
}

.site-footer__social-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    color: #fff;
    text-decoration: none;
    transition: opacity 0.2s ease, transform 0.2s ease
}

.site-footer__social-link svg {
    width: 1.15rem;
    height: 1.15rem
}

.site-footer__social-link:hover,
.site-footer__social-link:focus-visible {
    color: #fff;
    opacity: 0.85;
    transform: translateY(-1px)
}

.site-footer__heading {
    margin: 0 0 1rem;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: clamp(1.15rem, 2vw, 1.35rem);
    font-weight: 600;
    line-height: 1.2;
    color: #fff
}

.site-footer__links {
    display: grid;
    gap: 0.55rem
}

.site-footer__links a {
    font-family: Montserrat, sans-serif;
    font-size: clamp(0.78rem, 0.95vw, 0.84rem);
    font-weight: 400;
    line-height: 1.4;
    color: rgba(255, 255, 255, 0.82);
    text-decoration: none;
    transition: color 0.2s ease
}

.site-footer__links a:hover,
.site-footer__links a:focus-visible {
    color: #fff
}

.site-footer__newsletter-text {
    margin: 0 0 1rem;
    font-family: Montserrat, sans-serif;
    font-size: clamp(0.78rem, 0.95vw, 0.84rem);
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.8)
}

.site-footer__newsletter-field {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    width: 100%;
    max-width: 100%;
    padding: 0.35rem 0.35rem 0.35rem 1.1rem;
    background: rgba(0, 0, 0, 0.14);
    border-radius: 999rem
}

.site-footer__newsletter-field input {
    flex: 1;
    min-width: 0;
    padding: 0.55rem 0;
    font-family: Montserrat, sans-serif;
    font-size: 0.8rem;
    color: #fff;
    background: transparent;
    border: 0;
    outline: none
}

.site-footer__newsletter-field input::placeholder {
    color: rgba(255, 255, 255, 0.45)
}

.site-footer__newsletter-btn {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.15rem;
    height: 2.15rem;
    padding: 0;
    font-size: 1rem;
    line-height: 1;
    color: #6b704d;
    background: #fff;
    border: 0;
    border-radius: 50%;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease
}

.site-footer__newsletter-btn:hover,
.site-footer__newsletter-btn:focus-visible {
    transform: scale(1.04);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2)
}

.site-footer__rule {
    margin: clamp(2rem, 4vw, 2.75rem) 0 1.25rem;
    height: 1px;
    background: rgba(255, 255, 255, 0.22)
}

.site-footer__copy {
    text-align: center;
    font-family: Montserrat, sans-serif;
    font-size: 0.72rem;
    font-weight: 400;
    letter-spacing: 0.02em;
    color: rgba(255, 255, 255, 0.65)
}

@media (max-width: 767.98px) {
    .site-footer__brand {
        text-align: center
    }

    .site-footer__logo-link {
        margin-left: auto;
        margin-right: auto
    }

    .site-footer__about {
        margin-left: auto;
        margin-right: auto
    }

    .site-footer__social {
        justify-content: center
    }

    .site-footer__col {
        text-align: center
    }

    .site-footer__links {
        justify-items: center
    }

    .site-footer__newsletter-col {
        text-align: center
    }

    .site-footer__newsletter-field {
        margin-left: auto;
        margin-right: auto
    }
}

@media (prefers-reduced-motion: reduce) {
    .embroidery-card,
    .embroidery-btn.btn-primary {
        transition: none !important;
    }
    .embroidery-card:hover,
    .embroidery-btn.btn-primary:hover {
        transform: none !important;
    }
}

/* Workshop css start */
.workshop-page {
    overflow-x: clip;
}

.workshop-hero--editorial {
    position: relative;
    isolation: isolate;
    background:
        radial-gradient(120% 80% at 100% 0%, rgba(100, 115, 67, .14), rgba(100, 115, 67, 0) 52%),
        radial-gradient(90% 55% at 0% 100%, rgba(15, 23, 42, .05), rgba(15, 23, 42, 0) 45%),
        linear-gradient(165deg, #f3efe6 0%, #fbfaf6 45%, #e9e4d8 100%);
}

.workshop-hero__mesh {
    position: absolute;
    inset: 0;
    z-index: 0;
    opacity: .35;
    pointer-events: none;
    background-image:
        radial-gradient(rgba(15, 23, 42, .05) 1px, transparent 1px);
    background-size: 14px 14px;
}

.workshop-hero__diagonal {
    position: absolute;
    top: -40%;
    right: -25%;
    width: min(78vw, 920px);
    height: 140%;
    z-index: 0;
    pointer-events: none;
    background: linear-gradient(118deg, rgba(100, 115, 67, .12), rgba(100, 115, 67, 0) 58%);
    transform: rotate(-12deg);
    border-radius: 3rem;
}

.workshop-hero--editorial .container {
    z-index: 1;
}

.workshop-hero__jump {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .5rem .85rem;
    padding-top: 1.25rem;
    font-family: Montserrat, sans-serif;
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
}

.workshop-hero__jump a {
    color: rgba(15, 23, 42, .55);
    text-decoration: none;
    transition: color .2s ease;
}

.workshop-hero__jump a:hover {
    color: var(--embroidery-olive);
}

.workshop-hero__jump-dot {
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: rgba(100, 115, 67, .4);
}

.workshop-hero__label-row {
    display: flex;
    align-items: baseline;
    gap: 1rem;
    margin-bottom: .5rem;
}

.workshop-hero__index {
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(2.5rem, 6vw, 4rem);
    line-height: .85;
    font-weight: 600;
    color: rgba(100, 115, 67, .22);
    user-select: none;
}

.workshop-hero__eyebrow-tight {
    letter-spacing: .22em;
}

.workshop-hero__display {
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(2.35rem, 4.8vw, 3.65rem);
    font-weight: 600;
    line-height: 1.05;
    letter-spacing: .01em;
    color: var(--embroidery-ink);
    max-width: 16ch;
}

.workshop-hero__em {
    font-style: italic;
    color: var(--embroidery-olive);
}

.workshop-hero__lead {
    font-size: 1.08rem;
    line-height: 1.65;
    color: rgba(15, 23, 42, .72);
    max-width: 36rem;
}

.workshop-hero__btn {
    min-width: 11rem;
}

.workshop-hero__collage {
    position: relative;
    min-height: clamp(320px, 52vw, 460px);
    margin-top: .5rem;
}

.workshop-hero__frame {
    margin: 0;
    overflow: hidden;
    box-shadow:
        0 28px 55px rgba(15, 23, 42, .16),
        0 0 0 1px rgba(15, 23, 42, .06);
}

.workshop-hero__frame img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.workshop-hero__frame--primary {
    position: relative;
    width: 74%;
    border-radius: 0 2.25rem 2.25rem 2.25rem;
    aspect-ratio: 4 / 5;
    z-index: 1;
}

.workshop-hero__frame--overlap {
    position: absolute;
    right: 0;
    bottom: 8%;
    width: 48%;
    border-radius: 2rem;
    transform: rotate(4deg);
    z-index: 2;
    aspect-ratio: 1 / 1.15;
}

.workshop-hero__float-card {
    position: absolute;
    left: -4%;
    bottom: -2%;
    width: min(100%, 288px);
    z-index: 3;
    padding: 1.25rem 1.35rem 1.35rem;
    border-radius: 0 1.5rem 1.5rem 1.5rem;
    border: 1px solid rgba(255, 255, 255, .65);
    background: rgba(255, 255, 255, .88);
    backdrop-filter: blur(10px);
    box-shadow: 0 22px 48px rgba(15, 23, 42, .12);
}

.workshop-hero__float-kicker {
    font-family: Montserrat, sans-serif;
    font-weight: 800;
    font-size: .68rem;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: rgba(15, 23, 42, .5);
    margin-bottom: .85rem;
}

.workshop-hero__list li {
    position: relative;
    padding-left: 1rem;
    margin-bottom: .4rem;
    font-size: .88rem;
    font-weight: 600;
    color: rgba(15, 23, 42, .78);
}

.workshop-hero__list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: .45rem;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--embroidery-olive);
}

@media (max-width: 991.98px) {
    .workshop-hero__collage {
        min-height: 0;
        margin-top: 1.5rem;
    }

    .workshop-hero__frame--primary {
        width: 100%;
        max-width: 420px;
        margin-inline: auto;
    }

    .workshop-hero__frame--overlap {
        position: relative;
        right: auto;
        bottom: auto;
        width: 72%;
        max-width: 260px;
        margin: -2rem 0 0 auto;
        transform: rotate(3deg);
    }

    .workshop-hero__float-card {
        position: relative;
        left: 0;
        bottom: auto;
        width: 100%;
        max-width: 100%;
        margin-top: 1.25rem;
        border-radius: 1.5rem;
    }
}

/* About — bento grid */
.workshop-about {
    background:
        radial-gradient(700px 320px at 0% 0%, rgba(100, 115, 67, .08), rgba(100, 115, 67, 0) 60%),
        linear-gradient(180deg, #fbfaf6, #ece7de);
    border-top: 1px solid rgba(15, 23, 42, .06);
    border-bottom: 1px solid rgba(15, 23, 42, .06);
}

.workshop-about__layout {
    display: grid;
    gap: 2rem 2.5rem;
}

@media (min-width: 992px) {
    .workshop-about__layout {
        grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
        grid-template-areas:
            "intro intro"
            "copy timeline";
        align-items: start;
    }

    .workshop-about__intro {
        grid-area: intro;
    }

    .workshop-about__copy {
        grid-area: copy;
    }

    .workshop-about__timeline {
        grid-area: timeline;
    }
}

.workshop-about__title {
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(2rem, 3.5vw, 2.85rem);
    line-height: 1.08;
}

.workshop-about__text {
    font-size: 1.02rem;
    line-height: 1.7;
    color: rgba(15, 23, 42, .78);
}

.workshop-about__timeline {
    border-radius: 0 1.75rem 1.75rem 1.75rem;
    padding: 1.5rem 1.5rem 1.35rem;
    background: rgba(255, 255, 255, .72);
    border: 1px solid rgba(15, 23, 42, .1);
    box-shadow: 0 16px 40px rgba(15, 23, 42, .06);
}

.workshop-about__timeline-head {
    font-family: Montserrat, sans-serif;
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--embroidery-olive);
    margin-bottom: 1rem;
    padding-bottom: .75rem;
    border-bottom: 2px solid rgba(100, 115, 67, .25);
}

.workshop-about__steps {
    list-style: none;
    margin: 0;
    padding: 0;
}

.workshop-about__steps li {
    display: flex;
    align-items: flex-start;
    gap: .85rem;
    padding: .65rem 0;
    font-weight: 600;
    font-size: .95rem;
    color: rgba(15, 23, 42, .82);
    border-bottom: 1px dashed rgba(15, 23, 42, .12);
}

.workshop-about__steps li:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.workshop-about__step-num {
    flex-shrink: 0;
    width: 1.75rem;
    height: 1.75rem;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: Montserrat, sans-serif;
    font-size: .75rem;
    font-weight: 800;
    color: #fff;
    background: var(--embroidery-olive);
}

/* Tracks — band + zigzag rows */
.workshop-tracks__band {
    background: linear-gradient(90deg, var(--embroidery-olive-2), var(--embroidery-olive));
    color: rgba(255, 255, 255, .95);
    box-shadow: 0 12px 40px rgba(45, 55, 28, .28);
}

.workshop-tracks__band-label {
    font-family: Montserrat, sans-serif;
    font-weight: 800;
    font-size: .72rem;
    letter-spacing: .2em;
    text-transform: uppercase;
}

.workshop-tracks__band-meta {
    font-size: .82rem;
    opacity: .82;
}

.workshop-track-row {
    margin-bottom: 2.5rem;
    border-radius: 0 2.5rem 2.5rem 0;
    overflow: hidden;
    border: 1px solid rgba(15, 23, 42, .08);
    box-shadow: 0 26px 60px rgba(15, 23, 42, .09);
    background: #fff;
}

.workshop-track-row:last-child {
    margin-bottom: 0;
}

.workshop-track-row--flip {
    border-radius: 2.5rem 0 0 2.5rem;
}

@media (max-width: 767.98px) {
    .workshop-track-row,
    .workshop-track-row--flip {
        border-radius: 1.5rem;
    }
}

.workshop-track-row__visual {
    min-height: 220px;
    background: rgba(100, 115, 67, .12);
}

@media (min-width: 768px) {
    .workshop-track-row__visual {
        min-height: 100%;
    }
}

.workshop-track-row__media {
    height: 100%;
    min-height: 240px;
}

@media (min-width: 768px) {
    .workshop-track-row__media {
        min-height: 320px;
    }
}

.workshop-track-row__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    transition: transform .65s cubic-bezier(.25, .8, .25, 1);
}

.workshop-track-row:hover .workshop-track-row__media img {
    transform: scale(1.04);
}

.workshop-track-row__panel {
    position: relative;
    padding: 2.25rem 2rem 2.5rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background:
        radial-gradient(120% 80% at 100% 0%, rgba(100, 115, 67, .07), rgba(100, 115, 67, 0) 55%),
        linear-gradient(180deg, #fff, #faf8f3);
}

@media (min-width: 768px) {
    .workshop-track-row__panel {
        padding: 2.5rem 2.75rem;
    }
}

.workshop-track-row__index {
    position: absolute;
    top: .85rem;
    right: 1.25rem;
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(3rem, 8vw, 5rem);
    line-height: 1;
    font-weight: 600;
    color: rgba(100, 115, 67, .12);
    pointer-events: none;
}

.workshop-track-row__name {
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(1.75rem, 2.8vw, 2.35rem);
    font-weight: 600;
    margin-bottom: .75rem;
    color: var(--embroidery-ink);
}

.workshop-track-row__blurb {
    font-size: 1rem;
    line-height: 1.65;
    color: rgba(15, 23, 42, .68);
    margin-bottom: 1.35rem;
    max-width: 36rem;
}

.workshop-track-row__btn {
    align-self: flex-start;
}

/* Schedule — vertical timeline */
.workshop-schedule {
    background:
        linear-gradient(180deg, #fbfaf6, #efe9df);
}

.workshop-schedule__header {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
}

.workshop-schedule__title {
    max-width: 14ch;
}

.workshop-schedule__timeline {
    position: relative;
    padding-left: 0;
}

@media (min-width: 768px) {
    .workshop-schedule__timeline {
        padding-left: 1.5rem;
        border-left: 2px solid rgba(100, 115, 67, .35);
    }
}

.workshop-schedule__item {
    position: relative;
    margin-bottom: 1.25rem;
}

.workshop-schedule__item:last-child {
    margin-bottom: 0;
}

.workshop-schedule__marker {
    display: none;
}

@media (min-width: 768px) {
    .workshop-schedule__marker {
        display: block;
        position: absolute;
        left: calc(-1.5rem - 6px);
        top: 1.85rem;
        width: 14px;
        height: 14px;
        border-radius: 50%;
        background: var(--embroidery-olive);
        box-shadow: 0 0 0 4px rgba(100, 115, 67, .2);
    }

    .workshop-schedule__marker--end {
        box-shadow: 0 0 0 4px rgba(100, 115, 67, .2), 0 0 0 8px rgba(251, 250, 246, 1);
    }
}

.workshop-schedule__card {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: 1.25rem 1.35rem;
    border-radius: 0 1.5rem 1.5rem 1.5rem;
    background: rgba(255, 255, 255, .92);
    border: 1px solid rgba(15, 23, 42, .08);
    box-shadow: 0 14px 36px rgba(15, 23, 42, .07);
}

@media (min-width: 576px) {
    .workshop-schedule__card {
        flex-direction: row;
        align-items: center;
        padding: 1.35rem 1.5rem;
        gap: 1.25rem;
    }
}

.workshop-schedule__date.embroidery-date {
    margin-bottom: 0;
}

.workshop-schedule__body {
    flex: 1 1 auto;
    min-width: 0;
}

.workshop-schedule__event-title {
    font-weight: 700;
    color: var(--embroidery-ink);
}

.workshop-upcoming__panel {
    background: #fff;
    border: 1px solid rgba(100, 115, 67, .18);
    border-radius: 1.25rem;
    box-shadow: 0 12px 40px rgba(15, 23, 42, .06);
}

.workshop-upcoming__badge {
    letter-spacing: .18em;
    color: var(--embroidery-olive, #647343);
}

.workshop-upcoming__text {
    max-width: 36rem;
}

/* Private — full-bleed olive band */
.workshop-private {
    position: relative;
    color: rgba(255, 255, 255, .94);
    overflow: hidden;
}

.workshop-private__bg {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(80% 120% at 0% 0%, rgba(255, 255, 255, .12), rgba(255, 255, 255, 0) 45%),
        radial-gradient(60% 80% at 100% 100%, rgba(15, 23, 42, .18), rgba(15, 23, 42, 0) 50%),
        linear-gradient(125deg, #3d4829 0%, var(--embroidery-olive) 42%, var(--embroidery-olive-2) 100%);
}

.workshop-private .container {
    position: relative;
    z-index: 1;
}

.workshop-private__eyebrow {
    letter-spacing: .22em;
    opacity: .85;
    font-weight: 700;
}

.workshop-private__headline {
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(2.1rem, 4vw, 3.25rem);
    font-weight: 600;
    line-height: 1.05;
}

.workshop-private__headline-sub {
    font-family: Gantari, sans-serif;
    font-size: 1.05rem;
    font-weight: 500;
    letter-spacing: .04em;
    text-transform: uppercase;
    opacity: .88;
}

.workshop-private__lede {
    font-size: 1.05rem;
    line-height: 1.65;
    opacity: .88;
    max-width: 36rem;
}

.workshop-private__btn--ghost.btn-outline-light {
    color: rgba(255, 255, 255, .95) !important;
    border-color: rgba(255, 255, 255, .52) !important;
    background: transparent !important;
}

.workshop-private__btn--ghost.btn-outline-light:hover {
    background: rgba(255, 255, 255, .14) !important;
    border-color: rgba(255, 255, 255, .85) !important;
    color: #fff !important;
}

/* Past workshop gallery — simple album layout */
.workshop-past {
    background: #fcfcfc;
    border-top: 1px solid rgba(100, 115, 67, .12);
}

.workshop-past__bg {
    display: none;
}

.workshop-past .container {
    position: relative;
}

.workshop-past__title-row {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: space-between;
    gap: .75rem 1.5rem;
}

.workshop-past__title {
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: clamp(1.85rem, 4vw, 2.65rem);
    font-weight: 600;
    line-height: 1.1;
    color: #1e1d28;
}

.workshop-past__link {
    font-size: .88rem;
    font-weight: 600;
    letter-spacing: .04em;
    color: #647343;
    text-decoration: none;
    white-space: nowrap;
}

.workshop-past__link:hover {
    color: #523528;
    text-decoration: underline;
}

.workshop-past__album {
    padding: 1.15rem;
    background: #fff;
    border: 1px solid rgba(100, 115, 67, .14);
    border-radius: .75rem;
}

@media (min-width: 768px) {
    .workshop-past__album {
        padding: 1.35rem 1.5rem 1.5rem;
    }
}

.workshop-past__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: .75rem;
}

@media (min-width: 576px) {
    .workshop-past__grid {
        grid-template-columns: repeat(3, 1fr);
        gap: .85rem;
    }
}

@media (min-width: 992px) {
    .workshop-past__grid {
        grid-template-columns: repeat(4, 1fr);
        gap: 1rem;
    }
}

.workshop-past__tile {
    margin: 0;
    overflow: hidden;
    border-radius: .4rem;
    border: 1px solid rgba(30, 29, 40, .08);
    background: #f5f4f1;
}

.workshop-past__tile img {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    object-position: center;
    vertical-align: middle;
}

/* FAQ split column */
@media (min-width: 992px) {
    .workshop-faq__sticky-title {
        position: sticky;
        top: 6rem;
    }
}

.workshop-faq__accordion {
    border-left: 3px solid rgba(100, 115, 67, .35);
    padding-left: 1.25rem;
}

@media (max-width: 991.98px) {
    .workshop-faq__accordion {
        border-left: none;
        padding-left: 0;
    }
}

/* Kids & family workshop page */
.workshop-hero--kids.workshop-hero--editorial {
    background:
        radial-gradient(110% 75% at 92% 8%, rgba(196, 160, 95, .12), rgba(196, 160, 95, 0) 48%),
        radial-gradient(90% 55% at 0% 100%, rgba(100, 115, 67, .09), rgba(100, 115, 67, 0) 45%),
        linear-gradient(168deg, #faf6ee 0%, #fbfaf6 40%, #efe8db 100%);
}

.workshop-about--kids .workshop-about__steps li {
    font-size: .93rem;
}

.workshop-ages {
    background:
        radial-gradient(640px 280px at 50% 0%, rgba(100, 115, 67, .09), rgba(100, 115, 67, 0) 65%),
        linear-gradient(180deg, #fbfaf6, #ece6dc);
    border-top: 1px solid rgba(15, 23, 42, .05);
    border-bottom: 1px solid rgba(15, 23, 42, .05);
}

.workshop-ages__title {
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(2rem, 3.4vw, 2.75rem);
    line-height: 1.08;
    max-width: 20ch;
}

.workshop-ages__lede {
    max-width: 40rem;
}

.workshop-age-card {
    position: relative;
    border-radius: 1.35rem;
    padding: 1.5rem 1.35rem 1.45rem;
    background: rgba(255, 255, 255, .92);
    border: 1px solid rgba(15, 23, 42, .08);
    box-shadow: 0 18px 42px rgba(15, 23, 42, .07);
    transition: transform .25s ease, box-shadow .25s ease;
}

.workshop-age-card::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 5rem;
    height: 5rem;
    background: radial-gradient(circle at 100% 0%, rgba(100, 115, 67, .14), rgba(100, 115, 67, 0) 70%);
    pointer-events: none;
    border-radius: 0 1.35rem 0 0;
}

.workshop-age-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 24px 52px rgba(15, 23, 42, .1);
}

.workshop-age-card__badge {
    display: inline-block;
    font-family: Montserrat, sans-serif;
    font-weight: 800;
    font-size: .65rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: #fff;
    background: var(--embroidery-olive);
    padding: .4rem .8rem;
    border-radius: 999px;
    margin-bottom: .9rem;
}

.workshop-age-card__badge--dark {
    background: var(--embroidery-olive-2);
}

.workshop-age-card--accent {
    background: linear-gradient(155deg, rgba(255, 255, 255, .97) 0%, rgba(246, 241, 230, .95) 100%);
    border-color: rgba(100, 115, 67, .2);
}

.workshop-age-card--adult {
    background: rgba(255, 255, 255, .72);
    border-style: dashed;
    border-color: rgba(15, 23, 42, .14);
}

.workshop-age-card__name {
    font-family: "Cormorant Garamond", serif;
    font-size: 1.5rem;
    font-weight: 600;
    margin-bottom: .65rem;
    color: var(--embroidery-ink);
}

.workshop-age-card__desc {
    font-size: .95rem;
    line-height: 1.6;
    color: rgba(15, 23, 42, .72);
}

.workshop-age-card__link {
    font-family: Montserrat, sans-serif;
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--embroidery-olive);
}

.workshop-adults-note {
    padding: 1rem 1.15rem;
    border-radius: 1rem;
    background: rgba(255, 255, 255, .65);
    border: 1px dashed rgba(100, 115, 67, .35);
}

.workshop-track-row__age-tag {
    font-family: Montserrat, sans-serif;
    font-size: .68rem;
    font-weight: 800;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--embroidery-olive);
}

@media (prefers-reduced-motion: reduce) {
    .workshop-age-card:hover {
        transform: none;
    }

    .workshop-track-row:hover .workshop-track-row__media img {
        transform: none;
    }

    .workshop-hero__frame--overlap {
        transform: rotate(4deg);
    }
}

/* Classes css start */
.classes-page {
    overflow-x: clip;
}

/* Hero (distinct from workshop layout) */
.classes-hero2 {
    position: relative;
    isolation: isolate;
    background: linear-gradient(180deg, #fbfaf6, #efe9df);
    border-bottom: 1px solid rgba(15, 23, 42, .06);
}

.classes-hero2__bg-img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    display: block;
    z-index: 0;
    pointer-events: none;
}

.classes-hero2::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background: linear-gradient(
        105deg,
        rgba(251, 250, 246, .88) 0%,
        rgba(251, 250, 246, .72) 38%,
        rgba(251, 250, 246, .4) 58%,
        rgba(239, 233, 223, .35) 100%
    );
}

.classes-hero2__inner {
    position: relative;
    z-index: 2;
}

.classes-hero2__grain {
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: .22;
    background-image:
        radial-gradient(rgba(15, 23, 42, .06) 1px, transparent 1px);
    background-size: 16px 16px;
}

.classes-hero2__title {
    font-family: "Cormorant Garamond", serif;
    font-weight: 600;
    letter-spacing: .01em;
    line-height: 1.05;
    color: var(--embroidery-ink);
    font-size: clamp(2.3rem, 4.8vw, 3.7rem);
    max-width: 18ch;
}

.classes-hero2__lead {
    font-size: 1.08rem;
    line-height: 1.65;
    color: rgba(15, 23, 42, .72);
    max-width: 42rem;
}

.classes-hero2__stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .85rem;
}

.classes-stat {
    border-radius: 1.25rem;
    background: rgba(255, 255, 255, .86);
    border: 1px solid rgba(15, 23, 42, .08);
    padding: 1.05rem 1.1rem;
    box-shadow: 0 14px 34px rgba(15, 23, 42, .06);
}

.classes-stat__num {
    font-family: "Cormorant Garamond", serif;
    font-weight: 600;
    font-size: 1.9rem;
    line-height: 1;
    color: var(--embroidery-ink);
}

.classes-stat__label {
    margin-top: .35rem;
    font-family: Montserrat, sans-serif;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
    font-size: .62rem;
    color: rgba(15, 23, 42, .55);
}

.classes-stat--icon {
    text-align: center;
    padding: 1.15rem 1rem;
}

.classes-stat--icon .classes-stat__num {
    font-size: 1.05rem;
    line-height: 1.25;
    margin-top: .5rem;
}

.classes-stat--icon .classes-stat__label {
    letter-spacing: .08em;
    font-size: .58rem;
}

.classes-stat__icon {
    width: 42px;
    height: 42px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(100, 115, 67, .12);
    color: var(--embroidery-olive);
}

.classes-catalog__intro {
    max-width: 36rem;
}

.classes-hero2__note {
    border-radius: 1rem;
    padding: .85rem 1rem;
    background: rgba(255, 255, 255, .55);
    border: 1px dashed rgba(100, 115, 67, .35);
    color: rgba(15, 23, 42, .72);
}

/* Catalog + cards */
.classes-catalog {
    background: var(--embroidery-paper);
}

.classes-filters {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    justify-content: flex-end;
}

.classes-filter-chip {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: .35rem .75rem;
    background: rgba(15, 23, 42, .04);
    border: 1px solid rgba(15, 23, 42, .08);
    font-family: Montserrat, sans-serif;
    font-weight: 800;
    font-size: .64rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: rgba(15, 23, 42, .62);
}

.classes-filter-chip--olive {
    background: rgba(100, 115, 67, .10);
    border-color: rgba(100, 115, 67, .25);
    color: rgba(100, 115, 67, 1);
}

/* Classes page — list layout (mockup v2) */
.classes-page-hero {
    background: var(--embroidery-paper);
    border-bottom: 1px solid rgba(15, 23, 42, .06);
}

.classes-page-hero__title {
    font-family: "Cormorant Garamond", serif;
    font-weight: 600;
    font-size: clamp(2.2rem, 4.5vw, 3.25rem);
    line-height: 1.08;
    color: var(--embroidery-ink);
    max-width: 14ch;
}

.classes-page-hero__lead {
    font-size: 1.05rem;
    line-height: 1.65;
    color: rgba(15, 23, 42, .68);
    max-width: 32rem;
}

.classes-page-hero__figure {
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 20px 50px rgba(15, 23, 42, .1);
    border: 1px solid rgba(15, 23, 42, .08);
}

.classes-page-hero__img {
    width: 100%;
    height: clamp(220px, 32vw, 340px);
    object-fit: cover;
    display: block;
}

.classes-catalog--list {
    background: var(--embroidery-paper);
}

.classes-filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-bottom: 1.75rem;
}

.classes-filter-scroll {
    margin-left: -.75rem;
    margin-right: -.75rem;
    padding-left: .75rem;
    padding-right: .75rem;
}

@media (min-width: 576px) {
    .classes-filter-scroll {
        margin-left: 0;
        margin-right: 0;
        padding-left: 0;
        padding-right: 0;
    }
}

.classes-filter-btn {
    display: inline-flex;
    align-items: center;
    padding: .55rem 1.1rem;
    border-radius: 999px;
    border: 1px solid rgba(15, 23, 42, .12);
    background: #fff;
    color: rgba(15, 23, 42, .75);
    font-family: Montserrat, sans-serif;
    font-size: .78rem;
    font-weight: 600;
    cursor: pointer;
    transition: background .2s ease, color .2s ease, border-color .2s ease;
}

.classes-filter-btn:hover {
    border-color: rgba(100, 115, 67, .35);
    color: var(--embroidery-olive);
}

.classes-filter-btn.is-active {
    background: var(--embroidery-olive);
    border-color: var(--embroidery-olive);
    color: #fff;
}

.classes-list {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.classes-list-empty {
    text-align: center;
    padding: 2rem 1rem;
    color: rgba(15, 23, 42, .6);
    font-size: .95rem;
}

.classes-list-empty__reset {
    background: none;
    border: none;
    padding: 0;
    color: var(--embroidery-olive);
    font-weight: 600;
    text-decoration: underline;
    cursor: pointer;
}

/* Horizontal class card */
.classes-card-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    background: #fff;
    border-radius: 1rem;
    border: 1px solid rgba(15, 23, 42, .08);
    box-shadow: 0 14px 40px rgba(15, 23, 42, .07);
    overflow: hidden;
    transition: box-shadow .22s ease, transform .22s ease;
}

.classes-card-row:not(.is-hidden):hover {
    box-shadow: 0 20px 48px rgba(15, 23, 42, .1);
    transform: translateY(-2px);
}

.classes-card-row.is-hidden {
    display: none;
}

@media (min-width: 768px) {
    .classes-card-row {
        grid-template-columns: minmax(200px, 38%) 1fr;
        min-height: 280px;
    }
}

.classes-card-row__media {
    position: relative;
    min-height: 200px;
    background: rgba(100, 115, 67, .06);
}

@media (min-width: 768px) {
    .classes-card-row__media {
        min-height: 100%;
    }
}

.classes-card-row__media img {
    width: 100%;
    height: 100%;
    min-height: 200px;
    object-fit: cover;
    display: block;
}

@media (min-width: 768px) {
    .classes-card-row__media img {
        min-height: 100%;
    }
}

.classes-card-row__body {
    padding: 1.35rem 1.35rem 1.5rem;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

@media (min-width: 768px) {
    .classes-card-row__body {
        padding: 1.75rem 2rem 1.85rem;
    }
}

.classes-card-row__age {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    margin-bottom: .65rem;
    padding: .3rem .65rem;
    border-radius: .4rem;
    background: rgba(15, 23, 42, .04);
    font-family: Montserrat, sans-serif;
    font-size: .72rem;
    font-weight: 600;
    color: rgba(15, 23, 42, .65);
}

.classes-card-row__age svg {
    color: var(--embroidery-olive);
    flex-shrink: 0;
}

.classes-card-row__title {
    font-family: "Cormorant Garamond", serif;
    font-weight: 600;
    font-size: clamp(1.65rem, 2.5vw, 2rem);
    line-height: 1.15;
    color: var(--embroidery-ink);
    margin: 0 0 .75rem;
}

.classes-card-row__details {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .5rem 1rem;
    list-style: none;
    padding: 0;
    margin: 0 0 .75rem;
}

.classes-card-row__details li {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-family: Montserrat, sans-serif;
    font-size: .85rem;
    font-weight: 500;
    
}

.classes-card-row__details li svg {
    color: var(--embroidery-olive);
    flex-shrink: 0;
}

.classes-card-row__price {
    font-family: Montserrat, sans-serif;
    font-size: 1rem;
    font-weight: 700;
    color: var(--embroidery-ink);
    margin: 0 0 .75rem;
}

.classes-card-row__desc {
    font-size: .9rem;
    line-height: 1.65;
    color: rgba(15, 23, 42, .62);
    margin: 0 0 1rem;
    max-width: 52rem;
}

.classes-card-row__tags {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem;
    list-style: none;
    padding: 0;
    margin: 0 0 1.25rem;
}

.classes-card-row__tags li {
    display: inline-flex;
    align-items: center;
    padding: .28rem .7rem;
    border-radius: 999px;
    background: #f0ebe3;
    font-family: Montserrat, sans-serif;
    font-size: .68rem;
    font-weight: 600;
    color: rgba(15, 23, 42, .62);
}

.classes-card-row__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    margin-top: auto;
    padding: .8rem 1.5rem;
    min-width: 11rem;
    border-radius: .55rem;
    background: var(--embroidery-olive);
    color: #fff !important;
    font-family: Montserrat, sans-serif;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    text-decoration: none;
    transition: background .2s ease;
}

.classes-card-row__cta:hover {
    background: var(--embroidery-olive-2);
    color: #fff !important;
}

.classes-card-row__cta svg {
    flex-shrink: 0;
}

/* Features row */
.classes-features {
    background: #fff;
    border-top: 1px solid rgba(15, 23, 42, .08);
    border-bottom: 1px solid rgba(15, 23, 42, .08);
}

.classes-features__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

@media (min-width: 576px) {
    .classes-features__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 992px) {
    .classes-features__grid {
        grid-template-columns: repeat(4, 1fr);
        gap: 0;
    }

    .classes-features__item {
        padding: 0 1.5rem;
        border-right: 1px solid rgba(15, 23, 42, .1);
    }

    .classes-features__item:last-child {
        border-right: none;
    }
}

.classes-features__item {
    text-align: center;
}

.classes-features__icon {
    width: 52px;
    height: 52px;
    margin: 0 auto .85rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.classes-features__icon img {
    width: 52px;
    height: 52px;
    object-fit: contain;
    display: block;
}

.classes-features__title {
    font-family: "Cormorant Garamond", serif;
    font-weight: 600;
    font-size: 1.50rem;
    color: var(--embroidery-ink);
    margin: 0 0 .35rem;
}

.classes-features__text {
    font-size: .90rem;
}

/* Grid layout (5+ classes) — compact vertical cards */
.classes-catalog--grid .classes-list {
    display: none;
}

.classes-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
}

@media (min-width: 576px) {
    .classes-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 992px) {
    .classes-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 1.15rem;
    }
}

@media (min-width: 1200px) {
    .classes-grid {
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }
}

.classes-catalog--list .classes-grid {
    display: none;
}

.classes-card-tile {
    display: flex;
    flex-direction: column;
    height: 100%;
    background: #fff;
    border-radius: 1.1rem;
    border: 1px solid rgba(15, 23, 42, .07);
    box-shadow: 0 12px 32px rgba(15, 23, 42, .07);
    overflow: hidden;
    transition: transform .22s ease, box-shadow .22s ease;
}

.classes-card-tile:not(.is-hidden):hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 42px rgba(15, 23, 42, .1);
}

.classes-card-tile.is-hidden {
    display: none;
}

.classes-card-tile__media {
    position: relative;
    height: 140px;
    background: rgba(100, 115, 67, .06);
}

.classes-card-tile__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.classes-card-tile__age {
    position: absolute;
    left: .65rem;
    top: .65rem;
    padding: .28rem .55rem;
    border-radius: .4rem;
    background: var(--embroidery-olive);
    color: #fff;
    font-family: Montserrat, sans-serif;
    font-size: .58rem;
    font-weight: 700;
    line-height: 1.2;
    z-index: 1;
}

.classes-card-tile__panel {
    padding: 1rem .9rem 1.1rem;
    text-align: center;
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
}

.classes-card-tile__title {
    font-family: "Cormorant Garamond", serif;
    font-weight: 600;
    font-size: 1.05rem;
    line-height: 1.2;
    color: var(--embroidery-ink);
    margin: 0 0 .5rem;
}

.classes-card-tile__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: .3rem .4rem;
    margin-bottom: .55rem;
    font-family: Montserrat, sans-serif;
    font-size: .62rem;
    font-weight: 600;
    color: rgba(15, 23, 42, .55);
}

.classes-card-tile__meta span {
    display: inline-flex;
    align-items: center;
    gap: .2rem;
}

.classes-card-tile__meta svg {
    color: var(--embroidery-olive);
    flex-shrink: 0;
}

.classes-card-tile__meta-sep {
    color: rgba(15, 23, 42, .22);
}

.classes-card-tile__desc {
    font-size: .72rem;
    line-height: 1.5;
    color: rgba(15, 23, 42, .6);
    margin: 0 0 .85rem;
    flex: 1 1 auto;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.classes-card-tile__cta {
    display: block;
    width: 100%;
    padding: .65rem .75rem;
    border-radius: .55rem;
    background: var(--embroidery-olive);
    color: #fff !important;
    font-family: Montserrat, sans-serif;
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    text-decoration: none;
    text-align: center;
    transition: background .2s ease;
}

.classes-card-tile__cta:hover {
    background: var(--embroidery-olive-2);
    color: #fff !important;
}

.classes-saturday {
    display: none;
}

.classes-calendar {
    background: linear-gradient(180deg, #fbfaf6, #efe9df);
}

.classes-calendar__header {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
}

.classes-calendar__timeline {
    position: relative;
    padding-left: 0;
}

@media (min-width: 768px) {
    .classes-calendar__timeline {
        padding-left: 1.5rem;
        border-left: 2px solid rgba(100, 115, 67, .35);
    }
}

.classes-calendar__item {
    position: relative;
    margin-bottom: 1.25rem;
}

.classes-calendar__item:last-child {
    margin-bottom: 0;
}

.classes-calendar__dot {
    display: none;
}

@media (min-width: 768px) {
    .classes-calendar__dot {
        display: block;
        position: absolute;
        left: calc(-1.5rem - 6px);
        top: 1.85rem;
        width: 14px;
        height: 14px;
        border-radius: 50%;
        background: var(--embroidery-olive);
        box-shadow: 0 0 0 4px rgba(100, 115, 67, .2);
    }
    .classes-calendar__dot--end {
        box-shadow: 0 0 0 4px rgba(100, 115, 67, .2), 0 0 0 8px rgba(251, 250, 246, 1);
    }
}

.classes-calendar__card {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: 1.25rem 1.35rem;
    border-radius: 0 1.5rem 1.5rem 1.5rem;
    background: rgba(255, 255, 255, .92);
    border: 1px solid rgba(15, 23, 42, .08);
    box-shadow: 0 14px 36px rgba(15, 23, 42, .07);
}

@media (min-width: 576px) {
    .classes-calendar__card {
        flex-direction: row;
        align-items: center;
        padding: 1.35rem 1.5rem;
        gap: 1.25rem;
    }
}

.classes-calendar__body {
    flex: 1 1 auto;
    min-width: 0;
}

@media (min-width: 992px) {
    .classes-faq__title {
        position: sticky;
        top: 6rem;
    }
}

.classes-faq__accordion {
    border-left: 3px solid rgba(100, 115, 67, .35);
    padding-left: 1.25rem;
}

@media (max-width: 991.98px) {
    .classes-faq__accordion {
        border-left: none;
        padding-left: 0;
    }
}

@media (prefers-reduced-motion: reduce) {
    .classes-card,
    .classes-card:hover,
    .classes-card-row:not(.is-hidden):hover,
    .classes-card-tile:not(.is-hidden):hover {
        transition: none;
        transform: none;
    }

    .classes-card__media img,
    .classes-card-row__media img,
    .classes-card-tile__media img {
        transition: none;
        transform: none;
    }
}

/* Classes — mobile */
@media (max-width: 767.98px) {
    .classes-page {
        overflow-x: clip;
    }

    .classes-hero2 {
        min-height: 0;
    }

    .classes-hero2__bg-img {
        object-fit: cover;
        object-position: right center;
        min-height: 100%;
    }

    .classes-hero2::after {
        background: linear-gradient(
            180deg,
            rgba(251, 250, 246, .82) 0%,
            rgba(251, 250, 246, .62) 32%,
            rgba(251, 250, 246, .38) 55%,
            rgba(239, 233, 223, .22) 78%,
            rgba(239, 233, 223, .08) 100%
        );
    }

    .classes-hero2__inner {
        padding-top: 2rem !important;
        padding-bottom: 2.25rem !important;
    }

    .classes-hero2__title {
        max-width: none;
        font-size: clamp(1.85rem, 8vw, 2.5rem);
        line-height: 1.1;
    }

    .classes-hero2__lead {
        font-size: .95rem;
        line-height: 1.6;
        margin-bottom: 1.25rem !important;
    }

    .classes-hero2__stats {
        gap: .65rem;
    }

    .classes-stat {
        padding: .85rem .75rem;
    }

    .classes-stat__num {
        font-size: 1.45rem;
    }

    .classes-stat__label {
        font-size: .56rem;
        letter-spacing: .1em;
    }

    .classes-hero2__note {
        font-size: .88rem;
        line-height: 1.55;
        padding: .75rem .85rem;
    }

    .classes-catalog .container {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .classes-filter-scroll {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        margin-bottom: 1.25rem;
    }

    .classes-filter-scroll::-webkit-scrollbar {
        display: none;
    }

    .classes-filter-bar {
        flex-wrap: nowrap;
        width: max-content;
        min-width: 100%;
        gap: .4rem;
        margin-bottom: 0;
        padding-bottom: .15rem;
    }

    .classes-filter-btn {
        flex-shrink: 0;
        padding: .5rem .9rem;
        font-size: .72rem;
        white-space: nowrap;
    }

    .classes-list {
        gap: 1.15rem;
    }

    .classes-card-row {
        border-radius: .85rem;
    }

    .classes-card-row__media {
        min-height: 0;
        aspect-ratio: 16 / 10;
        max-height: 220px;
    }

    .classes-card-row__media img {
        min-height: 0;
        height: 100%;
        aspect-ratio: 16 / 10;
    }

    .classes-card-row__body {
        padding: 1.1rem 1rem 1.25rem;
        width: 100%;
        min-width: 0;
    }

    .classes-card-row__title {
        font-size: 1.45rem;
        margin-bottom: .6rem;
    }

    .classes-card-row__details {
        flex-direction: column;
        align-items: flex-start;
        gap: .4rem;
        width: 100%;
    }

    .classes-card-row__details li {
        font-size: .75rem;
        max-width: 100%;
    }

    .classes-card-row__desc {
        font-size: .85rem;
        margin-bottom: .85rem;
    }

    .classes-card-row__tags {
        margin-bottom: 1rem;
    }

    .classes-card-row__cta {
        width: 100%;
        min-width: 0;
        padding: .85rem 1rem;
        font-size: .68rem;
    }

    .classes-card-tile__panel {
        padding: .95rem .85rem 1rem;
    }

    .classes-card-tile__title {
        font-size: 1rem;
    }

    .classes-card-tile__meta {
        font-size: .58rem;
    }

    .classes-card-tile__cta {
        padding: .7rem .65rem;
        font-size: .62rem;
    }

    .classes-features__item {
        padding-bottom: 1.25rem;
        border-bottom: 1px solid rgba(15, 23, 42, .08);
    }

    .classes-features__item:last-child {
        border-bottom: none;
        padding-bottom: 0;
    }

    .classes-faq .container {
        padding-left: 1rem;
        padding-right: 1rem;
    }
}

@media (max-width: 575.98px) {
    .classes-hero2__stats {
        grid-template-columns: 1fr 1fr;
    }
}

@media (hover: none) {
    .classes-card-row:not(.is-hidden):hover,
    .classes-card-tile:not(.is-hidden):hover {
        transform: none;
    }
}

/* ==========================================================
   Class detail page (mockup layout)
   ========================================================== */

.class-detail-page {
    --class-detail-text: rgba(15, 23, 42, .9);
    --class-detail-text-muted: rgba(15, 23, 42, .72);
    background: var(--embroidery-paper, #fbfaf6);
    color: var(--embroidery-ink);
}

.class-detail-page p,
.class-detail-page .class-detail-about__body,
.class-detail-page .class-detail-about__body p,
.class-detail-page .class-detail-about__body li {
    color: var(--class-detail-text);
}

/* Override global blue link color (#217fff) inside class detail */
.class-detail-page a {
    color: inherit;
}

.class-detail-crumb__nav a {
    color: rgba(15, 23, 42, .55) !important;
}

.class-detail-crumb__nav a:hover {
    color: var(--embroidery-olive) !important;
}

.class-detail-page a.class-detail-btn--primary,
.class-detail-page a.class-detail-btn--primary:hover,
.class-detail-page a.class-detail-btn--primary:focus {
    color: #fff !important;
}

.class-detail-page a.class-detail-btn--outline,
.class-detail-page a.class-detail-btn--outline:hover,
.class-detail-page a.class-detail-btn--outline:focus {
    color: var(--embroidery-ink) !important;
}

.class-detail-page a.class-detail-btn--outline:hover {
    color: var(--embroidery-olive) !important;
}

.class-detail-crumb {
    background: #fff;
    border-bottom: 1px solid rgba(15, 23, 42, .06);
}

.class-detail-crumb__nav {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .35rem .5rem;
    padding: .85rem 0;
    font-family: Montserrat, sans-serif;
    font-size: .78rem;
    font-weight: 500;
    color: rgba(15, 23, 42, .5);
}

.class-detail-crumb__nav a {
    color: rgba(15, 23, 42, .55);
    text-decoration: none;
}

.class-detail-crumb__nav a:hover {
    color: var(--embroidery-olive);
}

.class-detail-crumb__nav [aria-current="page"] {
    color: var(--embroidery-ink);
    font-weight: 600;
}

.class-detail-hero {
    background: var(--embroidery-paper, #fbfaf6);
}

.class-detail-hero > .container > .row {
    align-items: stretch;
    min-height: 22rem;
}

.class-detail-hero .col-lg-5:first-child {
    display: flex;
    flex-direction: column;
}

.class-detail-hero__figure {
    border-radius: 1rem;
    overflow: hidden;
    width: 100%;
    height: 69%;
    min-height: 260px;
    flex: 1 1 auto;
    background: rgba(100, 115, 67, .08);
    box-shadow: 0 16px 40px rgba(15, 23, 42, .08);
}

.class-detail-hero__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

@media (max-width: 991.98px) {
    .class-detail-hero > .container > .row {
        min-height: 0;
    }

    .class-detail-hero .col-lg-5:first-child {
        display: block;
    }

    .class-detail-hero__figure {
        height: auto;
        min-height: 0;
        aspect-ratio: 4 / 3;
    }
}

.class-detail-badge {
    display: inline-block;
    padding: .35rem .85rem;
    margin-bottom: .85rem;
    border-radius: 2rem;
    background: var(--embroidery-olive);
    color: #fff;
    font-family: Montserrat, sans-serif;
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.class-detail-hero__title {
    font-family: "Cormorant Garamond", serif;
    font-weight: 600;
    font-size: clamp(2.25rem, 4.5vw, 3rem);
    line-height: 1.1;
    color: var(--embroidery-ink);
    margin: 0 0 1.25rem;
}

.class-detail-quick {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem 1.25rem;
    margin-bottom: 1.25rem;
}

@media (min-width: 576px) {
    .class-detail-quick {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.class-detail-quick li {
    display: flex;
    align-items: flex-start;
    gap: .5rem;
    font-family: Montserrat, sans-serif;
}

.class-detail-quick__icon {
    display: flex;
    flex-shrink: 0;
    margin-top: .15rem;
    color: var(--embroidery-olive);
}

.class-detail-quick__text {
    display: flex;
    flex-direction: column;
    gap: .15rem;
    min-width: 0;
}

.class-detail-quick__label {
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: rgba(15, 23, 42, .45);
    line-height: 1.2;
}

.class-detail-quick__value {
    font-size: .8rem;
    font-weight: 600;
    color: var(--embroidery-ink);
    line-height: 1.35;
}

.class-detail-hero__price {
    font-family: Montserrat, sans-serif;
    font-weight: 600;
    font-size: 1rem;
    line-height: 1.5;
    color: var(--embroidery-olive);
    margin: 0 0 .75rem;
    max-width: 36rem;
    white-space: normal;
    word-break: break-word;
}

.class-detail-details__row--price dd {
    max-width: 65%;
    text-align: right;
    white-space: normal;
    word-break: break-word;
    line-height: 1.45;
}

.classes-card-row__price {
    white-space: normal;
    word-break: break-word;
    line-height: 1.45;
}

.class-detail-hero__desc {
    font-size: .95rem;
    line-height: 1.65;
    color: var(--class-detail-text);
    margin-bottom: 1.35rem;
    max-width: 36rem;
}

.class-detail-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
}

.class-detail-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: .75rem 1.35rem;
    border-radius: .55rem;
    font-family: Montserrat, sans-serif;
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    text-decoration: none;
    transition: background .2s ease, color .2s ease, border-color .2s ease;
}

.class-detail-btn--primary {
    background: var(--embroidery-olive) !important;
    border: 1px solid var(--embroidery-olive) !important;
    color: #fff !important;
}

.class-detail-btn--primary:hover {
    background: var(--embroidery-olive-2) !important;
    border-color: var(--embroidery-olive-2) !important;
    color: #fff !important;
}

.class-detail-btn--outline {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .15);
    color: var(--embroidery-ink);
}

.class-detail-btn--outline:hover {
    border-color: var(--embroidery-olive);
    color: var(--embroidery-olive);
}

.class-detail-section-title {
    font-family: "Cormorant Garamond", serif;
    font-weight: 600;
    font-size: clamp(1.65rem, 3vw, 2rem);
    color: var(--embroidery-ink);
    margin: 0 0 1rem;
}

.class-detail-about__body {
    font-family: Montserrat, sans-serif;
    font-size: .95rem;
    line-height: 1.75;
    color: var(--class-detail-text);
}

.class-detail-about__body p,
.class-detail-about__body li {
    color: var(--class-detail-text);
}

.class-detail-about__body p:last-child {
    margin-bottom: 0;
}

.class-detail-about__body h2,
.class-detail-about__body h3,
.class-detail-about__body h4 {
    font-family: "Cormorant Garamond", serif;
    color: var(--embroidery-ink);
    margin-top: 1.25rem;
}

.class-detail-about__body a {
    color: var(--embroidery-olive) !important;
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.class-detail-about__body strong,
.class-detail-about__body b {
    font-weight: 600;
    color: var(--embroidery-ink);
    background: none !important;
}

.class-detail-about__body mark,
.class-detail-about__body span[style*="background"],
.class-detail-about__body font[color] {
    background: transparent !important;
    color: var(--class-detail-text) !important;
}

.class-detail-checklist {
    list-style: none;
    padding: 0;
    margin: 0;
}

.class-detail-checklist li {
    position: relative;
    padding-left: 1.65rem;
    margin-bottom: .65rem;
    font-family: Montserrat, sans-serif;
    font-size: .9rem;
    line-height: 1.55;
    color: var(--class-detail-text);
    background: none;
}

.class-detail-checklist li strong,
.class-detail-checklist li b {
    font-weight: 600;
    color: var(--embroidery-ink);
    background: none !important;
}

.class-detail-checklist li::before {
    content: "";
    position: absolute;
    left: 0;
    top: .35rem;
    width: 1rem;
    height: 1rem;
    border-radius: 50%;
    background: rgba(100, 115, 67, .15);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23647343' stroke-width='2.5'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: .65rem;
}

.class-detail-tagline {
    padding: 1.5rem 1.75rem;
    border-radius: 1rem;
    background: var(--embroidery-cream, #f6f3ea);
    border: 1px solid rgba(100, 115, 67, .12);
}

.class-detail-tagline__label {
    font-family: Montserrat, sans-serif;
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: rgba(15, 23, 42, .45);
    margin: 0 0 .5rem;
}

.class-detail-tagline__text {
    font-family: "Cormorant Garamond", serif;
    font-weight: 600;
    font-size: clamp(1.35rem, 2.5vw, 1.75rem);
    color: var(--embroidery-ink);
    margin: 0;
    line-height: 1.35;
    letter-spacing: normal;
}

.class-detail-tagline__text strong,
.class-detail-tagline__text b {
    font-weight: 600;
    background: none;
}

.class-detail-sidebar {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

@media (min-width: 992px) {
    .class-detail-sidebar {
        position: sticky;
        top: 6rem;
    }
}

.class-detail-card {
    padding: 1.35rem 1.5rem;
    border-radius: 1rem;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .08);
    box-shadow: 0 12px 32px rgba(15, 23, 42, .06);
}

.class-detail-card__title {
    font-family: "Cormorant Garamond", serif;
    font-weight: 600;
    font-size: 1.35rem;
    color: var(--embroidery-ink);
    margin: 0 0 1rem;
    padding-bottom: .75rem;
    border-bottom: 1px solid rgba(15, 23, 42, .08);
}

.class-detail-details {
    margin: 0 0 1rem;
}

.class-detail-details__row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: .55rem 0;
    border-bottom: 1px solid rgba(15, 23, 42, .06);
}

.class-detail-details__row:last-of-type {
    border-bottom: none;
}

.class-detail-details dt {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-family: Montserrat, sans-serif;
    font-size: .72rem;
    font-weight: 600;
    color: rgba(15, 23, 42, .5);
    margin: 0;
}

.class-detail-details__icon {
    display: flex;
    color: var(--embroidery-olive);
}

.class-detail-details dd {
    font-family: Montserrat, sans-serif;
    font-size: .78rem;
    font-weight: 600;
    color: var(--embroidery-ink);
    text-align: right;
    margin: 0;
    background: none;
}

.class-detail-details dd strong,
.class-detail-details dt strong {
    font-weight: 600;
    background: none;
    color: inherit;
}

.class-detail-share {
    width: 100%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: .7rem 1rem;
    border-radius: .55rem;
    border: 1px solid rgba(15, 23, 42, .12) !important;
    background: #fff;
    font-family: Montserrat, sans-serif;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--embroidery-ink) !important;
}

.class-detail-share:hover {
    border-color: var(--embroidery-olive) !important;
    color: var(--embroidery-olive) !important;
}

.class-detail-included {
    list-style: none;
    padding: 0;
    margin: 0;
}

.class-detail-included li {
    display: flex;
    align-items: flex-start;
    gap: .65rem;
    padding: .5rem 0;
    font-family: Montserrat, sans-serif;
    font-size: .88rem;
    color: var(--class-detail-text);
    border-bottom: 1px solid rgba(15, 23, 42, .06);
    background: none;
}

.class-detail-included li:last-child {
    border-bottom: none;
}

.class-detail-included__icon {
    display: flex;
    flex-shrink: 0;
    width: 1.35rem;
    height: 1.35rem;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(100, 115, 67, .12);
    color: var(--embroidery-olive);
}

.class-detail-activities__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .75rem;
}

@media (min-width: 576px) {
    .class-detail-activities__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (min-width: 992px) {
    .class-detail-activities__grid {
        grid-template-columns: repeat(5, minmax(0, 1fr));
        gap: 1rem;
    }
}

.class-detail-activities__item {
    border-radius: .75rem;
    overflow: hidden;
    aspect-ratio: 1;
    background: rgba(100, 115, 67, .06);
}

.class-detail-activities__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.class-detail-cta-band__inner {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1.25rem 2rem;
    padding: 1.5rem 1.5rem;
    border-radius: 1.15rem;
    background: linear-gradient(135deg, rgba(100, 115, 67, .14), rgba(100, 115, 67, .06));
    border: 1px solid rgba(100, 115, 67, .18);
    overflow: hidden;
}

.class-detail-cta-band__deco {
    position: absolute;
    width: 120px;
    height: auto;
    opacity: .35;
    pointer-events: none;
}

.class-detail-cta-band__deco--left {
    left: -10px;
    bottom: -20px;
    transform: rotate(-25deg);
}

.class-detail-cta-band__deco--right {
    right: -10px;
    top: -20px;
    transform: rotate(155deg) scaleX(-1);
}

.class-detail-cta-band__content {
    position: relative;
    z-index: 1;
    flex: 1 1 auto;
    min-width: 0;
    max-width: 520px;
}

.class-detail-cta-band__title {
    font-family: "Cormorant Garamond", serif;
    font-weight: 600;
    font-size: clamp(1.5rem, 3vw, 2rem);
    color: var(--embroidery-ink);
    margin: 0 0 .35rem;
}

.class-detail-cta-band__text {
    font-size: .9rem;
    color: var(--class-detail-text);
}

.class-detail-cta-band__btn {
    position: relative;
    z-index: 1;
    flex-shrink: 0;
}

@media (max-width: 575.98px) {
    .class-detail-hero__actions {
        flex-direction: column;
    }

    .class-detail-hero__actions .class-detail-btn {
        width: 100%;
    }

    .class-detail-cta-band .container {
        padding-bottom: 2rem !important;
    }

    .class-detail-cta-band__inner {
        flex-direction: column;
        align-items: stretch;
        justify-content: flex-start;
        gap: 1rem;
        padding: 1.15rem 1rem;
        text-align: center;
    }

    .class-detail-cta-band__content {
        flex: 0 0 auto;
        max-width: none;
    }

    .class-detail-cta-band__title {
        font-size: 1.35rem;
        margin-bottom: .25rem;
    }

    .class-detail-cta-band__btn {
        width: 100%;
        margin-top: 0;
    }
}

@media (max-width: 991.98px) {
    .class-detail-cta-band__inner {
        gap: 1rem;
        padding: 1.25rem 1.15rem;
    }
}

/* ==========================================================
   Party Bookings - Header + Breadcrumb
   ========================================================== */

.party-page .aa-pagehead {
    position: relative;
    color: #fff;
    background: radial-gradient(1200px 600px at 18% 8%, rgba(255, 255, 255, .18), rgba(255, 255, 255, 0) 55%),
        radial-gradient(900px 550px at 92% 14%, rgba(100, 115, 67, .42), rgba(100, 115, 67, 0) 62%),
        linear-gradient(135deg, #0b1220, #0b1a14 35%, #1a2513);
    overflow: hidden;
}

.party-page .aa-pagehead__bg {
    position: absolute;
    inset: 0;
    background-image: url("../images/Embroidery.png");
    background-size: cover;
    background-position: center;
    opacity: .16;
    filter: saturate(1.05) contrast(1.05);
    transform: scale(1.02);
    pointer-events: none;
    z-index: 0;
}

.party-page .aa-pagehead > .container {
    position: relative;
    z-index: 1;
}

.party-page .aa-pagehead__title {
    font-family: "Cormorant Garamond", serif;
    font-weight: 600;
    letter-spacing: .2px;
    color: #fff;
}

/* Party booking section */
.party-page .party-booking-section {
    color: #fff;
    background: radial-gradient(1200px 600px at 18% 8%, rgba(255, 255, 255, .18), rgba(255, 255, 255, 0) 55%),
        radial-gradient(900px 550px at 92% 14%, rgba(100, 115, 67, .42), rgba(100, 115, 67, 0) 62%),
        linear-gradient(135deg, #0b1220, #0b1a14 35%, #1a2513);
}

.party-page .party-booking-section__bg {
    position: absolute;
    inset: 0;
    background-image: url("../images/children.png");
    background-size: cover;
    background-position: center;
    opacity: .16;
    filter: saturate(1.05) contrast(1.05);
    transform: scale(1.02);
    pointer-events: none;
}

/* Party booking - related content */
.party-page .party-related {
    background: var(--embroidery-paper);
}

.party-related__kicker {
    letter-spacing: .22em;
    font-weight: 600;
    color: var(--embroidery-olive);
}

.party-related__title {
    font-family: "Cormorant Garamond", serif;
    letter-spacing: .02em;
    color: var(--embroidery-ink);
}

.party-related__lead {
    max-width: 46rem;
    margin-left: auto;
    margin-right: auto;
    color: rgba(15, 23, 42, .70);
}

.party-related__card {
    position: relative;
    padding: 1.25rem 1.25rem 1.35rem;
    border-radius: 1.25rem;
    background: rgba(255, 255, 255, .92);
    border: 1px solid rgba(15, 23, 42, .08);
    box-shadow: 0 14px 36px rgba(15, 23, 42, .07);
}

.party-related__num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 999px;
    background: rgba(100, 115, 67, .12);
    color: var(--embroidery-olive);
    font-weight: 800;
    margin-bottom: .75rem;
}

.party-related__card-title {
    color: var(--embroidery-ink);
}

.party-related__card-text {
    color: rgba(15, 23, 42, .70);
    font-size: 15px;
    line-height: 1.6;
}

.party-related__note {
    padding: 1rem 1.15rem;
    border-radius: 1.25rem;
    border: 1px dashed rgba(100, 115, 67, .35);
    background: rgba(100, 115, 67, .06);
    color: rgba(15, 23, 42, .75);
}

/* Party booking - theme cards */
.party-page .party-themes {
    background: linear-gradient(180deg, rgba(100, 115, 67, .06), rgba(251, 250, 246, 1));
}

.party-theme-card {
    position: relative;
    border-radius: 1.5rem;
    overflow: hidden;
    min-height: 320px;
    border: 1px solid rgba(15, 23, 42, .12);
    box-shadow: 0 18px 44px rgba(15, 23, 42, .14);
    color: #fff;
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.party-theme-card::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(900px 360px at 20% 0%, rgba(255, 255, 255, .14), rgba(255, 255, 255, 0) 55%);
    opacity: .9;
    pointer-events: none;
    z-index: 0;
}

.party-theme-card:hover {
    transform: translateY(-4px);
    border-color: rgba(255, 255, 255, .18);
    box-shadow: 0 26px 70px rgba(15, 23, 42, .22);
}

.party-theme-card__bg {
    position: absolute;
    inset: 0;
    isolation: isolate;
    background-size: cover;
    background-position: center;
    filter: saturate(1.05) contrast(1.05);
    transform: scale(1.03);
    transition: transform .35s ease, filter .35s ease;
}

.party-theme-card__bg::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(11, 18, 32, 1);
    opacity: var(--party-card-overlay, .52);
    pointer-events: none;
    z-index: 1;
}

.party-theme-card--print {
    --party-card-overlay: .58;
}

.party-theme-card--stitch {
    --party-card-overlay: .56;
}

.party-theme-card--dye {
    --party-card-overlay: .62;
}

.party-theme-card:hover .party-theme-card__bg {
    transform: scale(1.06);
    filter: saturate(1.12) contrast(1.10);
}

.party-theme-card--print .party-theme-card__bg {
    background-image:
        url("../images/block-printing-1.png");
}

.party-theme-card--stitch .party-theme-card__bg {
    background-image:
        url("../images/Embroidery.png");
}

.party-theme-card--dye .party-theme-card__bg {
    background-image:
        url("../images/natural-dyeing.png");
}

.party-theme-card__body {
    position: relative;
    z-index: 1;
    padding: 1.25rem 1.25rem 1.35rem;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.party-theme-card__age {
    position: absolute;
    top: 1rem;
    right: 1rem;
    padding: .35rem .65rem;
    border-radius: 999px;
    background: rgba(11, 18, 32, .45);
    border: 1px solid rgba(255, 255, 255, .22);
    color: rgba(255, 255, 255, .92);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .04em;
    backdrop-filter: blur(8px);
}

.party-theme-card__tag {
    display: inline-flex;
    align-self: flex-start;
    padding: .35rem .65rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, .20);
    border: 1px solid rgba(255, 255, 255, .28);
    font-size: 12px;
    letter-spacing: .14em;
    text-transform: uppercase;
    font-weight: 700;
    box-shadow: 0 10px 24px rgba(15, 23, 42, .18);
}

.party-theme-card__title {
    margin-top: .75rem;
    margin-bottom: .5rem;
    font-family: "Cormorant Garamond", serif;
    letter-spacing: .02em;
    font-weight: 700;
    text-shadow: 0 10px 26px rgba(0, 0, 0, .35);
}

.party-theme-card__text {
    margin-bottom: .85rem;
    color: rgba(255, 255, 255, .90);
}

.party-theme-card__list {
    margin: 0 0 1rem;
    padding-left: 1.05rem;
    color: rgba(255, 255, 255, .88);
    font-size: 17px;
}

.party-theme-card__list li {
    margin-bottom: .35rem;
}

.party-theme-card__list li:last-child {
    margin-bottom: 0;
}

.party-theme-card__btn {
    margin-top: auto;
    align-self: flex-start;
    border-radius: 999px;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    padding: .55rem .85rem;
    box-shadow: 0 14px 30px rgba(15, 23, 42, .22);
}

/* Party booking - FAQ */
.party-page .party-faq {
    background: var(--embroidery-paper);
}

.party-faq__grid {
    display: grid;
    gap: .85rem;
}

.party-faq__item {
    border-radius: 1.25rem;
    background: rgba(255, 255, 255, .92);
    border: 1px solid rgba(15, 23, 42, .08);
    box-shadow: 0 14px 36px rgba(15, 23, 42, .07);
    padding: 1rem 1.15rem;
}

.party-faq__q {
    cursor: pointer;
    font-weight: 800;
    color: var(--embroidery-ink);
    list-style: none;
}

.party-faq__q::-webkit-details-marker {
    display: none;
}

.party-faq__item > summary::after {
    content: "+";
    float: right;
    color: rgba(100, 115, 67, .9);
    font-weight: 900;
}

.party-faq__item[open] > summary::after {
    content: "–";
}

.party-faq__a {
    margin-top: .65rem;
    color: rgba(15, 23, 42, .72);
    font-size: 15px;
    line-height: 1.65;
}

/* Party booking / fairs - enquiry form (shared) */
.party-enquiry {
    position: relative;
    background:
        radial-gradient(900px 420px at 18% 8%, rgba(100, 115, 67, .14), rgba(100, 115, 67, 0) 60%),
        radial-gradient(700px 420px at 92% 18%, rgba(15, 23, 42, .06), rgba(15, 23, 42, 0) 62%),
        linear-gradient(180deg, rgba(251, 250, 246, 1), rgba(100, 115, 67, .05));
    overflow: hidden;
}

.party-enquiry::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        radial-gradient(800px 380px at 12% 15%, rgba(255, 255, 255, .55), rgba(255, 255, 255, 0) 60%),
        url("../images/children.png");
    background-size: cover;
    background-position: center;
    opacity: .10;
    filter: saturate(1.05) contrast(1.02) blur(.2px);
    transform: scale(1.04);
    pointer-events: none;
    z-index: 0;
}

.party-enquiry .container {
    position: relative;
    z-index: 1;
}

.party-enquiry__help {
    border-radius: 1.25rem;
    border: 1px dashed rgba(100, 115, 67, .35);
    background: rgba(255, 255, 255, .78);
    padding: 1rem 1.15rem;
}

.party-enquiry__help-title {
    font-weight: 800;
    color: var(--embroidery-ink);
    margin-bottom: .65rem;
}

.party-enquiry__help-list {
    margin: 0;
    padding-left: 1.05rem;
    color: rgba(15, 23, 42, .72);
    font-size: 15px;
    line-height: 1.65;
}

.party-enquiry__fineprint {
    color: rgba(15, 23, 42, .65);
    font-size: 14px;
}

/* Party booking - form polish (scoped) */
.party-enquiry .aa-form-frame {
    border-radius: 1.5rem;
    background: rgba(255, 255, 255, .92);
    border: 1px solid rgba(15, 23, 42, .10);
    box-shadow: 0 18px 60px rgba(15, 23, 42, .10);
    padding: 1.25rem;
}

@media (min-width: 768px) {
    .party-enquiry .aa-form-frame {
        padding: 1.5rem;
    }
}

.party-enquiry .aa-label {
    font-weight: 800;
    color: rgba(15, 23, 42, .85);
    letter-spacing: .02em;
}

.party-enquiry .aa-input,
.party-enquiry .aa-input.form-control,
.party-enquiry .aa-input.form-select {
    border-radius: 1rem;
    border: 1px solid rgba(15, 23, 42, .14);
    background: rgba(251, 250, 246, 1);
    padding: .85rem .95rem;
    box-shadow: none;
}

.party-enquiry .aa-input:focus,
.party-enquiry .aa-input.form-control:focus,
.party-enquiry .aa-input.form-select:focus {
    border-color: rgba(100, 115, 67, .55);
    box-shadow: 0 0 0 .25rem rgba(100, 115, 67, .18);
}

.party-enquiry .aa-input--textarea {
    border-radius: 1.15rem;
}

.party-enquiry .aa-btn.btn-primary {
    border: none;
    background: linear-gradient(180deg, #6f7f48, var(--embroidery-olive));
    box-shadow: 0 14px 32px rgba(100, 115, 67, .22);
    border-radius: 999px;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.party-enquiry .aa-btn.btn-primary:hover {
    background: linear-gradient(180deg, var(--embroidery-olive), var(--embroidery-olive-2));
    transform: translateY(-1px);
}

.party-enquiry .aa-btn.btn-outline-primary {
    border-radius: 999px;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    border-color: rgba(100, 115, 67, .55) !important;
    color: var(--embroidery-olive) !important;
    background: rgba(255, 255, 255, .55);
}

.party-enquiry .aa-btn.btn-outline-primary:hover {
    border-color: var(--embroidery-olive) !important;
    background: rgba(100, 115, 67, .10) !important;
}

/* ==========================================================
   Fairs & Shows page
   ========================================================== */

.fairs-page .fairs-hero {
    color: #fff;
    background: radial-gradient(1200px 600px at 18% 8%, rgba(255, 255, 255, .18), rgba(255, 255, 255, 0) 55%),
        radial-gradient(900px 550px at 92% 14%, rgba(100, 115, 67, .42), rgba(100, 115, 67, 0) 62%),
        linear-gradient(135deg, #0b1220, #0b1a14 35%, #1a2513);
}

.fairs-page .fairs-hero__bg {
    position: absolute;
    inset: 0;
    background-image: url("../images/mission.png");
    background-size: cover;
    background-position: center;
    opacity: .14;
    filter: saturate(1.05) contrast(1.05);
    transform: scale(1.02);
    pointer-events: none;
}

.fairs-hero__stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .85rem;
}

.fairs-stat {
    border: 1px solid rgba(255, 255, 255, .18);
    background: rgba(15, 23, 42, .28);
    backdrop-filter: blur(8px);
    border-radius: 1rem;
    padding: 1rem;
}

.fairs-stat__num {
    font-weight: 800;
    letter-spacing: .02em;
}

.fairs-stat__label {
    margin-top: .25rem;
    font-size: .85rem;
    color: rgba(255, 255, 255, .76);
}

.fairs-card {
    border-radius: 1.5rem;
    background: rgba(255, 255, 255, .92);
    border: 1px solid rgba(15, 23, 42, .08);
    box-shadow: 0 14px 36px rgba(15, 23, 42, .07);
    padding: 1.25rem 1.25rem 1.35rem;
    display: flex;
    flex-direction: column;
    gap: .85rem;
}

.fairs-upcoming__list {
    display: grid;
    gap: 1rem;
}

.fairs-card--row {
    flex-direction: row;
    gap: 1rem;
    padding: 1.1rem;
}

.fairs-card__media {
    width: 7.25rem;
    flex: 0 0 auto;
    border-radius: 1.25rem;
    overflow: hidden;
    border: 1px solid rgba(15, 23, 42, .10);
    background: rgba(100, 115, 67, .08);
}

.fairs-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.fairs-card__body {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: .65rem;
}

@media (max-width: 575.98px) {
    .fairs-card--row {
        flex-direction: column;
    }

    .fairs-card__media {
        width: 100%;
        height: 9.5rem;
    }
}

.fairs-card__top {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
}

.fairs-card__date {
    width: 3.1rem;
    flex: 0 0 auto;
    text-align: center;
    border-radius: 1rem;
    border: 1px solid rgba(100, 115, 67, .22);
    background: rgba(100, 115, 67, .08);
    padding: .5rem .55rem;
}

.fairs-card__day {
    font-weight: 900;
    font-size: 1.25rem;
    color: var(--embroidery-ink);
    line-height: 1;
}

.fairs-card__meta {
    margin-top: .25rem;
    font-size: 12px;
    color: rgba(15, 23, 42, .62);
    letter-spacing: .08em;
    text-transform: uppercase;
}

.fairs-card__title {
    font-weight: 900;
    color: var(--embroidery-ink);
}

.fairs-card__desc {
    margin: 0;
    color: rgba(15, 23, 42, .72);
    font-size: 15px;
    line-height: 1.6;
}

.fairs-card__actions {
    margin-top: auto;
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}

.fairs-card__tags {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}

.fairs-tag {
    display: inline-flex;
    align-items: center;
    padding: .25rem .55rem;
    border-radius: 999px;
    border: 1px solid rgba(100, 115, 67, .22);
    background: rgba(100, 115, 67, .08);
    color: rgba(15, 23, 42, .76);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .04em;
}

/* Upcoming fairs - event cards */
.fairs-event {
    border-radius: 1.75rem;
    overflow: hidden;
    background: rgba(255, 255, 255, .92);
    border: 1px solid rgba(15, 23, 42, .08);
    box-shadow: 0 18px 50px rgba(15, 23, 42, .08);
    display: flex;
    flex-direction: column;
    min-height: 100%;
}

.fairs-event__media {
    position: relative;
    height: 210px;
    background: rgba(100, 115, 67, .08);
}

.fairs-event__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.fairs-event__date {
    position: absolute;
    left: 1rem;
    top: 1rem;
    border-radius: 1rem;
    border: 1px solid rgba(255, 255, 255, .22);
    background: rgba(15, 23, 42, .35);
    backdrop-filter: blur(10px);
    padding: .55rem .65rem;
    color: rgba(255, 255, 255, .95);
    min-width: 3.2rem;
    text-align: center;
}

.fairs-event__day {
    font-weight: 900;
    font-size: 1.25rem;
    line-height: 1;
}

.fairs-event__meta {
    margin-top: .25rem;
    font-size: 12px;
    letter-spacing: .10em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, .82);
}

.fairs-event__body {
    padding: 1.15rem 1.15rem 1.25rem;
    display: flex;
    flex-direction: column;
    gap: .6rem;
    flex: 1 1 auto;
}

.fairs-event__title {
    font-weight: 900;
    color: var(--embroidery-ink);
    font-size: 1.1rem;
    line-height: 1.25;
}

.fairs-event__loc {
    color: rgba(15, 23, 42, .62);
    font-size: 14px;
}

.fairs-event__desc {
    margin: 0;
    color: rgba(15, 23, 42, .72);
    font-size: 15px;
    line-height: 1.6;
}

.fairs-event__tags {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}

.fairs-event__actions {
    margin-top: auto;
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}

.fairs-bullets {
    padding-left: 1.1rem;
    margin: 0;
    color: rgba(15, 23, 42, .72);
}

.fairs-collage {
    border-radius: 1.75rem;
    overflow: hidden;
    border: 1px solid rgba(15, 23, 42, .08);
    box-shadow: 0 18px 50px rgba(15, 23, 42, .10);
}

.fairs-collage__img {
    width: 100%;
    height: auto;
    display: block;
}

/* Blog pages (listing + detail) */
.blog-hero,
.blog-article-hero {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, rgba(100, 115, 67, .10), rgba(255, 161, 23, .08), rgba(15, 23, 42, .03));
}

.blog-hero__mesh,
.blog-article-hero__mesh {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(900px 420px at 12% 18%, rgba(100, 115, 67, .22), transparent 60%),
        radial-gradient(700px 360px at 86% 30%, rgba(255, 161, 23, .16), transparent 62%),
        radial-gradient(800px 380px at 55% 92%, rgba(15, 23, 42, .06), transparent 62%);
    pointer-events: none;
}

.blog-hero__title {
    font-weight: 900;
    letter-spacing: -0.02em;
}

.blog-hero__lead {
    color: rgba(15, 23, 42, .72);
    max-width: 62ch;
}

.blog-hero__search {
    background: rgba(255, 255, 255, .7);
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 1.25rem;
    padding: 1rem;
    box-shadow: 0 18px 45px rgba(15, 23, 42, .08);
}

.blog-hero__label {
    letter-spacing: .12em;
    color: rgba(15, 23, 42, .65);
    display: block;
    margin-bottom: .35rem;
}

.blog-hero__search-row {
    display: flex;
    gap: .6rem;
    align-items: center;
}

.blog-hero__input {
    border-radius: .9rem;
    border: 1px solid rgba(15, 23, 42, .12);
}

.blog-hero__btn {
    border-radius: .9rem;
    padding: .75rem 1rem;
    font-weight: 700;
}

.blog-hero__hint {
    margin-top: .5rem;
}

.blog-filters {
    display: flex;
    flex-wrap: wrap;
    gap: .6rem;
}

.blog-filter {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    padding: .55rem .85rem;
    border-radius: 999px;
    border: 1px solid rgba(15, 23, 42, .10);
    background: rgba(255, 255, 255, .72);
    color: rgba(15, 23, 42, .75);
    font-weight: 700;
    font-size: 13px;
    letter-spacing: .06em;
    text-transform: uppercase;
}

.blog-filter:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 24px rgba(15, 23, 42, .10);
    color: rgba(15, 23, 42, .85);
}

.blog-filter.is-active {
    background: rgba(100, 115, 67, .12);
    border-color: rgba(100, 115, 67, .28);
    color: rgba(15, 23, 42, .9);
}

.blog-card {
    border-radius: 1.4rem;
    overflow: hidden;
    border: 1px solid rgba(15, 23, 42, .08);
    background: #fff;
    box-shadow: 0 18px 45px rgba(15, 23, 42, .07);
    transition: transform .18s ease, box-shadow .18s ease;
    height: 100%;
}

.blog-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 28px 70px rgba(15, 23, 42, .12);
}

.blog-card__media {
    position: relative;
    display: block;
    aspect-ratio: auto;
    height: 220px;
    background: rgba(15, 23, 42, .04);
    overflow: hidden;
}

.blog-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transform: scale(1.02);
    transition: transform .25s ease;
}

.blog-card:hover .blog-card__media img {
    transform: scale(1.06);
}

.blog-card__tag {
    position: absolute;
    left: 1rem;
    bottom: 1rem;
    display: inline-flex;
    padding: .45rem .7rem;
    border-radius: 999px;
    background: rgba(15, 23, 42, .72);
    color: rgba(255, 255, 255, .95);
    font-weight: 800;
    font-size: 12px;
    letter-spacing: .08em;
    text-transform: uppercase;
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, .18);
}

.blog-card__body {
    padding: 1.1rem 1.15rem 1.2rem;
    display: flex;
    flex-direction: column;
    gap: .45rem;
}

.blog-card__title {
  
        font-family: "Cormorant Garamond", Georgia, serif !important;
        font-weight: 600;
        font-size: 1.75rem;
        line-height: 1.15;
        margin: 0 0 .65rem;
        color: #1e1d28
    
}

.blog-card__title a {
    color: rgba(15, 23, 42, .92);
}

.blog-card__title a:hover {
    color: rgba(100, 115, 67, 1);
}

.blog-card__excerpt {
    color: rgba(15, 23, 42, .72);
    font-size: 15px;
    line-height: 1.6;
}

.blog-pagination .page-link {
    border-radius: .9rem;
    border: 1px solid rgba(15, 23, 42, .10);
    color: rgba(15, 23, 42, .78);
    font-weight: 800;
}

.blog-pagination .page-item.active .page-link {
    background: rgba(100, 115, 67, .14);
    border-color: rgba(100, 115, 67, .28);
    color: rgba(15, 23, 42, .92);
}

.blog-pagination .page-item.disabled .page-link {
    background: rgba(15, 23, 42, .03);
    color: rgba(15, 23, 42, .35);
}

/* Detail page */
.blog-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem;
    align-items: center;
    color: rgba(15, 23, 42, .65);
}

.blog-breadcrumb a {
    color: rgba(15, 23, 42, .78);
    font-weight: 700;
}

.blog-breadcrumb a:hover {
    color: rgba(100, 115, 67, 1);
}

.blog-breadcrumb__sep {
    opacity: .55;
}

.blog-article-hero__kicker {
    display: flex;
    flex-wrap: wrap;
    gap: .6rem;
    align-items: center;
    margin-bottom: .35rem;
}

.blog-article-hero__tag {
    display: inline-flex;
    padding: .35rem .65rem;
    border-radius: 999px;
    background: rgba(100, 115, 67, .14);
    border: 1px solid rgba(100, 115, 67, .28);
    font-weight: 900;
    font-size: 12px;
    letter-spacing: .10em;
    text-transform: uppercase;
    color: rgba(15, 23, 42, .86);
}

.blog-article-hero__dot {
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: rgba(15, 23, 42, .25);
}

.blog-article-hero__title {
    font-weight: 900;
    letter-spacing: -0.02em;
    line-height: 1.1;
}

.blog-article-hero__lead {
    color: rgba(15, 23, 42, .72);
    max-width: 70ch;
}

.blog-article-hero__cover {
    border-radius: 1.75rem;
    overflow: hidden;
    border: 1px solid rgba(15, 23, 42, .08);
    box-shadow: 0 22px 60px rgba(15, 23, 42, .10);
}

.blog-article-hero__cover img {
    width: 100%;
    height: 420px;
    display: block;
    object-fit: cover;
}

@media (max-width: 575.98px) {
    .blog-card__media {
        height: 190px;
    }

    .blog-article-hero__cover img {
        height: 260px;
    }
}

.blog-article__sidebar-card {
    border-radius: 1.25rem;
    border: 1px solid rgba(15, 23, 42, .08);
    background: rgba(255, 255, 255, .9);
    box-shadow: 0 16px 38px rgba(15, 23, 42, .06);
    padding: 1rem;
    margin-bottom: 1rem;
}

.blog-article__sidebar-title {
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
    font-size: 12px;
    color: rgba(15, 23, 42, .70);
    margin-bottom: .6rem;
}

.blog-toc {
    display: flex;
    flex-direction: column;
    gap: .35rem;
}

.blog-toc a {
    color: rgba(15, 23, 42, .78);
    font-weight: 700;
    padding: .35rem .45rem;
    border-radius: .75rem;
}

.blog-toc a:hover {
    background: rgba(15, 23, 42, .04);
    color: rgba(100, 115, 67, 1);
}

.blog-pill {
    display: inline-flex;
    align-items: center;
    padding: .45rem .7rem;
    border-radius: 999px;
    border: 1px solid rgba(15, 23, 42, .10);
    background: rgba(15, 23, 42, .03);
    color: rgba(15, 23, 42, .78);
    font-weight: 800;
    font-size: 12px;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.blog-pill:hover {
    color: rgba(100, 115, 67, 1);
    border-color: rgba(100, 115, 67, .28);
    background: rgba(100, 115, 67, .10);
}

.blog-article__content {
    max-width: 78ch;
}

.blog-article__intro {
    font-size: 1.05rem;
    color: rgba(15, 23, 42, .78);
    line-height: 1.75;
}

.blog-article__h2 {
    font-weight: 900;
    margin-top: 2rem;
    margin-bottom: .65rem;
    font-size: 1.55rem;
}

.blog-article__h3 {
    font-weight: 900;
    margin-top: 1.4rem;
    margin-bottom: .4rem;
    font-size: 1.2rem;
}

.blog-article__list {
    padding-left: 1.15rem;
    margin-bottom: 0;
    color: rgba(15, 23, 42, .74);
}

.blog-callout {
    border-radius: 1.25rem;
    border: 1px solid rgba(100, 115, 67, .22);
    background: rgba(100, 115, 67, .08);
    padding: 1rem 1rem;
    margin: 1.25rem 0;
}

.blog-callout__title {
    font-weight: 900;
    letter-spacing: .10em;
    text-transform: uppercase;
    font-size: 12px;
    color: rgba(15, 23, 42, .78);
    margin-bottom: .4rem;
}

.blog-article__rule {
    margin: 2.25rem 0 1.5rem;
    border-top: 1px solid rgba(15, 23, 42, .10);
    opacity: 1;
}

.blog-author {
    display: flex;
    gap: .8rem;
    align-items: center;
}

.blog-author__avatar {
    width: 44px;
    height: 44px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 900;
    background: rgba(15, 23, 42, .06);
    color: rgba(15, 23, 42, .8);
    border: 1px solid rgba(15, 23, 42, .10);
}

.blog-author__name {
    font-weight: 900;
    color: rgba(15, 23, 42, .92);
}

@media (max-width: 991.98px) {
    .blog-hero__search-row {
        flex-direction: column;
        align-items: stretch;
    }
}

/* Blog listing page font override (scoped to blog.html only) */
.blog-page h1,
.blog-page h2,
.blog-page h3,
.blog-page .h1,
.blog-page .h2,
.blog-page .h3 {
    font-family: "Cormorant Garamond", serif;
}

/* Ensure heading links don't inherit global link font */
.blog-page h1 a,
.blog-page h2 a,
.blog-page h3 a,
.blog-page .h1 a,
.blog-page .h2 a,
.blog-page .h3 a,
.blog-page .blog-card__title a {
    font-family: "Cormorant Garamond", serif;
}

/* Blog detail page heading font override (scoped to blog-detail.html only) */
.blog-detail-page h1,
.blog-detail-page h2,
.blog-detail-page h3,
.blog-detail-page .h1,
.blog-detail-page .h2,
.blog-detail-page .h3 {
    font-family: "Cormorant Garamond", serif;
}

.blog-detail-page h1 a,
.blog-detail-page h2 a,
.blog-detail-page h3 a,
.blog-detail-page .h1 a,
.blog-detail-page .h2 a,
.blog-detail-page .h3 a {
    font-family: "Cormorant Garamond", serif;
}

/* Header menu (used on blog pages) */
.site-menu {
    display: flex;
    justify-content: center;
}

.header-main__side {
    display: flex;
    flex-direction: column;
    gap: .55rem;
    align-items: flex-start;
}

.header-main__side--right {
    align-items: flex-start;
}

.header-main__side--left {
    flex-direction: row;
    align-items: center;
    gap: 1rem;
    justify-content: space-between;
    flex-wrap: wrap;
    width: 100%;
}

.header-main__side--left .header-social {
    margin: 0;
}

.header-main__side--left .site-menu__list {
    justify-content: flex-end;
}

.header-main__side--right .site-menu__list {
    justify-content: flex-start;
}

.site-menu--left {
    justify-content: flex-end;
}

.site-menu--right {
    justify-content: flex-start;
}

.site-menu__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .35rem .85rem;
}

.site-menu__link {
    display: inline-flex;
    align-items: center;
    padding: .45rem .65rem;
    border-radius: 999px;
    font-weight: 800;
    font-size: 13px;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: rgba(15, 23, 42, .78);
    border: 1px solid transparent;
    background: transparent;
}

.site-menu__link:hover {
    color: rgba(15, 23, 42, .92);
    background: rgba(15, 23, 42, .03);
    border-color: rgba(15, 23, 42, .08);
}

.site-menu__link.is-active,
.site-menu__link[aria-current="page"] {
    background: rgba(100, 115, 67, .12);
    border-color: rgba(100, 115, 67, .25);
    color: rgba(15, 23, 42, .92);
}

/* Mobile sidebar toggle */
.aa-nav-toggle,
.aa-nav-spacer {
    display: none;
}

.aa-nav-toggle {
    border: 1px solid rgba(15, 23, 42, .10);
    background: rgba(255, 255, 255, .9);
    border-radius: .9rem;
    padding: .55rem .75rem;
    line-height: 1;
    color: rgba(15, 23, 42, .85);
    box-shadow: 0 10px 22px rgba(15, 23, 42, .06);
}

.aa-nav-toggle:focus-visible {
    outline: 2px solid rgba(100, 115, 67, .65);
    outline-offset: 3px;
}

.aa-nav-toggle__bars {
    display: inline-block;
    letter-spacing: .08em;
    font-weight: 900;
    font-size: 12px;
    text-transform: uppercase;
}

@media (max-width: 991.98px) {
    .header-main__bar {
        display: grid;
        grid-template-columns: auto 1fr auto;
        align-items: center;
        gap: 10px;
    }

    .header-main__bar .logo {
        order: 0;
        justify-self: center;
    }

    .header-main__side--left,
    .header-main__side--right {
        display: none;
    }

    .aa-nav-toggle,
    .aa-nav-spacer {
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    .header-main__side,
    .header-main__side--right,
    .header-main__side--left {
        align-items: center;
        text-align: center;
    }

    .header-main__side--left {
        width: auto;
        flex-direction: column;
        justify-content: center;
    }

    .header-social {
        justify-content: center;
        justify-self: center;
    }

    .site-menu {
        width: 100%;
        justify-content: center;
    }

    .site-menu__list {
        justify-content: center;
    }

    .site-menu--left,
    .site-menu--right {
        justify-content: center;
    }
}

@media (max-width: 575.98px) {
    .site-menu__list {
        gap: .3rem .5rem;
    }

    .site-menu__link {
        padding: .4rem .55rem;
        font-size: 12px;
    }
}

/* —— About page —— */
.about-page .about-hero .workshop-hero__jump {
    padding-top: 0;
}

.about-founding {
    background: #fcfcfc;
    border-top: 1px solid rgba(100, 115, 67, .12);
}

.about-founding__figure {
    border-radius: clamp(.35rem, 1.2vw, .65rem);
    overflow: hidden;
    box-shadow: 0 16px 40px rgba(30, 29, 40, .1);
}

.about-team {
    background:
        radial-gradient(ellipse 70% 50% at 15% 10%, rgba(100, 115, 67, .07) 0%, transparent 55%),
        linear-gradient(180deg, #f7f8f5 0%, #fcfcfc 100%);
    border-top: 1px solid rgba(100, 115, 67, .14);
}

.about-team__lede {
    max-width: 36rem;
}

.about-team__card {
    display: flex;
    flex-direction: column;
    background: #fff;
    border: 1px solid rgba(100, 115, 67, .14);
    border-radius: clamp(.35rem, 1.2vw, .65rem);
    overflow: hidden;
    box-shadow: 0 12px 32px rgba(30, 29, 40, .06);
    transition: box-shadow .25s ease, transform .25s ease;
}

.about-team__card:hover {
    box-shadow: 0 18px 44px rgba(30, 29, 40, .1);
    transform: translateY(-2px);
}

.about-team__photo {
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: #f0f3ee;
}

.about-team__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.about-team__body {
    padding: 1.15rem 1.25rem 1.35rem;
    flex: 1;
}

.about-team__name {
    font-family: "Cormorant Garamond", Georgia, serif;
    font-weight: 600;
    letter-spacing: .02em;
    color: #1e1d28;
}

.about-team__role {
    font-family: Montserrat, sans-serif;
    font-weight: 600;
    letter-spacing: .14em;
    color: #647343;
}

/* Contact page */
.contact-details__kicker {
    letter-spacing: .14em;
    color: #647343;
    font-weight: 700;
}

.contact-details__title {
    font-family: "Cormorant Garamond", Georgia, serif;
    font-weight: 600;
    color: #1e1d28;
}

.contact-details__lead {
    max-width: 42rem;
    color: rgba(30, 29, 40, .72);
    line-height: 1.65;
}

.contact-details__card {
    padding: 1.25rem 1.35rem;
    background: #fff;
    border: 1px solid rgba(100, 115, 67, .14);
    border-radius: 1.25rem;
    box-shadow: 0 10px 28px rgba(30, 29, 40, .06);
    transition: transform .2s ease, box-shadow .2s ease;
}

.contact-details__card:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 32px rgba(30, 29, 40, .08);
}

.contact-details__card-title {
    font-family: Montserrat, sans-serif;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #647343;
}

.contact-details__card p {
    font-family: Montserrat, sans-serif;
    font-size: .9rem;
    line-height: 1.55;
    color: rgba(30, 29, 40, .78);
}

.contact-details__card a {
    color: #647343;
    font-weight: 600;
    text-decoration: none;
}

.contact-details__card a:hover {
    text-decoration: underline;
}

.contact-enquiry::before {
    background-image: url("../images/natural-dyeing.png");
    opacity: .08;
}

/* Social feeds — Instagram grid + Facebook Page Plugin */
.social-feeds {
    background: #f9f7f2;
    border-top: 1px solid rgba(100, 115, 67, 0.12)
}

.social-feeds__header {
    max-width: 44rem;
    margin: 0 auto 2rem
}

.social-feeds__eyebrow {
    margin-bottom: 0.5rem;
    font-family: Montserrat, sans-serif;
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #647343
}

.social-feeds__title {
    margin-bottom: 0.75rem;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: clamp(1.85rem, 4vw, 2.5rem);
    font-weight: 600;
    line-height: 1.1;
    color: #1e1d28
}

.social-feeds__intro {
    max-width: 44rem;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: clamp(1rem, 1.2vw, 1.90rem);
    line-height: 1.65;
    color: rgba(30, 29, 40, 0.78)
}

.social-feeds__panel {
    display: flex;
    flex-direction: column;
    padding: 1.25rem 1.25rem 1.35rem;
    background: #fff;
    border: 1px solid rgba(100, 115, 67, 0.12);
    border-radius: 1.25rem;
    box-shadow: 0 12px 32px rgba(30, 29, 40, 0.06)
}

.social-feeds__panel-head {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    margin-bottom: 1.1rem
}

.social-feeds__brand-icon {
    display: inline-flex;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%
}

.social-feeds__brand-icon svg {
    width: 1.2rem;
    height: 1.2rem
}

.social-feeds__brand-icon--ig {
    color: #fff;
    background: linear-gradient(135deg, #f58529 0%, #dd2a7b 45%, #8134af 100%)
}

.social-feeds__brand-icon--fb {
    color: #fff;
    background: #1877f2
}

.social-feeds__brand-icon--fb svg {
    width: 1.1rem;
    height: 1.1rem
}

.social-feeds__panel-title {
    margin: 0 0 0.1rem;
    font-family: Montserrat, sans-serif;
    font-size: 0.95rem;
    font-weight: 700;
    color: #1e1d28
}

.social-feeds__panel-handle {
    font-family: Montserrat, sans-serif;
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    color: rgba(30, 29, 40, 0.55)
}

.social-feeds__live-badge {
    display: inline-block;
    margin-bottom: 0.5rem;
    padding: 0.2rem 0.55rem;
    font-family: Montserrat, sans-serif;
    font-size: 0.58rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #647343;
    background: rgba(100, 115, 67, 0.12);
    border-radius: 999px
}

.social-feeds__live-badge[hidden] {
    display: none
}

.social-feeds__posts-grid,
.social-feeds__instagram-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.45rem;
    flex: 1;
    min-height: 8rem
}

.social-feeds__posts-grid--status,
.social-feeds__instagram-grid--status {
    display: flex;
    align-items: center;
    justify-content: center;
    place-items: center
}

.social-feeds__posts-grid--error .social-feeds__grid-message,
.social-feeds__instagram-grid--error .social-feeds__grid-message {
    color: rgba(30, 29, 40, 0.65)
}

.social-feeds__grid-message {
    margin: 0;
    padding: 1.5rem 1rem;
    font-family: Montserrat, sans-serif;
    font-size: 0.8rem;
    font-weight: 500;
    text-align: center;
    color: rgba(30, 29, 40, 0.55)
}

.social-feeds__setup-hint {
    max-width: 36rem;
    margin-left: auto;
    margin-right: auto;
    font-family: Montserrat, sans-serif;
    font-size: 0.72rem;
    line-height: 1.55
}

.social-feeds__setup-hint code {
    font-size: 0.65rem;
    color: #647343
}

.social-feeds__post {
    position: relative;
    display: block;
    overflow: hidden;
    aspect-ratio: 1 / 1;
    border-radius: 0.5rem;
    background: #efe9df
}

.social-feeds__post img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.35s ease
}

.social-feeds__post-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    background: rgba(30, 29, 40, 0.35);
    opacity: 0;
    transition: opacity 0.25s ease
}

.social-feeds__post-overlay svg {
    width: 1.5rem;
    height: 1.5rem
}

.social-feeds__post:hover img,
.social-feeds__post:focus-visible img {
    transform: scale(1.05)
}

.social-feeds__post:hover .social-feeds__post-overlay,
.social-feeds__post:focus-visible .social-feeds__post-overlay {
    opacity: 1
}

.social-feeds__post:focus-visible {
    outline: 2px solid #647343;
    outline-offset: 2px
}

.social-feeds__post-overlay svg {
    width: 1.35rem;
    height: 1.35rem
}

.social-feeds__panel-foot {
    margin-top: 1.1rem;
    text-align: center
}

.social-feeds__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.75rem;
    padding: 0.65rem 1.5rem;
    font-family: Montserrat, sans-serif;
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    text-decoration: none;
    color: #fff;
    border-radius: 999px;
    transition: transform 0.2s ease, box-shadow 0.2s ease
}

.social-feeds__cta:hover,
.social-feeds__cta:focus-visible {
    color: #fff;
    transform: translateY(-1px);
    box-shadow: 0 8px 20px rgba(30, 29, 40, 0.15)
}

.social-feeds__cta--ig {
    background: linear-gradient(135deg, #6b7c52 0%, #647343 100%)
}

.social-feeds__cta--fb {
    background: #1877f2
}

@media (max-width: 575.98px) {
    .social-feeds__header {
        margin-bottom: 1.5rem
    }

    .social-feeds__title {
        font-size: clamp(1.65rem, 7vw, 2rem)
    }

    .social-feeds__intro {
        font-size: 1rem
    }

    .social-feeds__panel {
        padding: 1rem
    }

    .social-feeds__posts-grid,
    .social-feeds__instagram-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.4rem
    }

    .social-feeds__panel-title {
        font-size: 0.9rem
    }

    .social-feeds__cta {
        width: 100%;
        font-size: 0.72rem
    }

}

@media (min-width: 576px) and (max-width: 991.98px) {
    .social-feeds__posts-grid {
        min-height: 14rem
    }
}



