*{box-sizing:border-box}
:root{
    --bg:#ffffff;
    --surface:#ffffff;
    --surface-soft:#f8f8f8;
    --surface-dark:#0b0b0c;
    --text:#111111;
    --muted:#575757;
    --line:#e9e9e9;
    --line-strong:#d8d8d8;
    --shadow:0 24px 70px rgba(0,0,0,.08);
    --shadow-soft:0 14px 34px rgba(0,0,0,.05);
    --radius:28px;
    --radius-sm:20px;
}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
main{min-height:60vh}
.container{width:min(1240px,calc(100% - 32px));margin:0 auto}

.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:blur(16px);border-bottom:1px solid rgba(17,17,17,.08);box-shadow:0 10px 28px rgba(0,0,0,.04)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:88px;flex-wrap:wrap;padding:14px 0}
.logo-wrap{display:inline-flex;align-items:center;gap:12px}
.brand-lockup{padding:0;flex:0 0 auto}
.site-logo{width:170px;max-width:44vw;height:auto;object-fit:contain;display:block}
.logo-text{font-weight:800;letter-spacing:.02em;font-size:1.03rem}
.main-nav{display:flex;gap:8px;flex-wrap:wrap}
.main-nav a,.lang-switch a{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:0 15px;border-radius:999px;color:#1a1a1a;font-size:.94rem;font-weight:600;transition:.2s ease;background:transparent}
.main-nav a:hover,.main-nav a.active{background:#111;color:#fff;box-shadow:0 12px 28px rgba(0,0,0,.12)}
.lang-switch{display:flex;gap:6px;flex-wrap:wrap}
.lang-switch a{min-width:44px;padding:0 10px;border:1px solid var(--line);background:#fff}
.lang-switch a.active{background:#111;color:#fff;border-color:#111;box-shadow:0 10px 24px rgba(0,0,0,.10)}

.hero{padding:30px 0 18px}
.hero-grid{display:grid;grid-template-columns:1fr;gap:16px}
.surface-dark{background:var(--surface-dark);color:#fff;border-radius:36px;padding:30px 24px;box-shadow:var(--shadow)}
.eyebrow{display:inline-flex;align-items:center;gap:8px;min-height:34px;padding:0 12px;border-radius:999px;background:#f1f1f1;font-size:.76rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#444;margin-bottom:16px}
.eyebrow-dark{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.1)}
.hero h1{margin:0;font-size:2.7rem;line-height:.96;letter-spacing:-.045em}
.hero-lead,.hero p{margin:16px 0 0;color:rgba(255,255,255,.78);font-size:1.02rem;max-width:62ch}
.hero-actions{display:grid;grid-template-columns:1fr;gap:10px;margin-top:24px}
.hero-visual,.page-hero-photo{min-width:0}
.card-premium{position:relative;overflow:hidden;border-radius:32px;background:#fff;border:1px solid rgba(17,17,17,.08);box-shadow:var(--shadow-soft);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}
.card-photo-large{min-height:420px}
.card-photo-large img,.ambient-card img,.gallery-main img,.gallery-side img,.listing-media img,.experience-photo img,.page-hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-image-card{height:100%}
.card-overlay{position:absolute;left:18px;right:18px;bottom:18px;padding:16px 18px;border-radius:22px;background:linear-gradient(180deg,rgba(17,17,17,.02),rgba(17,17,17,.72));color:#fff}
.card-overlay span,.overlay-kicker{display:block;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;opacity:.82;margin-bottom:8px}
.card-overlay strong{font-size:1rem;line-height:1.35}

.btn{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:0 22px;border-radius:999px;font-weight:700;letter-spacing:.01em;transition:.2s ease;border:1px solid transparent;cursor:pointer}
.btn:hover{transform:translateY(-1px)}
.btn-dark{background:#111;color:#fff}
.btn-light{background:#fff;color:#111}
.btn-dark-outline{background:transparent;color:#111;border-color:#111}
.surface-dark .btn-dark-outline,.light-outline{color:#fff;border-color:rgba(255,255,255,.3)}
.surface-dark .btn-dark-outline:hover,.light-outline:hover{background:#fff;color:#111}
.btn-dark:hover{background:#000}
.btn-light:hover{background:#f4f4f4}
.btn-dark-outline:hover{background:#111;color:#fff}

.section{padding:42px 0}
.section-tight{padding-top:18px}
.section-soft{background:var(--surface-soft)}
.section-title{margin:0;font-size:2.1rem;line-height:1.03;letter-spacing:-.04em}
.large-title{font-size:2.25rem}
.section-intro{margin:0;color:var(--muted);font-size:1.02rem;line-height:1.72}
.split-head,.intro-split{display:grid;grid-template-columns:1fr;gap:16px}
.bullet-inline-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:18px}
.bullet-inline-grid span,.feature-pills span,.listing-meta span{display:inline-flex;align-items:center;min-height:40px;padding:0 14px;border-radius:999px;background:#fff;border:1px solid var(--line);font-size:.92rem;color:#1c1c1d}
.feature-grid{display:grid;grid-template-columns:1fr;gap:18px}
.listing-card,.detail-card,.status-card,.empty-state{background:var(--surface);border:1px solid var(--line);border-radius:32px;box-shadow:var(--shadow-soft)}
.listing-card-featured{overflow:hidden}
.listing-card-premium{overflow:hidden;height:100%}
.listing-media{aspect-ratio:16/10;background:#ececec}
.premium-body{padding:24px}
.mini-label{display:inline-block;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:#777;margin-bottom:12px;font-weight:700}
.listing-card h2,.detail-card h2,.status-card h1,.empty-state h2,.experience-body h3{margin:0 0 10px;line-height:1.06;letter-spacing:-.03em}
.listing-card p,.detail-card p,.status-card p,.empty-state p,.experience-body p{margin:0;color:var(--muted);line-height:1.72}
.listing-meta{display:flex;flex-direction:column;gap:8px;margin-top:18px}
.listing-meta-inline{flex-wrap:wrap}
.listing-card .btn{margin-top:18px}
.feature-pills{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0 0}
.ambient-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ambient-card{aspect-ratio:1/1}
.ambient-card .card-overlay{left:12px;right:12px;bottom:12px;padding:14px 16px;border-radius:18px}
.ambient-card .card-overlay span{margin:0;font-size:.85rem;font-weight:700}

.experience-grid{display:grid;grid-template-columns:1fr;gap:18px}
.experience-card{overflow:hidden}
.experience-photo{aspect-ratio:16/10;background:#ececec}
.experience-body{padding:22px}
.text-link{display:inline-flex;align-items:center;gap:8px;margin-top:18px;font-weight:700}
.text-link::after{content:'→';font-size:1rem}
.gallery-premium{display:grid;grid-template-columns:1fr;gap:16px}
.gallery-main{aspect-ratio:16/11}
.gallery-side{aspect-ratio:16/11}

.page-hero{padding:30px 0 16px}
.page-hero-premium{padding-top:28px}
.page-hero-grid{display:grid;grid-template-columns:1fr;gap:16px;align-items:center}
.page-hero-photo{aspect-ratio:16/10}
.page-title{margin:0 0 12px;font-size:2.45rem;line-height:.98;letter-spacing:-.045em}
.page-subtitle{margin:0;color:var(--muted);max-width:72ch;line-height:1.75;font-size:1.04rem}
.listing-grid-premium{display:grid;grid-template-columns:1fr;gap:18px}

.detail-grid{display:grid;grid-template-columns:1fr;gap:18px}
.detail-main,.detail-side{display:grid;gap:18px}
.detail-card{padding:24px}
.detail-specs{display:grid;grid-template-columns:1fr;gap:12px}
.detail-specs div{padding:14px 0;border-bottom:1px solid var(--line)}
.detail-specs div:last-child{border-bottom:none}
.detail-specs strong{display:block;margin-bottom:6px}
.booking-form{display:grid;gap:12px}
.booking-form label{font-size:.95rem;font-weight:700}
.booking-form input{width:100%;min-height:52px;padding:12px 14px;border:1px solid var(--line-strong);border-radius:16px;background:#fff;transition:border-color .2s ease, box-shadow .2s ease}
.sticky-card{position:sticky;top:92px}
.narrow-container{max-width:820px}
.status-card,.empty-state{padding:28px}
.success-card{background:#eff8f1;border-color:#c8dfcf}
.error-card{background:#fff2f2;border-color:#efcccc}

.cta-section{padding-top:10px}
.cta-panel{display:grid;grid-template-columns:1fr;gap:18px;padding:26px 22px;border-radius:32px;background:#111;color:#fff;box-shadow:var(--shadow)}
.cta-panel h2{margin:10px 0 0;font-size:2rem;line-height:1.04;letter-spacing:-.03em}
.cta-panel p{margin:12px 0 0;color:rgba(255,255,255,.74)}
.cta-actions{display:grid;gap:10px}

.site-footer{background:#0b0b0c;color:#fff;margin-top:52px;padding-top:38px}
.footer-logo{width:180px;max-width:100%;margin:0 0 14px}
.footer-grid{display:grid;grid-template-columns:1fr;gap:22px;padding-bottom:26px}
.footer-brand{margin:0 0 10px;font-size:1.15rem;font-weight:800}
.footer-copy{margin:0;color:rgba(255,255,255,.74)}
.footer-heading{margin:0 0 12px;font-size:.92rem;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.55)}
.footer-links{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.footer-links a{color:rgba(255,255,255,.88);transition:opacity .2s ease,transform .2s ease}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:16px 0;text-align:center;color:rgba(255,255,255,.7)}

@media (min-width:768px){
    .container{width:min(1240px,calc(100% - 52px))}
    .hero{padding-top:36px}
    .hero-grid,.page-hero-grid{grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr)}
    .surface-dark{padding:48px}
    .hero h1{font-size:4.9rem}
    .hero-lead{font-size:1.08rem}
    .hero-actions,.cta-actions{grid-template-columns:repeat(2,minmax(0,1fr))}
    .card-photo-large{min-height:620px}
    .intro-split,.split-head{grid-template-columns:minmax(0,1fr) minmax(0,.9fr);align-items:end}
    .feature-grid{grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);align-items:stretch}
    .listing-grid-premium{grid-template-columns:repeat(2,minmax(0,1fr))}
    .listing-card-featured{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,.9fr)}
    .listing-card-featured .listing-media{aspect-ratio:auto;height:100%}
    .experience-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
    .gallery-premium{grid-template-columns:minmax(0,1.4fr) minmax(0,.8fr);grid-template-rows:1fr 1fr}
    .gallery-main{grid-row:1 / span 2;height:100%}
    .ambient-grid{gap:16px}
    .detail-grid{grid-template-columns:minmax(0,1.35fr) minmax(360px,.78fr)}
    .footer-grid{grid-template-columns:1.3fr .9fr .9fr}
}


.premium-hero-home .hero-grid{align-items:stretch}
.hero-brand-panel{display:flex;flex-direction:column;justify-content:flex-end;min-height:100%}
.stack-blocks{display:grid;gap:22px}
.feature-block{display:grid;grid-template-columns:1fr;overflow:hidden}
.feature-block-media{min-height:320px;background:#ececec}
.feature-block-media img{width:100%;height:100%;object-fit:cover}
.feature-block-body{padding:24px 22px;display:flex;flex-direction:column;justify-content:center}
.feature-block-body h2{margin:0 0 12px;font-size:2rem;line-height:1.02;letter-spacing:-.03em}
.feature-block-body p{margin:0;color:var(--muted)}
.feature-block-body .btn{margin-top:22px;align-self:flex-start}
.feature-block-experiences{background:#0f0f10;color:#fff;border-color:#1d1d1d}
.feature-block-body-dark p{color:rgba(255,255,255,.76)}
.mini-label-light{color:rgba(255,255,255,.78)}
.terceira-experiences-grid{display:grid;grid-template-columns:1fr;gap:14px;padding:0 22px 22px}
.terceira-card{position:relative;display:block;min-height:220px;overflow:hidden;border-radius:24px;border:1px solid rgba(255,255,255,.1);background:#111}
.terceira-card img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease,filter .35s ease}
.terceira-card:hover img{transform:scale(1.03);filter:brightness(1.03)}
.terceira-card .card-overlay{background:linear-gradient(180deg,rgba(17,17,17,.05),rgba(17,17,17,.84))}
.terceira-card .card-overlay strong{font-size:1.05rem}

@media (min-width:768px){
    .site-logo{width:190px;max-width:none}
    .stack-blocks{gap:26px}
    .feature-block-accommodation{grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr)}
    .feature-block-experiences{grid-template-columns:minmax(360px,.78fr) minmax(0,1.22fr)}
    .feature-block-media{min-height:540px}
    .feature-block-body{padding:34px 34px}
    .terceira-experiences-grid{grid-template-columns:repeat(3,minmax(0,1fr));padding:34px 34px 34px 0;align-items:stretch}
    .terceira-card{min-height:460px}
}


@media (max-width:767px){
    .site-header{position:static}
    .header-inner{display:grid;grid-template-columns:1fr;justify-items:center;min-height:auto;padding:18px 0 18px;gap:16px}
    .logo-wrap{width:100%;justify-content:center}
    .site-logo{width:168px;max-width:64vw}
    .main-nav{width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
    .main-nav a{width:100%;min-height:54px;padding:0 16px;font-size:1rem}
    .lang-switch{width:100%;display:grid;grid-template-columns:repeat(4,58px);justify-content:center;gap:12px;padding-top:0}
    .lang-switch a{width:58px;min-width:58px;min-height:58px;height:58px;padding:0;border-radius:999px}
    .site-header .lang-switch:nth-of-type(n+2){display:none!important}
}

@media (min-width:768px){
    .header-inner{display:grid;grid-template-columns:auto 1fr auto;align-items:center}
    .site-logo{width:178px;max-width:none}
    .main-nav a{padding:12px 18px}
    .lang-switch{justify-self:end}
}

.accommodation-premium-stack{display:grid;gap:26px}
.accommodation-showcase{overflow:hidden;padding:0}
.accommodation-showcase-main{display:grid;grid-template-columns:1fr;gap:0}
.accommodation-showcase-copy{padding:26px 22px 22px}
.accommodation-showcase-copy h2{margin:0 0 12px;font-size:2.2rem;line-height:1.02;letter-spacing:-.04em}
.accommodation-showcase-copy p{margin:0;color:var(--muted);max-width:62ch}
.accommodation-showcase-hero{min-height:320px;background:#ececec}
.accommodation-showcase-hero img{width:100%;height:100%;object-fit:cover}
.accommodation-showcase-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:22px}
.accommodation-gallery-strip{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding:0 22px 22px}
.accommodation-gallery-thumb{aspect-ratio:1.15/1;border-radius:22px;overflow:hidden;background:#ececec}
.accommodation-gallery-thumb img{width:100%;height:100%;object-fit:cover}
.accommodation-highlight-pills{margin-top:18px}
.accommodation-premium-hero .page-hero-photo{aspect-ratio:16/11}
.accommodation-detail-hero .page-subtitle{max-width:62ch}
.detail-gallery-premium{display:grid;grid-template-columns:1fr;gap:16px}
.detail-gallery-main{aspect-ratio:16/10;overflow:hidden}
.detail-gallery-main img,.detail-gallery-thumb img{width:100%;height:100%;object-fit:cover}
.detail-gallery-side{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.detail-gallery-thumb{aspect-ratio:1/1;overflow:hidden}
.detail-hero-pills span{background:#fff;border-color:rgba(17,17,17,.12)}

@media (min-width:768px){
    .accommodation-showcase-main{grid-template-columns:minmax(0,.88fr) minmax(0,1.12fr);align-items:stretch}
    .accommodation-showcase-copy{padding:34px 34px 28px}
    .accommodation-showcase-hero{min-height:520px}
    .accommodation-gallery-strip{grid-template-columns:repeat(5,minmax(0,1fr));padding:0 34px 34px}
    .detail-gallery-premium{grid-template-columns:minmax(0,1.5fr) minmax(0,.95fr)}
    .detail-gallery-main{height:100%}
    .detail-gallery-side{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:1fr}
}


.card-premium:hover,
.listing-card:hover,
.detail-card:hover,
.experience-card:hover{
    transform:translateY(-2px);
    box-shadow:0 20px 48px rgba(0,0,0,.08);
    border-color:rgba(17,17,17,.12);
}

.booking-form input:focus,
.booking-form select:focus,
.booking-form textarea:focus{
    outline:none;
    border-color:#111;
    box-shadow:0 0 0 4px rgba(17,17,17,.06);
}

.footer-links a:hover{
    opacity:1;
    transform:translateX(2px);
}

.footer-copy,
.footer-links,
.footer-bottom{
    line-height:1.7;
}

@media (max-width:767px){
    .page-title{font-size:2.15rem}
    .section{padding:34px 0}
}




/* Casa Milhafre header clean */
.header-inner-clean{
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:18px;
    padding:18px 0 20px;
}
.header-logo-center{
    display:flex;
    justify-content:center;
    width:100%;
}
.header-logo-center .site-logo{
    width:190px;
    max-width:72vw;
    height:auto;
    margin:0 auto;
}
.header-lang-single{
    display:flex;
    flex-wrap:wrap;
    justify-content:center;
    gap:10px;
    width:100%;
}
.header-nav-clean{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
    width:100%;
    max-width:780px;
}
.header-nav-clean a,
.main-nav.header-nav-clean a{
    display:flex;
    align-items:center;
    justify-content:center;
    min-height:44px;
    padding:0 8px;
    border:0 !important;
    border-radius:0 !important;
    background:transparent !important;
    box-shadow:none !important;
    color:#151515;
    font-size:1.02rem;
    font-weight:700;
    text-align:center;
    line-height:1.35;
    white-space:normal;
    text-decoration:none !important;
}
.header-nav-clean a.active,
.header-nav-clean a:hover,
.main-nav.header-nav-clean a.active,
.main-nav.header-nav-clean a:hover{
    background:transparent !important;
    color:#111 !important;
    text-decoration:none !important;
}
.header-lang-single a{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:48px;
    min-height:48px;
    padding:0 16px;
    border-radius:999px;
    font-size:1rem;
    font-weight:600;
    background:#fff;
    border:1px solid #e6e6e6;
    color:#151515;
    text-decoration:none !important;
}
.header-lang-single a.active,
.header-lang-single a:hover{
    background:#111;
    color:#fff;
    border-color:#111;
}
.header-nav-clean a::before,
.header-nav-clean a::after,
.main-nav a::before,
.main-nav a::after{
    content:none !important;
    display:none !important;
}

@media (max-width:767px){
    .site-header{position:relative;box-shadow:none;padding:0}
    .header-inner-clean .main-nav,
    .main-nav.header-nav-clean{width:100%;justify-content:initial}
}

@media (min-width:768px){
    .header-inner-clean{
        display:grid;
        grid-template-columns:auto 1fr auto;
        align-items:center;
        gap:18px;
        padding:14px 0;
    }
    .header-logo-center{
        justify-content:flex-start;
        width:auto;
    }
    .header-logo-center .site-logo{
        width:178px;
        max-width:none;
    }
    .header-nav-clean{
        display:flex;
        justify-content:center;
        flex-wrap:wrap;
        gap:28px;
        max-width:none;
    }
    .header-nav-clean a{
        display:inline-flex;
        align-items:center;
        justify-content:center;
        min-height:auto;
        padding:0;
        border-radius:0 !important;
        font-size:1rem;
        font-weight:700;
        background:transparent !important;
        border:none !important;
        color:#151515;
        box-shadow:none !important;
    }
    .header-nav-clean a.active,
    .header-nav-clean a:hover{
        background:transparent !important;
        color:#111 !important;
        border:none !important;
        box-shadow:none !important;
    }
    .header-lang-single{
        width:auto;
        justify-content:flex-end;
    }
}
