/* ═══════════════════════════════════════════════════════════════
   TRANQUILITY FARM & WINERY — Global Stylesheet
   tranquility-global.css

   Covers: reset, design tokens, nav, mobile menu, footer,
           weather strip, scroll-fade, shared utilities, responsive.

   Page-specific styles live in each page's own <style> block.

   Wine pages (wines-draksha, wines-otium) override tokens via
   their own :root block for the sage/dark palette — intentional.
   Journal pages override --dark and --stone — intentional.
   All other pages use this file as-is with no overrides.
═══════════════════════════════════════════════════════════════ */


/* ═══════════════════════════════════
   RESET
═══════════════════════════════════ */
*{margin:0;padding:0;box-sizing:border-box;}
a{text-decoration:none;color:inherit;}
html{scroll-behavior:smooth;max-width:100%;}
img{display:block;width:100%;height:100%;object-fit:cover;}
body{overflow-x:hidden;}


/* ═══════════════════════════════════
   DESIGN TOKENS
═══════════════════════════════════ */
:root{
  /* Gold */
  --gold:#B8935A;
  --gold2:#D4B07A;

  /* Light backgrounds */
  --stone:#EDE8DF;
  --linen:#EEEADF;
  --warm:#F3EEE6;

  /* Ink / text */
  --ink:#1C1710;
  --ink2:#3A3020;
  --ink3:#4A3F2F;
  --ink4:#6A5C48;

  /* Dark backgrounds */
  --dark:#16181A;
  --bg-mid:#2A2E2B;
  --bg-warm:#222820;

  /* Borders */
  --border-g:rgba(90,110,80,0.18);

  /* Typography */
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost','PT Sans',sans-serif;
}

body{
  font-family:var(--sans);
  background:var(--dark);
  color:var(--stone);
  -webkit-font-smoothing:antialiased;
}


/* ═══════════════════════════════════
   NAVIGATION — Desktop
═══════════════════════════════════ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:300;
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 64px;
  background:rgba(22,24,26,0.97);
  backdrop-filter:blur(16px);
  border-bottom:0.5px solid rgba(184,147,90,0.15);
  transition:padding 0.4s;
}
nav.scrolled{
  padding:8px 64px;
  background:rgba(22,24,26,0.97);
}
.nav-logo{text-decoration:none;display:block;line-height:0;flex-shrink:0;}
.nav-logo img{height:52px;width:auto;object-fit:contain;}

.nav-links{display:flex;gap:32px;list-style:none;}
.nav-links a{
  font-size:10px;font-weight:500;letter-spacing:0.2em;
  text-transform:uppercase;color:rgba(242,237,228,0.88);
  text-decoration:none;transition:color 0.2s;
}
.nav-links a:hover,
.nav-links a.active{color:var(--gold2);}

.nav-right{display:flex;align-items:center;gap:20px;flex-shrink:0;}
.nav-divider{width:0.5px;height:16px;background:rgba(90,110,80,0.2);flex-shrink:0;}

.nav-faq{
  font-size:9px;font-weight:500;letter-spacing:0.14em;
  text-transform:uppercase;color:rgba(242,237,228,0.5);
  text-decoration:none;transition:color 0.2s;display:flex;align-items:center;
}
.nav-faq:hover{color:var(--gold2);}

.nav-login{
  font-size:9px;font-weight:500;letter-spacing:0.14em;
  text-transform:uppercase;color:rgba(242,237,228,0.6);
  text-decoration:none;display:flex;align-items:center;transition:color 0.2s;
}
.nav-login:hover{color:var(--gold2);}

.nav-cta{
  padding:9px 24px;
  border:0.5px solid rgba(184,147,90,0.85);
  color:var(--gold2);
  font-size:9px;letter-spacing:0.22em;text-transform:uppercase;
  background:transparent;font-family:var(--sans);
  transition:all 0.3s;text-decoration:none;
}
.nav-cta:hover{background:var(--gold);color:var(--dark);border-color:var(--gold);}


/* ═══════════════════════════════════
   NAVIGATION — Mobile hamburger
═══════════════════════════════════ */
.nav-hamburger{
  display:none;flex-direction:column;justify-content:center;
  gap:5px;background:none;border:none;cursor:pointer;
  padding:8px;z-index:1001;min-height:44px;min-width:44px;
}
.nav-hamburger span{
  display:block;width:24px;height:1.5px;
  background:rgba(242,237,228,0.85);transition:all 0.3s ease;
}
.nav-hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.nav-hamburger.open span:nth-child(2){opacity:0;}
.nav-hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}


/* ═══════════════════════════════════
   MOBILE MENU OVERLAY
═══════════════════════════════════ */
.mobile-menu{
  position:fixed;inset:0;background:rgba(22,24,26,0.98);
  z-index:999;display:flex;flex-direction:column;
  justify-content:flex-start;align-items:center;
  opacity:0;pointer-events:none;
  transition:opacity 0.35s ease;
  overflow-y:auto;padding:80px 20px 48px;
}
.mobile-menu.open{opacity:1;pointer-events:all;}

.mobile-menu-close{
  position:absolute;top:24px;right:24px;
  background:none;border:none;color:rgba(242,237,228,0.6);
  font-size:32px;cursor:pointer;padding:8px;
}
.mobile-menu-nav{
  display:flex;flex-direction:column;align-items:center;
  gap:2px;margin-bottom:0;
}
.mobile-menu-nav a{
  font-family:var(--serif);font-size:clamp(26px,6.5vw,42px);
  font-weight:300;color:rgba(242,237,228,0.85);
  text-decoration:none;padding:10px 20px;
  transition:color 0.2s;line-height:1.1;
}
.mobile-menu-nav a:hover{color:var(--gold2);}

.mobile-menu-footer{
  display:flex;flex-direction:column;align-items:center;
  gap:6px;margin-top:32px;
}
.mobile-menu-footer span{
  font-size:11px;letter-spacing:0.12em;
  color:rgba(242,237,228,0.25);
}


/* ═══════════════════════════════════
   SHARED UTILITIES
═══════════════════════════════════ */

/* Eyebrow labels — gold, used across all pages */
.hero-ey,.section-ey,.win-ey,.prop-ey,.hist-ey,.cl-ey,
.faq-hero-ey,.ret-ey,.ret-ey-lt,.wn-eyebrow,.sn-eyebrow,
.vyd-eyebrow,.ph-eyebrow,.club-eyebrow,.vs-eyebrow,.ds-ey-r,
.wp-eyebrow,.hail-eyebrow,.wcs-ey,.wms-ey{color:var(--gold)!important;}

.hero-ey::before,.section-ey::before,.win-ey::before,.prop-ey::before,
.hist-ey::before,.cl-ey::before,.faq-hero-ey::before,.ret-ey::before,
.wn-eyebrow::before,.sn-eyebrow::before{background:var(--gold)!important;}

.section-ey-lt,.ret-ey-lt{color:var(--gold)!important;}
.section-ey-lt::before,.ret-ey-lt::before{background:var(--gold)!important;}

/* Body links — inline contextual links */
.body-link{
  color:var(--gold);text-decoration:none;
  border-bottom:0.5px solid rgba(184,147,90,0.4);
  transition:border-color 0.2s;
}
.body-link:hover{border-color:var(--gold);}

/* Shared CTA buttons */
.btn-gold{
  display:inline-flex;align-items:center;justify-content:center;
  padding:13px 32px;border:1px solid var(--gold);color:var(--gold);
  font-size:10px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;
  background:transparent;font-family:var(--sans);transition:all 0.3s;
  text-decoration:none;min-height:44px;
}
.btn-gold:hover{background:var(--gold);color:var(--dark);}

.btn-outline{
  display:inline-flex;align-items:center;justify-content:center;
  padding:13px 32px;border:1px solid rgba(242,237,228,0.65);
  color:rgba(242,237,228,0.88);font-size:10px;font-weight:600;
  letter-spacing:0.22em;text-transform:uppercase;background:transparent;
  font-family:var(--sans);transition:all 0.3s;text-decoration:none;min-height:44px;
}
.btn-outline:hover{background:var(--stone);border-color:var(--stone);color:var(--dark);}

.btn-gold-solid{
  display:inline-flex;align-items:center;justify-content:center;
  padding:13px 32px;background:var(--gold);color:var(--dark);
  font-family:var(--sans);font-size:10px;font-weight:600;
  letter-spacing:0.22em;text-transform:uppercase;
  border:0.5px solid var(--gold);text-decoration:none;
  transition:background 0.25s;min-height:44px;white-space:nowrap;
}
.btn-gold-solid:hover{background:var(--gold2);border-color:var(--gold2);}


/* Pillars — defined per-page to avoid responsive conflicts */


/* ═══════════════════════════════════
   INSTAGRAM BAND — shared across pages
═══════════════════════════════════ */
.instagram-band{
  background:var(--dark);padding:48px 64px;
  border-top:0.5px solid var(--border-g);
  display:flex;align-items:center;justify-content:space-between;
  gap:48px;flex-wrap:wrap;
}
.instagram-band-label{
  font-size:9px;font-weight:500;letter-spacing:0.32em;
  text-transform:uppercase;color:rgba(184,147,90,0.5);flex-shrink:0;
}
.instagram-handles{display:flex;gap:48px;align-items:center;flex-wrap:wrap;}
.instagram-handle{display:flex;flex-direction:column;gap:4px;}
.instagram-handle a{
  font-family:var(--serif);font-size:clamp(18px,2vw,24px);
  font-weight:300;color:var(--stone);transition:color 0.2s;
  line-height:1;text-decoration:none;
}
.instagram-handle a:hover{color:var(--gold2);}
.instagram-handle span{
  font-size:11px;font-weight:400;letter-spacing:0.08em;
  color:rgba(242,237,228,0.35);
}
.instagram-band-cta{
  font-size:10px;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--gold);display:inline-flex;align-items:center;gap:8px;
  border-bottom:0.5px solid rgba(184,147,90,0.4);padding-bottom:3px;
  transition:color 0.2s;white-space:nowrap;text-decoration:none;
}
.instagram-band-cta:hover{color:var(--gold2);}


/* ═══════════════════════════════════
   WEATHER STRIP
═══════════════════════════════════ */
.wx-strip{
  background:rgba(22,24,26,0.97);
  border-top:1px solid rgba(184,147,90,0.15);
  padding:18px 40px;
  display:flex;align-items:center;justify-content:center;
  flex-wrap:wrap;gap:0;
}
.wx-strip-label{
  font-size:10px;font-weight:500;letter-spacing:0.18em;
  text-transform:uppercase;color:rgba(184,147,90,0.6);
  margin-right:28px;white-space:nowrap;
}
.wx-strip-item{
  display:flex;flex-direction:column;align-items:center;
  padding:0 20px;border-right:1px solid rgba(184,147,90,0.15);
}
.wx-strip-item:last-child{border-right:none;}
.wx-strip-val{
  font-family:var(--serif);font-size:20px;
  font-weight:300;color:var(--gold2);line-height:1;
}
.wx-strip-unit{
  font-size:10px;font-weight:400;letter-spacing:0.1em;
  color:rgba(242,237,228,0.45);text-transform:uppercase;margin-left:3px;
}
.wx-strip-sub{
  font-size:9px;letter-spacing:0.12em;text-transform:uppercase;
  color:rgba(242,237,228,0.3);display:block;margin-top:3px;text-align:center;
}
.wx-strip-loading{
  font-size:10px;letter-spacing:0.15em;
  text-transform:uppercase;color:rgba(184,147,90,0.4);
}


/* ═══════════════════════════════════
   FOOTER — Two-zone layout
   Left: estate identity block
   Right: 3-col navigation sub-grid
═══════════════════════════════════ */
footer{
  background:#0A0806;
  padding:72px 64px 32px;
  border-top:0.5px solid rgba(90,110,80,0.1);
}

/* Main two-zone grid: identity | navigation */
.ft-body{
  display:grid;
  grid-template-columns:300px 1fr;
  gap:80px;
  margin-bottom:56px;
  align-items:start;
}

/* ── LEFT: Estate identity ── */
.ft-identity{
  display:flex;
  flex-direction:column;
  gap:0;
}

.ft-estate-name{
  font-family:var(--serif);
  font-size:22px;
  font-weight:300;
  line-height:1.2;
  color:var(--stone);
  margin-bottom:8px;
}

.ft-tagline{
  font-size:10px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:rgba(242,237,228,0.28);
  margin-bottom:28px;
}

.ft-divider{
  height:0.5px;
  background:rgba(90,110,80,0.2);
  margin-bottom:28px;
}

.ft-address{
  display:block;
  font-size:13px;
  font-weight:400;
  line-height:1.7;
  color:rgba(242,237,228,0.55);
  text-decoration:none;
  transition:color 0.2s;
  margin-bottom:22px;
}
.ft-address:hover{color:var(--gold2);}

/* Hours block — stacked, clearly grouped */
.ft-hours-block{
  display:flex;
  flex-direction:column;
  gap:4px;
  margin-bottom:22px;
}
.ft-hours-label{
  font-size:9px;
  font-weight:600;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:rgba(184,147,90,0.7);
  margin-bottom:2px;
}
.ft-hours-row{
  font-size:12px;
  color:rgba(242,237,228,0.5);
  line-height:1.6;
}

/* Action links — phone, tasting, inquire */
.ft-actions{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom:22px;
}
.ft-actions a{
  font-size:12px;
  font-weight:400;
  color:rgba(242,237,228,0.65);
  text-decoration:none;
  transition:color 0.2s;
  display:flex;
  align-items:center;
  gap:8px;
}
.ft-actions a::before{
  content:'';
  display:block;
  width:12px;
  height:0.5px;
  background:rgba(184,147,90,0.4);
  flex-shrink:0;
}
.ft-actions a:hover{color:var(--gold2);}

/* Social handles */
.ft-social{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding-top:18px;
  border-top:0.5px solid rgba(90,110,80,0.15);
}
.ft-social a{
  font-family:var(--serif);
  font-size:14px;
  font-weight:300;
  font-style:italic;
  color:rgba(242,237,228,0.38);
  text-decoration:none;
  transition:color 0.2s;
}
.ft-social a:hover{color:var(--gold2);}

/* ── RIGHT: Navigation 3-col grid ── */
.ft-nav{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:40px;
  align-items:start;
}

.ft-nav-col h5{
  font-size:9px;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:16px;
}
.ft-nav-col ul{list-style:none;}
.ft-nav-col li{margin-bottom:10px;}
.ft-nav-col a{
  font-size:13px;
  font-weight:400;
  color:rgba(242,237,228,0.55);
  transition:color 0.2s;
  text-decoration:none;
}
.ft-nav-col a:hover{color:var(--gold2);}

/* ── BOTTOM BAR ── */
.ft-bottom{
  border-top:0.5px solid rgba(90,110,80,0.1);
  padding-top:22px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:10px;
}
.ft-copy{font-size:10px;letter-spacing:0.1em;color:rgba(242,237,228,0.28);}
.ft-credits-link{
  color:rgba(184,147,90,0.6);
  border-bottom:0.5px solid rgba(184,147,90,0.3);
  transition:color 0.2s;text-decoration:none;
}
.ft-credits-link:hover{color:var(--gold2);}
.ft-labels{display:flex;gap:18px;}
.ft-lbl{font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:rgba(242,237,228,0.12);}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .ft-body{grid-template-columns:260px 1fr;gap:60px;}
}
@media(max-width:960px){
  footer{padding:56px 24px 28px;}
  .ft-body{grid-template-columns:1fr;gap:48px;}
  .ft-nav{grid-template-columns:repeat(3,1fr);gap:32px;}
}
@media(max-width:640px){
  .ft-nav{grid-template-columns:1fr 1fr;gap:32px;}
}
@media(max-width:480px){
  .ft-nav{grid-template-columns:1fr 1fr;gap:24px;}
  .ft-bottom{flex-direction:column;align-items:flex-start;gap:8px;}
}



/* ═══════════════════════════════════
   SCROLL FADE
═══════════════════════════════════ */
.sf{opacity:0;transform:translateY(20px);transition:opacity 0.75s ease,transform 0.75s ease;}
.sf.vis{opacity:1;transform:translateY(0);}


/* ═══════════════════════════════════
   RESPONSIVE — NAV
═══════════════════════════════════ */
@media(max-width:1280px){
  nav,nav.scrolled{padding-left:48px;padding-right:48px;}
  .nav-links{gap:24px;}
}
@media(max-width:1100px){
  nav,nav.scrolled{padding-left:32px;padding-right:32px;align-items:center;}
  .nav-links{gap:14px;}
  .nav-links a{font-size:9px;letter-spacing:0.10em;}
  .nav-cta{padding:8px 12px;font-size:8px;letter-spacing:0.14em;}
  .nav-faq{font-size:8px;}
  .nav-right{flex-shrink:0;align-items:center;display:flex;gap:12px;}
  .nav-login{display:none;}
  .nav-divider{display:none;}
}
@media(max-width:960px){
  nav,nav.scrolled{padding-left:20px;padding-right:20px;}
  .nav-links{display:none;}
  .nav-cta{display:none;}
  .nav-faq,.nav-divider{display:none;}
  .nav-hamburger{display:flex;}
  .instagram-band{padding:36px 24px;flex-direction:column;align-items:flex-start;gap:24px;}
  footer{padding:48px 24px 28px;}
  .ft-grid{grid-template-columns:1fr 1fr;gap:32px;}
}
@media(max-width:768px){
  body{overflow-x:hidden;}
  .nav-logo img{height:48px;}
  .wx-strip{padding:14px 16px;justify-content:flex-start;overflow-x:auto;}
  .wx-strip-item{padding:0 12px;}
  .ft-bottom{flex-direction:column;align-items:flex-start;gap:8px;}
  .btn-gold,.btn-outline,.btn-gold-solid{min-height:44px;}
}
@media(max-width:480px){
  .ft-grid{grid-template-columns:1fr;}
}
@media(hover:none){
  a,button{min-height:36px;}
  .nav-hamburger{min-height:44px;min-width:44px;}
}
