/*
  Designed and developed by Wave Agency - waveagency.com
  Version 1-0-0
*/

/* ============================================================
   Self-hosted fonts (latin subset, woff2)
   ============================================================ */
@font-face{
  font-family:"Cormorant Garamond";font-style:normal;font-weight:400;font-display:swap;
  src:url("../../fonts/cormorant-garamond-latin-400-normal.woff2") format("woff2");
}
@font-face{
  font-family:"Cormorant Garamond";font-style:italic;font-weight:400;font-display:swap;
  src:url("../../fonts/cormorant-garamond-latin-400-italic.woff2") format("woff2");
}
@font-face{
  font-family:"Cormorant Garamond";font-style:normal;font-weight:500;font-display:swap;
  src:url("../../fonts/cormorant-garamond-latin-500-normal.woff2") format("woff2");
}
@font-face{
  font-family:"Cormorant Garamond";font-style:normal;font-weight:600;font-display:swap;
  src:url("../../fonts/cormorant-garamond-latin-600-normal.woff2") format("woff2");
}
@font-face{
  font-family:"Spectral";font-style:normal;font-weight:400;font-display:swap;
  src:url("../../fonts/spectral-latin-400-normal.woff2") format("woff2");
}
@font-face{
  font-family:"Spectral";font-style:italic;font-weight:400;font-display:swap;
  src:url("../../fonts/spectral-latin-400-italic.woff2") format("woff2");
}
@font-face{
  font-family:"Spectral";font-style:normal;font-weight:500;font-display:swap;
  src:url("../../fonts/spectral-latin-500-normal.woff2") format("woff2");
}
@font-face{
  font-family:"Jost";font-style:normal;font-weight:300;font-display:swap;
  src:url("../../fonts/jost-latin-300-normal.woff2") format("woff2");
}
@font-face{
  font-family:"Jost";font-style:normal;font-weight:400;font-display:swap;
  src:url("../../fonts/jost-latin-400-normal.woff2") format("woff2");
}
@font-face{
  font-family:"Jost";font-style:normal;font-weight:500;font-display:swap;
  src:url("../../fonts/jost-latin-500-normal.woff2") format("woff2");
}

/* ============================================================
   Tokens
   ============================================================ */
:root{
  --espresso:#1F1A17;
  --espresso-soft:#2A2320;
  --cream:#F4EDE1;
  --parchment:#EFE7D8;
  --parchment-2:#FAF6EE;
  --burgundy:#6F1D2E;
  --burgundy-deep:#571320;
  --brass:#B0894F;
  --taupe:#6A5F54;
  --rule:rgba(31,26,23,0.16);
  --rule-strong:rgba(31,26,23,0.32);
  --rule-light:rgba(244,237,225,0.22);
  --display:"Cormorant Garamond",Georgia,serif;
  --body:"Spectral",Georgia,serif;
  --label:"Jost",system-ui,sans-serif;
}

/* ============================================================
   Base
   ============================================================ */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--cream);
  color:var(--espresso);
  font-family:var(--body);
  font-weight:400;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.visually-hidden{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:100;
  background:var(--espresso);color:var(--cream);padding:12px 18px;
  font-family:var(--label);text-transform:uppercase;letter-spacing:0.18em;font-size:0.7rem;
}
.skip-link:focus{left:12px;top:12px}

.label{
  font-family:var(--label);font-weight:400;text-transform:uppercase;
  letter-spacing:0.28em;font-size:0.66rem;color:var(--taupe);
}

/* ============================================================
   Utility bar
   ============================================================ */
.utility{background:var(--espresso);color:var(--cream);border-bottom:1px solid var(--rule-light)}
.utility .wrap{display:flex;justify-content:space-between;align-items:center;padding:10px 28px;gap:18px}
.utility .label{color:rgba(244,237,225,0.7);font-size:0.6rem;letter-spacing:0.24em}
.utility .u-right{text-align:right}
@media(max-width:680px){
  .utility .wrap{flex-direction:column;gap:4px;text-align:center}
  .utility .u-right{text-align:center}
}

/* ============================================================
   Masthead
   ============================================================ */
.masthead{padding:54px 0 0;text-align:center;animation:rise 0.9s ease-out both}
.masthead .pre{margin-bottom:20px;display:block}
.nameplate{
  font-family:var(--display);font-weight:600;
  font-size:clamp(3.2rem,9vw,6.6rem);line-height:0.92;letter-spacing:0.005em;color:var(--espresso);
}
.nameplate .the{
  display:block;font-size:0.26em;letter-spacing:0.42em;font-weight:500;
  text-transform:uppercase;color:var(--burgundy);margin-bottom:0.55em;font-family:var(--label);
}
.tagline{
  font-family:var(--display);font-style:italic;font-weight:400;
  font-size:clamp(1.1rem,2.4vw,1.5rem);color:var(--taupe);margin-top:18px;
}
.rule-set{display:flex;align-items:center;justify-content:center;gap:16px;margin:30px auto 0;max-width:560px}
.rule-set .line{flex:1;height:1px;background:var(--rule-strong)}
.rule-set .diamond{width:7px;height:7px;background:var(--burgundy);transform:rotate(45deg);flex:none}

/* ============================================================
   Section nav
   ============================================================ */
.sectnav{border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);margin-top:30px}
.sectnav .wrap{display:flex;justify-content:center;flex-wrap:wrap}
.sectnav a{
  font-family:var(--label);text-transform:uppercase;letter-spacing:0.2em;font-size:0.68rem;
  color:var(--espresso);padding:16px 22px;position:relative;transition:color 0.2s ease;
}
.sectnav a::after{
  content:"";position:absolute;left:22px;right:22px;bottom:10px;height:1px;
  background:var(--burgundy);transform:scaleX(0);transform-origin:center;transition:transform 0.25s ease;
}
.sectnav a:hover{color:var(--burgundy)}
.sectnav a:hover::after,.sectnav a:focus-visible::after{transform:scaleX(1)}
@media(max-width:680px){
  .sectnav a{padding:12px 14px;font-size:0.6rem;letter-spacing:0.16em}
}

/* ============================================================
   Lead feature
   ============================================================ */
.lead{padding:58px 0}
.lead-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:52px;align-items:center}
.feature-img{
  aspect-ratio:5/4;
  background:
    radial-gradient(120% 120% at 30% 20%, rgba(176,137,79,0.16), transparent 55%),
    linear-gradient(150deg,var(--espresso-soft),var(--burgundy-deep));
  border:1px solid var(--rule);position:relative;display:flex;align-items:flex-end;overflow:hidden;
}
.feature-img .imglabel{
  margin:18px;color:rgba(244,237,225,0.62);
  font-family:var(--label);text-transform:uppercase;letter-spacing:0.24em;font-size:0.58rem;
}
.feature-img .glass{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);opacity:0.5}
.lead-copy .eyebrow{color:var(--burgundy);margin-bottom:18px;display:block}
.lead-copy h1{
  font-family:var(--display);font-weight:600;
  font-size:clamp(2.1rem,4.4vw,3.2rem);line-height:1.04;letter-spacing:0.003em;margin-bottom:20px;
}
.lead-copy .dek{font-size:1.12rem;color:#3a322c;margin-bottom:24px;max-width:38ch}
.byline{font-family:var(--label);text-transform:uppercase;letter-spacing:0.2em;font-size:0.64rem;color:var(--taupe)}
.readmore{
  display:inline-block;margin-top:22px;
  font-family:var(--label);text-transform:uppercase;letter-spacing:0.18em;font-size:0.66rem;
  color:var(--burgundy);border-bottom:1px solid var(--burgundy);padding-bottom:3px;transition:opacity 0.2s ease;
}
.readmore:hover{opacity:0.65}
@media(max-width:840px){
  .lead-grid{grid-template-columns:1fr;gap:30px}
  .feature-img{aspect-ratio:16/10}
}

/* ============================================================
   Secondary stories
   ============================================================ */
.stories{padding-bottom:64px}
.band-head{display:flex;align-items:center;gap:18px;margin-bottom:34px}
.band-head .label{flex:none}
.band-head .line{flex:1;height:1px;background:var(--rule)}
.story-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:42px}
.story{border-top:2px solid var(--espresso);padding-top:20px}
.story .eyebrow{color:var(--burgundy);margin-bottom:14px;display:block}
.story h2,.story h3{font-family:var(--display);font-weight:600;font-size:1.62rem;line-height:1.1;margin-bottom:12px}
.story p{font-size:1rem;color:#473f38}
.story .card-link{display:block;transition:opacity 0.2s ease}
.story .card-link:hover{opacity:0.72}
@media(max-width:840px){
  .story-grid{grid-template-columns:1fr;gap:34px}
}

/* ============================================================
   From the Cellar List
   ============================================================ */
.cellar{background:var(--espresso);color:var(--cream);padding:72px 0}
.cellar .wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:start}
.cellar .intro .label{color:var(--brass)}
.cellar .intro h2{
  font-family:var(--display);font-weight:500;
  font-size:clamp(2rem,3.6vw,2.8rem);line-height:1.06;margin:18px 0 20px;color:var(--cream);
}
.cellar .intro p{color:rgba(244,237,225,0.78);font-size:1.06rem;max-width:40ch;margin-bottom:28px}
.cta-row{display:flex;flex-wrap:wrap;gap:12px}
.cta{
  display:inline-block;background:var(--burgundy);color:var(--cream);
  font-family:var(--label);text-transform:uppercase;letter-spacing:0.2em;font-size:0.68rem;
  padding:15px 28px;transition:background 0.2s ease;
}
.cta:hover{background:var(--burgundy-deep)}
.cta.ghost{background:transparent;border:1px solid var(--rule-light);color:var(--cream)}
.cta.ghost:hover{border-color:var(--brass);color:var(--brass);background:transparent}
.cl-head{
  text-align:center;font-family:var(--label);text-transform:uppercase;letter-spacing:0.3em;
  font-size:0.64rem;color:var(--brass);padding-bottom:14px;margin-bottom:22px;
  border-bottom:1px solid var(--rule-light);display:flex;align-items:center;justify-content:center;gap:14px;
}
.cl-head .d{width:6px;height:6px;background:var(--brass);transform:rotate(45deg)}
.pour{padding:16px 0;border-bottom:1px solid var(--rule-light)}
.pour:last-child{border-bottom:none}
.pour .top{display:flex;justify-content:space-between;align-items:baseline;gap:14px}
.pour .name{font-family:var(--display);font-weight:600;font-size:1.32rem;color:var(--cream)}
.pour .region{
  font-family:var(--label);text-transform:uppercase;letter-spacing:0.18em;
  font-size:0.56rem;color:var(--brass);flex:none;white-space:nowrap;
}
.pour .note{font-style:italic;color:rgba(244,237,225,0.72);font-size:1rem;margin-top:5px;max-width:46ch}
@media(max-width:840px){
  .cellar .wrap{grid-template-columns:1fr;gap:42px}
}

/* ============================================================
   Departments
   ============================================================ */
.depts{padding:66px 0}
.dept-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:34px;margin-top:34px}
.dept{padding-top:18px;border-top:1px solid var(--rule-strong)}
.dept .num{font-family:var(--display);font-style:italic;font-size:1.1rem;color:var(--burgundy);margin-bottom:8px}
.dept h2,.dept h3{font-family:var(--display);font-weight:600;font-size:1.34rem;margin-bottom:8px}
.dept p{font-size:0.95rem;color:#4a423b}
@media(max-width:840px){.dept-grid{grid-template-columns:1fr 1fr;gap:28px}}
@media(max-width:520px){.dept-grid{grid-template-columns:1fr}}

/* ============================================================
   Newsletter
   ============================================================ */
.news{
  background:var(--parchment);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
  padding:66px 0;text-align:center;
}
.news h2{font-family:var(--display);font-weight:600;font-size:clamp(1.9rem,3.6vw,2.7rem);line-height:1.05;margin-bottom:14px}
.news p{color:#473f38;font-size:1.08rem;max-width:46ch;margin:0 auto 30px}
.signup{display:flex;gap:10px;max-width:480px;margin:0 auto;justify-content:center;flex-wrap:wrap}
.signup input{
  flex:1;min-width:240px;font-family:var(--body);font-size:1rem;padding:14px 18px;
  background:var(--parchment-2);border:1px solid var(--rule-strong);color:var(--espresso);
}
.signup input::placeholder{color:#9b9087}
.signup input:focus{outline:2px solid var(--burgundy);outline-offset:1px}
.signup button{
  font-family:var(--label);text-transform:uppercase;letter-spacing:0.2em;font-size:0.68rem;
  background:var(--espresso);color:var(--cream);border:none;padding:14px 28px;cursor:pointer;transition:background 0.2s ease;
}
.signup button:hover{background:var(--burgundy)}
.news .fineprint{margin-top:16px;font-size:0.8rem;color:var(--taupe)}
.form-status{margin-top:18px;font-family:var(--label);text-transform:uppercase;letter-spacing:0.16em;font-size:0.7rem;color:var(--burgundy);min-height:1em}

/* ============================================================
   Footer
   ============================================================ */
footer{background:var(--espresso);color:var(--cream);padding:58px 0 30px}
.foot-top{
  display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;
  padding-bottom:34px;border-bottom:1px solid var(--rule-light);
}
.foot-name{font-family:var(--display);font-weight:600;font-size:2rem;line-height:1}
.foot-name .the{
  font-family:var(--label);font-size:0.6rem;letter-spacing:0.4em;text-transform:uppercase;
  color:var(--brass);display:block;margin-bottom:8px;font-weight:400;
}
.foot-disclosure{max-width:40ch;color:rgba(244,237,225,0.72);font-size:0.96rem}
.foot-disclosure a{color:var(--brass);border-bottom:1px solid rgba(176,137,79,0.4)}
.foot-nav{display:flex;gap:26px;flex-wrap:wrap}
.foot-nav a{
  font-family:var(--label);text-transform:uppercase;letter-spacing:0.16em;font-size:0.64rem;
  color:rgba(244,237,225,0.8);transition:color 0.2s ease;
}
.foot-nav a:hover{color:var(--brass)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;margin-top:26px}
.foot-bottom .label{color:rgba(244,237,225,0.5);font-size:0.58rem}
.foot-bottom a{color:rgba(244,237,225,0.7)}
.foot-bottom a:hover{color:var(--brass)}

/* ============================================================
   Interior pages (about, 404)
   ============================================================ */
.page-hero{padding:64px 0 10px;text-align:center}
.page-hero .eyebrow{color:var(--burgundy);display:block;margin-bottom:18px}
.page-hero h1{font-family:var(--display);font-weight:600;font-size:clamp(2.4rem,6vw,4rem);line-height:1;letter-spacing:0.004em}
.prose{max-width:680px;margin:0 auto;padding:44px 28px 72px}
.prose p{font-size:1.12rem;color:#3a322c;margin-bottom:22px}
.prose h2{font-family:var(--display);font-weight:600;font-size:1.9rem;margin:38px 0 14px}
.prose a{color:var(--burgundy);border-bottom:1px solid rgba(111,29,46,0.35)}
.prose a:hover{opacity:0.7}
.center-cta{text-align:center;padding:0 28px 80px}

/* ============================================================
   Motion + focus
   ============================================================ */
:focus-visible{outline:2px solid var(--burgundy);outline-offset:3px}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
/* Reveal is additive only: content is visible by default and stays visible
   without JS. When JS is present, .js-reveal sets the pre-animation state. */
.js-reveal.reveal{opacity:0;transform:translateY(16px);transition:opacity 0.6s ease,transform 0.6s ease}
.js-reveal.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important}
}
