:root {
  --cream:      #f7f0e6;
  --parchment:  #ede3d1;
  --wine:       #8b1a3a;
  --wine-deep:  #4a0e20;
  --wine-mid:   #b04060;
  --gold:       #c4933a;
  --gold-pale:  #e8d5a3;
  --charcoal:   #1c1410;
  --ink:        #2a1f18;
  --muted:      #7a5c62;
  --rust:       #c05a30;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--ink);overflow-x:hidden;cursor:none;}

/* Visually hidden (for accessible labels) */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}

/* ── CURSOR ── */
.cursor{width:14px;height:14px;background:var(--wine);border:2px solid #fff;border-radius:50%;position:fixed;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .3s,height .3s,background .3s;}
.cursor-ring{width:36px;height:36px;border:1px solid var(--wine);border-radius:50%;position:fixed;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .3s,height .3s;opacity:.45;}

/* ── NOISE OVERLAY ── */
body::after{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");pointer-events:none;z-index:500;opacity:.5;}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:1.1rem 3.5rem;background:rgba(247,240,230,.9);backdrop-filter:blur(16px);border-bottom:1px solid rgba(139,26,58,.1);}
.nav-logo{display:flex;align-items:baseline;gap:.5rem;}
.nav-logo .vino{font-family:'Bebas Neue',sans-serif;font-size:2rem;color:var(--wine);letter-spacing:.05em;line-height:1;}
.nav-logo .and-vibes{font-family:'Reenie Beanie',cursive;font-size:1.4rem;color:var(--gold);}
.nav-links{display:flex;gap:2.5rem;list-style:none;}
.nav-links a{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);text-decoration:none;position:relative;transition:color .3s;}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1.5px;background:var(--rust);transition:width .35s ease;}
.nav-links a:hover{color:var(--wine);}
.nav-links a:hover::after{width:100%;}

/* ── HERO ── */
.hero{min-height:100vh;display:grid;grid-template-columns:55% 45%;position:relative;overflow:hidden;background:var(--cream);}
.hero-sketch{position:absolute;inset:0;width:100%;height:100%;opacity:.07;z-index:0;}
.hero-left{display:flex;flex-direction:column;justify-content:center;padding:10rem 4rem 5rem 5.5rem;position:relative;z-index:2;}
.hero-stamp{display:inline-block;border:2px solid var(--rust);padding:.25rem .8rem;font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--rust);width:fit-content;margin-bottom:1.8rem;opacity:0;animation:fadeUp .7s .2s forwards;transform:rotate(-1.5deg);}
.hero-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(5rem,9vw,10rem);line-height:.92;color:var(--wine-deep);letter-spacing:.03em;opacity:0;animation:fadeUp .9s .4s forwards;}
.hero-title .italic-v{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(4rem,8vw,9rem);color:var(--wine);display:block;}
.hero-amp{font-family:'Reenie Beanie',cursive;font-size:clamp(2rem,4vw,4rem);color:var(--gold);display:block;margin-left:2rem;opacity:0;animation:fadeUp .9s .55s forwards;}
.hero-tagline{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.2rem;line-height:1.7;color:var(--muted);max-width:380px;margin:1.8rem 0 2.5rem;opacity:0;animation:fadeUp .9s .75s forwards;}
.hero-cta{display:inline-flex;align-items:center;gap:.9rem;background:var(--wine-deep);color:var(--cream);text-decoration:none;font-size:.75rem;letter-spacing:.22em;text-transform:uppercase;padding:.95rem 2.2rem;width:fit-content;position:relative;overflow:hidden;opacity:0;animation:fadeUp .9s 1s forwards;transition:color .35s;}
.hero-cta::before{content:'';position:absolute;inset:0;background:var(--rust);transform:translateX(-105%);transition:transform .4s cubic-bezier(.77,0,.175,1);z-index:0;}
.hero-cta:hover::before{transform:translateX(0);}
.hero-cta span,.hero-cta svg{position:relative;z-index:1;}
.hero-right{position:relative;background:var(--wine-deep);overflow:hidden;}
.hero-right-img{position:absolute;top:55px;right:0;bottom:0;left:0;z-index:2;}.hero-right-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:top right;display:block;}
.hero-right-img2{display:none;}
.hero-counter{position:absolute;top:12rem;right:2.5rem;writing-mode:vertical-rl;font-family:'Bebas Neue',sans-serif;font-size:.9rem;letter-spacing:.4em;color:rgba(247,240,230,.35);z-index:3;}
.hero-rule{position:absolute;bottom:2rem;left:4rem;display:flex;align-items:center;gap:1rem;font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);z-index:3;opacity:0;animation:fadeIn 1s 1.8s forwards;}
.hero-rule-line{width:50px;height:1px;background:var(--gold);flex-shrink:0;}

/* ── WELCOME ── */
.welcome{padding:8rem 5.5rem;display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center;position:relative;overflow:hidden;background:var(--parchment);}
.welcome-sketch{position:absolute;right:-60px;top:50%;transform:translateY(-50%);width:55%;opacity:.055;z-index:0;}
.welcome-text{position:relative;z-index:2;}
.eyebrow{font-family:'Reenie Beanie',cursive;font-size:1.5rem;color:var(--rust);margin-bottom:.5rem;transform:rotate(-1deg);display:inline-block;}
.section-tag{font-size:.65rem;letter-spacing:.35em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem;display:flex;align-items:center;gap:.8rem;}
.section-tag::before{content:'';width:28px;height:1px;background:var(--gold);flex-shrink:0;}
.welcome h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.5rem,4vw,4rem);line-height:1;color:var(--wine-deep);letter-spacing:.04em;margin-bottom:.4rem;}
.welcome h2 em{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(2rem,3vw,3rem);color:var(--wine-mid);display:block;letter-spacing:0;}
.rule-gold{width:50px;height:2px;background:var(--gold);margin:1.4rem 0;}
.welcome p{font-family:'Cormorant Garamond',serif;font-size:1.15rem;line-height:1.85;color:#3d2a2e;margin-bottom:1rem;}
.welcome-collage{position:relative;height:520px;z-index:2;}
.wc-img{position:absolute;background-size:cover;background-position:center;background-repeat:no-repeat;}
.wc-1{top:0;right:0;width:72%;height:340px;background-image:url('../images/welcome-wine-pour.jpg');box-shadow:8px 8px 0 var(--wine);}
.wc-2{bottom:0;left:0;width:52%;height:240px;background-image:url('../images/welcome-wine-tasting.jpg');box-shadow:-6px 6px 0 var(--gold);border:5px solid var(--cream);}
.wc-caption{position:absolute;bottom:2.5rem;right:-1.5rem;background:var(--wine-deep);color:var(--cream);padding:1rem 1.4rem;font-family:'Reenie Beanie',cursive;font-size:1.2rem;line-height:1.4;width:180px;transform:rotate(2deg);box-shadow:4px 4px 0 var(--gold);z-index:5;}

/* ── BLOG ── */
.blog{padding:7rem 5.5rem;background:var(--cream);position:relative;overflow:hidden;}
.blog-sketch{position:absolute;bottom:0;left:0;width:100%;height:60%;opacity:.05;z-index:0;}
.blog-header{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:flex-end;margin-bottom:4rem;position:relative;z-index:2;}
.blog-header h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.5rem,4.5vw,5rem);line-height:.95;color:var(--wine-deep);letter-spacing:.03em;}
.blog-header h2 em{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;color:var(--rust);font-size:.7em;letter-spacing:0;}
.blog-header-right{border-left:2px solid var(--gold);padding-left:1.8rem;}
.blog-header-right p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.1rem;line-height:1.7;color:var(--muted);}
.blog-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:1.5rem;position:relative;z-index:2;}
.blog-card{position:relative;overflow:hidden;cursor:none;background:var(--parchment);}
.blog-card-img{width:100%;height:380px;display:block;background-size:cover;background-position:center;transition:transform .7s cubic-bezier(.25,.46,.45,.94);filter:saturate(.85);}
.blog-card:hover .blog-card-img{transform:scale(1.06);filter:saturate(1);}
.blog-card-featured .blog-card-img{height:480px;}
.blog-card-body{padding:1.6rem 1.8rem 2rem;}
.blog-tag{font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;color:var(--rust);margin-bottom:.6rem;}
.blog-card h3{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;line-height:1.25;color:var(--wine-deep);margin-bottom:.7rem;transition:color .3s;}
.blog-card:hover h3{color:var(--wine);}
.blog-card p{font-family:'Cormorant Garamond',serif;font-size:1rem;line-height:1.7;color:var(--muted);}
.blog-link{display:inline-flex;align-items:center;gap:.5rem;margin-top:1rem;font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--wine);text-decoration:none;border-bottom:1px solid currentColor;padding-bottom:1px;transition:gap .3s,color .3s;}
.blog-link:hover{gap:1rem;color:var(--rust);}
.blog-link-soon{color:var(--muted);border-color:var(--muted);cursor:default;pointer-events:none;opacity:.6;}
.blog-card-draft{opacity:.75;}
.blog-side{display:flex;flex-direction:column;gap:1.5rem;}

/* ── "Previous Posts" link ── */
.blog-archive-link{display:inline-flex;align-items:center;justify-content:center;gap:.9rem;margin-top:.4rem;padding:1rem 1.4rem;background:var(--wine-deep);color:var(--cream);text-decoration:none;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;position:relative;overflow:hidden;transition:color .35s;align-self:center;width:100%;}
.blog-archive-link::before{content:'';position:absolute;inset:0;background:var(--rust);transform:translateX(-105%);transition:transform .4s cubic-bezier(.77,0,.175,1);z-index:0;}
.blog-archive-link:hover::before{transform:translateX(0);}
.blog-archive-link span,.blog-archive-link svg{position:relative;z-index:1;}
.blog-archive-link svg{transition:transform .3s;}
.blog-archive-link:hover svg{transform:translateX(4px);}

/* ═══════════════════════════════════════════
   NEWSLETTER
   ═══════════════════════════════════════════ */
.newsletter{padding:6rem 5.5rem;background:var(--parchment);position:relative;overflow:hidden;}
.newsletter-inner{max-width:640px;margin:0 auto;text-align:center;position:relative;z-index:2;}
.newsletter-inner .eyebrow{display:inline-block;}
.newsletter-inner h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.2rem,3.5vw,3.5rem);line-height:1;color:var(--wine-deep);letter-spacing:.04em;margin-bottom:.4rem;}
.newsletter-inner h2 em{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(1.8rem,2.8vw,2.8rem);color:var(--wine-mid);display:block;letter-spacing:0;}
.newsletter-inner .rule-gold{margin:1.4rem auto;}
.newsletter-inner > p{font-family:'Cormorant Garamond',serif;font-size:1.15rem;line-height:1.8;color:#3d2a2e;margin:0 auto 2rem;max-width:520px;}
/* Simple CTA button — no form, just links to Substack */
.newsletter-btn{display:inline-flex;align-items:center;gap:.9rem;background:var(--wine-deep);color:var(--cream);text-decoration:none;font-size:.75rem;letter-spacing:.22em;text-transform:uppercase;padding:.95rem 2.4rem;position:relative;overflow:hidden;transition:color .35s;}
.newsletter-btn::before{content:'';position:absolute;inset:0;background:var(--rust);transform:translateX(-105%);transition:transform .4s cubic-bezier(.77,0,.175,1);z-index:0;}
.newsletter-btn:hover::before{transform:translateX(0);}
.newsletter-btn span,.newsletter-btn svg{position:relative;z-index:1;}
.newsletter-btn svg{transition:transform .3s;}
.newsletter-btn:hover svg{transform:translateX(4px);}
.newsletter-fineprint{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:.9rem;color:var(--muted);margin-top:1.2rem !important;}

/* ── ABOUT ── */
.about{background:var(--wine-deep);padding:8rem 5.5rem;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;position:relative;overflow:hidden;}
.about-sketch{position:absolute;inset:0;width:100%;height:100%;opacity:.07;z-index:0;}
.about-text{position:relative;z-index:2;}
.about .section-tag{color:var(--gold-pale);}
.about .section-tag::before{background:var(--gold-pale);}
.about h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.5rem,4vw,4.5rem);color:var(--cream);line-height:1;letter-spacing:.04em;margin-bottom:.3rem;}
.about h2 em{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;color:var(--gold-pale);font-size:.75em;display:block;letter-spacing:0;}
.about .rule-gold{margin:1.4rem 0;background:var(--gold);}
.about p{font-family:'Cormorant Garamond',serif;font-size:1.15rem;line-height:1.85;color:rgba(247,240,230,.72);margin-bottom:1rem;}
.about-link{display:inline-flex;align-items:center;gap:.8rem;color:var(--gold-pale);text-decoration:none;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;border-bottom:1px solid rgba(232,213,163,.4);padding-bottom:3px;transition:all .35s;}
.about-link:hover{color:var(--cream);border-color:var(--cream);gap:1.2rem;}
.about-mosaic{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:.8rem;position:relative;z-index:2;}
.am{background-size:cover;background-position:center;filter:saturate(.7) brightness(.85);transition:filter .5s;}
.am:hover{filter:saturate(1) brightness(1);}
.am-1{grid-column:1/3;height:240px;background-image:url('../images/about-vineyard-landscape.jpg');border-bottom:3px solid var(--gold);}
.am-2{height:180px;background-image:url('../images/about-wine-cellar-barrels.jpg');}
.am-3{height:180px;background-image:url('../images/about-wine-glass-closeup.jpg');border-left:3px solid var(--wine-mid);}

/* ── FOOTER ── */
footer{background:var(--charcoal);color:var(--cream);padding:5rem 5.5rem 2.5rem;position:relative;overflow:hidden;}
.footer-sketch{position:absolute;inset:0;width:100%;height:100%;opacity:.04;z-index:0;}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr;gap:4rem;margin-bottom:4rem;position:relative;z-index:2;}
.footer-brand .big-logo{font-family:'Bebas Neue',sans-serif;font-size:3rem;color:var(--cream);letter-spacing:.05em;line-height:1;}
.footer-brand .big-logo span{font-family:'Reenie Beanie',cursive;font-size:2rem;color:var(--gold);letter-spacing:0;}
.footer-brand p{margin-top:1rem;font-family:'Cormorant Garamond',serif;font-size:1rem;line-height:1.7;color:rgba(247,240,230,.45);max-width:300px;}
.footer-col h4{font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem;}
.footer-col ul{list-style:none;}
.footer-col ul li{margin-bottom:.55rem;}
.footer-col ul a{font-family:'Cormorant Garamond',serif;font-size:1rem;color:rgba(247,240,230,.55);text-decoration:none;transition:color .3s;}
.footer-col ul a:hover{color:var(--cream);}
.footer-bottom{border-top:1px solid rgba(247,240,230,.07);padding-top:2rem;display:flex;justify-content:space-between;align-items:center;font-size:.68rem;letter-spacing:.12em;color:rgba(247,240,230,.25);position:relative;z-index:2;}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(32px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
@keyframes slideUp{from{opacity:0;transform:translateY(30px);}to{opacity:1;transform:translateY(0);}}
.reveal{opacity:0;transform:translateY(36px);transition:opacity .85s ease,transform .85s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}
.reveal-delay-2{transition-delay:.2s;}

/* ═══════════════════════════════════════════
   PREVIOUS POSTS (archive) PAGE
   ═══════════════════════════════════════════ */
.archive-page{padding:10rem 5.5rem 6rem;background:var(--cream);position:relative;overflow:hidden;min-height:70vh;}
.archive-header{max-width:1200px;margin:0 auto 4rem;position:relative;z-index:2;}
.archive-header .section-tag{margin-bottom:1rem;}
.archive-header h1{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.8rem,5vw,5rem);line-height:.95;color:var(--wine-deep);letter-spacing:.03em;margin-bottom:.6rem;}
.archive-header h1 em{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;color:var(--rust);font-size:.7em;letter-spacing:0;}
.archive-header .archive-intro{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.15rem;line-height:1.7;color:var(--muted);max-width:640px;margin-top:1.2rem;}
.archive-rule{width:60px;height:2px;background:var(--gold);margin:1.4rem 0 1.6rem;}
.archive-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem;position:relative;z-index:2;}
.archive-card{background:var(--parchment);overflow:hidden;cursor:none;display:flex;flex-direction:column;transition:transform .45s ease,box-shadow .45s ease;}
.archive-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(74,14,32,.1);}
.archive-card-img{width:100%;height:220px;background-size:cover;background-position:center;transition:transform .7s cubic-bezier(.25,.46,.45,.94);filter:saturate(.85);}
.archive-card:hover .archive-card-img{transform:scale(1.06);filter:saturate(1);}
.archive-card-body{padding:1.6rem 1.8rem 2rem;display:flex;flex-direction:column;flex:1;}
.archive-card-date{font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem;}
.archive-card .blog-tag{margin-bottom:.5rem;}
.archive-card h3{font-family:'Cormorant Garamond',serif;font-size:1.45rem;font-weight:600;line-height:1.25;color:var(--wine-deep);margin-bottom:.7rem;transition:color .3s;}
.archive-card:hover h3{color:var(--wine);}
.archive-card p{font-family:'Cormorant Garamond',serif;font-size:1rem;line-height:1.65;color:var(--muted);margin-bottom:1.2rem;flex:1;}
.archive-empty{max-width:640px;margin:3rem auto;text-align:center;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.15rem;color:var(--muted);}
.archive-back{max-width:1200px;margin:4rem auto 0;position:relative;z-index:2;}
.archive-back a{display:inline-flex;align-items:center;gap:.6rem;font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--wine);text-decoration:none;border-bottom:1px solid currentColor;padding-bottom:2px;transition:gap .3s,color .3s;}
.archive-back a:hover{gap:1rem;color:var(--rust);}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  nav{padding:1rem 1.5rem;}
  .nav-links{gap:1.3rem;}
  .hero{grid-template-columns:1fr;}
  .hero-right{height:45vh;clip-path:none;}
  .hero-left{padding:8rem 2rem 3rem;}
  .welcome,.about,.first-post{padding:5rem 2rem;}
  .welcome,.about{grid-template-columns:1fr;gap:3rem;}
  .blog{padding:5rem 2rem;}
  .blog-header,.blog-grid{grid-template-columns:1fr;}
  .newsletter{padding:4rem 1.5rem;}
  footer{padding:3rem 2rem;}
  .footer-grid{grid-template-columns:1fr;gap:2rem;}
  .archive-page{padding:8rem 1.5rem 4rem;}
  .archive-grid{grid-template-columns:1fr;gap:1.5rem;}
}
