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

html{
    scroll-behavior:smooth;
}

body{
    font-family:'Manrope',sans-serif;
    background:#F7F2EA;
    color:#343B35;
    line-height:1.7;
}

.hero{
    height:100vh;
    position:relative;
    overflow:hidden;
}

.hero-video{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    height:100vh;
    object-fit:cover;
    z-index:-2;
    will-change:transform;
    transform:translateZ(0);
}

.overlay{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    height:100vh;
    background:rgba(24,24,24,.48);
    z-index:-1;
}

.nav{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    z-index:99999;
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:34px 60px;
    color:white;
    transition:background .45s ease, box-shadow .45s ease, padding .45s ease;
}

.nav::before{
    content:"";
    position:absolute;
    inset:0;
    background:rgba(34,34,34,.42);
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    opacity:0;
    transition:opacity .45s ease;
    z-index:-1;
}

.nav.scrolled{
    padding:24px 60px;
    box-shadow:0 12px 40px rgba(0,0,0,.14);
}

.nav.scrolled::before{
    opacity:1;
}

.logo-main{
    letter-spacing:2px;
    font-size:.9rem;
    font-weight:600;
}

.logo-sub{
    font-size:.72rem;
    opacity:.8;
    margin-top:3px;
    letter-spacing:3px;
}

.nav-links{
    display:flex;
    gap:52px;
    align-items:center;
}

.nav-links a{
    color:white;
    text-decoration:none;
    font-size:.92rem;
    opacity:.9;
    padding:10px 18px;
    border-radius:100px;
    transition:.25s ease;
}

.nav-links a:hover{
    background:rgba(247,242,234,.18);
    opacity:1;
}

.hero-content{
    position:relative;
    z-index:5;
    max-width:760px;
    padding:0 60px;
    top:50%;
    transform:translateY(-42%);
    color:white;
}

.hero-content h1{
    font-size:4.4rem;
    line-height:1.05;
    font-weight:300;
    margin-bottom:30px;
    letter-spacing:-2px;
}

.hero-content p{
    font-size:1.15rem;
    max-width:620px;
    opacity:.92;
    margin-bottom:42px;
    font-weight:300;
}

.hero-buttons{
    display:flex;
    gap:18px;
}

.btn{
    padding:16px 28px;
    border-radius:100px;
    text-decoration:none;
    font-size:.92rem;
    transition:.25s ease;
}

.btn-light{
    background:#F7F2EA;
    color:#343B35;
}

.btn-outline{
    border:1px solid rgba(255,255,255,.6);
    color:white;
}

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

.about{
    display:flex;
    align-items:flex-start;
    gap:40px;
    padding:120px 8vw;
    background:transparent;
    position:relative;
    z-index:2;
}

.about-image{
    flex:0 0 auto;
    display:flex;
    justify-content:flex-start;
    padding-top:39px;
}

.about-image img{
    width:min(100%, 180px);
    border-radius:18px;
    display:block;
    box-shadow:0 18px 50px rgba(52,59,53,.12);
}

.about-text{
    flex:1;
    padding-top:4px;
}

.section-label{
    letter-spacing:3px;
    font-size:.72rem;
    color:#8A8E85;
    margin-bottom:18px;
}

.about-text h2,
.section-header h2{
    font-size:3rem;
    font-weight:300;
    line-height:1.15;
    margin-bottom:32px;
    letter-spacing:-1px;
}

.about-text p{
    margin-bottom:14px;
    color:#5D615B;
    font-size:1.05rem;
}

.services{
    background:rgba(247,242,234,.72);
    backdrop-filter:blur(3px);
    -webkit-backdrop-filter:blur(3px);
    padding:120px 8vw;
    position:relative;
    z-index:2;
}

.section-header{
    max-width:700px;
    margin-bottom:60px;
}

.service-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:28px;
}

.service-card{
    background:white;
    padding:42px;
    border-radius:22px;
}

.service-card h3{
    font-size:1.25rem;
    margin-bottom:16px;
    font-weight:500;
}

.service-card p{
    color:#5D615B;
}

.credentials{
    padding:90px 8vw;
    background:#343B35;
    color:white;
    position:relative;
    z-index:2;
}

.credentials-inner{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:40px;
}

.credential-title{
    font-size:.8rem;
    letter-spacing:2px;
    opacity:.7;
    margin-bottom:18px;
}

.credential-value{
    font-size:2rem;
    line-height:1.2;
    font-weight:300;
}

.small{
    font-size:1.2rem;
}

.location{
    padding:120px 8vw;
    background:transparent;
    position:relative;
    z-index:2;
}

.center{
    text-align:center;
    margin:0 auto 60px auto;
}

.location-card{
    max-width:800px;
    margin:0 auto;
    background:white;
    padding:60px;
    border-radius:24px;
    text-align:center;
}

.location-card h3{
    margin-bottom:20px;
    font-size:1.6rem;
    font-weight:500;
}

.location-card a{
    color:#343B35;
}

footer{
    padding:70px 8vw;
    border-top:1px solid rgba(255,255,255,.14);
    background:rgba(20,20,20,.35);
    backdrop-filter:blur(6px);
    -webkit-backdrop-filter:blur(6px);
    position:relative;
    z-index:2;
    color:white;
}

.footer-inner{
    display:flex;
    justify-content:space-between;
    gap:40px;
}

.footer-title{
    font-size:1.1rem;
    font-weight:600;
}

.footer-sub{
    opacity:.7;
    margin-top:6px;
}

.footer-contact{
    color:#5D615B;
}

@media (max-width: 1100px){

    .service-grid{
        grid-template-columns:repeat(2,1fr);
    }

    .about{
        grid-template-columns:1fr;
    }

    .hero-content h1{
        font-size:3.5rem;
    }

}

@media (max-width: 768px){

    .hero{
        min-height:100svh;
    }

    .nav{
        padding:24px 22px;
    }

    .nav.scrolled{
        padding:18px 22px;
    }

    .logo-main{
        font-size:.78rem;
        letter-spacing:1.5px;
    }

    .logo-sub{
        font-size:.65rem;
    }

    .nav-links{
        display:none;
    }

    .hero-content{
        padding:0 24px;
        top:54%;
        transform:translateY(-50%);
    }

    .hero-content h1{
        font-size:clamp(2.25rem, 11vw, 3rem);
        line-height:1.06;
        letter-spacing:-1.3px;
        margin-bottom:24px;
    }

    .hero-content p{
        font-size:1rem;
        line-height:1.65;
        margin-bottom:32px;
    }

    .hero-buttons{
        flex-direction:column;
        align-items:flex-start;
        gap:14px;
    }

    .btn{
        padding:14px 23px;
        font-size:.9rem;
    }

    .about,
    .services,
    .location{
        padding:82px 24px;
    }

    .about{
        flex-direction:row;
        align-items:flex-start;
        gap:22px;
    }

    .about-image{
        justify-content:flex-start;
        padding-top:37px;
    }

    .about-image img{
        width:90px;
        border-radius:14px;
    }

    .about-text h2,
    .section-header h2{
        font-size:2.15rem;
        line-height:1.14;
    }

    .about-text p,
    .service-card p{
        font-size:1rem;
        line-height:1.75;
    }

    .service-grid{
        grid-template-columns:1fr;
        gap:18px;
    }

    .service-card{
        padding:32px 28px;
    }

    .credentials{
        padding:74px 24px;
    }

    .credentials-inner{
        grid-template-columns:1fr;
        gap:34px;
    }

    .location-card{
        padding:38px 26px;
        text-align:left;
    }

    .footer-inner{
        flex-direction:column;
    }

}


strong{
    font-weight:700;
}


.cottage-logo{
    width:220px;
    opacity:.9;
    margin:0 auto 34px auto;
    display:block;
}

@media (max-width:768px){

    .cottage-logo{
        width:170px;
        margin:0 auto 26px auto;
    }

}


.about-text,
.location-card,
.section-header,
.footer-contact,
.footer-sub{
    color:white;
}

.about-text p{
    color:rgba(255,255,255,.82);
}

.service-card p{
    color:#5D615B;
}

.about-text h2,
.section-header h2,
.location-card h3{
    color:white;
}

.location-card{
    background:transparent;
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
    color:white;
    border:none;
    box-shadow:none;
}

.location-card a{
    color:white;
}

.section-label{
    color:rgba(255,255,255,.68);
}

.about strong{
    color:white;
}

.footer-title{
    color:white;
}


.services .section-label{
    color:#343B35;
}

.services .section-header h2{
    color:#343B35;
}


.nav .logo,
.nav .nav-links{
    position:relative;
    z-index:100000;
}

.nav::before{
    z-index:-1;
}


.btn-outline:hover{
    background:rgba(247,242,234,.18);
    border-color:rgba(255,255,255,.68);
    color:white;
}


@media (max-width:768px){

    .about-text p{
        margin-bottom:12px;
    }

}


.map-panel{
    max-width:1000px;
    margin:42px auto 0 auto;
    border-radius:24px;
    overflow:hidden;
    box-shadow:0 24px 70px rgba(0,0,0,.20);
    border:1px solid rgba(255,255,255,.16);
}

.map-panel iframe{
    width:100%;
    height:390px;
    display:block;
    border:0;
    filter:saturate(.85) contrast(.95);
}

.footer-map-button{
    display:inline-block;
    margin:14px 0 12px 0;
    padding:9px 20px;
    border:1px solid rgba(255,255,255,.52);
    border-radius:100px;
    color:white;
    text-decoration:none;
    font-size:.88rem;
    letter-spacing:.04em;
    transition:.25s ease;
}

.footer-map-button:hover{
    background:rgba(247,242,234,.18);
    border-color:rgba(255,255,255,.68);
}

@media (max-width:768px){

    .map-panel{
        margin-top:30px;
        border-radius:18px;
    }

    .map-panel iframe{
        height:300px;
    }

}


/* Mobile hero video uses a separate right-biased crop of the original video */
@media (max-width:768px){
    .hero-video{
        object-position:70% center;
    }
}

/* Map appears only as a popup after clicking View Map */
.map-panel{
    display:none !important;
}

.map-modal{
    position:fixed;
    inset:0;
    z-index:100001;
    background:rgba(18,18,18,.62);
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
    display:flex;
    align-items:center;
    justify-content:center;
    padding:28px;
    opacity:0;
    pointer-events:none;
    transition:opacity .3s ease;
}

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

.map-modal-inner{
    position:relative;
    width:min(100%, 980px);
    height:min(72vh, 560px);
    border-radius:24px;
    overflow:hidden;
    box-shadow:0 30px 90px rgba(0,0,0,.42);
    border:1px solid rgba(255,255,255,.18);
    background:#F7F2EA;
}

.map-modal iframe{
    width:100%;
    height:100%;
    border:0;
    display:block;
    filter:saturate(.9) contrast(.96);
}

.map-close{
    position:absolute;
    top:16px;
    right:16px;
    z-index:2;
    width:42px;
    height:42px;
    border-radius:50%;
    border:1px solid rgba(255,255,255,.55);
    background:rgba(34,34,34,.58);
    color:white;
    font-size:30px;
    line-height:36px;
    cursor:pointer;
    transition:.25s ease;
}

.map-close:hover{
    background:rgba(34,34,34,.78);
}

body.map-open{
    overflow:hidden;
}

@media (max-width:768px){
    .map-modal{
        padding:18px;
    }

    .map-modal-inner{
        height:72vh;
        border-radius:18px;
    }

    .map-close{
        top:12px;
        right:12px;
    }
}


.about-text{
    max-width:75%;
}

@media (max-width:1100px){
    .about-text{
        max-width:100%;
    }
}


.location-card{
    display:grid;
    grid-template-columns:1fr minmax(320px, 420px);
    gap:56px;
    align-items:start;
    text-align:left;
}

.clinic-info{
    padding-top:8px;
}

.appointment-form{
    scroll-margin-top:130px;
    background:rgba(235,235,235,.72);
    color:#343B35;
    border-radius:22px;
    padding:30px;
    box-shadow:0 22px 70px rgba(0,0,0,.20);
    border:1px solid rgba(255,255,255,.45);
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
}

.appointment-form h3{
    color:#343B35;
    font-size:1.35rem;
    margin-bottom:22px;
    font-weight:600;
}

.appointment-form label{
    display:block;
    font-size:.82rem;
    letter-spacing:.04em;
    margin-bottom:14px;
    color:#343B35;
}

.appointment-form input,
.appointment-form textarea{
    width:100%;
    margin-top:7px;
    padding:12px 13px;
    border-radius:12px;
    border:1px solid rgba(52,59,53,.22);
    background:rgba(255,255,255,.78);
    color:#343B35;
    font-family:'Manrope',sans-serif;
    font-size:.95rem;
    outline:none;
}

.appointment-form input:focus,
.appointment-form textarea:focus{
    border-color:rgba(52,59,53,.55);
    background:white;
}

.form-row{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
}

.appointment-form button{
    margin-top:8px;
    padding:13px 23px;
    border-radius:100px;
    border:1px solid rgba(52,59,53,.25);
    background:#343B35;
    color:white;
    font-family:'Manrope',sans-serif;
    font-size:.9rem;
    cursor:pointer;
    transition:.25s ease;
}

.appointment-form button:hover{
    background:rgba(52,59,53,.82);
    transform:translateY(-2px);
}

@media (max-width:900px){

    .location-card{
        grid-template-columns:1fr;
        gap:34px;
    }

    .appointment-form{
        width:100%;
    }

}

@media (max-width:768px){

    .location-card{
        text-align:left;
    }

    .appointment-form{
        padding:24px;
        border-radius:18px;
    }

    .form-row{
        grid-template-columns:1fr;
        gap:0;
    }

}


/* Widen the location block so the appointment form sits farther right on desktop */
@media (min-width:901px){

    .location-card{
        max-width:1120px;
        grid-template-columns:minmax(440px, 1fr) 390px;
        gap:86px;
    }

    .clinic-info{
        max-width:520px;
    }

    .appointment-form{
        justify-self:end;
    }

}


/* Revised appointment layout: form below clinic info, horizontal on desktop */
.location-card{
    display:block;
    max-width:860px;
    margin-left:auto;
    margin-right:auto;
}

.clinic-info{
    max-width:520px;
    margin-bottom:34px;
}

.appointment-form{
    width:100%;
    max-width:860px;
}

.appointment-form{
    display:grid;
    grid-template-columns:1fr 1fr;
    column-gap:22px;
    row-gap:0;
}

.appointment-form h3{
    grid-column:1 / -1;
}

.appointment-form label{
    margin-bottom:16px;
}

.appointment-form label:has(textarea){
    grid-column:1 / -1;
}

.appointment-form .form-row{
    display:contents;
}

.appointment-form button{
    grid-column:1 / -1;
    justify-self:start;
}

@media (max-width:768px){

    .location-card{
        display:block;
        max-width:100%;
    }

    .clinic-info{
        max-width:100%;
        margin-bottom:28px;
    }

    .appointment-form{
        display:block;
        max-width:100%;
    }

    .appointment-form .form-row{
        display:block;
    }

}


@media (min-width:901px){
    .credentials-inner{
        grid-template-columns:repeat(4,1fr);
    }
}


.faq-section{
    padding:110px 8vw 70px 8vw;
    position:relative;
    z-index:2;
}

.faq-section .section-header{
    margin-bottom:46px;
}

.faq-section .section-header h2{
    color:white;
}

.faq-list{
    border-top:1px solid rgba(255,255,255,.18);
}

.faq-item{
    display:grid;
    grid-template-columns:1fr auto;
    gap:40px;
    align-items:center;
    padding:28px 0;
    border-bottom:1px solid rgba(255,255,255,.14);
}

.faq-question{
    color:white;
    font-size:1.08rem;
    font-weight:500;
}

.faq-answer{
    color:rgba(255,255,255,.82);
    text-align:right;
}

.faq-answer a{
    color:white;
    text-decoration:none;
    border-bottom:1px solid rgba(255,255,255,.35);
}

@media (max-width:768px){

    .faq-section{
        padding:84px 24px 50px 24px;
    }

    .faq-item{
        grid-template-columns:1fr;
        gap:12px;
        padding:22px 0;
    }

    .faq-answer{
        text-align:left;
    }

}


/* Mid-size navigation fix */
.logo{
    flex:0 0 auto;
    min-width:210px;
    white-space:nowrap;
}

.logo-main,
.logo-sub{
    white-space:nowrap;
}

.menu-toggle{
    display:none;
    position:relative;
    z-index:100001;
    width:46px;
    height:46px;
    border:1px solid rgba(255,255,255,.45);
    border-radius:100px;
    background:rgba(247,242,234,.12);
    cursor:pointer;
    padding:0;
    transition:.25s ease;
}

.menu-toggle:hover{
    background:rgba(247,242,234,.18);
}

.menu-toggle span{
    display:block;
    width:19px;
    height:2px;
    background:white;
    margin:5px auto;
    border-radius:2px;
    transition:.25s ease;
}

/* Collapse nav before it has a chance to wrap */
@media (max-width:1080px){

    .nav{
        padding:28px 34px;
    }

    .nav.scrolled{
        padding:22px 34px;
    }

    .logo{
        min-width:auto;
    }

    .logo-main{
        font-size:.86rem;
        letter-spacing:1.6px;
    }

    .logo-sub{
        font-size:.68rem;
        letter-spacing:2.5px;
    }

    .menu-toggle{
        display:block;
        margin-left:auto;
    }

    .nav-links{
        position:absolute;
        top:calc(100% + 10px);
        right:34px;
        display:flex;
        flex-direction:column;
        align-items:stretch;
        gap:8px;
        min-width:220px;
        padding:14px;
        border-radius:22px;
        background:rgba(34,34,34,.74);
        backdrop-filter:blur(14px);
        -webkit-backdrop-filter:blur(14px);
        box-shadow:0 18px 60px rgba(0,0,0,.28);
        opacity:0;
        transform:translateY(-8px);
        pointer-events:none;
        transition:.25s ease;
    }

    .nav.menu-open .nav-links{
        opacity:1;
        transform:translateY(0);
        pointer-events:auto;
    }

    .nav-links a{
        padding:13px 18px;
        border-radius:16px;
        white-space:nowrap;
    }

    .nav.menu-open .menu-toggle span:nth-child(1){
        transform:translateY(7px) rotate(45deg);
    }

    .nav.menu-open .menu-toggle span:nth-child(2){
        opacity:0;
    }

    .nav.menu-open .menu-toggle span:nth-child(3){
        transform:translateY(-7px) rotate(-45deg);
    }
}

@media (max-width:768px){

    .nav-links{
        right:22px;
        left:22px;
        min-width:0;
    }

    .logo-main{
        font-size:.78rem;
        letter-spacing:1.3px;
    }

    .logo-sub{
        font-size:.65rem;
    }
}

@media (max-width:768px){
    .nav-links{
        display:flex !important;
    }
}


/* Fix hamburger breakpoint positioning: keep nav pinned to top like desktop */
.nav{
    position:fixed !important;
    top:0 !important;
    left:0 !important;
    right:0 !important;
    width:100% !important;
    z-index:999999 !important;
}

.nav::before{
    content:"";
    position:absolute;
    inset:0;
    background:rgba(34,34,34,.42);
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    opacity:0;
    transition:opacity .45s ease;
    z-index:-1;
}

.nav.scrolled::before{
    opacity:1;
}

@media (max-width:1080px){

    .nav{
        position:fixed !important;
        top:0 !important;
        left:0 !important;
        right:0 !important;
        transform:none !important;
        align-items:center;
        padding:22px 34px !important;
    }

    .nav.scrolled{
        padding:18px 34px !important;
    }

    .logo{
        align-self:center;
        line-height:1.15;
    }

    .menu-toggle{
        align-self:center;
    }

    .nav-links{
        top:calc(100% + 10px);
    }

}

@media (max-width:768px){

    .nav{
        padding:20px 22px !important;
    }

    .nav.scrolled{
        padding:16px 22px !important;
    }

}


/* FINAL NAV FIX: keep hamburger/header short and pinned */
.nav{
    position:fixed !important;
    top:0 !important;
    left:0 !important;
    right:0 !important;
    width:100% !important;
    height:auto !important;
    min-height:0 !important;
    max-height:none !important;
    padding:22px 60px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    z-index:999999 !important;
    overflow:visible !important;
}

.nav.scrolled{
    padding:18px 60px !important;
}

.nav::before{
    content:"" !important;
    position:absolute !important;
    top:0 !important;
    left:0 !important;
    right:0 !important;
    bottom:0 !important;
    height:auto !important;
    background:rgba(34,34,34,.42) !important;
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    opacity:0;
    transition:opacity .45s ease;
    z-index:-1 !important;
    pointer-events:none !important;
}

.nav.scrolled::before{
    opacity:1 !important;
}

.logo{
    position:relative !important;
    top:auto !important;
    transform:none !important;
    align-self:center !important;
    flex:0 0 auto !important;
    min-width:max-content !important;
    white-space:nowrap !important;
    z-index:1000000 !important;
}

.menu-toggle{
    position:relative !important;
    top:auto !important;
    transform:none !important;
    align-self:center !important;
    flex:0 0 auto !important;
    z-index:1000000 !important;
}

/* Mid desktop / tablet: collapse to hamburger before nav wraps, but keep bar normal height */
@media (max-width:1080px){

    .nav{
        height:auto !important;
        min-height:0 !important;
        padding:18px 34px !important;
    }

    .nav.scrolled{
        padding:15px 34px !important;
    }

    .logo-main{
        font-size:.84rem !important;
        letter-spacing:1.5px !important;
        line-height:1.15 !important;
    }

    .logo-sub{
        font-size:.66rem !important;
        letter-spacing:2.3px !important;
        line-height:1.15 !important;
        margin-top:4px !important;
    }

    .menu-toggle{
        display:block !important;
        width:44px !important;
        height:44px !important;
        margin-left:auto !important;
    }

    .nav-links{
        position:absolute !important;
        top:calc(100% + 10px) !important;
        right:34px !important;
        left:auto !important;
        display:flex !important;
        flex-direction:column !important;
        align-items:stretch !important;
        gap:8px !important;
        min-width:220px !important;
        padding:14px !important;
        border-radius:22px !important;
        background:rgba(34,34,34,.74) !important;
        backdrop-filter:blur(14px);
        -webkit-backdrop-filter:blur(14px);
        box-shadow:0 18px 60px rgba(0,0,0,.28) !important;
        opacity:0 !important;
        transform:translateY(-8px) !important;
        pointer-events:none !important;
        transition:.25s ease !important;
    }

    .nav.menu-open .nav-links{
        opacity:1 !important;
        transform:translateY(0) !important;
        pointer-events:auto !important;
    }
}

/* Small mobile */
@media (max-width:768px){

    .nav{
        padding:16px 22px !important;
    }

    .nav.scrolled{
        padding:13px 22px !important;
    }

    .nav-links{
        right:22px !important;
        left:22px !important;
        min-width:0 !important;
    }

    .menu-toggle{
        width:42px !important;
        height:42px !important;
    }
}


/* Desktop/tablet hamburger opens on rollover; mobile still opens on click */
@media (min-width:769px) and (max-width:1080px){

    .nav:hover .nav-links,
    .nav:focus-within .nav-links{
        opacity:1 !important;
        transform:translateY(0) !important;
        pointer-events:auto !important;
    }

    .nav:hover .menu-toggle span:nth-child(1),
    .nav:focus-within .menu-toggle span:nth-child(1){
        transform:translateY(7px) rotate(45deg);
    }

    .nav:hover .menu-toggle span:nth-child(2),
    .nav:focus-within .menu-toggle span:nth-child(2){
        opacity:0;
    }

    .nav:hover .menu-toggle span:nth-child(3),
    .nav:focus-within .menu-toggle span:nth-child(3){
        transform:translateY(-7px) rotate(-45deg);
    }
}

@media (max-width:768px){

    .nav:hover .nav-links{
        opacity:0 !important;
        transform:translateY(-8px) !important;
        pointer-events:none !important;
    }

    .nav.menu-open .nav-links{
        opacity:1 !important;
        transform:translateY(0) !important;
        pointer-events:auto !important;
    }
}


/* Keep desktop hamburger dropdown open while moving cursor from icon to menu */
@media (min-width:769px) and (max-width:1080px){

    .nav-links{
        top:100% !important;
        padding-top:24px !important;
    }

    .nav:hover .nav-links,
    .nav:focus-within .nav-links,
    .nav-links:hover{
        opacity:1 !important;
        transform:translateY(0) !important;
        pointer-events:auto !important;
    }

}


/* Redesigned credentials section */
.credentials{
    padding:110px 8vw;
    background:#343B35;
    position:relative;
    z-index:2;
}

.credentials-inner{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:42px;
    max-width:1400px;
    margin:0 auto;
}

.credential-card{
    text-align:center;
    color:white;
}

.credential-icon{
    width:72px;
    height:72px;
    object-fit:contain;
    display:block;
    margin:0 auto 26px auto;
    opacity:.96;
}

.credential-title{
    font-size:1.45rem;
    line-height:1.1;
    font-weight:700;
    margin-bottom:18px;
    color:white;
}

.credential-value{
    font-size:1.15rem;
    line-height:1.65;
    color:rgba(255,255,255,.82);
}

.credential-value.small{
    font-size:1rem;
    line-height:1.7;
}

@media (max-width:1100px){

    .credentials-inner{
        grid-template-columns:repeat(2,1fr);
        gap:56px 34px;
    }

}

@media (max-width:768px){

    .credentials{
        padding:82px 24px;
    }

    .credentials-inner{
        grid-template-columns:1fr;
        gap:54px;
    }

    .credential-icon{
        width:62px;
        height:62px;
        margin-bottom:22px;
    }

    .credential-title{
        font-size:1.9rem;
    }

    .credential-value{
        font-size:1.02rem;
    }
}


/* Mobile copy refinement: reduce widows/orphans in About body */
.about-text p{
    text-wrap:pretty;
}

@media (max-width:768px){

    .about-text{
        max-width:96%;
    }

    .about-text p{
        max-width:34em;
        font-size:.98rem;
        line-height:1.72;
        text-wrap:pretty;
        overflow-wrap:normal;
    }

}

@media (max-width:430px){

    .about-text{
        max-width:100%;
    }

    .about-text p{
        font-size:.96rem;
        line-height:1.7;
        max-width:31em;
    }

}


/* Narrow hero intro copy slightly on mobile to prevent widow/orphan */
@media (max-width:768px){

    .hero-content p{
        max-width:19.5em;
    }

}

@media (max-width:430px){

    .hero-content p{
        max-width:18.5em;
    }

}


/* Added Request Appointment nav item; tighten desktop spacing slightly */
@media (min-width:1081px){

    .nav-links{
        gap:28px;
    }

    .nav-links a{
        padding:10px 15px;
        font-size:.88rem;
        white-space:nowrap;
    }

}


/* Reliable fixed hero video */
.hero-video{
    position:fixed !important;
    top:0 !important;
    left:0 !important;
    width:100vw !important;
    height:100vh !important;
    object-fit:cover !important;
    z-index:-2 !important;
    display:block !important;
    opacity:1 !important;
    visibility:visible !important;
}

@media (max-width:768px){
    .hero-video{
        object-position:70% center !important;
    }
}
