@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=Inter:wght@300;400;500;600&display=swap');

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    font-family:'Inter', sans-serif;
    color:#f3eee7;
    background:#0f0c0a;
    overflow-x:hidden;
}

.hero{
    position:relative;
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:140px 24px 80px;
    background-size:cover;
    background-position:center;
    background-attachment:fixed;
    overflow:hidden;
}

.home-hero{
    background-image:url('assets/farm-web-bg.png');
}

.animals-hero{
    background-image:url('assets/animals-bg.jpg');
}

.faq-hero{
    background-image:url('assets/farm-web-bg.png');
}

.hero-overlay{
    display:none;
}

.top-nav{
    position:absolute;
    top:0;
    left:0;
    width:100%;
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:24px 6vw;
    z-index:20;
}

.nav-logo{
    font-family:'Cormorant Garamond', serif;
    font-size:2rem;
    font-weight:600;
    color:#f4e7d0;
    letter-spacing:1px;
}

.nav-links{
    display:flex;
    gap:22px;
    flex-wrap:wrap;
}

.nav-links a{
    text-decoration:none;
    color:#f2ede7;
    font-size:.95rem;
    letter-spacing:1px;
    transition:.25s ease;
}

.nav-links a:hover{
    color:#d7a269;
}

.hero-frame{
    position:relative;
    z-index:5;
    width:min(1150px, 94%);
    margin:auto;
    padding:55px 50px 60px;
    border-radius:28px;
    background:transparent;
    border:none;
    box-shadow:none;
    backdrop-filter:none;
}

.hero-content{
    position:relative;
    z-index:5;
    width:min(100%, 1050px);
    margin:auto;
    text-align:center;
}

.hero-sign{
    width:min(900px, 100%);
    margin:0 auto 38px;
    display:block;
    filter:drop-shadow(0 10px 25px rgba(0,0,0,.45));
}

.hero h1{
    font-family:'Cormorant Garamond', serif;
    font-size:clamp(3rem, 7vw, 6.2rem);
    font-weight:600;
    color:#f4e4c8;
    margin-bottom:22px;
    text-shadow:0 3px 10px rgba(0,0,0,.45);
}

.hero p{
    max-width:850px;
    margin:0 auto 38px;
    font-size:1.15rem;
    line-height:1.85;
    color:#f3ece2;
    text-shadow:0 2px 6px rgba(0,0,0,.38);
}

.hero-buttons{
    display:flex;
    justify-content:center;
    gap:18px;
    flex-wrap:wrap;
}

.image-buttons{
    align-items:center;
}

.image-btn-link{
    display:inline-block;
    text-decoration:none;
    line-height:0;
    transition:.25s ease;
}

.image-btn-link:hover{
    transform:translateY(-2px);
}

.image-btn{
    width:min(260px, 72vw);
    display:block;
    filter:drop-shadow(0 6px 14px rgba(0,0,0,.28));
}

.facebook-banner-section{
    width:100%;
    padding:6px 20px 0;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    text-align:center;
    background:transparent;
}

.facebook-banner-section .eyebrow{
    margin-bottom:4px;
    opacity:.9;
    letter-spacing:2px;
    font-size:.95rem;
    font-weight:700;
}

.facebook-banner-link{
    display:inline-block;
    transition:.25s ease;
}

.facebook-banner-link:hover{
    transform:translateY(-1px);
}

.facebook-banner{
    width:min(240px, 44vw);
    display:block;
    opacity:.92;
    filter:drop-shadow(0 3px 8px rgba(0,0,0,.22));
    transition:.25s ease;
}

.facebook-banner:hover{
    opacity:1;
}

main{
    background:url('assets/farm-web-bg.png');
    background-size:cover;
    background-position:center;
    background-attachment:fixed;
}

.welcome-section{
    padding:95px 20px;
}

.section-card,
.cavalier-panel{
    width:min(1120px, 92%);
    margin:auto;
    padding:56px;
    background:transparent;
    border:none;
    border-radius:24px;
    box-shadow:none;
    backdrop-filter:none;
    text-align:center;
}

.eyebrow{
    color:#d7a269;
    text-transform:uppercase;
    letter-spacing:3px;
    font-size:.82rem;
    margin-bottom:18px;
    text-align:center;
}

.section-card h2,
.cavalier-panel h2{
    font-family:'Cormorant Garamond', serif;
    font-size:clamp(2.5rem, 5vw, 4.2rem);
    font-weight:600;
    color:#f4e4c8;
    margin-bottom:24px;
    text-shadow:0 3px 12px rgba(0,0,0,.45);
    text-align:center;
}

.section-card p,
.cavalier-panel p{
    font-size:1.05rem;
    line-height:1.95;
    color:#f5efe8;
    margin-bottom:20px;
    text-shadow:0 2px 6px rgba(0,0,0,.35);
    text-align:center;
}

.feature-grid,
.animal-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(250px, 1fr));
    gap:26px;
    margin-top:52px;
}

.feature-card,
.animal-card,
.faq-item,
.feature-card-body{
    background:transparent;
    border:none;
    box-shadow:none;
    backdrop-filter:none;
    text-align:center;
}

.feature-card,
.animal-card,
.faq-item{
    padding:32px 28px;
}

.feature-card h3,
.animal-card h3,
.cta-box h3,
.faq-item h3{
    font-family:'Cormorant Garamond', serif;
    font-size:2rem;
    font-weight:600;
    margin-bottom:14px;
    color:#f2dfbf;
    text-align:center;
}

.feature-card p,
.animal-card p,
.cta-box li,
.faq-item p{
    line-height:1.8;
    color:#f2ebe1;
    text-align:center;
}

.cta-box ul{
    padding-left:0;
    list-style-position:inside;
}

.split-card{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:42px;
    align-items:center;
}

.crest-image{
    width:100%;
    max-height:560px;
    object-fit:cover;
    object-position:center;
    border-radius:22px;
    box-shadow:0 14px 34px rgba(0,0,0,.45);
    transition:.3s ease;
}

.crest-image:hover{
    transform:scale(1.01);
}

.cavalier-wrapper{
    width:100%;
    padding:100px 0;
    background:transparent;
}

.image-card{
    padding:0;
    overflow:hidden;
    background:transparent;
}

.image-card img{
    width:100%;
    height:280px;
    display:block;
    object-fit:cover;
    object-position:center;
    transition:.35s ease;
}

.image-card:hover img{
    transform:scale(1.035);
}

.feature-card-body{
    padding:30px 28px 32px;
}

.small-link{
    display:inline-block;
    margin-top:14px;
    margin-left:auto;
    margin-right:auto;
    color:#d7a269;
    text-decoration:none;
}

.small-link:hover{
    text-decoration:underline;
}

.faq-list{
    display:grid;
    gap:24px;
    margin-top:34px;
}

.site-footer{
    text-align:center;
    padding:50px 20px;
    color:#d9c7ae;
    font-size:.95rem;
    background:#0b0908;
}

/* BIO POSTER */

.bio-poster-wrap{
    width:min(1200px, 94%);
    margin:auto;
    text-align:center;
}

.bio-poster{
    width:100%;
    display:block;
    border-radius:22px;
    box-shadow:0 18px 42px rgba(0,0,0,.38);
}

.bio-mobile-hint{
    display:none;
}

.bio-modal{
    display:none;
}

/* ANIMALS PAGE */

.animals-page{
    background:url('assets/farm-web-bg.png') center center / cover fixed no-repeat;
}

.animals-page main{
    background:transparent;
}

.animals-header{
    position:relative;
    min-height:110px;
}

/* CREST HERO */

.crest-hero-section{
    padding:60px 20px 40px;
}

.crest-hero-inner{
    width:min(1100px, 92%);
    margin:auto;
    text-align:center;
}

.main-crest{
    width:min(720px, 100%);
    display:block;
    margin:auto;
    padding:24px;
    background:linear-gradient(
        180deg,
        rgba(18,14,11,.42) 0%,
        rgba(10,8,6,.58) 100%
    );
    border-radius:28px;
    box-shadow:
        0 24px 60px rgba(0,0,0,.42),
        inset 0 1px 0 rgba(255,255,255,.04);
    filter:drop-shadow(0 20px 40px rgba(0,0,0,.55));
}

.animal-card.image-card{
    display:flex;
    flex-direction:column;
    min-height:100%;
}

.animal-card.image-card img{
    height:300px;
}

.animal-card.image-card .feature-card-body{
    flex:1;
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
}

.animal-card.image-card .feature-card-body p{
    margin-bottom:0;
}

/* PHOTOGRAPHY SECTION */

.photography-section{
    position:relative;
    overflow:hidden;
    background:
        linear-gradient(
            to bottom,
            rgba(8,7,6,.82) 0%,
            rgba(8,7,6,.18) 18%,
            rgba(8,7,6,.18) 82%,
            rgba(8,7,6,.82) 100%
        ),
        url('assets/animals-bg.jpg');
    background-size:cover;
    background-position:center;
    background-attachment:fixed;
}

.photography-section::before{
    content:"";
    position:absolute;
    inset:0;
    pointer-events:none;
    background:
        linear-gradient(
            to top,
            rgba(0,0,0,.72) 0%,
            rgba(0,0,0,0) 22%
        ),
        linear-gradient(
            to bottom,
            rgba(0,0,0,.72) 0%,
            rgba(0,0,0,0) 22%
        ),
        linear-gradient(
            to left,
            rgba(0,0,0,.55) 0%,
            rgba(0,0,0,0) 18%
        ),
        linear-gradient(
            to right,
            rgba(0,0,0,.55) 0%,
            rgba(0,0,0,0) 18%
        ),
        radial-gradient(
            ellipse at center,
            rgba(0,0,0,0) 42%,
            rgba(0,0,0,.28) 100%
        );
}

.photography-section .cta-box{
    padding:34px 36px;
    background:rgba(20,18,22,.24);
    border:1px solid rgba(255,255,255,.08);
    border-radius:24px;
    backdrop-filter:blur(7px);
    -webkit-backdrop-filter:blur(7px);
    box-shadow:
        0 12px 32px rgba(0,0,0,.22),
        inset 0 1px 0 rgba(255,255,255,.04);
    text-align:center;
}

.photography-section .cta-box h3,
.photography-section .cta-box li{
    text-shadow:0 2px 8px rgba(0,0,0,.55);
}

.photography-section .cta-box ul li::marker{
    color:#d29a63;
}

/* SECTION EDGE FADES */

.cavalier-section,
.petting-section{
    position:relative;
    overflow:hidden;
}

.cavalier-section::after{
    content:"";
    position:absolute;
    left:0;
    right:0;
    bottom:0;
    height:190px;
    pointer-events:none;
    z-index:2;
    background:linear-gradient(
        to top,
        rgba(0,0,0,.82) 0%,
        rgba(0,0,0,.48) 38%,
        rgba(0,0,0,0) 100%
    );
}

.petting-section::before{
    content:"";
    position:absolute;
    left:0;
    right:0;
    top:0;
    height:190px;
    pointer-events:none;
    z-index:2;
    background:linear-gradient(
        to bottom,
        rgba(0,0,0,.82) 0%,
        rgba(0,0,0,.48) 38%,
        rgba(0,0,0,0) 100%
    );
}

.cavalier-section .section-card,
.petting-section .section-card{
    position:relative;
    z-index:3;
}

.site-credit{
    margin-top:14px;
    font-size:.82rem;
    letter-spacing:1px;
    color:#bda98f;
}

.site-credit a{
    color:#d7a269;
    text-decoration:none;
}

.site-credit a:hover{
    text-decoration:underline;
}

/* APPLICATIONS MODAL */

.applications-modal{
    position:fixed;
    inset:0;
    z-index:99999;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:12px;
    background:rgba(0,0,0,.78);
    opacity:0;
    pointer-events:none;
    transition:opacity .25s ease;
    overflow:hidden;
}

.applications-modal.active{
    opacity:1;
    pointer-events:auto;
}

.applications-modal-content{
    position:relative;
    width:auto;
    max-width:92vw;
    height:auto;
    max-height:86vh;
    padding:0;
    background:none;
    border:none;
    border-radius:0;
    box-shadow:none;
    overflow:visible;
}

.applications-modal-bg{
    width:auto;
    height:auto;
    max-width:92vw;
    max-height:86vh;
    display:block;
    filter:drop-shadow(0 24px 60px rgba(0,0,0,.55));
}

.applications-modal-inner{
    position:absolute;
    inset:0;
    z-index:2;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:flex-start;
    padding:9% 8% 7%;
}

.applications-modal-content .eyebrow{
    color:#111;
    font-size:clamp(.68rem, 1.45vw, .95rem);
    font-weight:700;
    letter-spacing:.28em;
    margin-bottom:.8%;
    text-shadow:
        0 2px 3px rgba(255,255,255,.28),
        0 5px 12px rgba(0,0,0,.35);
}

.applications-modal-content h2{
    font-family:'Cormorant Garamond', serif;
    font-size:clamp(2rem, 5.3vw, 3.65rem);
    font-weight:700;
    color:#f4e4c8;
    margin-bottom:2%;
    text-align:center;
    line-height:.95;
    text-shadow:
        0 4px 4px rgba(0,0,0,.95),
        0 10px 18px rgba(0,0,0,.9),
        0 0 28px rgba(0,0,0,.8);
}

.applications-modal-grid{
    width:100%;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:1.15vh;
    margin-top:1%;
}

.application-image-link{
    width:100%;
    display:flex;
    justify-content:center;
    line-height:0;
    transition:.22s ease;
}

.application-image-link:hover{
    transform:translateY(-2px);
}

.application-image-btn{
    width:78%;
    display:block;
}

.applications-modal-close{
    position:absolute;
    top:4.5%;
    right:4.5%;
    width:clamp(28px, 4vw, 36px);
    height:clamp(28px, 4vw, 36px);
    background:none;
    border:none;
    padding:0;
    cursor:pointer;
    z-index:10;
}

.farm-x-btn{
    width:100%;
    height:100%;
    display:block;
    object-fit:contain;
    transition:.2s ease;
}

.farm-x-btn:hover{
    transform:rotate(6deg) scale(1.06);
}

/* PUPPY DISPLAY */

.puppy-display-section{
    padding:70px 20px 90px;
    position:relative;
    overflow:hidden;
}

.puppy-intro{
    padding-bottom:24px;
}

.puppy-display-wrap{
    --photo-w:13%;
    --photo-h:21%;
    --photo-zoom:1.06;
    --name-size:clamp(.72rem, 1.1vw, 1.08rem);

    position:relative;
    width:min(1280px, 96%);
    margin:10px auto 0;
    aspect-ratio:16 / 10;
    filter:drop-shadow(0 20px 42px rgba(0,0,0,.42));
}

.puppy-display-wrap::after{
    content:"";
    position:absolute;
    inset:0;
    z-index:5;
    background:url('assets/puppy-display.webp') center center / contain no-repeat;
    pointer-events:none;
}

.puppy-photo{
    position:absolute;
    z-index:2;
    display:block;
    overflow:hidden;
    background:transparent;
    cursor:pointer;
    transition:.25s ease;
    transform-origin:center center;
}

.puppy-photo:hover{
    filter:brightness(1.08) saturate(1.04);
}

.puppy-photo img{
    width:100%;
    height:100%;
    display:block;
    object-fit:cover;
    object-position:center;
    transform:scale(var(--photo-zoom));
}

.puppy-photo.is-empty{
    pointer-events:none;
}

.puppy-name{
    position:absolute;
    z-index:6;
    font-family:'Cormorant Garamond', serif;
    font-size:var(--name-size);
    font-weight:700;
    letter-spacing:.08em;
    text-transform:uppercase;
    color:#201005;
    text-shadow:
        0 1px 0 rgba(255,223,154,.45),
        0 2px 4px rgba(0,0,0,.32);
    pointer-events:none;
    white-space:nowrap;
    text-align:center;
}

/* SLOT 1 */

.puppy-photo-1{
    left:23.6%;
    top:21.5%;
    width:var(--photo-w);
    height:var(--photo-h);
    transform:rotate(-6.2deg);
}

.puppy-name-1{
    left:30.6%;
    top:43.5%;
    transform:translateX(-50%) rotate(-6.2deg);
}

/* SLOT 2 */

.puppy-photo-2{
    left:37.5%;
    top:23.5%;
    width:var(--photo-w);
    height:var(--photo-h);
    transform:rotate(2.1deg);
}

.puppy-name-2{
    left:46%;
    top:44%;
    transform:translateX(-50%) rotate(2.1deg);
}

/* SLOT 3 */

.puppy-photo-3{
    left:51.2%;
    top:23.5%;
    width:var(--photo-w);
    height:var(--photo-h);
    transform:rotate(-2.4deg);
}

.puppy-name-3{
    left:58.2%;
    top:44.9%;
    transform:translateX(-50%) rotate(-2.4deg);
}

/* SLOT 4 */

.puppy-photo-4{
    left:64.7%;
    top:23%;
    width:var(--photo-w);
    height:var(--photo-h);
    transform:rotate(4.1deg);
}

.puppy-name-4{
    left:70.7%;
    top:44.1%;
    transform:translateX(-50%) rotate(4.1deg);
}

/* SLOT 5 */

.puppy-photo-5{
    left:11.1%;
    top:59.5%;
    width:var(--photo-w);
    height:var(--photo-h);
    transform:rotate(3.2deg);
}

.puppy-name-5{
    left:18.1%;
    top:82.6%;
    transform:translateX(-50%) rotate(3.2deg);
}

/* SLOT 6 */

.puppy-photo-6{
    left:31.4%;
    top:61.3%;
    width:var(--photo-w);
    height:var(--photo-h);
    transform:rotate(-3.8deg);
}

.puppy-name-6{
    left:38.4%;
    top:84.4%;
    transform:translateX(-50%) rotate(-3.8deg);
}

/* SLOT 7 */

.puppy-photo-7{
    left:51.6%;
    top:59.6%;
    width:var(--photo-w);
    height:var(--photo-h);
    transform:rotate(2.7deg);
}

.puppy-name-7{
    left:58.6%;
    top:82.7%;
    transform:translateX(-50%) rotate(2.7deg);
}

/* SLOT 8 */

.puppy-photo-8{
    left:71.2%;
    top:61%;
    width:var(--photo-w);
    height:var(--photo-h);
    transform:rotate(-2.2deg);
}

.puppy-name-8{
    left:78.2%;
    top:84.1%;
    transform:translateX(-50%) rotate(-2.2deg);
}

/* MOBILE */

@media(max-width:900px){
    .split-card{
        grid-template-columns:1fr;
    }
}

@media(max-width:768px){

    body::before{
        content:"";
        position:fixed;
        inset:0;
        z-index:-1;
        background:url('assets/farm-mobile-bg.png') center top / cover no-repeat;
        transform:translateZ(0);
    }

    body{
        background:transparent;
    }

    body.bio-modal-open{
        overflow:hidden;
    }

    .hero,
    main,
    .facebook-banner-section,
    .animals-page main{
        background:transparent;
        background-image:none;
        background-attachment:scroll;
    }

    .animals-hero{
        background:url('assets/animals-bg.jpg') center top / cover no-repeat;
    }

    .top-nav{
        flex-direction:column;
        gap:14px;
        padding:20px;
    }

    .nav-logo{
        font-size:1.55rem;
    }

    .nav-links{
        gap:14px;
        justify-content:center;
    }

    .nav-links a{
        font-size:.84rem;
    }

    .hero{
        padding:145px 20px 70px;
    }

    .hero-frame{
        padding:38px 22px 42px;
    }

    .hero h1{
        font-size:clamp(2.6rem, 13vw, 4.2rem);
    }

    .hero p{
        font-size:1rem;
        line-height:1.75;
    }

    .image-btn{
        width:min(230px, 74vw);
    }

    .facebook-banner{
        width:min(210px, 42vw);
    }

    .section-card,
    .cavalier-panel{
        padding:38px 24px;
    }

    .welcome-section,
    .cavalier-wrapper{
        padding:70px 0;
        background:transparent;
    }

    .split-card{
        display:flex;
        flex-direction:column;
    }

    .split-card img{
        order:-1;
        margin-bottom:24px;
    }

    .crest-image{
        max-height:380px;
    }

    .image-card img,
    .animal-card.image-card img{
        height:230px;
    }

    .animals-header{
        min-height:125px;
    }

    .crest-hero-section{
        padding:30px 20px 10px;
    }

    .main-crest{
        width:min(460px, 100%);
        padding:16px;
        border-radius:22px;
    }

    .photography-section{
        background:
            linear-gradient(rgba(8,7,6,.5), rgba(8,7,6,.62)),
            url('assets/animals-bg.jpg');
        background-size:cover;
        background-position:center;
        background-attachment:scroll;
    }

    .photography-section .cta-box{
        padding:28px 24px;
        border-radius:20px;
    }

    .bio-poster-wrap{
        cursor:pointer;
    }

    .bio-mobile-hint{
        display:block;
        margin-top:12px;
        color:#d7a269;
        font-size:.78rem;
        letter-spacing:2px;
        text-transform:uppercase;
        opacity:.9;
        text-align:center;
    }

    .bio-modal{
        position:fixed;
        inset:0;
        z-index:99999;
        display:flex;
        align-items:center;
        justify-content:center;
        padding:20px;
        background:rgba(0,0,0,.88);
        opacity:0;
        pointer-events:none;
        transition:opacity .25s ease;
    }

    .bio-modal.active{
        opacity:1;
        pointer-events:auto;
    }

    .bio-modal-image{
        width:auto;
        max-width:94vw;
        max-height:92vh;
        display:block;
        object-fit:contain;
        border-radius:12px;
        box-shadow:0 20px 55px rgba(0,0,0,.65);
    }

    .bio-modal .modal-close{
        position:absolute;
        top:12px;
        right:12px;
        width:42px;
        height:42px;
        border:none;
        background:none;
        padding:0;
        cursor:pointer;
        z-index:100;
        display:block;
    }

    .bio-modal .farm-x-btn{
        width:100%;
        height:100%;
        display:block;
        object-fit:contain;
    }

    .bio-modal .modal-close::before,
    .bio-modal .modal-close::after{
        display:none;
        content:none;
    }

    .bio-modal .modal-close:hover{
        transform:scale(1.05);
    }

    .bio-modal .modal-close:active{
        transform:scale(.95);
    }

    .applications-modal{
        padding:10px;
    }

    .applications-modal-content{
        max-width:94vw;
        max-height:82vh;
    }

    .applications-modal-bg{
        max-width:94vw;
        max-height:82vh;
    }

    .applications-modal-inner{
        padding:9% 7.5% 7%;
    }

    .applications-modal-content .eyebrow{
        font-size:clamp(.58rem, 2.1vw, .76rem);
        margin-bottom:.7%;
    }

    .applications-modal-content h2{
        font-size:clamp(1.75rem, 7.8vw, 2.75rem);
        margin-bottom:1.7%;
    }

    .applications-modal-grid{
        gap:.78vh;
        margin-top:.7%;
    }

    .application-image-btn{
        width:79%;
    }

    .applications-modal-close{
        top:4.4%;
        right:4.4%;
        width:30px;
        height:30px;
    }

    .puppy-display-section{
        padding:45px 8px 65px;
    }

    .puppy-intro{
        padding:28px 18px 12px;
    }

    .puppy-display-wrap{
        width:1120px;
        max-width:none;
        margin-left:50%;
        transform:translateX(-50%);
    }

    .puppy-name{
        font-size:.8rem;
    }
}
