/* ===========================================================
   NVT A Wonderful World Eterna — theme "Estate Ivory"
   White background, elegant beige, brown highlight. High contrast.
   =========================================================== */
@font-face{font-family:'Inter';font-style:normal;font-weight:300;font-display:swap;src:url('../fonts/inter-latin-300-normal.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/inter-latin-400-normal.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/inter-latin-500-normal.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/inter-latin-600-normal.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/inter-latin-700-normal.woff2') format('woff2')}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/playfair-display-latin-500-normal.woff2') format('woff2')}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/playfair-display-latin-600-normal.woff2') format('woff2')}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/playfair-display-latin-700-normal.woff2') format('woff2')}

:root{
  --bg:#FFFFFF;            /* page background — white */
  --beige:#F4EDE1;         /* warm beige sections */
  --beige-2:#EDE3D2;       /* deeper beige */
  --sand:#FBF8F2;          /* card surface */
  --ink:#201B15;           /* text (~14:1 on white) */
  --muted:#5E564A;         /* muted text (~6.4:1 on white) */
  --line:#E7DDCB;          /* warm hairline */
  --brown:#8A5A34;         /* accent brown */
  --brown-mid:#7A4E2E;     /* eyebrows / table head / CTA */
  --brown-deep:#5A3A1F;    /* links / strong accents (~8.5:1) */
  --brown-bright:#A9743F;  /* hover / decorative */
  --espresso:#2A2017;      /* dark bands + footer */
  --cream:#F6EFE3;         /* text on dark */
  --muted-d:#CABCA6;       /* muted text on dark */
  --line-d:rgba(214,178,128,.26);
  --maxw:1160px;--r:10px;
  --shadow:0 1px 2px rgba(42,32,23,.05),0 16px 40px -20px rgba(42,32,23,.26);
  --shadow-sm:0 1px 2px rgba(42,32,23,.05),0 8px 22px -16px rgba(42,32,23,.24);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation:none!important;transition:none!important}}
body{margin:0;font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--bg);line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;height:auto;display:block}
a{color:var(--brown-deep);text-decoration:none}
/* Prose links get underline so they don't rely on color alone (WCAG 1.4.1) */
p a,li a,.article a,.aeo a,.faq a,.loc-grid a,.pc a,.foot-disc a{text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
p a:hover,li a:hover,.article a:hover{text-decoration-thickness:2px}
a:hover{color:var(--brown-bright)}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;font-weight:600;line-height:1.14;color:var(--ink);margin:0 0 .5em}
h1{font-size:clamp(2.1rem,5.2vw,3.45rem);letter-spacing:-.01em}
h2{font-size:clamp(1.6rem,3.6vw,2.45rem)}
h3{font-size:1.3rem}
p{margin:0 0 1rem}
:focus-visible{outline:3px solid var(--brown);outline-offset:2px;border-radius:4px}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:72px 0}
.section--tight{padding:52px 0}
.eyebrow{font-family:'Inter';font-weight:700;font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brown-mid);margin:0 0 .9rem;display:flex;align-items:center;gap:.6rem}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--brown);display:inline-block}
.lede{font-size:1.12rem;color:var(--muted);max-width:62ch}

/* dark / light bands */
.band{background:var(--beige)}
.band--deep{background:var(--espresso);color:var(--cream)}
.band--deep h2,.band--deep h3,.band--deep h4{color:#fff}
.band--deep .lede{color:var(--muted-d)}
.band--deep a{color:#E4C49A}
.band--deep .eyebrow{color:#E4C49A}
.band--deep .eyebrow::before{background:#E4C49A}

/* header — white, elegant */
.site-head{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.94);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:12px;max-width:var(--maxw);margin:0 auto;padding:12px 22px;flex-wrap:nowrap}
.brand{display:flex;align-items:center;gap:11px;margin-right:auto;color:var(--ink)}
.brand:hover{color:var(--ink)}
.brand .mark{width:36px;height:36px;flex:0 0 36px}
.brand b{font-family:'Playfair Display',serif;font-weight:700;font-size:1.06rem;letter-spacing:.01em;display:block;line-height:1.1;color:var(--ink)}
.brand small{display:block;font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brown-mid);font-weight:700}
.nav-links{display:flex;gap:2px;align-items:center}
.nav-links a{color:var(--ink);font-size:.9rem;font-weight:500;padding:8px 10px;border-radius:7px}
.nav-links a:hover{color:var(--brown-deep);background:var(--beige)}
.nav-links a[aria-current="page"]{color:var(--brown-deep);font-weight:600}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:'Inter';font-weight:600;font-size:.95rem;padding:12px 22px;border-radius:8px;border:1px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease;text-align:center}
.btn--gold{background:var(--brown-mid);color:#fff;box-shadow:0 8px 20px -10px rgba(122,78,46,.55)}
.btn--gold:hover{background:var(--brown-deep);color:#fff;transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--brown-deep);border-color:var(--brown)}
.btn--ghost:hover{background:var(--beige);color:var(--brown-deep);border-color:var(--brown-deep)}
.btn--lg{padding:15px 30px;font-size:1.02rem}
.nav .btn{padding:11px 22px;margin-left:10px;flex:0 0 auto;font-weight:700;box-shadow:0 6px 16px -8px rgba(122,78,46,.6)}
.nav-links .btn--gold{color:#fff}
.burger{display:none;background:none;border:1px solid var(--line);border-radius:8px;width:42px;height:40px;cursor:pointer;color:var(--ink);font-size:1.2rem}
.band--deep .btn--ghost,.cta-band .btn--ghost,.hero-banner .btn--ghost{color:#fff;border-color:rgba(255,255,255,.5)}
.band--deep .btn--ghost:hover,.cta-band .btn--ghost:hover{background:rgba(255,255,255,.12);color:#fff}

@media(max-width:1080px){
  .nav-links{position:fixed;inset:62px 0 auto 0;flex-direction:column;align-items:stretch;background:#fff;padding:10px 16px 18px;gap:2px;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .25s ease;max-height:calc(100vh - 62px);overflow:auto;box-shadow:var(--shadow)}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{padding:13px 12px;font-size:1rem;border-radius:8px}
  .nav-links .btn{margin-top:8px;margin-left:0}
  .burger{display:inline-flex;align-items:center;justify-content:center}
}

/* hero — light, high contrast */
.hero{background:var(--beige)}
.hero-inner{max-width:var(--maxw);margin:0 auto;padding:60px 22px 56px;display:grid;grid-template-columns:1.1fr .9fr;gap:46px;align-items:center}
.hero h1{margin-bottom:.32em}
.hero .sub{color:var(--muted);font-size:1.14rem;max-width:52ch}
.hero .meta{display:flex;flex-wrap:wrap;gap:10px;margin:22px 0 8px}
.chip{display:inline-flex;align-items:center;gap:7px;font-size:.86rem;font-weight:500;color:var(--ink);background:#fff;border:1px solid var(--line);padding:7px 13px;border-radius:50px}
.chip b{color:var(--brown-deep);font-weight:700}
.hero-banner{padding:0}
.hero-banner .wrap{padding-top:0}
.hero-banner img{width:100%;height:clamp(260px,42vw,460px);object-fit:cover;border-radius:14px;box-shadow:var(--shadow);margin-top:-26px}

.lead-card{background:#fff;color:var(--ink);border-radius:14px;padding:26px 24px;box-shadow:var(--shadow);border:1px solid var(--line)}
.lead-card h2{font-size:1.4rem;margin-bottom:.15em}
.lead-card .sm{font-size:.9rem;color:var(--muted);margin-bottom:16px}
.field{margin-bottom:12px}
.field label{display:block;font-size:.8rem;font-weight:600;color:var(--brown-deep);margin-bottom:5px}
.field input,.field textarea{width:100%;font-family:inherit;font-size:.97rem;padding:11px 13px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--brown);box-shadow:0 0 0 3px rgba(138,90,52,.16)}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{font-size:.76rem;color:var(--muted);margin-top:10px}
.form-msg{font-size:.92rem;margin-top:10px;font-weight:600}
@media(max-width:860px){.hero-inner{grid-template-columns:1fr;gap:30px;padding:42px 22px 44px}.hero-banner img{margin-top:0}}

/* USP */
.usp{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--sand)}
.usp div{padding:24px 22px;border-right:1px solid var(--line)}
.usp div:last-child{border-right:none}
.usp .n{font-family:'Playfair Display',serif;font-size:1.9rem;color:var(--brown);line-height:1}
.usp .l{font-size:.86rem;color:var(--muted);margin-top:6px}
@media(max-width:760px){.usp{grid-template-columns:1fr 1fr}.usp div:nth-child(2){border-right:none}.usp div:nth-child(1),.usp div:nth-child(2){border-bottom:1px solid var(--line)}}

.aeo{background:var(--sand);border:1px solid var(--line);border-left:4px solid var(--brown);border-radius:var(--r);padding:24px 26px;box-shadow:var(--shadow-sm)}
.aeo p:last-child{margin-bottom:0}

.grid{display:grid;gap:22px}
.g2{grid-template-columns:1fr 1fr}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:860px){.g3,.g4{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.g2,.g3,.g4{grid-template-columns:1fr}}
.card{background:var(--sand);border:1px solid var(--line);border-radius:var(--r);padding:24px;box-shadow:var(--shadow-sm);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;position:relative}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--brown)}
.card .ic{font-size:1.7rem;line-height:1;margin-bottom:12px}
.card h3{font-size:1.18rem;margin-bottom:.4em}
.card ul{margin:.4rem 0 0;padding-left:1.1rem;color:var(--muted);font-size:.95rem}
.card ul li{margin-bottom:.3rem}
/* cards inside light beige bands stay white */
.band .card{background:#fff}
/* cards inside deep bands go brown */
.band--deep .card{background:#3A2C1F;border-color:var(--line-d)}
.band--deep .card h3{color:#fff}.band--deep .card ul,.band--deep .card p{color:var(--muted-d)}
.band--deep .card:hover{border-color:var(--brown-bright)}

.tbl-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm)}
table.data{width:100%;border-collapse:collapse;font-size:.96rem;background:var(--sand);min-width:560px}
table.data caption{text-align:left;padding:14px 18px;font-weight:600;color:var(--muted);font-size:.85rem;background:var(--sand)}
table.data th,table.data td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--line)}
table.data thead th{background:var(--brown-mid);color:#fff;font-weight:600;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;border-bottom:none}
table.data tbody tr:last-child td{border-bottom:none}
table.data tbody tr:nth-child(even){background:rgba(138,90,52,.05)}
table.data td b{color:var(--ink)}
.hl{color:var(--brown-deep);font-weight:700}

/* villa selector */
.vsel{background:var(--sand);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}
.vtabs{display:flex;flex-wrap:wrap;gap:0;background:var(--espresso)}
.vtabs button{flex:1;min-width:90px;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--muted-d);font-family:'Inter';font-weight:600;font-size:.95rem;padding:15px 10px;cursor:pointer;transition:color .15s,border-color .15s}
.vtabs button:hover{color:#fff}
.vtabs button.on{color:#E4C49A;border-bottom-color:var(--brown-bright)}
.vbody{display:grid;grid-template-columns:1.25fr 1fr;gap:0}
.vplan{background:#fff;border-right:1px solid var(--line);padding:18px;display:flex;align-items:center;justify-content:center}
.vplan img{border-radius:8px}
.vspec{padding:26px 28px}
.vspec h3{font-size:1.5rem;margin-bottom:.1em}
.vspec .price{font-family:'Playfair Display',serif;font-size:1.7rem;color:var(--brown);margin:.1em 0 .6em}
.vspec dl{display:grid;grid-template-columns:auto 1fr;gap:8px 18px;margin:0 0 18px;font-size:.95rem}
.vspec dt{color:var(--muted);font-weight:500}
.vspec dd{margin:0;font-weight:600;color:var(--ink);text-align:right}
.vspec .rooms{font-size:.86rem;color:var(--muted);border-top:1px dashed var(--line);padding-top:12px}
@media(max-width:760px){.vbody{grid-template-columns:1fr}.vplan{border-right:none;border-bottom:1px solid var(--line)}}
.vplan-na{text-align:center;color:var(--muted);max-width:330px;padding:30px 18px}
.vplan-na svg{color:var(--brown);opacity:.75;margin:0 auto 8px}
.vplan-na .t{font-size:1.08rem;color:var(--ink);margin:.3rem 0 .3rem;font-weight:600}
.vplan-na .t b{color:var(--brown-deep)}
.vplan-na .d{font-size:.9rem;margin:0 0 16px}

.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gal button{padding:0;border:none;border-radius:var(--r);overflow:hidden;cursor:pointer;background:none;aspect-ratio:4/3;box-shadow:var(--shadow-sm)}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.gal button:hover img{transform:scale(1.05)}
@media(max-width:600px){.gal{grid-template-columns:1fr 1fr}}
.lightbox{position:fixed;inset:0;background:rgba(32,27,21,.92);display:none;align-items:center;justify-content:center;z-index:200;padding:20px}
.lightbox.on{display:flex}
.lightbox img{max-width:94vw;max-height:88vh;border-radius:8px}
.lightbox .x{position:absolute;top:18px;right:22px;background:none;border:none;color:#fff;font-size:2.4rem;cursor:pointer;line-height:1}

.loc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
@media(max-width:760px){.loc-grid{grid-template-columns:1fr}}
.loc-grid h3{display:flex;align-items:center;gap:.5rem;font-size:1.1rem}
.loc-grid ul{list-style:none;margin:0;padding:0}
.loc-grid li{display:flex;justify-content:space-between;gap:14px;padding:9px 0;border-bottom:1px solid var(--line);font-size:.95rem}
.loc-grid li span:last-child{color:var(--brown-deep);font-weight:600;white-space:nowrap}

.faq details{background:var(--sand);border:1px solid var(--line);border-radius:var(--r);margin-bottom:12px;overflow:hidden}
.faq summary{cursor:pointer;padding:18px 22px;font-weight:600;color:var(--ink);list-style:none;display:flex;justify-content:space-between;gap:14px;align-items:center;font-size:1.02rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--brown);font-size:1.5rem;font-weight:400;line-height:1;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details > div{padding:0 22px 20px;color:var(--muted);font-size:.97rem}
.faq details > div p:last-child{margin-bottom:0}

.pc{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media(max-width:600px){.pc{grid-template-columns:1fr}}
.pc .card h3{display:flex;align-items:center;gap:.5rem}
.pc ul{list-style:none;padding:0;margin:.4rem 0 0}
.pc li{padding:7px 0 7px 26px;position:relative;font-size:.95rem;color:var(--muted);border:none}
.pc .pro li::before{content:"✓";position:absolute;left:0;color:#2E7D55;font-weight:700}
.pc .con li::before{content:"!";position:absolute;left:2px;color:var(--brown);font-weight:700}

.cta-band{text-align:center;background:var(--espresso);color:var(--cream)}
.cta-band h2{color:#fff;max-width:20ch;margin:0 auto .4em}
.cta-band .lede{color:var(--muted-d);margin:0 auto 26px}
.cta-band .eyebrow{color:#E4C49A}
.cta-band .lead-card{text-align:left}
.cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

.hub-card{background:#3A2C1F;border:1px solid var(--line-d);border-radius:var(--r);padding:24px;color:var(--cream);display:block;transition:transform .18s,border-color .18s}
.hub-card:hover{transform:translateY(-3px);border-color:var(--brown-bright);color:var(--cream)}
.hub-card .k{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#E4C49A;font-weight:700}
.hub-card h3{color:#fff;font-size:1.2rem;margin:.5em 0 .3em}
.hub-card p{color:var(--muted-d);font-size:.93rem;margin:0}
.hub-card .more{color:#E4C49A;font-weight:600;font-size:.9rem;margin-top:14px;display:inline-block}

.crumb{font-size:.85rem;color:var(--muted);padding:18px 0 0}
.crumb a{color:var(--muted)}.crumb a:hover{color:var(--brown)}
.crumb span{color:var(--ink);font-weight:600}
.band--deep .crumb,.band--deep .crumb a{color:var(--muted-d)}

.article{max-width:760px;margin:0 auto}
.article h2{margin-top:1.6em}
.article h3{margin-top:1.4em;color:var(--brown-deep)}
.article p,.article li{font-size:1.05rem}
.article ul,.article ol{padding-left:1.3rem;margin:0 0 1.2rem}
.article li{margin-bottom:.5rem}
.article .callout{background:var(--beige);border-left:4px solid var(--brown);border-radius:8px;padding:16px 20px;margin:1.4rem 0;font-size:.98rem;color:var(--muted)}
.article .meta-line{font-size:.85rem;color:var(--muted);margin-bottom:1.5rem;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.article .tag-pill{background:rgba(138,90,52,.14);color:var(--brown-deep);padding:3px 11px;border-radius:50px;font-weight:600;font-size:.78rem}

.site-foot{background:var(--espresso);color:var(--muted-d);padding:54px 0 30px;font-size:.92rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px;margin-bottom:34px}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr;gap:26px}}
.site-foot .foot-head{color:#fff;font-family:'Inter';font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;margin:0 0 14px;font-weight:700;display:block}
.site-foot a{color:#CABCA6;display:block;padding:4px 0}
.site-foot a:hover{color:#E4C49A}
.foot-brand b{font-family:'Playfair Display',serif;color:#fff;font-size:1.2rem}
.foot-disc{border-top:1px solid var(--line-d);padding-top:22px;font-size:.78rem;color:#B8AA96;line-height:1.6}
.foot-disc a{display:inline;color:#F0D4A0;text-decoration:underline;text-underline-offset:3px}

.mcta{position:fixed;left:0;right:0;bottom:0;z-index:80;display:none;gap:10px;padding:10px 14px;background:rgba(255,255,255,.97);border-top:1px solid var(--line);backdrop-filter:blur(6px);box-shadow:0 -8px 24px -16px rgba(42,32,23,.4)}
.mcta .btn{flex:1}
@media(max-width:760px){.mcta{display:flex}body{padding-bottom:74px}}

.center{text-align:center}.mt0{margin-top:0}.muted{color:var(--muted)}
.divider{height:1px;background:var(--line);border:none;margin:0}
.tagline-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:10px}
.verified{font-size:.82rem;color:var(--muted);display:inline-flex;align-items:center;gap:6px}
.verified b{color:var(--brown-deep)}
