/* Turner Vineyard — a private offering. Immersive single-page site. */

@font-face{font-family:"EB Garamond";src:url("fonts/EBGaramond-Regular.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:"EB Garamond";src:url("fonts/EBGaramond-Italic.woff2") format("woff2");font-weight:400;font-style:italic;font-display:swap;}
@font-face{font-family:"EB Garamond SC";src:url("fonts/EBGaramond-SC.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap;}

:root{
  --paper:#FBF8F1; --ink:#211E19; --ink-soft:#4A443B; --oak:#6E5A40; --cream:#F4EDDF; --dark:#191510;
  --measure:34rem;
  --pad: clamp(1.5rem, 6vw, 7rem);
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  background:var(--paper); color:var(--ink);
  font-family:"EB Garamond","Iowan Old Style",Georgia,serif;
  font-size:clamp(1.05rem,0.6rem + 0.9vw,1.32rem); line-height:1.66;
  font-feature-settings:"onum" 1,"liga" 1,"kern" 1;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;width:100%;height:100%;object-fit:cover;}
a{color:inherit;}

/* ---- shared type ---- */
.kicker{
  font-family:"EB Garamond SC","EB Garamond",serif;
  font-size:.74rem; letter-spacing:.34em; text-transform:none;
  color:var(--oak); margin:0 0 1.3em; padding-left:.04em;
}
.kicker--light{color:rgba(246,237,223,.92);}
.locator{font-family:"EB Garamond SC",serif;font-size:.82rem;letter-spacing:.26em;color:var(--oak);}
.locator--light{color:rgba(246,237,223,.86);}

/* ---- top bar ---- */
.topbar{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; justify-content:space-between; align-items:center;
  padding:1.25rem var(--pad); pointer-events:none;
  opacity:0; transition:opacity .8s ease;
  mix-blend-mode:difference; color:#fff;
}
.topbar.is-shown{opacity:1;}
.topbar a{pointer-events:auto;text-decoration:none;}
.topbar__mark{font-size:1.12rem;letter-spacing:.02em;}
.topbar__link{font-family:"EB Garamond SC",serif;font-size:.72rem;letter-spacing:.28em;}

/* ---- hero ---- */
.hero{position:relative;height:100svh;min-height:40rem;overflow:hidden;display:flex;align-items:flex-end;}
.hero__bg{position:absolute;inset:0;z-index:0;}
.hero__bg img{transform:scale(1.02);animation:kenburns 26s ease-out forwards;}
@keyframes kenburns{from{transform:scale(1.02);}to{transform:scale(1.12);}}
.hero__scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top,rgba(12,9,6,.66) 0%,rgba(12,9,6,.18) 34%,rgba(12,9,6,0) 60%),
             linear-gradient(to bottom,rgba(12,9,6,.32) 0%,rgba(12,9,6,0) 22%);}
.hero__content{position:relative;z-index:2;padding:0 var(--pad) clamp(2.5rem,7vh,6rem);max-width:46rem;
  opacity:0;transform:translateY(18px);animation:rise 1.4s .25s cubic-bezier(.2,.7,.2,1) forwards;color:var(--cream);}
@keyframes rise{to{opacity:1;transform:none;}}
.hero__title{font-size:clamp(3.1rem,2rem + 5.4vw,6.4rem);line-height:.98;font-weight:400;letter-spacing:.005em;margin:.06em 0 .18em;}
.hero__line{font-style:italic;font-size:clamp(1.12rem,.9rem + .7vw,1.6rem);color:rgba(246,237,223,.92);max-width:32rem;margin-top:1.1rem;line-height:1.4;}

.scrollcue{position:absolute;left:50%;bottom:1.6rem;z-index:3;width:1px;height:3.2rem;transform:translateX(-50%);overflow:hidden;}
.scrollcue span{position:absolute;inset:0;background:rgba(246,237,223,.6);animation:cue 2.4s ease-in-out infinite;}
@keyframes cue{0%{transform:translateY(-100%);}50%{transform:translateY(0);}100%{transform:translateY(100%);}}

/* ---- interlude (calm paper statement) ---- */
.interlude{padding:clamp(6rem,16vh,12rem) var(--pad);display:flex;justify-content:center;}
.interlude__text{max-width:46rem;font-size:clamp(1.5rem,1rem + 1.7vw,2.5rem);line-height:1.42;font-style:italic;color:var(--ink);text-align:left;text-wrap:balance;}

/* ---- full-bleed scenes ---- */
.scene{position:relative;height:84svh;min-height:34rem;overflow:hidden;display:flex;align-items:flex-end;}
.scene--tall{height:100svh;min-height:42rem;}
.scene__bg{position:absolute;inset:-6% 0;z-index:0;}
.scene__bg img{height:110%;}
.scene__scrim{position:absolute;inset:0;z-index:1;}
.scene__scrim--bottom{background:linear-gradient(to top,rgba(12,9,6,.72) 0%,rgba(12,9,6,.2) 38%,rgba(12,9,6,0) 66%);}
.scene__content{position:relative;z-index:2;padding:0 var(--pad) clamp(2.5rem,7vh,5.5rem);max-width:42rem;color:var(--cream);}
.scene__text{font-size:clamp(1.1rem,.9rem + .55vw,1.42rem);line-height:1.56;color:rgba(246,237,223,.94);}

/* ---- feature (paper, image + text) ---- */
.feature{display:grid;grid-template-columns:1.1fr .9fr;align-items:center;gap:clamp(2rem,5vw,5.5rem);
  padding:clamp(5rem,12vh,9rem) var(--pad);}
.feature__media{aspect-ratio:4/3;overflow:hidden;}
.feature__media img{transition:transform 1.6s ease;}
.feature:hover .feature__media img{transform:scale(1.03);}
.feature__body{max-width:30rem;}
.feature__text{font-size:clamp(1.05rem,.9rem + .4vw,1.28rem);color:var(--ink-soft);}

/* ---- duo ---- */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:clamp(.5rem,1.5vw,1.5rem);padding:0 0 clamp(1rem,3vh,2.5rem);}
.duo__item{position:relative;aspect-ratio:3/2;overflow:hidden;}
.cap{position:absolute;left:0;right:0;bottom:0;padding:2rem 1.6rem .95rem;
  font-family:"EB Garamond SC",serif;font-size:.72rem;letter-spacing:.22em;color:#fff;
  background:linear-gradient(to top,rgba(12,9,6,.8),rgba(12,9,6,.1) 70%,rgba(12,9,6,0));}

/* ---- offering ---- */
.offer{max-width:50rem;margin:0 auto;padding:clamp(6rem,15vh,11rem) var(--pad);text-align:center;}
.offer .kicker{display:block;}
.offer__lead{font-size:clamp(1.4rem,1rem + 1.4vw,2.15rem);line-height:1.42;text-wrap:balance;margin-bottom:1.6em;}
.offer__facts{font-family:"EB Garamond SC",serif;font-size:clamp(.82rem,.78rem + .2vw,.96rem);letter-spacing:.13em;
  line-height:2.1;color:var(--ink);max-width:40rem;margin:0 auto 1.8em;}
.offer__note{font-style:italic;color:var(--ink-soft);}

/* ---- enquiry ---- */
.enquire{background:var(--dark);color:var(--cream);padding:clamp(6rem,16vh,11rem) var(--pad);text-align:center;}
.enquire__inner{max-width:40rem;margin:0 auto;}
.enquire__line{font-size:clamp(1.3rem,1rem + 1vw,1.85rem);line-height:1.5;font-style:italic;color:rgba(246,237,223,.95);margin-bottom:2.2rem;}
.enquire__btn{display:inline-block;text-decoration:none;font-family:"EB Garamond SC",serif;letter-spacing:.24em;font-size:.8rem;
  color:var(--cream);border:1px solid rgba(246,237,223,.5);padding:1.05rem 2.4rem;transition:background .5s ease,color .5s ease,border-color .5s ease;}
.enquire__btn:hover{background:var(--cream);color:var(--dark);border-color:var(--cream);}
.enquire__contact{margin-top:2rem;font-family:"EB Garamond SC",serif;letter-spacing:.18em;font-size:.78rem;color:rgba(246,237,223,.55);}

/* ---- footer ---- */
.foot{background:var(--dark);color:rgba(246,237,223,.5);padding:0 var(--pad) clamp(3rem,8vh,5rem);text-align:center;border-top:1px solid rgba(246,237,223,.1);padding-top:clamp(2.5rem,6vh,4rem);}
.foot p{font-family:"EB Garamond SC",serif;letter-spacing:.16em;font-size:.74rem;line-height:2;}
.foot__fine{font-family:"EB Garamond",serif;letter-spacing:0;font-style:italic;font-size:.92rem;color:rgba(246,237,223,.4);margin-top:.6rem;}

/* ---- reveal ---- */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity 1.1s cubic-bezier(.2,.7,.2,1),transform 1.1s cubic-bezier(.2,.7,.2,1);}
[data-reveal].is-visible{opacity:1;transform:none;}
.scene__content [data-reveal]:nth-child(2){transition-delay:.12s;}

/* ---- focus + fallbacks ---- */
:focus-visible{outline:2px solid currentColor;outline-offset:3px;border-radius:1px;}
@supports not (mix-blend-mode:difference){
  .topbar{mix-blend-mode:normal;color:var(--cream);text-shadow:0 1px 10px rgba(0,0,0,.5);}
}

/* ---- responsive ---- */
@media (max-width:820px){
  .feature{grid-template-columns:1fr;gap:1.8rem;}
  .feature__media{aspect-ratio:3/2;}
  .duo{grid-template-columns:1fr;}
  .hero__content,.scene__content{max-width:none;}
  .interlude__text,.offer__lead{font-size:clamp(1.45rem,4.6vw,2rem);}
}

/* ---- reduced motion ---- */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;}
  .hero__bg img{animation:none;transform:none;}
  [data-reveal]{opacity:1;transform:none;}
  .scrollcue{display:none;}
}
