/* Cabo Estate Management — global stylesheet */
:root{
  --navy:#13243C; --navy-deep:#0C1830; --ink:#26303F;
  --beige:#F6F1E8; --beige-deep:#EFE7D8; --white:#FFFFFF;
  --gold:#B59154; --gold-soft:#D9C49A; --line:#E5DCCB;
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Jost","Helvetica Neue",Arial,sans-serif;
  --max:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{transition:none!important;animation:none!important}}
body{font-family:var(--sans);color:var(--ink);background:var(--white);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--navy);text-decoration:none}
a:focus-visible,button:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
h1,h2,h3{font-family:var(--serif);color:var(--navy);font-weight:600;line-height:1.15}
h1{font-size:clamp(2.2rem,5vw,3.6rem)}
h2{font-size:clamp(1.7rem,3.4vw,2.5rem)}
h3{font-size:1.35rem}
.eyebrow{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:500;display:block;margin-bottom:14px}
.gold-rule{width:64px;height:1px;background:var(--gold);margin:22px 0;position:relative}
.gold-rule::after{content:"";position:absolute;left:50%;top:-3px;width:7px;height:7px;border:1px solid var(--gold);transform:translateX(-50%) rotate(45deg);background:var(--white)}
.center .gold-rule{margin-left:auto;margin-right:auto}
.center .gold-rule::after{background:inherit}

/* Top contact bar */
.topbar{background:var(--navy-deep);color:#E9E2D2;font-size:.85rem;position:sticky;top:0;z-index:60}
.topbar .wrap{display:flex;gap:22px;justify-content:flex-end;align-items:center;min-height:38px;flex-wrap:wrap}
.topbar a{color:#E9E2D2;display:inline-flex;gap:7px;align-items:center}
.topbar a:hover{color:var(--gold-soft)}
.topbar .tag{margin-right:auto;color:var(--gold-soft);letter-spacing:.14em;text-transform:uppercase;font-size:.72rem}
@media(max-width:720px){.topbar .tag{display:none}.topbar .wrap{justify-content:center;gap:14px}}

/* Header / nav */
.site-header{background:var(--white);border-bottom:1px solid var(--line);position:sticky;top:38px;z-index:50}
.site-header .wrap{display:flex;align-items:center;gap:28px;min-height:74px}
.logo{font-family:var(--serif);font-size:1.45rem;color:var(--navy);font-weight:600;letter-spacing:.02em}
.logo span{color:var(--gold)}
nav.main{margin-left:auto}
nav.main ul{list-style:none;display:flex;gap:22px;flex-wrap:wrap}
nav.main a{font-size:.86rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink)}
nav.main a:hover,nav.main a[aria-current]{color:var(--gold)}
.nav-toggle{display:none;background:none;border:1px solid var(--line);padding:8px 12px;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;color:var(--navy)}
@media(max-width:980px){
  .nav-toggle{display:block;margin-left:auto}
  nav.main{display:none;position:absolute;left:0;right:0;top:100%;background:var(--white);border-bottom:1px solid var(--line);margin:0}
  nav.main.open{display:block}
  nav.main ul{flex-direction:column;gap:0;padding:10px 24px 18px}
  nav.main li{border-bottom:1px solid var(--beige-deep)}
  nav.main a{display:block;padding:13px 0}
}

/* Buttons */
.btn{display:inline-block;padding:14px 30px;font-size:.84rem;letter-spacing:.14em;text-transform:uppercase;border:1px solid var(--gold);transition:background .25s,color .25s}
.btn-gold{background:var(--gold);color:var(--white)}
.btn-gold:hover{background:var(--navy);border-color:var(--navy);color:var(--white)}
.btn-outline{color:var(--navy)}
.btn-outline:hover{background:var(--gold);color:var(--white)}
.btn-light{border-color:#fff;color:#fff}
.btn-light:hover{background:#fff;color:var(--navy)}
.btn-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}

/* Hero */
.hero{background:linear-gradient(120deg,var(--navy-deep),var(--navy) 60%,#1D3354);color:#F4EFE3;padding:96px 0 88px;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;inset:auto -120px -180px auto;width:420px;height:420px;border:1px solid rgba(181,145,84,.35);transform:rotate(45deg)}
.hero h1{color:#fff;max-width:760px}
.hero p.lead{max-width:640px;margin-top:20px;font-size:1.1rem;color:#D9D3C2}
.hero .eyebrow{color:var(--gold-soft)}
.hero .gold-rule::after{background:var(--navy)}

/* Sections */
section.block{padding:78px 0}
section.block.beige{background:var(--beige)}
section.block.navy{background:var(--navy);color:#E7E1D1}
section.block.navy h2{color:#fff}
.intro{max-width:740px}
.grid{display:grid;gap:26px;margin-top:44px}
.grid.c3{grid-template-columns:repeat(3,1fr)}
.grid.c2{grid-template-columns:repeat(2,1fr)}
.grid.c4{grid-template-columns:repeat(4,1fr)}
@media(max-width:920px){.grid.c3,.grid.c4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.grid.c3,.grid.c2,.grid.c4{grid-template-columns:1fr}}
.card{background:var(--white);border:1px solid var(--line);padding:34px 30px;transition:border-color .25s,transform .25s}
.card:hover{border-color:var(--gold);transform:translateY(-3px)}
.card h3{margin-bottom:12px}
.card p{font-size:.96rem;color:#4A5364}
.card .more{display:inline-block;margin-top:16px;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.navy .card{background:rgba(255,255,255,.04);border-color:rgba(217,196,154,.25);color:#E7E1D1}
.navy .card h3{color:var(--gold-soft)}
.navy .card p{color:#C8C2B2}

/* Steps */
.steps{counter-reset:step;display:grid;gap:0;margin-top:40px;border-top:1px solid var(--line)}
.step{display:grid;grid-template-columns:90px 1fr;gap:24px;padding:30px 0;border-bottom:1px solid var(--line)}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);font-family:var(--serif);font-size:2.2rem;color:var(--gold)}
.step h3{margin-bottom:8px}
@media(max-width:620px){.step{grid-template-columns:1fr;gap:8px}}

/* FAQ */
details.faq{border-bottom:1px solid var(--line);padding:6px 0}
details.faq summary{cursor:pointer;font-family:var(--serif);font-size:1.18rem;color:var(--navy);padding:16px 0;list-style:none;position:relative;padding-right:36px}
details.faq summary::-webkit-details-marker{display:none}
details.faq summary::after{content:"+";position:absolute;right:4px;color:var(--gold);font-size:1.4rem;font-family:var(--sans)}
details.faq[open] summary::after{content:"–"}
details.faq p{padding:0 0 18px;color:#4A5364}

/* Testimonials */
.quote{background:var(--white);border:1px solid var(--line);border-top:2px solid var(--gold);padding:34px 30px;font-size:1.02rem}
.quote footer{margin-top:18px;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.quote em{font-family:var(--serif);font-style:italic;font-size:1.12rem;color:var(--navy)}

/* Trust strip */
.trust{display:flex;gap:10px 34px;flex-wrap:wrap;justify-content:center;padding:22px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--beige);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--navy)}
.trust span::before{content:"◆";color:var(--gold);margin-right:9px;font-size:.6rem;vertical-align:2px}

/* Forms */
form.lux{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:36px}
form.lux .full{grid-column:1/-1}
form.lux label{display:block;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--navy);margin-bottom:7px}
form.lux input,form.lux select,form.lux textarea{width:100%;padding:13px 14px;border:1px solid var(--line);background:var(--white);font-family:var(--sans);font-size:.95rem;color:var(--ink)}
form.lux input:focus,form.lux select:focus,form.lux textarea:focus{outline:none;border-color:var(--gold)}
form.lux textarea{min-height:130px;resize:vertical}
@media(max-width:620px){form.lux{grid-template-columns:1fr}}

/* Breadcrumbs */
.crumbs{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;padding:16px 0;color:#7A8294}
.crumbs a{color:#7A8294}.crumbs a:hover{color:var(--gold)}
.crumbs span.sep{margin:0 8px;color:var(--gold)}

/* CTA band */
.cta-band{background:var(--navy);color:#E7E1D1;padding:70px 0;text-align:center}
.cta-band h2{color:#fff;max-width:720px;margin:0 auto}
.cta-band p{max-width:600px;margin:16px auto 0;color:#C8C2B2}
.cta-band .btn-row{justify-content:center}

/* Blog */
.post-card{border:1px solid var(--line);background:var(--white);display:flex;flex-direction:column;transition:border-color .25s,transform .25s}
.post-card:hover{border-color:var(--gold);transform:translateY(-3px)}
.thumb{aspect-ratio:16/9;background:linear-gradient(130deg,var(--beige-deep),var(--beige));display:flex;align-items:center;justify-content:center;color:var(--gold);font-family:var(--serif);font-size:1.05rem;border-bottom:1px solid var(--line)}
.post-card .body{padding:26px 26px 30px}
.post-card .cat{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.post-card h3{margin:10px 0 10px;font-size:1.25rem}
.post-card p{font-size:.93rem;color:#4A5364}
.badge{display:inline-block;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;padding:4px 10px;border:1px solid var(--gold);color:var(--gold);margin-left:10px;vertical-align:3px}
.filter-row{display:flex;gap:10px;flex-wrap:wrap;margin:34px 0 6px}
.filter-row a,.filter-row button{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;padding:8px 16px;border:1px solid var(--line);background:var(--white);cursor:pointer;color:var(--navy)}
.filter-row a:hover,.filter-row .active,.filter-row button:hover{border-color:var(--gold);color:var(--gold)}
.searchbox{display:flex;gap:0;max-width:460px;margin-top:30px}
.searchbox input{flex:1;padding:13px 14px;border:1px solid var(--line);font-size:.95rem}
.searchbox button{padding:13px 22px;background:var(--gold);color:#fff;border:1px solid var(--gold);letter-spacing:.12em;text-transform:uppercase;font-size:.78rem;cursor:pointer}
.author-box{display:flex;gap:22px;border:1px solid var(--line);background:var(--beige);padding:28px;margin-top:50px;align-items:center}
.author-box .avatar{width:84px;height:84px;border-radius:50%;background:var(--navy);color:var(--gold-soft);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.6rem;flex-shrink:0}
.prose{max-width:760px}
.prose h2{margin:44px 0 16px}
.prose h3{margin:32px 0 12px}
.prose p{margin-bottom:18px}
.prose ul,.prose ol{margin:0 0 18px 22px}
.prose li{margin-bottom:8px}

/* Tables / dashboard */
table.admin{width:100%;border-collapse:collapse;font-size:.9rem;margin-top:26px}
table.admin th{background:var(--navy);color:#fff;text-align:left;padding:11px 14px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;font-size:.72rem}
table.admin td{border:1px solid var(--line);padding:10px 14px;vertical-align:top}
table.admin tr:nth-child(even) td{background:var(--beige)}
.pill{display:inline-block;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;padding:3px 10px}
.pill.draft{background:var(--beige-deep);color:var(--navy)}
.pill.ok{background:var(--navy);color:var(--gold-soft)}

/* Footer */
footer.site{background:var(--navy-deep);color:#B9B3A3;padding:70px 0 36px;font-size:.92rem}
footer.site h4{color:var(--gold-soft);font-family:var(--serif);font-size:1.15rem;margin-bottom:16px}
footer.site .grid{margin-top:0}
footer.site ul{list-style:none}
footer.site li{margin-bottom:9px}
footer.site a{color:#B9B3A3}
footer.site a:hover{color:var(--gold-soft)}
.foot-bottom{border-top:1px solid rgba(217,196,154,.18);margin-top:50px;padding-top:24px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.8rem}
.whatsapp-fab{position:fixed;right:22px;bottom:22px;z-index:70;background:#1FA855;color:#fff;width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:0 6px 18px rgba(0,0,0,.25)}
