/* Shared styles for service subpages and blog — matches the luxury zafari.to redesign */
:root {
  --ivory:     #faf8f3;
  --cream:     #f3efe6;
  --white:     #ffffff;
  --ink:       #1b1b1b;
  --charcoal:  #2d2d2d;
  --steel:     #6b7280;
  --warm-gray: #9ca3af;
  --gold:      #c5a47e;
  --gold-lt:   rgba(197,164,126,0.12);
  --gold-dark: #a88a64;
  --rule:      #e5e0d5;
  --rule-lt:   rgba(229,224,213,0.5);
  --serif:     'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:      'DM Sans', system-ui, -apple-system, sans-serif;
  --max:       1140px;
  --measure:   68ch;
  --ease:      cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{font-family:var(--sans);background:var(--ivory);color:var(--ink);line-height:1.75;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}
a{color:var(--gold-dark);text-decoration:none;transition:color 0.3s var(--ease);}
a:hover{color:var(--gold);text-decoration:none;}

/* Nav */
nav.primary{position:sticky;top:0;z-index:50;background:rgba(250,248,243,0.88);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);border-bottom:1px solid var(--rule-lt);}
nav.primary .wrap{max-width:var(--max);margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:1.1rem 2rem;}
nav.primary .brand{font-family:var(--serif);font-size:1.35rem;font-weight:400;color:var(--ink);display:flex;flex-direction:column;line-height:1;text-decoration:none;letter-spacing:0.02em;}
nav.primary .brand small{font-family:var(--sans);font-size:0.68rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);margin-top:4px;font-weight:400;}
nav.primary ul{list-style:none;display:flex;gap:2.2rem;align-items:center;}
nav.primary a{color:var(--steel);font-size:0.78rem;font-weight:400;letter-spacing:0.1em;text-transform:uppercase;transition:color 0.3s var(--ease);}
nav.primary a:hover{color:var(--ink);text-decoration:none;}
nav.primary a.cta{background:var(--ink);color:var(--ivory);padding:0.55rem 1.4rem;border-radius:2px;font-weight:500;letter-spacing:0.1em;}
nav.primary a.cta:hover{background:var(--charcoal);color:var(--ivory);text-decoration:none;}
@media(max-width:820px){nav.primary .wrap{padding:1rem 1.5rem;}nav.primary ul{gap:1.1rem;}nav.primary a:not(.cta){display:none;}}

/* Hero for article-style pages */
.page-hero{padding:5.5rem 2rem 3.5rem;border-bottom:1px solid var(--rule);background:var(--white);}
.page-hero .wrap{max-width:var(--max);margin:0 auto;}
.page-hero .kicker{font-size:0.68rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem;font-weight:500;display:flex;align-items:center;gap:1rem;}
.page-hero .kicker::before{content:'';width:24px;height:1px;background:var(--gold);}
.page-hero h1{font-family:var(--serif);font-weight:300;font-size:clamp(2.4rem,5vw,3.8rem);line-height:1.08;letter-spacing:-0.02em;color:var(--ink);max-width:22ch;}
.page-hero h1 em{font-style:italic;color:var(--gold-dark);}
.page-hero .lede{margin-top:1.6rem;font-size:1.05rem;color:var(--steel);max-width:var(--measure);font-weight:300;line-height:1.85;}
.breadcrumb{font-size:0.78rem;color:var(--warm-gray);margin-bottom:1.4rem;letter-spacing:0.02em;}
.breadcrumb a{color:var(--warm-gray);transition:color 0.3s;}
.breadcrumb a:hover{color:var(--gold-dark);}
.breadcrumb span[aria-current]{color:var(--ink);}

/* Article body */
article.long{max-width:var(--max);margin:0 auto;padding:4rem 2rem 5rem;display:grid;grid-template-columns:minmax(0,var(--measure)) 1fr;gap:5rem;}
article.long .prose{min-width:0;}
article.long h2{font-family:var(--serif);font-size:2rem;font-weight:300;margin:3rem 0 1rem;line-height:1.15;color:var(--ink);}
article.long h3{font-family:var(--serif);font-size:1.4rem;font-weight:400;margin:2rem 0 0.6rem;color:var(--ink);}
article.long p{margin-bottom:1.2rem;color:var(--steel);font-weight:300;line-height:1.85;}
article.long ul,article.long ol{margin:1rem 0 1.5rem 1.4rem;color:var(--steel);font-weight:300;line-height:1.85;}
article.long li{margin-bottom:0.6rem;}
article.long strong{color:var(--ink);font-weight:500;}
article.long a{color:var(--gold-dark);border-bottom:1px solid var(--gold-lt);transition:border-color 0.3s var(--ease);}
article.long a:hover{border-bottom-color:var(--gold);text-decoration:none;}
article.long aside.pull{background:var(--gold-lt);border-left:2px solid var(--gold);padding:1.6rem 1.8rem;margin:2.5rem 0;border-radius:0;color:var(--ink);font-family:var(--serif);font-size:1.2rem;line-height:1.55;font-style:italic;}
article.long .facts{position:sticky;top:6rem;align-self:start;background:var(--white);border:1px solid var(--rule);border-radius:2px;padding:1.8rem;font-size:0.9rem;}
article.long .facts h4{font-family:var(--serif);font-size:1.15rem;font-weight:400;margin-bottom:1rem;color:var(--ink);}
article.long .facts dl{display:grid;gap:0.7rem;}
article.long .facts dt{font-size:0.68rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold-dark);font-weight:500;}
article.long .facts dd{color:var(--steel);font-weight:300;}
article.long .cta-box{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--rule);}
article.long .cta-box a{display:block;background:var(--ink);color:var(--ivory);text-align:center;padding:0.95rem 1rem;border-radius:0;border:1px solid var(--ink);font-weight:500;font-size:0.82rem;letter-spacing:0.1em;text-transform:uppercase;transition:background 0.3s var(--ease), color 0.3s;border-bottom:none;}
article.long .cta-box a:hover{background:transparent;color:var(--ink);text-decoration:none;}
@media(max-width:900px){article.long{grid-template-columns:1fr;gap:2.5rem;padding:3rem 1.5rem 4rem;}article.long .facts{position:static;}}

/* FAQ */
.faq{background:var(--white);padding:5rem 2rem;border-top:1px solid var(--rule);}
.faq .wrap{max-width:var(--max);margin:0 auto;}
.faq h2{font-family:var(--serif);font-size:2.2rem;font-weight:300;margin-bottom:2.5rem;color:var(--ink);}
.faq details{border-bottom:1px solid var(--rule);transition:background 0.3s var(--ease);}
.faq details:hover{background:var(--ivory);}
.faq summary{font-weight:400;cursor:pointer;color:var(--ink);font-family:var(--serif);font-size:1.15rem;padding:1.4rem 0.5rem;list-style:none;display:flex;justify-content:space-between;align-items:center;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:'+';font-family:var(--sans);font-size:1.4rem;font-weight:300;color:var(--gold);flex-shrink:0;margin-left:1rem;transition:transform 0.3s var(--ease);}
.faq details[open] summary::after{content:'\2212';}
.faq details[open]{background:var(--ivory);}
.faq details p{padding:0 0.5rem 1.4rem;color:var(--steel);font-weight:300;line-height:1.8;font-size:0.95rem;}

/* Blog index */
.blog-grid{max-width:var(--max);margin:0 auto;padding:3.5rem 2rem 6rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;}
.blog-card{border:1px solid var(--rule);border-radius:2px;padding:2.2rem 2rem;background:var(--white);transition:transform 0.3s var(--ease), box-shadow 0.3s var(--ease), border-color 0.3s;position:relative;}
.blog-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transition:transform 0.5s var(--ease);}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(27,27,27,0.06);border-color:var(--rule-lt);}
.blog-card:hover::before{transform:scaleX(1);}
.blog-card time{font-size:0.68rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold-dark);font-weight:500;}
.blog-card h3{font-family:var(--serif);font-size:1.5rem;font-weight:400;margin:0.8rem 0 0.9rem;line-height:1.2;color:var(--ink);}
.blog-card p{color:var(--steel);font-weight:300;font-size:0.92rem;line-height:1.75;}
.blog-card a.more{display:inline-block;margin-top:1.2rem;color:var(--gold-dark);font-weight:500;font-size:0.82rem;letter-spacing:0.06em;border-bottom:1px solid transparent;transition:border-color 0.3s var(--ease);}
.blog-card a.more:hover{border-bottom-color:var(--gold);text-decoration:none;}

/* Footer */
footer.site{background:var(--ink);color:var(--warm-gray);padding:3.5rem 2rem;text-align:center;font-size:0.78rem;font-weight:300;letter-spacing:0.06em;}
footer.site a{color:var(--gold);transition:color 0.3s;border-bottom:none;}
footer.site a:hover{color:var(--gold-dark);text-decoration:none;}
footer.site .row{max-width:var(--max);margin:0 auto;display:flex;flex-wrap:wrap;justify-content:center;gap:1rem 2.5rem;margin-bottom:1.2rem;}
