/* Ubuntu Villas — variant_2 — editorial boutique system */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Inter:wght@300;400;500;600&display=swap');

:root{
  --paper:#f6f2ea; --paper-2:#ede6d7; --paper-3:#e0d8c4;
  --ink:#1c1c1a; --ink-soft:#494640; --ink-mute:#8a847a;
  --rule:#d6cdba; --rule-soft:#e3dccb;
  --accent:#6c7a5b; --accent-deep:#4a5640; --accent-soft:#b6bea4;
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,sans-serif;
  --gutter:clamp(20px,4vw,56px); --max:1320px;
  --section:clamp(72px,11vw,160px);
  --ease:cubic-bezier(.2,.7,.2,1);
}
[data-accent="gold"]{--accent:#a08439;--accent-deep:#6b561e;--accent-soft:#d8c08b}
[data-accent="terracotta"]{--accent:#a8624a;--accent-deep:#793f2c;--accent-soft:#d8a48f}
[data-accent="teal"]{--accent:#3d6062;--accent-deep:#244043;--accent-soft:#8eaeaf}
[data-accent="ink"]{--accent:#1c1c1a;--accent-deep:#000;--accent-soft:#a8a299}
[data-type="modern"]{--serif:"Fraunces",Georgia,serif}
[data-type="classic"]{--serif:"EB Garamond",Georgia,serif}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
::selection{background:var(--accent);color:var(--paper)}

h1,h2,h3,h4{font-family:var(--serif);font-weight:400;letter-spacing:-0.01em;line-height:1.05;margin:0;text-wrap:balance}
h1{font-size:clamp(54px,9vw,140px);letter-spacing:-0.025em;line-height:0.95}
h2{font-size:clamp(36px,5vw,72px);letter-spacing:-0.015em}
h3{font-size:clamp(26px,3vw,40px)}
h4{font-size:clamp(20px,2vw,26px);line-height:1.2}
p{margin:0 0 1em;text-wrap:pretty;max-width:62ch;color:var(--ink-soft)}
em{font-style:italic}
.lead{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(20px,2.2vw,30px);line-height:1.4;color:var(--ink-soft);max-width:32ch}
.eyebrow{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent-deep);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:24px;height:1px;background:currentColor}
.eyebrow.muted{color:var(--ink-mute)}
.eyebrow.on-dark{color:rgba(246,242,234,.85)}

.wrap{max-width:var(--max);margin:0 auto;padding-inline:var(--gutter)}
.wrap-w{max-width:1600px;margin:0 auto;padding-inline:var(--gutter)}
.section{padding-block:var(--section)}
.section-tight{padding-block:clamp(48px,6vw,88px)}
.rule{border:0;height:1px;background:var(--rule);margin:0}

.btn{display:inline-flex;align-items:center;gap:12px;padding:15px 26px;font-size:11.5px;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;white-space:nowrap;border:1px solid var(--ink);color:var(--ink);background:transparent;border-radius:999px;transition:background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease),gap .3s var(--ease)}
.btn:hover{background:var(--ink);color:var(--paper);gap:18px}
.btn--solid{background:var(--ink);color:var(--paper)}
.btn--solid:hover{background:var(--accent-deep);border-color:var(--accent-deep)}
.btn--accent{background:var(--accent);color:var(--paper);border-color:var(--accent)}
.btn--accent:hover{background:var(--accent-deep);border-color:var(--accent-deep)}
.btn--inverse{border-color:var(--paper);color:var(--paper)}
.btn--inverse:hover{background:var(--paper);color:var(--ink)}
.link-arrow{display:inline-flex;align-items:center;gap:10px;font-size:12px;letter-spacing:0.18em;text-transform:uppercase;font-weight:500;border-bottom:1px solid currentColor;padding-bottom:4px;transition:gap .25s var(--ease),color .25s var(--ease)}
.link-arrow:hover{gap:16px;color:var(--accent-deep)}

/* Image well — every photo wrapped here; tasteful placeholder if missing */
.img{position:relative;overflow:hidden;background:var(--paper-2);isolation:isolate}
.img::before{content:"";position:absolute;inset:0;z-index:0;background:radial-gradient(120% 80% at 30% 20%,rgba(255,255,255,.55),transparent 60%),radial-gradient(80% 60% at 80% 90%,var(--accent-soft),transparent 70%),linear-gradient(160deg,var(--paper-2),var(--paper-3))}
.img > img{position:relative;z-index:2;width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease),opacity .5s var(--ease)}
.img.zoom:hover > img{transform:scale(1.04)}
.img__label{position:absolute;left:14px;bottom:12px;z-index:3;font-family:var(--serif);font-style:italic;font-size:13px;color:var(--ink-soft);background:rgba(246,242,234,.7);padding:4px 10px;border:1px solid var(--rule-soft)}
.img--dark::before{background:linear-gradient(160deg,#2c2a26,#3a342a)}
.img--dark .img__label{color:var(--paper);background:rgba(28,28,26,.5);border-color:rgba(255,255,255,.15)}
.r-3-4{aspect-ratio:3/4}.r-4-5{aspect-ratio:4/5}.r-1-1{aspect-ratio:1/1}
.r-3-2{aspect-ratio:3/2}.r-4-3{aspect-ratio:4/3}.r-2-3{aspect-ratio:2/3}
.r-16-9{aspect-ratio:16/9}.r-21-9{aspect-ratio:21/9}

/* Header */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;padding:18px 0;color:var(--paper);transition:background .35s var(--ease),padding .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease);border-bottom:1px solid transparent}
.site-header.solid,.site-header.scrolled{background:rgba(246,242,234,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);color:var(--ink);padding:12px 0;border-bottom-color:var(--rule-soft)}
.nav{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px}
.nav__brand{display:inline-flex;align-items:center;gap:12px;font-family:var(--serif);font-size:22px}
.nav__brand .glyph{width:32px;height:32px;border:1px solid currentColor;border-radius:50%;display:grid;place-items:center;font-style:italic;font-size:17px;line-height:1}
.nav__brand .word{display:flex;flex-direction:column;line-height:1;white-space:nowrap}
.nav__brand .word b{font-weight:400;font-size:18px;letter-spacing:0.04em}
.nav__brand .word small{font-family:var(--sans);font-size:9px;font-weight:500;letter-spacing:0.32em;text-transform:uppercase;margin-top:5px;opacity:0.72}
.nav__menu{display:flex;gap:36px;justify-self:center;font-size:12px;letter-spacing:0.16em;text-transform:uppercase;font-weight:500}
.nav__menu a{position:relative;padding:6px 0;opacity:0.85;white-space:nowrap}
.nav__menu a:hover,.nav__menu a.active{opacity:1}
.nav__menu a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:currentColor;transition:right .3s var(--ease)}
.nav__menu a:hover::after,.nav__menu a.active::after{right:0}
.nav__cta{justify-self:end;display:inline-flex;align-items:center;gap:14px}
.nav__cta .btn{padding:10px 18px;font-size:10.5px}
@media(max-width:880px){.nav{grid-template-columns:1fr auto}.nav__menu{display:none}}

/* Home hero */
.hero{position:relative;min-height:100svh;display:grid;align-items:end;color:var(--paper);overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media .img{width:100%;height:100%}
.hero__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.45) 0%,transparent 30%,transparent 55%,rgba(0,0,0,.55) 100%);pointer-events:none}
.hero__inner{position:relative;z-index:2;display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:end;padding-block:140px 64px}
.hero__title{font-size:clamp(56px,9.4vw,156px);line-height:0.94;letter-spacing:-0.03em;max-width:14ch}
.hero__title em{color:var(--accent-soft)}
.hero__meta{border-left:1px solid rgba(246,242,234,.3);padding-left:24px;max-width:380px}
.hero__meta p{color:rgba(246,242,234,.88);margin-top:14px}
.hero__meta .actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}
.hero__loc{position:absolute;top:110px;left:0;right:0;display:flex;justify-content:space-between;padding-inline:var(--gutter);font-size:11px;letter-spacing:0.24em;text-transform:uppercase;color:rgba(246,242,234,.85);z-index:2}
.hero__scroll{position:absolute;left:var(--gutter);bottom:32px;z-index:3;font-size:10px;letter-spacing:0.3em;text-transform:uppercase;display:inline-flex;align-items:center;gap:14px;color:rgba(246,242,234,.85)}
.hero__scroll::after{content:"";width:1px;height:32px;background:currentColor;animation:scrollPulse 2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{transform:scaleY(.4);transform-origin:top;opacity:.4}50%{transform:scaleY(1);opacity:1}}
@media(max-width:880px){.hero__inner{grid-template-columns:1fr;gap:24px;padding-block:120px 56px}.hero__loc{display:none}}

/* Marquee */
.marquee{border-block:1px solid var(--rule);overflow:hidden;background:var(--paper)}
.marquee__track{display:flex;gap:60px;align-items:center;padding-block:18px;white-space:nowrap;font-family:var(--serif);font-style:italic;font-size:clamp(22px,2.6vw,30px);color:var(--ink-soft);animation:marq 60s linear infinite}
.marquee__track .dot{width:5px;height:5px;background:var(--accent);border-radius:50%;display:inline-block}
@keyframes marq{to{transform:translateX(-50%)}}

/* Philosophy */
.philosophy{display:grid;grid-template-columns:1fr 1.3fr;gap:clamp(40px,6vw,96px);align-items:start}
.philosophy h2{max-width:14ch}
.philosophy h2 em{color:var(--accent-deep)}
.philosophy__body p{font-size:clamp(16px,1.4vw,18px);max-width:54ch}
.philosophy__quote{font-family:var(--serif);font-style:italic;font-size:clamp(26px,3.4vw,42px);line-height:1.18;margin:32px 0 0;padding:24px 0 0;border-top:1px solid var(--rule);max-width:24ch;color:var(--accent-deep)}
@media(max-width:760px){.philosophy{grid-template-columns:1fr;gap:32px}}

/* Villa rows (homepage) */
.villas{display:flex;flex-direction:column;gap:clamp(80px,10vw,160px)}
.villa-row{display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(36px,5vw,80px);align-items:center}
.villa-row.reverse{grid-template-columns:1fr 1.15fr}
.villa-row.reverse .villa-row__media{order:2}
.villa-row__media{position:relative}
.villa-row__media .img{aspect-ratio:4/5}
.villa-row__num{position:absolute;top:14px;left:18px;z-index:4;font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(40px,5vw,72px);color:var(--paper);text-shadow:0 2px 16px rgba(0,0,0,.5);line-height:1}
.villa-row__copy{display:flex;flex-direction:column;gap:18px;max-width:36rem}
.villa-row__title{font-size:clamp(36px,4.6vw,68px)}
.villa-row__title em{color:var(--accent-deep)}
.villa-row__meta{display:flex;flex-wrap:wrap;gap:18px 28px;margin:8px 0 16px;padding:14px 0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);font-size:11.5px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-mute)}
.villa-row__meta strong{font-weight:500;color:var(--ink);font-family:var(--sans);font-size:13px;letter-spacing:0;text-transform:none;display:block;margin-top:2px}
.villa-row__meta > div{display:flex;flex-direction:column}
@media(max-width:880px){.villa-row,.villa-row.reverse{grid-template-columns:1fr;gap:24px}.villa-row.reverse .villa-row__media{order:0}.villa-row__media .img{aspect-ratio:4/3}}

/* Stats strip */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:48px;padding-block:clamp(56px,7vw,96px);border-block:1px solid var(--rule)}
.stats div{display:flex;flex-direction:column;gap:8px}
.stats .num{font-family:var(--serif);font-size:clamp(40px,5vw,72px);line-height:1;color:var(--ink)}
.stats .lbl{font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-mute)}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr);gap:32px}}

/* Map block */
.map{display:grid;grid-template-columns:1fr 1.3fr;gap:clamp(40px,5vw,80px);align-items:center}
.map__body h2{max-width:14ch}
.map__list{margin-top:28px;display:flex;flex-direction:column}
.map__list li{list-style:none;display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;padding:18px 0;border-bottom:1px solid var(--rule);font-size:13px;letter-spacing:0.04em}
.map__list li:first-child{border-top:1px solid var(--rule)}
.map__list .num{font-family:var(--serif);font-style:italic;color:var(--accent-deep);font-size:18px}
.map__list .name{font-family:var(--serif);font-size:22px;color:var(--ink)}
.map__list .dist{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-mute)}
.map__svg{aspect-ratio:4/3;background:var(--paper-2);border:1px solid var(--rule);position:relative;overflow:hidden}
@media(max-width:880px){.map{grid-template-columns:1fr}}

/* Footer */
.footer{background:#1a1a18;color:#e8e2d3;padding:80px 0 40px}
.footer .grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:48px;align-items:start}
.footer h4{font-size:18px;color:#fff;margin-bottom:16px}
.footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-size:13px;color:#a8a195}
.footer ul a:hover{color:#fff}
.footer .brand-block .word small{color:#85807a}
.footer__bottom{margin-top:64px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:#85807a}
@media(max-width:760px){.footer .grid{grid-template-columns:1fr 1fr;gap:32px}}

/* Villa page hero */
.hero-villa{position:relative;height:88svh;min-height:560px;max-height:840px;color:var(--paper);overflow:hidden}
.hero-villa .img{position:absolute;inset:0}
.hero-villa::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.32),transparent 35%,transparent 55%,rgba(0,0,0,.6))}
.hero-villa__inner{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding-block:140px clamp(40px,6vw,80px)}
.hero-villa__head{display:flex;align-items:center;gap:14px;margin-bottom:18px;font-size:11px;letter-spacing:0.24em;text-transform:uppercase;color:rgba(246,242,234,.85)}
.hero-villa__num{font-family:var(--serif);font-style:italic;font-size:22px}
.hero-villa__title{font-size:clamp(48px,8.6vw,124px);line-height:0.95;letter-spacing:-0.025em;max-width:16ch}
.hero-villa__title em{color:var(--accent-soft)}
.hero-villa__meta{display:flex;flex-wrap:wrap;gap:14px 36px;margin-top:28px;padding-top:18px;border-top:1px solid rgba(246,242,234,.35);font-size:12px;letter-spacing:0.18em;text-transform:uppercase;color:rgba(246,242,234,.88)}

/* Villa page intro */
.intro{display:grid;grid-template-columns:1fr 1.3fr;gap:clamp(40px,6vw,96px);align-items:start}
.intro__label{position:sticky;top:120px}
.intro__body p{font-size:clamp(17px,1.4vw,19px);color:var(--ink-soft)}
.intro__body p + p{margin-top:1em}
.intro__body .lead{margin-bottom:1.2em}
@media(max-width:880px){.intro{grid-template-columns:1fr}.intro__label{position:static}}

/* Feature grid (asymmetric editorial) */
.feature-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.feature-grid .img{min-height:240px}
.fg-1{grid-column:1/8;aspect-ratio:4/3}
.fg-2{grid-column:8/13;aspect-ratio:3/4}
.fg-3{grid-column:1/5;aspect-ratio:1/1}
.fg-4{grid-column:5/9;aspect-ratio:1/1}
.fg-5{grid-column:9/13;aspect-ratio:1/1}
.fg-6{grid-column:1/8;aspect-ratio:3/2}
.fg-7{grid-column:8/13;aspect-ratio:3/4;align-self:center}
@media(max-width:880px){.feature-grid{grid-template-columns:repeat(2,1fr)}.fg-1,.fg-2,.fg-3,.fg-4,.fg-5,.fg-6,.fg-7{grid-column:auto;aspect-ratio:4/3}.fg-1,.fg-6{grid-column:1/-1}}

/* Amenities list */
.amenities{display:grid;grid-template-columns:1fr 2fr;gap:clamp(40px,6vw,96px)}
.amenity-cols{display:grid;grid-template-columns:repeat(2,1fr);gap:32px 64px}
.amenity-col h4{font-family:var(--serif);font-size:18px;letter-spacing:0;font-style:italic;color:var(--accent-deep);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--rule)}
.amenity-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-size:14.5px;color:var(--ink-soft)}
@media(max-width:760px){.amenities{grid-template-columns:1fr}.amenity-cols{grid-template-columns:1fr}}

/* Bedroom list */
.bedrooms{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.4vw,40px)}
.bedroom .img{aspect-ratio:3/4;margin-bottom:16px}
.bedroom h4{font-family:var(--serif);font-style:italic;font-weight:400;font-size:24px;color:var(--ink);margin-bottom:6px}
.bedroom p{font-size:14px;color:var(--ink-soft);margin:0}
@media(max-width:880px){.bedrooms{grid-template-columns:1fr 1fr;gap:20px}}
@media(max-width:560px){.bedrooms{grid-template-columns:1fr}}

/* Big quote */
.bigquote{background:var(--paper-2);padding-block:clamp(80px,10vw,140px)}
.bigquote q{display:block;font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(28px,4vw,54px);line-height:1.18;color:var(--ink);max-width:24ch;quotes:none}
.bigquote q::before,.bigquote q::after{content:none}
.bigquote .who{margin-top:32px;font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-mute)}

/* Enquiry */
.enquiry{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(40px,6vw,96px);align-items:start}
.enquiry__head h2{max-width:14ch}
.enquiry__head .lead{margin-top:18px}
.enquiry__head ul{list-style:none;padding:0;margin:24px 0 0;display:flex;flex-direction:column;gap:12px;font-size:13px;color:var(--ink-soft)}
.enquiry__head ul a{border-bottom:1px solid var(--rule);padding-bottom:2px}
.enquiry__head ul a:hover{color:var(--accent-deep);border-bottom-color:var(--accent)}
.form{display:grid;gap:18px;grid-template-columns:1fr 1fr}
.form .full{grid-column:1/-1}
.field{display:flex;flex-direction:column;gap:6px;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-mute)}
.field input,.field select,.field textarea{border:0;border-bottom:1px solid var(--rule);background:transparent;padding:10px 0 12px;font:inherit;color:var(--ink);text-transform:none;letter-spacing:0;font-size:15px;border-radius:0}
.field textarea{resize:vertical;min-height:120px}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-bottom-color:var(--accent-deep)}
.form .submit{margin-top:8px}
@media(max-width:880px){.enquiry{grid-template-columns:1fr}.form{grid-template-columns:1fr}}

/* Tweaks panel */
.tweaks{position:fixed;right:20px;bottom:20px;z-index:90;width:300px;background:var(--paper);border:1px solid var(--rule);box-shadow:0 30px 60px -30px rgba(0,0,0,.25);padding:18px 20px;display:none;font-size:13px}
.tweaks.open{display:block}
.tweaks h5{font-family:var(--serif);font-size:18px;margin:0 0 14px}
.tweaks .grp{margin-bottom:14px}
.tweaks .grp:last-child{margin-bottom:0}
.tweaks label{font-size:10.5px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-mute);display:block;margin-bottom:6px}
.tweaks .opts{display:flex;gap:6px;flex-wrap:wrap}
.tweaks .opts button{font-size:11px;letter-spacing:0.04em;padding:6px 10px;border:1px solid var(--rule);border-radius:999px;color:var(--ink-soft);background:transparent}
.tweaks .opts button.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.tweaks .swatches{display:flex;gap:8px}
.tweaks .swatches button{width:24px;height:24px;border-radius:50%;border:1px solid var(--rule);padding:0}
.tweaks .swatches button.active{box-shadow:0 0 0 2px var(--paper),0 0 0 3px var(--ink)}
.tweaks-toggle{position:fixed;right:20px;bottom:20px;z-index:80;background:var(--ink);color:var(--paper);width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-size:14px}
.tweaks-toggle.hidden{display:none}
.tweaks .close{position:absolute;top:10px;right:14px;font-size:14px;color:var(--ink-mute)}
