/* ===== VineRoot — editorial natural aesthetic ===== */
:root{
  --ink:#1a1410;
  --ink-soft:#4a3f35;
  --cream:#f6f0e6;
  --cream-deep:#ede3d2;
  --grape:#4a1d4f;
  --grape-deep:#2d0f30;
  --vine:#3d5a2f;
  --vine-soft:#6b8a52;
  --amber:#c87f2d;
  --rose:#b85c6b;
  --line:rgba(26,20,16,.12);
  --shadow:0 2px 30px rgba(26,20,16,.08);
  --shadow-lg:0 24px 60px rgba(26,20,16,.18);
  --r:18px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Outfit',sans-serif;
  font-weight:400;
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
.container{max-width:1240px;margin:0 auto;padding:0 32px}
em{font-style:italic}

/* typography */
h1,h2,h3{font-family:'Fraunces',serif;font-weight:600;line-height:1.05;letter-spacing:-.02em;color:var(--ink)}
h1{font-size:clamp(2.8rem,7vw,5.2rem)}
h2{font-size:clamp(2.1rem,4.5vw,3.4rem)}
h3{font-size:1.5rem}
p{color:var(--ink-soft)}
.eyebrow{
  display:inline-block;font-family:'Outfit',sans-serif;font-size:.75rem;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.85);
  padding:8px 16px;border:1px solid rgba(255,255,255,.3);border-radius:100px;
  margin-bottom:24px;
}
.eyebrow.dark{color:var(--amber);border-color:rgba(200,127,45,.35);background:rgba(200,127,45,.06)}

/* buttons */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Outfit',sans-serif;font-weight:500;font-size:.95rem;
  padding:14px 28px;border-radius:100px;cursor:pointer;border:none;
  transition:all .3s cubic-bezier(.2,.8,.2,1);
}
.btn-primary{background:var(--grape);color:var(--cream)}
.btn-primary:hover{background:var(--grape-deep);transform:translateY(-2px);box-shadow:0 12px 30px rgba(74,29,79,.3)}
.btn-ghost{background:transparent;color:var(--cream);border:1px solid rgba(255,255,255,.4)}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.7)}
.btn i{transition:transform .3s}
.btn:hover i{transform:translateX(4px)}

/* reveal animation */
[data-reveal]{opacity:0;transform:translateY(30px);animation:reveal .9s cubic-bezier(.2,.8,.2,1) forwards}
@keyframes reveal{to{opacity:1;transform:translateY(0)}}

/* ===== NAV ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:all .4s ease;padding:20px 0;
}
.nav.scrolled{background:rgba(246,240,230,.92);backdrop-filter:blur(14px);padding:12px 0;box-shadow:0 1px 0 var(--line)}
.nav-inner{max-width:1240px;margin:0 auto;padding:0 32px;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{
  width:38px;height:38px;display:grid;place-items:center;border-radius:50%;
  background:var(--grape);color:var(--cream);font-size:1.2rem;
}
.brand-name{font-family:'Fraunces',serif;font-weight:600;font-size:1.4rem;letter-spacing:-.01em}
.nav.scrolled .brand-name,.nav.scrolled .nav-links a{color:var(--ink)}
.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{font-size:.92rem;font-weight:400;color:var(--cream);transition:color .3s}
.nav-links a:hover{color:var(--amber)}
.nav-cta{padding:8px 20px;border:1px solid rgba(255,255,255,.4);border-radius:100px}
.nav.scrolled .nav-cta{border-color:var(--grape);color:var(--grape)}
.nav.scrolled .nav-cta:hover{background:var(--grape);color:var(--cream)!important}
.nav-toggle{display:none;background:none;border:none;color:var(--cream);font-size:1.6rem;cursor:pointer}
.nav.scrolled .nav-toggle{color:var(--ink)}

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05)}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(115deg,rgba(26,20,16,.75) 0%,rgba(45,15,48,.55) 45%,rgba(26,20,16,.35) 100%);
}
.hero-content{position:relative;z-index:2;max-width:760px;padding:0 32px;margin:0 auto;width:100%}
.hero-content .eyebrow,.hero-content h1,.hero-content p,.hero-content .hero-actions{color:var(--cream)}
.hero-content p{color:rgba(255,255,255,.85);font-size:1.15rem;max-width:540px;margin-bottom:36px}
.hero-title em{color:var(--amber);font-style:italic;font-weight:500}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:6px;color:rgba(255,255,255,.7);font-size:.75rem;letter-spacing:.2em;text-transform:uppercase}
.hero-scroll i{animation:bob 2s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}

/* ===== STORY ===== */
.story{padding:120px 0;background:var(--cream)}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.story-text p{margin-bottom:20px;font-size:1.05rem}
.story-stats{display:flex;gap:40px;margin-top:40px;padding-top:36px;border-top:1px solid var(--line)}
.story-stats div{display:flex;flex-direction:column}
.story-stats strong{font-family:'Fraunces',serif;font-size:2.4rem;color:var(--grape);line-height:1}
.story-stats span{font-size:.85rem;color:var(--ink-soft);margin-top:6px}
.story-image{position:relative}
.story-image img{border-radius:var(--r);box-shadow:var(--shadow-lg);aspect-ratio:4/5;object-fit:cover;width:100%}
.image-caption{display:block;margin-top:14px;font-size:.85rem;color:var(--ink-soft);font-style:italic}

/* ===== VARIETIES ===== */
.varieties{padding:120px 0;background:var(--cream-deep)}
.section-head{max-width:680px;margin-bottom:64px}
.section-head p{font-size:1.1rem;margin-top:16px}
.grape-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.grape-card{
  background:var(--cream);border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow);transition:transform .4s cubic-bezier(.2,.8,.2,1),box-shadow .4s;
  display:flex;flex-direction:column;
}
.grape-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.grape-img{height:280px;overflow:hidden}
.grape-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.grape-card:hover .grape-img img{transform:scale(1.06)}
.grape-body{padding:28px 24px 32px}
.grape-body h3{margin-bottom:8px;color:var(--grape)}
.grape-tag{display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--vine);background:rgba(61,90,47,.1);padding:4px 12px;border-radius:100px;margin-bottom:16px}
.grape-body p{font-size:.95rem}
.varieties-foot{margin-top:48px;text-align:center}
.varieties-foot p{margin-bottom:12px}
.link-arrow{display:inline-flex;align-items:center;gap:6px;font-weight:500;color:var(--grape);border-bottom:1px solid var(--grape);padding-bottom:2px;transition:gap .3s}
.link-arrow:hover{gap:12px}

/* ===== GROW ===== */
.grow{padding:120px 0;background:var(--vine);color:var(--cream)}
.grow-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:center}
.grow-image img{border-radius:var(--r);aspect-ratio:4/5;object-fit:cover;width:100%;box-shadow:var(--shadow-lg)}
.grow-text h2{color:var(--cream)}
.grow-text p{color:rgba(255,255,255,.8);font-size:1.05rem;margin-bottom:32px}
.grow-list{list-style:none;display:flex;flex-direction:column;gap:20px}
.grow-list li{display:flex;gap:16px;align-items:flex-start;color:rgba(255,255,255,.9);font-size:.98rem}
.grow-list i{color:var(--amber);font-size:1.4rem;flex-shrink:0;margin-top:2px}
.grow-list strong{color:var(--cream);font-weight:600}

/* ===== EXPERIENCES ===== */
.experiences{padding:120px 0;background:var(--cream)}
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.exp-card{
  background:var(--cream-deep);border-radius:var(--r);padding:36px 28px;
  border:1px solid var(--line);transition:all .4s;position:relative;overflow:hidden;
}
.exp-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--amber);transform:scaleX(0);transform-origin:left;transition:transform .4s}
.exp-card:hover::before{transform:scaleX(1)}
.exp-card:hover{background:var(--cream);transform:translateY(-4px);box-shadow:var(--shadow)}
.exp-month{display:inline-block;font-family:'Fraunces',serif;font-style:italic;color:var(--amber);font-size:1rem;margin-bottom:12px}
.exp-card h3{margin-bottom:14px;color:var(--grape)}
.exp-card p{font-size:.95rem;margin-bottom:20px}
.exp-meta{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--ink-soft);font-weight:500}
.exp-meta i{color:var(--vine)}

/* ===== TESTIMONIALS ===== */
.testimonials{padding:120px 0;background:var(--cream-deep)}
.quote-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
blockquote{
  background:var(--cream);padding:36px 28px;border-radius:var(--r);
  border-left:3px solid var(--amber);box-shadow:var(--shadow);
}
blockquote p{font-family:'Fraunces',serif;font-style:italic;font-size:1.1rem;color:var(--ink);line-height:1.5;margin-bottom:24px}
blockquote footer{display:flex;flex-direction:column}
blockquote strong{font-weight:600;color:var(--grape)}
blockquote span{font-size:.85rem;color:var(--ink-soft)}

/* ===== VISIT ===== */
.visit{padding:120px 0;background:var(--cream)}
.visit-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:80px;align-items:center}
.visit-text p{font-size:1.05rem;margin-bottom:32px;max-width:520px}
.subscribe-form{display:flex;gap:12px;max-width:480px;margin-bottom:16px}
.subscribe-form input{
  flex:1;padding:14px 20px;border:1px solid var(--line);border-radius:100px;
  background:var(--cream-deep);font-family:'Outfit',sans-serif;font-size:.95rem;color:var(--ink);
  transition:border-color .3s;
}
.subscribe-form input:focus{outline:none;border-color:var(--grape)}
.form-note{font-size:.85rem;color:var(--ink-soft)}
.visit-card{
  background:var(--grape-deep);border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow-lg);color:var(--cream);
}
.visit-card img{width:100%;height:240px;object-fit:cover}
.visit-card-body{padding:32px 28px}
.visit-card-body h3{color:var(--cream);margin-bottom:20px}
.visit-card-body ul{list-style:none;margin-bottom:24px}
.visit-card-body li{display:flex;align-items:center;gap:10px;padding:8px 0;color:rgba(255,255,255,.85);font-size:.95rem}
.visit-card-body i{color:var(--amber)}
.price{font-family:'Fraunces',serif;font-size:2.2rem;color:var(--amber)}
.price small{font-size:1rem;color:rgba(255,255,255,.6)}

/* ===== FOOTER ===== */
.footer{background:var(--ink);color:rgba(255,255,255,.7);padding:60px 0}
.footer-inner{display:grid;grid-template-columns:1fr auto 1fr;gap:40px;align-items:center}
.footer-brand{display:flex;align-items:center;gap:12px}
.footer-brand strong{color:var(--cream);font-family:'Fraunces',serif;font-size:1.2rem}
.footer-brand span{display:block;font-size:.8rem}
.footer-links{display:flex;gap:24px}
.footer-links a{font-size:.9rem;transition:color .3s}
.footer-links a:hover{color:var(--amber)}
.footer-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;font-size:.8rem;text-align:right}

/* ===== RESPONSIVE ===== */
@media(max-width:900px){
  .nav-links{display:none}
  .nav-toggle{display:block}
  .nav-links.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:rgba(246,240,230,.97);backdrop-filter:blur(14px);padding:24px;gap:18px;box-shadow:var(--shadow)}
  .nav-links.open a{color:var(--ink)!important}
  .story-grid,.grow-grid,.visit-inner{grid-template-columns:1fr;gap:48px}
  .grape-grid,.exp-grid,.quote-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr;text-align:center}
  .footer-brand{justify-content:center}
  .footer-meta{align-items:center;text-align:center}
  .footer-links{justify-content:center}
  .subscribe-form{flex-direction:column}
  .subscribe-form .btn{justify-content:center}
}
@media(max-width:600px){
  .container{padding:0 20px}
  .story-stats{flex-wrap:wrap;gap:24px}
  .hero-actions{flex-direction:column;align-items:stretch}
  .btn{justify-content:center}
}
