:root{
    --teal:#2A7B7F;
    --teal-deep:#1F5E62;
    --teal-soft:#E8F1F1;
    --gold:#C9A24C;
    --gold-soft:#F5EBD3;
    --ink:#1F2A2B;
    --ink-soft:#5A6869;
    --cream:#FBF8F3;
    --white:#FFFFFF;
    --shadow-sm: 0 2px 8px rgba(31,42,43,0.04), 0 4px 16px rgba(31,42,43,0.04);
    --shadow-md: 0 8px 24px rgba(31,42,43,0.06), 0 16px 40px rgba(31,42,43,0.05);
    --shadow-lg: 0 20px 50px rgba(31,42,43,0.08), 0 30px 80px rgba(42,123,127,0.07);
    --radius-sm: 14px;
    --radius-md: 22px;
    --radius-lg: 32px;
    --radius-xl: 44px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
    font-family:'Outfit', sans-serif;
    font-weight:300;
    color:var(--ink);
    background:var(--white);
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
    width:100%;
}
img{max-width:100%;height:auto;display:block}

/* type */
h1,h2,h3,h4{font-family:'Cormorant Garamond', serif;font-weight:500;letter-spacing:-0.01em;color:var(--ink);line-height:1.15}
.script{font-family:'Allura', cursive;color:var(--gold);font-weight:400;letter-spacing:0;font-style:normal}
.eyebrow{
    font-family:'Outfit',sans-serif;
    font-size:.72rem;
    font-weight:500;
    letter-spacing:.32em;
    text-transform:uppercase;
    color:var(--teal);
    display:inline-block;
}

/* layout */
.wrap{max-width:1240px;margin:0 auto;padding:0 32px}
@media (max-width:768px){.wrap{padding:0 24px}}
@media (max-width:480px){.wrap{padding:0 20px}}
section{padding:120px 0;position:relative}
@media (max-width:960px){section{padding:90px 0}}
@media (max-width:768px){section{padding:70px 0}}
@media (max-width:480px){section{padding:60px 0}}

/* ================= NAV ================= */
.nav{
    position:fixed;top:18px;left:50%;transform:translateX(-50%);
    width:calc(100% - 36px);max-width:1180px;
    background:rgba(255,255,255,.82);
    backdrop-filter:blur(20px) saturate(1.2);
    -webkit-backdrop-filter:blur(20px) saturate(1.2);
    border:1px solid rgba(42,123,127,.08);
    border-radius:100px;
    padding:10px 14px 10px 22px;
    display:flex;align-items:center;justify-content:space-between;
    z-index:100;
    box-shadow:var(--shadow-sm);
}
.nav-logo{
    font-family:'Allura',cursive;
    font-size:1.7rem;
    color:var(--teal);
    text-decoration:none;
    line-height:1;
    display:flex;align-items:center;
    flex-shrink:0;
}
.nav-logo img{max-height:140px;width:auto}
.nav-links{display:flex;gap:36px;align-items:center}
.nav-links a{
    color:var(--ink-soft);
    text-decoration:none;
    font-size:.92rem;
    font-weight:400;
    transition:color .25s ease;
    white-space:nowrap;
}
.nav-links a:hover{color:var(--teal)}
.nav-cta{
    background:var(--teal);
    color:#fff !important;
    padding:11px 22px;
    border-radius:100px;
    font-size:.88rem;
    font-weight:500;
    transition:all .3s ease;
    box-shadow:0 4px 14px rgba(42,123,127,.25);
}
.nav-cta:hover{background:var(--teal-deep);transform:translateY(-1px);box-shadow:0 6px 20px rgba(42,123,127,.35)}

/* mobile menu toggle */
.nav-toggle{
    display:none;
    background:none;border:none;cursor:pointer;
    width:42px;height:42px;
    border-radius:50%;
    align-items:center;justify-content:center;
    color:var(--teal);
    transition:background .2s ease;
}
.nav-toggle:hover{background:var(--teal-soft)}
.nav-toggle span{
    display:block;
    width:18px;height:1.5px;
    background:currentColor;
    position:relative;
    transition:all .3s ease;
}
.nav-toggle span::before,.nav-toggle span::after{
    content:"";position:absolute;left:0;
    width:18px;height:1.5px;background:currentColor;
    transition:all .3s ease;
}
.nav-toggle span::before{top:-6px}
.nav-toggle span::after{top:6px}
.nav.open .nav-toggle span{background:transparent}
.nav.open .nav-toggle span::before{top:0;transform:rotate(45deg)}
.nav.open .nav-toggle span::after{top:0;transform:rotate(-45deg)}

@media (max-width:860px){
    .nav{padding:8px 8px 8px 18px;border-radius:80px}
    .nav-logo img{max-height:50px}
    .nav-toggle{display:flex}
    .nav-links{
        position:absolute;
        top:calc(100% + 12px);
        left:0;right:0;
        flex-direction:column;
        gap:0;
        background:rgba(255,255,255,.96);
        backdrop-filter:blur(20px) saturate(1.2);
        -webkit-backdrop-filter:blur(20px) saturate(1.2);
        border:1px solid rgba(42,123,127,.08);
        border-radius:26px;
        padding:16px;
        box-shadow:var(--shadow-md);
        opacity:0;
        pointer-events:none;
        transform:translateY(-10px);
        transition:all .3s ease;
    }
    .nav.open .nav-links{opacity:1;pointer-events:auto;transform:translateY(0)}
    .nav-links a{
        padding:14px 18px;
        width:100%;text-align:center;
        font-size:1rem;
        border-radius:18px;
    }
    .nav-links a:not(.nav-cta):hover{background:var(--teal-soft);color:var(--teal)}
    .nav-cta{margin-top:6px;justify-content:center;display:flex}
}
@media (max-width:480px){
    .nav{top:12px;width:calc(100% - 24px)}
    .nav-logo img{max-height:44px}
}

/* ================= HERO ================= */
.hero{padding:170px 0 100px;position:relative;overflow:hidden}
@media (max-width:768px){.hero{padding:140px 0 80px}}
@media (max-width:480px){.hero{padding:120px 0 60px}}

.hero::before{
    content:"";position:absolute;
    top:-200px;right:-200px;
    width:700px;height:700px;
    background:radial-gradient(circle,rgba(42,123,127,.08) 0%,rgba(42,123,127,0) 60%);
    border-radius:50%;z-index:0;pointer-events:none;
}
.hero::after{
    content:"";position:absolute;
    bottom:-150px;left:-150px;
    width:500px;height:500px;
    background:radial-gradient(circle,rgba(201,162,76,.08) 0%,rgba(201,162,76,0) 60%);
    border-radius:50%;z-index:0;pointer-events:none;
}
.hero-grid{
    display:grid;
    grid-template-columns:1.05fr .95fr;
    gap:80px;align-items:center;
    position:relative;z-index:1;
}
@media (max-width:960px){.hero-grid{grid-template-columns:1fr;gap:60px;text-align:center}}
@media (max-width:480px){.hero-grid{gap:50px}}

.hero h1{
    font-size:clamp(2.2rem, 6vw, 4.6rem);
    margin:18px 0 8px;line-height:1.05;
    word-wrap:break-word;
}
.hero h1 .script{
    display:block;
    font-size:clamp(3rem, 8.5vw, 6.2rem);
    line-height:.9;
    margin:-6px 0 -6px;
    transform:translateX(-4px);
}
@media (max-width:960px){.hero h1 .script{transform:none}}
@media (max-width:480px){
    .hero h1{font-size:clamp(2rem,9vw,2.6rem)}
    .hero h1 .script{font-size:clamp(2.8rem,13vw,3.6rem);margin:-4px 0}
}

.hero p.lead{
    color:var(--ink-soft);
    font-size:1.12rem;
    max-width:480px;
    margin:28px 0 38px;
    font-weight:300;
}
@media (max-width:960px){.hero p.lead{margin-left:auto;margin-right:auto}}
@media (max-width:480px){.hero p.lead{font-size:1rem;margin:22px auto 30px}}

.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
@media (max-width:960px){.hero-cta{justify-content:center}}
@media (max-width:380px){.hero-cta{flex-direction:column;align-items:stretch;gap:10px}}

.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;
    padding:16px 30px;
    border-radius:100px;
    font-size:.95rem;
    font-weight:500;
    text-decoration:none;
    transition:all .3s cubic-bezier(.2,.7,.3,1);
    cursor:pointer;border:none;
    font-family:'Outfit',sans-serif;
    white-space:nowrap;
}
@media (max-width:480px){.btn{padding:14px 26px;font-size:.92rem}}

.btn-primary{background:var(--teal);color:#fff;box-shadow:0 8px 22px rgba(42,123,127,.28)}
.btn-primary:hover{background:var(--teal-deep);transform:translateY(-2px);box-shadow:0 12px 30px rgba(42,123,127,.4)}
.btn-ghost{background:#fff;color:var(--ink);border:1px solid rgba(42,123,127,.15);box-shadow:var(--shadow-sm)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal);transform:translateY(-2px)}
.btn-arrow{transition:transform .3s ease;display:inline-block}
.btn:hover .btn-arrow{transform:translateX(3px)}

/* hero visual */
.hero-visual{
    position:relative;
    aspect-ratio:4/5;
    max-width:520px;
    margin-left:auto;
    width:100%;
}
@media (max-width:960px){.hero-visual{margin:0 auto;max-width:440px}}
@media (max-width:480px){.hero-visual{max-width:320px}}

.hero-photo{
    width:100%;height:100%;
    border-radius:var(--radius-xl);
    overflow:hidden;
    box-shadow:var(--shadow-lg);
    position:relative;
    background:var(--teal-soft);
}
@media (max-width:480px){.hero-photo{border-radius:var(--radius-lg)}}

.hero-photo img{width:100%;height:100%;object-fit:cover;display:block}
.hero-badge{
    position:absolute;
    top:24px;left:24px;
    background:rgba(255,255,255,.95);
    backdrop-filter:blur(10px);
    padding:10px 18px;
    border-radius:100px;
    font-size:.78rem;
    color:var(--teal);
    font-weight:500;
    display:flex;align-items:center;gap:8px;
    box-shadow:var(--shadow-sm);
    z-index:3;
}
@media (max-width:480px){
    .hero-badge{top:16px;left:16px;padding:8px 14px;font-size:.7rem}
}

.hero-badge::before{
    content:"";
    width:8px;height:8px;
    border-radius:50%;
    background:#3ab35e;
    box-shadow:0 0 0 3px rgba(58,179,94,.2);
    animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{
    0%,100%{box-shadow:0 0 0 3px rgba(58,179,94,.2)}
    50%{box-shadow:0 0 0 6px rgba(58,179,94,.05)}
}

.float-card{
    position:absolute;
    background:#fff;
    border-radius:var(--radius-md);
    padding:18px 22px;
    box-shadow:var(--shadow-md);
    display:flex;align-items:center;gap:14px;
    z-index:2;
}
.float-card .num{
    font-family:'Cormorant Garamond',serif;
    font-size:2rem;
    color:var(--teal);
    line-height:1;font-weight:500;
    white-space:nowrap;
}
.float-card .lbl{font-size:.78rem;color:var(--ink-soft);line-height:1.3;max-width:100px}
.float-1{top:30px;left:-40px;animation:floatA 6s ease-in-out infinite}
.float-2{bottom:50px;right:-30px;animation:floatA 6s ease-in-out infinite reverse}
@keyframes floatA{
    0%,100%{transform:translateY(0)}
    50%{transform:translateY(-10px)}
}
@media (max-width:600px){
    .float-1{top:16px;left:-10px}
    .float-2{bottom:30px;right:-10px}
    .float-card{padding:12px 14px;border-radius:16px;gap:10px}
    .float-card .num{font-size:1.35rem}
    .float-card .lbl{font-size:.68rem;max-width:75px;line-height:1.25}
}
@media (max-width:380px){
    .float-card .lbl{display:none}
    .float-card{padding:10px 14px}
}

/* ================= MARQUEE ================= */
.strip{
    background:var(--cream);
    padding:32px 0;
    overflow:hidden;
    border-top:1px solid rgba(42,123,127,.06);
    border-bottom:1px solid rgba(42,123,127,.06);
}
@media (max-width:480px){.strip{padding:24px 0}}

.strip-track{
    display:flex;align-items:center;
    white-space:nowrap;
    animation:scroll 40s linear infinite;
    width:max-content;
}
.strip-item{
    font-family:'Cormorant Garamond',serif;
    font-size:1.5rem;
    color:var(--ink-soft);
    font-style:italic;
    padding:0 50px;
}
@media (max-width:480px){.strip-item{font-size:1.2rem;padding:0 30px}}

.strip-sep{color:var(--gold);font-size:1rem;flex-shrink:0}
@keyframes scroll{
    from{transform:translateX(0)}
    to{transform:translateX(-50%)}
}

/* ================= SECTION HEADING ================= */
.section-head{text-align:center;max-width:680px;margin:0 auto 70px;padding:0 8px}
@media (max-width:768px){.section-head{margin-bottom:50px}}
.section-head h2{font-size:clamp(1.9rem,4vw,3.4rem);margin:14px 0 18px}
.section-head h2 .script{display:inline;font-size:1.25em;line-height:.9;vertical-align:baseline}
.section-head p{color:var(--ink-soft);font-size:1.05rem}
@media (max-width:480px){.section-head p{font-size:.98rem}}

/* ================= SERVICES ================= */
.services{background:var(--cream);position:relative}
.services-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:28px;
}
@media (max-width:900px){.services-grid{grid-template-columns:1fr 1fr;gap:22px}}
@media (max-width:600px){.services-grid{grid-template-columns:1fr;gap:20px}}

.service-card{
    background:#fff;
    border-radius:var(--radius-lg);
    overflow:hidden;
    box-shadow:var(--shadow-sm);
    transition:all .4s cubic-bezier(.2,.7,.3,1);
    position:relative;
    border:1px solid rgba(42,123,127,.04);
    display:flex;flex-direction:column;
}
.service-card:hover{
    transform:translateY(-6px);
    box-shadow:var(--shadow-md);
    border-color:rgba(42,123,127,.12);
}
.service-img{
    width:100%;
    aspect-ratio:5/3;
    overflow:hidden;
    position:relative;
    background:var(--teal-soft);
}
.service-img img{
    width:100%;height:100%;
    object-fit:cover;
    transition:transform .8s ease;
    display:block;
}
.service-card:hover .service-img img{transform:scale(1.05)}
.service-body{padding:30px 28px;display:flex;flex-direction:column;flex:1}
@media (max-width:480px){.service-body{padding:26px 24px}}

.service-card h3{font-size:1.45rem;margin-bottom:8px}
.service-card .service-desc{color:var(--ink-soft);font-size:.93rem;margin-bottom:22px;flex:1}
.service-meta{
    display:flex;justify-content:space-between;align-items:center;
    padding-top:20px;
    border-top:1px dashed rgba(42,123,127,.18);
    gap:10px;
    flex-wrap:wrap;
}
.service-price{
    font-family:'Cormorant Garamond',serif;
    font-size:1.55rem;color:var(--teal);font-weight:500;
}
.service-price small{font-size:.72rem;color:var(--ink-soft);font-weight:300;font-family:'Outfit',sans-serif;margin-left:4px}
.service-time{
    font-size:.78rem;color:var(--ink);
    background:var(--gold-soft);
    padding:6px 14px;border-radius:100px;
    font-weight:500;
    white-space:nowrap;
}

/* ================= ABOUT ================= */
.about-grid{
    display:grid;
    grid-template-columns:.9fr 1.1fr;
    gap:80px;align-items:center;
}
@media (max-width:900px){.about-grid{grid-template-columns:1fr;gap:60px}}
@media (max-width:480px){.about-grid{gap:50px}}

.about-img-wrap{position:relative}
.about-img{
    aspect-ratio:4/5;
    border-radius:var(--radius-lg);
    overflow:hidden;
    box-shadow:var(--shadow-lg);
    position:relative;
}
.about-img img{width:100%;height:100%;object-fit:cover;display:block}
.about-img-small{
    position:absolute;
    bottom:-40px;right:-40px;
    width:55%;
    aspect-ratio:1/1;
    border-radius:var(--radius-md);
    overflow:hidden;
    box-shadow:var(--shadow-lg);
    border:8px solid #fff;
}
.about-img-small img{width:100%;height:100%;object-fit:cover;display:block}
@media (max-width:900px){.about-img-small{right:-10px;bottom:-30px;width:45%}}
@media (max-width:600px){.about-img-small{width:42%;border-width:6px;bottom:-20px;right:-10px}}
@media (max-width:380px){.about-img-small{display:none}}

.about-content h2{font-size:clamp(1.9rem,4vw,3.4rem);margin:14px 0 24px}
.about-content h2 .script{display:inline;font-size:1.25em;line-height:.9}
.about-content > p{color:var(--ink-soft);margin-bottom:18px;font-size:1.02rem}
@media (max-width:480px){.about-content > p{font-size:.98rem}}

.check-list{margin-top:30px;display:grid;gap:16px}
.check-list li{
    list-style:none;
    display:flex;align-items:center;gap:14px;
    font-size:.98rem;color:var(--ink);
}
@media (max-width:480px){.check-list li{font-size:.92rem;gap:12px}}

.check-list li svg{
    flex-shrink:0;
    width:26px;height:26px;
    background:var(--teal-soft);
    color:var(--teal);
    border-radius:50%;
    padding:5px;
}

/* ================= GALLERY ================= */
.gallery{padding:80px 0 60px}
@media (max-width:768px){.gallery{padding:60px 0 40px}}

.gallery-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:18px;
}
@media (max-width:900px){.gallery-grid{grid-template-columns:repeat(2,1fr);gap:14px}}
@media (max-width:480px){.gallery-grid{gap:12px}}

.gallery-item{
    border-radius:var(--radius-md);
    overflow:hidden;
    aspect-ratio:1/1.2;
    box-shadow:var(--shadow-sm);
    transition:all .4s ease;
    background:var(--teal-soft);
}
.gallery-item:nth-child(2),.gallery-item:nth-child(3){aspect-ratio:1/1}
@media (max-width:900px){.gallery-item,.gallery-item:nth-child(2),.gallery-item:nth-child(3){aspect-ratio:1/1.1}}

.gallery-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease;display:block}
.gallery-item:hover img{transform:scale(1.08)}

/* ================= PROCESS ================= */
.process{background:var(--cream);position:relative;overflow:hidden}
.process-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:24px;
}
@media (max-width:900px){.process-grid{grid-template-columns:1fr 1fr;gap:18px}}
@media (max-width:520px){.process-grid{grid-template-columns:1fr;gap:16px}}

.process-card{
    background:#fff;
    border-radius:var(--radius-md);
    padding:36px 26px;
    box-shadow:var(--shadow-sm);
    text-align:center;
    position:relative;
    transition:all .3s ease;
}
@media (max-width:480px){.process-card{padding:30px 24px}}

.process-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.process-num{
    font-family:'Cormorant Garamond',serif;
    font-size:3.4rem;
    color:var(--gold);
    line-height:1;margin-bottom:14px;
    font-style:italic;font-weight:500;
}
.process-card h4{font-size:1.25rem;margin-bottom:10px}
.process-card p{color:var(--ink-soft);font-size:.9rem}

/* ================= TESTIMONIALS ================= */
.testimonials-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:24px;
}
@media (max-width:900px){.testimonials-grid{grid-template-columns:1fr;gap:20px}}

.testimonial{
    background:#fff;
    border-radius:var(--radius-lg);
    padding:36px 34px;
    box-shadow:var(--shadow-sm);
    border:1px solid rgba(42,123,127,.05);
    position:relative;
    transition:all .3s ease;
}
@media (max-width:480px){.testimonial{padding:30px 26px}}

.testimonial:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}
.testimonial.featured{background:var(--teal);color:#fff;border:none}
.testimonial.featured .t-name{color:#fff}
.testimonial.featured .t-role{color:rgba(255,255,255,.7)}
.testimonial.featured p{color:rgba(255,255,255,.95)}
.stars{color:var(--gold);font-size:.95rem;margin-bottom:16px;letter-spacing:2px}
.testimonial p{
    font-family:'Cormorant Garamond',serif;
    font-size:1.18rem;
    line-height:1.5;
    margin-bottom:24px;
    color:var(--ink);font-style:italic;
}
@media (max-width:480px){.testimonial p{font-size:1.1rem}}

.t-author{display:flex;align-items:center;gap:14px}
.t-avatar{
    width:48px;height:48px;
    border-radius:50%;
    background:linear-gradient(135deg,var(--gold),#a08234);
    display:flex;align-items:center;justify-content:center;
    color:#fff;
    font-family:'Cormorant Garamond',serif;
    font-size:1.2rem;
    flex-shrink:0;font-weight:500;
}
.testimonial.featured .t-avatar{background:linear-gradient(135deg,#fff,#f5ebd3);color:var(--teal)}
.t-name{font-weight:500;color:var(--ink);font-size:.98rem;font-family:'Outfit',sans-serif}
.t-role{font-size:.82rem;color:var(--ink-soft)}

/* ================= CTA ================= */
.cta-section{padding:80px 0 120px}
@media (max-width:768px){.cta-section{padding:60px 0 90px}}
@media (max-width:480px){.cta-section{padding:40px 0 70px}}

.cta-card{
    background:
        radial-gradient(circle at 80% 20%, rgba(201,162,76,.18) 0%, transparent 50%),
        linear-gradient(135deg,#1F5E62 0%,#2A7B7F 100%);
    border-radius:var(--radius-xl);
    padding:90px 60px;
    text-align:center;color:#fff;
    box-shadow:var(--shadow-lg);
    position:relative;overflow:hidden;
}
@media (max-width:768px){.cta-card{padding:70px 40px;border-radius:var(--radius-lg)}}
@media (max-width:480px){.cta-card{padding:55px 26px;border-radius:var(--radius-md)}}

.cta-card::before{
    content:"";position:absolute;
    top:-100px;left:-100px;
    width:300px;height:300px;
    background:radial-gradient(circle,rgba(201,162,76,.2) 0%,transparent 60%);
    border-radius:50%;
}
.cta-card .eyebrow{color:var(--gold)}
.cta-card h2{
    color:#fff;
    font-size:clamp(1.9rem,5vw,3.6rem);
    margin:16px 0 14px;
    position:relative;
}
.cta-card h2 .script{color:var(--gold);font-size:1.3em;display:inline;line-height:.9}
.cta-card p{
    color:rgba(255,255,255,.85);
    max-width:520px;
    margin:0 auto 36px;
    position:relative;font-size:1.05rem;
}
@media (max-width:480px){.cta-card p{font-size:.98rem;margin-bottom:28px}}

.cta-card .btn-primary{background:var(--gold);color:var(--ink);box-shadow:0 8px 24px rgba(201,162,76,.35);position:relative}
.cta-card .btn-primary:hover{background:#d4b262;box-shadow:0 12px 32px rgba(201,162,76,.5)}

/* ================= FOOTER ================= */
footer{
    background:var(--cream);
    padding:80px 0 30px;
    border-top:1px solid rgba(42,123,127,.06);
}
@media (max-width:768px){footer{padding:60px 0 30px}}

.foot-grid{
    display:grid;
    grid-template-columns:1.4fr 1fr 1fr 1.2fr;
    gap:50px;margin-bottom:60px;
}
@media (max-width:900px){.foot-grid{grid-template-columns:1fr 1fr 1fr;gap:40px}}
@media (max-width:780px){.foot-grid{grid-template-columns:1fr 1fr;gap:36px;margin-bottom:40px}}
@media (max-width:480px){.foot-grid{grid-template-columns:1fr;gap:30px}}

.foot-brand{grid-column:1/-1}
@media (min-width:781px){.foot-brand{grid-column:auto}}

.foot-brand .nav-logo{font-size:2.4rem;display:inline-block;margin-bottom:14px}
.foot-brand .nav-logo img{max-height:70px}
.foot-brand > p{color:var(--ink-soft);font-size:.95rem;max-width:280px;margin-bottom:0}

.foot-col h5{
    font-family:'Outfit',sans-serif;
    font-size:.78rem;
    letter-spacing:.28em;
    text-transform:uppercase;
    color:var(--teal);
    margin-bottom:20px;font-weight:500;
}
.foot-col a, .foot-col p{
    display:block;
    color:var(--ink-soft);
    text-decoration:none;
    font-size:.92rem;margin-bottom:10px;
    transition:color .2s ease;
}
.foot-col a:hover{color:var(--teal)}
.socials{display:flex;gap:10px;margin-top:18px}
.socials a{
    width:38px;height:38px;
    border-radius:50%;
    background:#fff;
    display:flex;align-items:center;justify-content:center;
    color:var(--teal);
    box-shadow:var(--shadow-sm);
    transition:all .3s ease;margin:0;
}
.socials a:hover{background:var(--teal);color:#fff;transform:translateY(-2px)}
.foot-bottom{
    text-align:center;
    padding-top:30px;
    border-top:1px solid rgba(42,123,127,.08);
    color:var(--ink-soft);font-size:.82rem;
}

/* ================= REVEAL ================= */
.reveal{opacity:0;transform:translateY(20px);transition:all .8s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:translateY(0)}

@media (prefers-reduced-motion: reduce){
    *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
    .reveal{opacity:1;transform:none}
}