/* =========================================================
   VINO BROTHERS — Premium Wine Importer
   Design system + layout + scroll motion
   ========================================================= */

:root{
  --bg:#0b0a08;            /* near-black, warm */
  --bg-2:#111010;
  --bg-3:#16140f;
  --cream:#f4efe4;         /* primary text */
  --cream-dim:#bdb7a8;
  --gold:#c8a96a;          /* champagne gold */
  --gold-2:#e3c98f;
  --gold-deep:#9b8049;
  --line:rgba(200,169,106,.22);
  --maxw:1280px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --serif:"Cormorant Garamond","Noto Serif KR",serif;
  --kserif:"Noto Serif KR",serif;
  --sans:"Pretendard","Pretendard Variable",system-ui,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  background:var(--bg);
  color:var(--cream);
  font-family:var(--sans);
  font-weight:400;
  line-height:1.7;
  letter-spacing:-.01em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;width:100%;height:100%;object-fit:cover}
a{color:inherit;text-decoration:none}
em{font-style:italic;color:var(--gold-2)}
::selection{background:var(--gold);color:#1a1206}

/* ---------- scroll progress ---------- */
.scroll-progress{
  position:fixed;top:0;left:0;height:2px;width:0;z-index:120;
  background:linear-gradient(90deg,var(--gold-deep),var(--gold-2));
  box-shadow:0 0 12px rgba(200,169,106,.6);
}

/* ---------- shared ---------- */
.section-tag{
  font-family:var(--sans);
  font-size:.72rem;font-weight:600;letter-spacing:.32em;
  color:var(--gold);text-transform:uppercase;margin-bottom:1.4rem;
}
.section-tag.light{color:var(--gold-2)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:.5em;padding:.95em 2.1em;border-radius:100px;
  font-size:.92rem;font-weight:600;letter-spacing:.02em;
  cursor:pointer;border:1px solid transparent;
  transition:transform .4s var(--ease),background .4s var(--ease),
             color .4s var(--ease),box-shadow .4s var(--ease);
}
.btn--lg{padding:1.1em 2.6em;font-size:1rem}
.btn--gold{
  background:linear-gradient(135deg,var(--gold-2),var(--gold));
  color:#1c1304;box-shadow:0 8px 30px rgba(200,169,106,.22);
}
.btn--gold:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(200,169,106,.4)}
.btn--ghost{border-color:rgba(244,239,228,.35);color:var(--cream)}
.btn--ghost:hover{background:rgba(244,239,228,.08);border-color:var(--cream);transform:translateY(-3px)}

/* ---------- reveal animation ----------
   Two layers:
   1) Fallback (older browsers): JS adds .in once via IntersectionObserver.
   2) Scroll-driven (modern): the @supports block below re-binds the same
      elements to a view() timeline so they SCRUB in/out with the wheel —
      i.e. the motion reverses as you scroll back up (Apple-style). */
.reveal{opacity:0;transform:translateY(38px);
  transition:opacity 1s var(--ease),transform 1.1s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
}

/* ---------- scroll-driven (scrubbed) motion ---------- */
@keyframes sd-reveal{from{opacity:0;transform:translateY(64px)}to{opacity:1;transform:none}}
@keyframes sd-drift{from{transform:translateY(-8%)}to{transform:translateY(8%)}}
@keyframes sd-zoom{from{transform:scale(1.24)}to{transform:scale(1.02)}}
@keyframes sd-wipe{from{opacity:.0;transform:translateY(40px) scale(.97)}to{opacity:1;transform:none}}

@media (prefers-reduced-motion:no-preference){
  @supports (animation-timeline: view()){
    /* reveal now scrubs continuously while the element crosses the lower viewport */
    .reveal{opacity:1;transform:none;
      animation:sd-reveal both linear;
      animation-timeline:view();
      animation-range:entry 0% entry 60%}

    /* background layers drift through their whole pass = visible parallax on every wheel tick */
    [data-parallax]{animation:sd-drift both linear;
      animation-timeline:view();animation-range:cover 0% cover 100%}

    /* cinematic feature images slowly zoom out while on screen */
    .story__bg img,.quote__bg img,.signature__media img{
      animation:sd-zoom both linear;
      animation-timeline:view();animation-range:cover 0% cover 100%}

    /* section headlines get a slightly stronger scrub-in */
    .hero__title .line,.intro__statement span,.story__title,.terroir__title,
    .collection__title,.gmap__title,.signature__title,.heritage__title,
    .contact__title,.quote__text{
      animation:sd-wipe both linear;
      animation-timeline:view();animation-range:entry 0% entry 55%}
  }
}

/* =========================================================
   NAV
   ========================================================= */
.nav{position:fixed;top:0;left:0;width:100%;z-index:100;
  transition:background .5s var(--ease),backdrop-filter .5s var(--ease),
             border-color .5s var(--ease),padding .5s var(--ease);
  border-bottom:1px solid transparent;padding:.6rem 0}
.nav.scrolled{
  background:rgba(11,10,8,.72);backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom-color:var(--line);
}
.nav__inner{max-width:var(--maxw);margin:0 auto;padding:.9rem 2rem;
  display:flex;align-items:center;justify-content:space-between}
.nav__logo{display:flex;align-items:center;gap:.7rem}
.nav__logo-mark{
  font-family:var(--serif);font-weight:600;font-size:1.05rem;letter-spacing:.04em;
  width:38px;height:38px;display:grid;place-items:center;border-radius:50%;
  color:var(--gold-2);border:1px solid var(--gold);
  background:radial-gradient(circle at 30% 25%,rgba(200,169,106,.22),transparent 70%);
}
.nav__logo-text{font-family:var(--serif);font-weight:500;font-size:1.15rem;
  letter-spacing:.18em;color:var(--cream)}
.nav__menu{display:flex;gap:2.2rem}
.nav__menu a{font-size:.9rem;font-weight:500;color:var(--cream-dim);position:relative;
  transition:color .35s var(--ease)}
.nav__menu a::after{content:"";position:absolute;left:0;bottom:-6px;height:1px;width:0;
  background:var(--gold);transition:width .4s var(--ease)}
.nav__menu a:hover{color:var(--cream)}
.nav__menu a:hover::after{width:100%}
.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav__toggle span{width:26px;height:2px;background:var(--cream);transition:.4s var(--ease)}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;height:100svh;min-height:640px;display:flex;
  align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__media img{transform:scale(1.12);will-change:transform;filter:saturate(105%)}
.hero__overlay{position:absolute;inset:0;
  background:
    radial-gradient(120% 90% at 50% 30%,rgba(11,10,8,.25),rgba(11,10,8,.78) 70%),
    linear-gradient(180deg,rgba(11,10,8,.55) 0%,rgba(11,10,8,.2) 40%,rgba(11,10,8,.92) 100%);}
.hero__content{position:relative;z-index:2;max-width:920px;padding:0 1.5rem}
.hero__eyebrow{font-size:.8rem;letter-spacing:.42em;color:var(--gold-2);
  font-weight:600;margin-bottom:2rem}
.hero__title{font-family:var(--kserif);font-weight:500;
  font-size:clamp(2.5rem,6.4vw,5.4rem);line-height:1.12;letter-spacing:-.02em}
.hero__title .line{display:block}
.hero__title em{font-family:var(--serif);font-style:italic;font-weight:500}
.hero__sub{margin:2rem auto 0;max-width:640px;color:var(--cream-dim);
  font-size:clamp(1rem,1.5vw,1.18rem);line-height:1.8}
.hero__sub strong{color:var(--gold-2);font-weight:600}
.hero__cta{margin-top:2.6rem;display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.hero__scroll{position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);
  z-index:2;display:flex;flex-direction:column;align-items:center;gap:.7rem}
.hero__scroll-line{width:1px;height:46px;background:linear-gradient(var(--gold),transparent);
  position:relative;overflow:hidden}
.hero__scroll-line::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;
  background:var(--gold-2);animation:scrollDown 2.2s var(--ease) infinite}
@keyframes scrollDown{0%{transform:translateY(-100%)}100%{transform:translateY(260%)}}
.hero__scroll-text{font-size:.62rem;letter-spacing:.3em;color:var(--cream-dim)}

/* =========================================================
   MARQUEE
   ========================================================= */
.marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--bg-2);padding:1.5rem 0}
.marquee__track{display:flex;gap:2.5rem;white-space:nowrap;width:max-content;
  animation:marquee 32s linear infinite}
.marquee__track span{font-family:var(--serif);font-size:1.4rem;letter-spacing:.16em;
  color:var(--cream-dim);font-weight:500}
.marquee__track span:nth-child(even){color:var(--gold)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* =========================================================
   INTRO
   ========================================================= */
.intro{padding:clamp(6rem,12vw,11rem) 2rem;max-width:var(--maxw);margin:0 auto}
.intro__statement{font-family:var(--kserif);font-weight:400;
  font-size:clamp(1.8rem,4.6vw,3.6rem);line-height:1.32;letter-spacing:-.02em;
  margin-bottom:3.5rem}
.intro__statement span{display:block}
.intro__statement em{font-family:var(--serif)}
.intro__cols{display:grid;grid-template-columns:1fr 1fr;gap:3rem;max-width:920px;
  margin-left:auto}
.intro__cols p{color:var(--cream-dim);font-size:1.02rem}
.intro__stats{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);
  gap:1.5rem;margin-top:5rem;border-top:1px solid var(--line);padding-top:3rem}
.intro__stats li{display:flex;flex-direction:column;gap:.4rem}
.intro__stats .num{font-family:var(--serif);font-size:clamp(2.6rem,5vw,3.8rem);
  font-weight:500;color:var(--gold-2);line-height:1}
.intro__stats .lbl{font-size:.85rem;color:var(--cream-dim);letter-spacing:.02em}

/* =========================================================
   STORY (sticky parallax)
   ========================================================= */
.story{position:relative}
.story__pin{position:relative;min-height:100svh;display:flex;align-items:center;
  overflow:hidden}
.story__bg{position:absolute;inset:-10% 0;z-index:0;will-change:transform}
.story__bg img{filter:brightness(.55) saturate(.95)}
.story__bg-overlay{position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(11,10,8,.92) 0%,rgba(11,10,8,.6) 45%,rgba(11,10,8,.25) 100%)}
.story__text{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;
  padding:6rem 2rem;width:100%}
.story__text>*{max-width:600px}
.story__title{font-family:var(--kserif);font-weight:500;
  font-size:clamp(2.2rem,5.5vw,4.4rem);line-height:1.18;margin-bottom:2rem}
.story__title em{font-family:var(--serif);font-style:italic}
.story__body{color:var(--cream-dim);font-size:1.05rem;margin-bottom:1.3rem}

/* =========================================================
   TERROIR
   ========================================================= */
.terroir{padding:clamp(6rem,12vw,11rem) 2rem;max-width:var(--maxw);margin:0 auto}
.terroir__head{max-width:760px;margin-bottom:4rem}
.terroir__title{font-family:var(--kserif);font-weight:500;
  font-size:clamp(2rem,5vw,3.6rem);line-height:1.2;margin-bottom:1.8rem}
.terroir__title em{font-family:var(--serif);font-style:italic}
.terroir__lead{color:var(--cream-dim);font-size:1.05rem}
.terroir__map{position:relative;border-radius:18px;overflow:hidden;height:clamp(320px,46vw,560px);
  border:1px solid var(--line);margin-bottom:5rem}
.terroir__map img{filter:brightness(.7) saturate(.9);transition:transform 1.4s var(--ease)}
.terroir__map:hover img{transform:scale(1.05)}
.terroir__pins{position:absolute;inset:0}
.pin{position:absolute;transform:translate(-50%,-50%);color:var(--cream);
  font-size:.82rem;font-weight:600;letter-spacing:.05em;display:flex;align-items:center;gap:.5rem;
  background:rgba(11,10,8,.55);padding:.4rem .8rem;border-radius:100px;
  border:1px solid var(--line);backdrop-filter:blur(6px);white-space:nowrap}
.pin i{width:8px;height:8px;border-radius:50%;background:var(--gold-2);
  box-shadow:0 0 0 0 rgba(200,169,106,.7);animation:ping 2.4s var(--ease) infinite}
@keyframes ping{0%{box-shadow:0 0 0 0 rgba(200,169,106,.6)}
  100%{box-shadow:0 0 0 14px rgba(200,169,106,0)}}

.grapes{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.grape{background:var(--bg-2);border:1px solid var(--line);border-radius:16px;overflow:hidden;
  transition:transform .5s var(--ease),border-color .5s var(--ease)}
.grape:hover{transform:translateY(-6px);border-color:rgba(200,169,106,.45)}
.grape__img{height:230px;overflow:hidden}
.grape__img img{transition:transform 1.2s var(--ease);filter:saturate(.95)}
.grape:hover .grape__img img{transform:scale(1.08)}
.grape__info{padding:1.8rem}
.grape__pct{font-family:var(--serif);font-size:2rem;color:var(--gold-2);font-weight:500}
.grape__info h3{font-family:var(--kserif);font-weight:600;font-size:1.4rem;margin:.3rem 0 .8rem}
.grape__info h3 small{font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:1rem;color:var(--cream-dim);margin-left:.4rem}
.grape__info p{color:var(--cream-dim);font-size:.96rem}

/* =========================================================
   COLLECTION
   ========================================================= */
.collection{padding:clamp(6rem,12vw,11rem) 2rem;background:var(--bg-2);
  border-top:1px solid var(--line)}
.collection__head{max-width:var(--maxw);margin:0 auto 4rem;text-align:center}
.collection__title{font-family:var(--kserif);font-weight:500;
  font-size:clamp(2.2rem,5vw,3.8rem);margin-bottom:1.4rem}
.collection__lead{color:var(--cream-dim);max-width:620px;margin:0 auto;font-size:1.05rem}
.cards{max-width:var(--maxw);margin:0 auto;display:grid;
  grid-template-columns:repeat(4,1fr);gap:1.6rem}
.card{background:var(--bg);border:1px solid var(--line);border-radius:16px;overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .55s var(--ease),box-shadow .55s var(--ease),border-color .55s var(--ease)}
.card:hover{transform:translateY(-8px);border-color:rgba(200,169,106,.5);
  box-shadow:0 24px 50px rgba(0,0,0,.5)}
.card__media{position:relative;height:230px;overflow:hidden}
.card__media img{transition:transform 1.3s var(--ease);filter:brightness(.85) saturate(1)}
.card:hover .card__media img{transform:scale(1.1);filter:brightness(1)}
.card__badge{position:absolute;top:1rem;left:1rem;font-size:.62rem;letter-spacing:.2em;
  font-weight:700;color:var(--gold-2);background:rgba(11,10,8,.7);padding:.4rem .8rem;
  border-radius:100px;border:1px solid var(--line);backdrop-filter:blur(6px)}
.card__body{padding:1.6rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.card__body h3{font-family:var(--kserif);font-weight:600;font-size:1.32rem;line-height:1.25}
.card__en{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:1rem;margin-top:-.2rem}
.card__cepage{font-size:.78rem;letter-spacing:.04em;color:var(--cream-dim);
  padding-bottom:.7rem;border-bottom:1px solid var(--line);margin-bottom:.3rem}
.card__note{font-size:.92rem;color:var(--cream-dim);flex:1}
.card__tags{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.6rem}
.card__tags li{font-size:.7rem;letter-spacing:.06em;color:var(--gold);
  border:1px solid var(--line);border-radius:100px;padding:.3rem .7rem}

/* =========================================================
   SIGNATURE
   ========================================================= */
.signature{position:relative;display:grid;grid-template-columns:1.05fr .95fr;
  min-height:100svh;align-items:stretch;overflow:hidden}
.signature__media{position:relative;overflow:hidden}
.signature__media img{filter:brightness(.8) saturate(1.05);transform:scale(1.1);will-change:transform}
.signature__panel{background:var(--bg-3);display:flex;flex-direction:column;
  justify-content:center;padding:clamp(3rem,7vw,7rem)}
.signature__title{font-family:var(--kserif);font-weight:500;
  font-size:clamp(2.2rem,4.5vw,3.6rem);line-height:1.15;margin:.4rem 0}
.signature__en{font-family:var(--serif);font-style:italic;color:var(--gold-2);
  font-size:1.2rem;margin-bottom:1.8rem}
.signature__body{color:var(--cream-dim);font-size:1.04rem;margin-bottom:2.2rem;max-width:520px}
.spec{display:grid;gap:1rem;margin-bottom:2.4rem;max-width:520px}
.spec div{display:grid;grid-template-columns:80px 1fr;gap:1.2rem;padding-bottom:1rem;
  border-bottom:1px solid var(--line)}
.spec dt{font-size:.78rem;letter-spacing:.16em;color:var(--gold);text-transform:uppercase;
  padding-top:.15rem}
.spec dd{color:var(--cream);font-size:.98rem}

/* =========================================================
   HERITAGE
   ========================================================= */
.heritage{padding:clamp(6rem,12vw,11rem) 2rem;max-width:var(--maxw);margin:0 auto}
.heritage__head{text-align:center;margin-bottom:4rem}
.heritage__title{font-family:var(--kserif);font-weight:500;
  font-size:clamp(2rem,5vw,3.6rem)}
.heritage__title em{font-family:var(--serif);font-style:italic}
.heritage__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem}
.hcard{border:1px solid var(--line);border-radius:16px;padding:2.2rem 1.8rem;
  background:linear-gradient(180deg,var(--bg-2),var(--bg));
  transition:transform .5s var(--ease),border-color .5s var(--ease)}
.hcard:hover{transform:translateY(-6px);border-color:rgba(200,169,106,.45)}
.hcard__no{font-family:var(--serif);font-size:2.4rem;color:var(--gold-deep);font-weight:500;
  display:block;margin-bottom:1rem}
.hcard h3{font-family:var(--kserif);font-weight:600;font-size:1.3rem;margin-bottom:.9rem}
.hcard p{color:var(--cream-dim);font-size:.95rem}

/* =========================================================
   QUOTE
   ========================================================= */
.quote{position:relative;min-height:80svh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;overflow:hidden;padding:6rem 2rem}
.quote__bg{position:absolute;inset:-12% 0;z-index:0;will-change:transform}
.quote__bg img{filter:brightness(.4) saturate(.9)}
.quote__overlay{position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,
  rgba(11,10,8,.4),rgba(11,10,8,.85))}
.quote__text{position:relative;z-index:2;font-family:var(--kserif);font-weight:400;
  font-size:clamp(1.8rem,4.5vw,3.4rem);line-height:1.4;max-width:900px}
.quote__cite{position:relative;z-index:2;margin-top:2rem;font-size:.82rem;
  letter-spacing:.24em;color:var(--gold-2)}

/* =========================================================
   INSTAGRAM FEED
   ========================================================= */
.insta{padding:clamp(6rem,12vw,11rem) 2rem;max-width:var(--maxw);margin:0 auto;text-align:center}
.insta__head{max-width:680px;margin:0 auto 3rem}
.insta__title{font-family:var(--kserif);font-weight:500;
  font-size:clamp(1.7rem,4vw,2.8rem);margin-bottom:1.2rem;word-break:keep-all}
.insta__lead{color:var(--cream-dim);font-size:1.02rem}
.insta__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1rem;margin-bottom:2.6rem}
.insta__tile{position:relative;aspect-ratio:1/1;border-radius:14px;overflow:hidden;
  border:1px solid var(--line);display:block}
.insta__tile img{transition:transform 1.1s var(--ease),filter .5s var(--ease);filter:saturate(.96)}
.insta__tile:hover img{transform:scale(1.1)}
.insta__ov{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:.5rem;text-align:center;padding:.6rem;
  font-size:.62rem;letter-spacing:.02em;color:var(--cream);
  background:linear-gradient(180deg,rgba(11,10,8,.1),rgba(11,10,8,.78));
  opacity:0;transition:opacity .4s var(--ease)}
.insta__tile:hover .insta__ov{opacity:1}
.insta__ov svg{width:26px;height:26px;fill:var(--gold-2)}
.insta__more{margin:0 auto}

@media (max-width:880px){
  .insta__grid{grid-template-columns:repeat(3,1fr)}
  .insta__ov{opacity:1;background:linear-gradient(180deg,rgba(11,10,8,0) 55%,rgba(11,10,8,.7))}
  .insta__ov svg{display:none}
}
@media (max-width:480px){
  .insta__grid{grid-template-columns:repeat(2,1fr)}
}

/* =========================================================
   CONTACT
   ========================================================= */
.contact{padding:clamp(6rem,12vw,11rem) 2rem;background:var(--bg-2);
  border-top:1px solid var(--line)}
.contact__inner{max-width:760px;margin:0 auto;text-align:center}
.contact__title{font-family:var(--kserif);font-weight:500;
  font-size:clamp(2rem,5vw,3.4rem);margin-bottom:1.4rem}
.contact__lead{color:var(--cream-dim);margin-bottom:3rem}
.contact__form{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;text-align:left;margin-bottom:3rem}
.field{position:relative}
.field--full{grid-column:1/-1}
.field input,.field textarea{width:100%;background:transparent;border:0;
  border-bottom:1px solid var(--line);padding:1.5rem 0 .7rem;color:var(--cream);
  font-family:var(--sans);font-size:1rem;transition:border-color .4s var(--ease)}
.field textarea{resize:vertical;min-height:80px}
.field label{position:absolute;left:0;top:1.4rem;color:var(--cream-dim);
  pointer-events:none;transition:.35s var(--ease);font-size:1rem}
.field input:focus,.field textarea:focus{outline:none;border-bottom-color:var(--gold)}
.field input:focus+label,.field input:not(:placeholder-shown)+label,
.field textarea:focus+label,.field textarea:not(:placeholder-shown)+label{
  top:0;font-size:.72rem;letter-spacing:.12em;color:var(--gold)}
.contact__form .btn{grid-column:1/-1;justify-self:center}
.contact__hint{grid-column:1/-1;text-align:center;font-size:.9rem;color:var(--gold-2);min-height:1.2em}
.contact__info{display:flex;justify-content:center;gap:2.5rem;flex-wrap:wrap;
  border-top:1px solid var(--line);padding-top:3rem}
.contact__item{display:flex;flex-direction:column;gap:.4rem;font-size:1rem;color:var(--cream);
  transition:color .35s var(--ease)}
.contact__item span{font-size:.68rem;letter-spacing:.2em;color:var(--gold);font-weight:600}
.contact__item:hover{color:var(--gold-2)}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{padding:4rem 2rem 3rem;border-top:1px solid var(--line);text-align:center}
.footer__inner{max-width:var(--maxw);margin:0 auto;display:flex;flex-direction:column;
  align-items:center;gap:1.2rem}
.footer__brand{display:flex;align-items:center;gap:.8rem;font-family:var(--serif);
  font-size:1.3rem;letter-spacing:.18em;color:var(--cream)}
.footer__desc{color:var(--cream-dim);font-size:.95rem}
.footer__nav{display:flex;gap:1.8rem;flex-wrap:wrap;justify-content:center}
.footer__nav a{font-size:.9rem;color:var(--cream-dim);transition:color .3s var(--ease)}
.footer__nav a:hover{color:var(--gold-2)}
.footer__legal{color:#6f6a5e;font-size:.78rem;line-height:1.7;margin-top:.6rem}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1080px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .heritage__grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:880px){
  .nav__menu{position:fixed;inset:0 0 0 auto;width:min(80vw,320px);
    flex-direction:column;justify-content:center;gap:2rem;padding:2rem;
    background:rgba(11,10,8,.96);backdrop-filter:blur(20px);
    transform:translateX(100%);transition:transform .5s var(--ease)}
  .nav__menu.open{transform:none}
  .nav__menu a{font-size:1.3rem}
  .nav__toggle{display:flex;z-index:101}
  .nav__toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav__toggle.open span:nth-child(2){opacity:0}
  .nav__toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .nav__logo-text{font-size:1rem;letter-spacing:.12em}

  .intro__cols{grid-template-columns:1fr;gap:1.5rem}
  .intro__stats{grid-template-columns:repeat(2,1fr);gap:2rem 1.5rem}
  .grapes{grid-template-columns:1fr;gap:1.4rem}
  .grape{display:grid;grid-template-columns:130px 1fr}
  .grape__img{height:100%}
  .signature{grid-template-columns:1fr}
  .signature__media{height:60vh}
  .story__bg-overlay{background:linear-gradient(180deg,rgba(11,10,8,.55),rgba(11,10,8,.9))}
}
@media (max-width:600px){
  .nav__inner{padding:.8rem 1.2rem}
  .hero__content{padding:0 1.9rem}
  .hero__eyebrow{font-size:.58rem;letter-spacing:.2em;margin-bottom:1.3rem}
  .hero__title{font-size:clamp(1.5rem,6.2vw,2.2rem);line-height:1.22;letter-spacing:-.01em}
  .hero__sub{font-size:.86rem;line-height:1.7;margin-top:1.4rem}
  .hero__sub br{display:none}
  .hero__cta{margin-top:2rem}
  .intro__statement{font-size:clamp(1.5rem,6.6vw,2rem);line-height:1.4}
  .story__title{font-size:clamp(1.8rem,8vw,2.4rem)}
  .terroir__title,.collection__title,.heritage__title,.contact__title,
  .signature__title{font-size:clamp(1.7rem,7.4vw,2.3rem)}
  .quote__text{font-size:clamp(1.5rem,6.6vw,2rem)}
  .hero__cta{flex-direction:column;align-items:stretch}
  .cards{grid-template-columns:1fr}
  .heritage__grid{grid-template-columns:1fr}
  .contact__form{grid-template-columns:1fr}
  .contact__info{gap:1.6rem}
  .marquee__track span{font-size:1.1rem}
  .grape{grid-template-columns:1fr}
  .grape__img{height:200px}
  .intro__stats{grid-template-columns:1fr 1fr}
  .pin{font-size:.7rem;padding:.3rem .6rem}
}

/* =========================================================
   GLOBAL MAP / PORTFOLIO
   ========================================================= */
.gmap{position:relative;padding:clamp(6rem,12vw,11rem) 2rem;
  background:
    radial-gradient(120% 80% at 50% 0%,rgba(200,169,106,.06),transparent 60%),
    var(--bg)}
.gmap__head{max-width:760px;margin:0 auto 3.5rem;text-align:center}
.gmap__title{font-family:var(--kserif);font-weight:500;
  font-size:clamp(2rem,5vw,3.6rem);line-height:1.18;margin-bottom:1.6rem}
.gmap__lead{color:var(--cream-dim);font-size:1.05rem}
.gmap__wrap{position:relative;max-width:1180px;margin:0 auto;
  display:grid;grid-template-columns:1.62fr 1fr;gap:1.6rem;align-items:center}
.gmap__stage{position:relative;width:100%;aspect-ratio:2/1;overflow:hidden;
  border-radius:20px;border:1px solid var(--line);cursor:default;
  background:
    radial-gradient(140% 120% at 50% 30%,rgba(30,42,56,.45),transparent 70%),
    linear-gradient(180deg,#0c1015,#0a0c0e)}
.gmap__inner{position:absolute;inset:0;transform-origin:0 0;
  transition:transform 1s var(--ease);will-change:transform}
.gmap__img{width:100%;height:100%;object-fit:contain;display:block;
  filter:drop-shadow(0 0 14px rgba(200,169,106,.12))}
.gmap__pins{position:absolute;inset:0}

.pinm{position:absolute;transform:translate(-50%,-50%) scale(calc(1/var(--z,1)));
  background:none;border:0;padding:0;cursor:pointer;z-index:2;
  transition:transform .4s var(--ease)}
.gmap__inner.zoomed .pinm{transform:translate(-50%,-50%) scale(calc(1/var(--z,1)))}
.pinm__dot{display:block;width:11px;height:11px;border-radius:50%;
  background:var(--gold-2);box-shadow:0 0 0 3px rgba(200,169,106,.18),0 0 10px rgba(200,169,106,.6);
  position:relative;transition:transform .35s var(--ease)}
.pinm__dot::after{content:"";position:absolute;inset:-4px;border-radius:50%;
  border:1px solid rgba(200,169,106,.5);animation:ping 2.6s var(--ease) infinite}
.pinm--flag .pinm__dot{width:15px;height:15px;background:#fff;
  box-shadow:0 0 0 4px rgba(200,169,106,.35),0 0 18px rgba(227,201,143,.9)}
.pinm--flag .pinm__dot::after{inset:-7px;border-color:rgba(227,201,143,.8);border-width:1.5px}
/* home destination hub (대한민국) — always-on gold marker */
.pinm--home .pinm__dot{width:17px;height:17px;background:radial-gradient(circle at 35% 30%,#fff,var(--gold-2) 70%);
  box-shadow:0 0 0 5px rgba(200,169,106,.30),0 0 24px rgba(227,201,143,1)}
.pinm--home .pinm__dot::after{inset:-9px;border-color:rgba(227,201,143,.85);border-width:1.6px}
.pinm--home .pinm__label{opacity:1;background:linear-gradient(135deg,var(--gold-2),var(--gold));
  color:#1a1408;border-color:transparent;font-weight:700}
.pinm:hover .pinm__dot,.pinm.active .pinm__dot{transform:scale(1.35)}
.pinm__label{position:absolute;left:50%;bottom:170%;transform:translateX(-50%);
  white-space:nowrap;font-size:.72rem;font-weight:600;letter-spacing:.02em;color:var(--cream);
  background:rgba(11,10,8,.82);border:1px solid var(--line);backdrop-filter:blur(6px);
  padding:.35rem .7rem;border-radius:100px;opacity:0;pointer-events:none;
  transition:opacity .3s var(--ease);z-index:3}
.pinm:hover .pinm__label,.pinm.active .pinm__label{opacity:1}

.gmap__reset{position:absolute;top:1rem;left:1rem;z-index:5;
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(11,10,8,.7);border:1px solid var(--line);backdrop-filter:blur(8px);
  color:var(--cream);font-size:.8rem;font-weight:600;letter-spacing:.02em;
  padding:.6rem 1.1rem;border-radius:100px;cursor:pointer;
  opacity:0;transform:translateY(-6px);pointer-events:none;
  transition:opacity .4s var(--ease),transform .4s var(--ease),background .3s var(--ease)}
.gmap__reset.show{opacity:1;transform:none;pointer-events:auto}
.gmap__reset:hover{background:rgba(200,169,106,.2)}
.gmap__reset span{width:13px;height:13px;border:1.5px solid var(--gold-2);border-radius:3px;
  position:relative}
.gmap__reset span::after{content:"";position:absolute;inset:2px;border:1px solid var(--gold-2);border-radius:1px;opacity:.6}

.gmap__detail{position:relative;z-index:5;align-self:stretch;
  display:flex;flex-direction:column;justify-content:center;
  background:linear-gradient(180deg,var(--bg-2),var(--bg-3));
  border:1px solid var(--line);border-radius:18px;padding:2rem 1.9rem;
  box-shadow:0 18px 50px rgba(0,0,0,.4);transition:opacity .4s var(--ease)}
.gmap__detail-tag{font-size:.66rem;letter-spacing:.22em;color:var(--gold);font-weight:700;margin-bottom:.6rem}
.gmap__detail-region{font-family:var(--kserif);font-weight:600;font-size:1.5rem;line-height:1.2}
.gmap__detail-sub{font-family:var(--serif);font-style:italic;color:var(--gold-2);font-size:1rem;margin-bottom:.9rem}
.gmap__detail-body{color:var(--cream-dim);font-size:.92rem;line-height:1.7;margin-bottom:1rem}
.gmap__detail-grapes{list-style:none;display:flex;flex-wrap:wrap;gap:.45rem}
.gmap__detail-grapes li{font-size:.7rem;letter-spacing:.04em;color:var(--gold);
  border:1px solid var(--line);border-radius:100px;padding:.28rem .65rem}

.gmap__stats{list-style:none;max-width:1120px;margin:3.5rem auto 0;
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
  border-top:1px solid var(--line);padding-top:2.8rem;text-align:center}
.gmap__stats li{display:flex;flex-direction:column;gap:.4rem}
.gmap__stats .num{font-family:var(--serif);font-size:clamp(2.4rem,5vw,3.4rem);
  font-weight:500;color:var(--gold-2);line-height:1}
.gmap__stats .lbl{font-size:.85rem;color:var(--cream-dim)}

/* Keep the stage at 2:1 on every breakpoint so the equirectangular map fills
   it edge-to-edge (object-fit:contain == no letterbox at 2:1) and the pin
   percentages stay geographically accurate. On small screens the detail card
   drops below the map instead of overlaying the now-shorter map. */
@media (max-width:880px){
  .gmap__wrap{grid-template-columns:1fr;gap:1.2rem}
  .gmap__detail{position:static;width:auto;margin-top:1.2rem;
    background:var(--bg-2);backdrop-filter:none;box-shadow:none}
}
@media (max-width:600px){
  .gmap__title{font-size:clamp(1.7rem,7.4vw,2.3rem)}
  .pinm__label{font-size:.64rem}
  .gmap__stats{grid-template-columns:1fr;gap:1.8rem}
}

/* =========================================================
   WINE DETAIL PAGE (wine.html)
   ========================================================= */
.card__body{position:relative}
.card__more{margin-top:.9rem;font-size:.74rem;letter-spacing:.05em;color:var(--gold);
  opacity:.7;transition:opacity .4s var(--ease),transform .4s var(--ease)}
.card:hover .card__more{opacity:1;transform:translateX(3px)}

/* solid nav for sub-pages */
.nav--detail{background:rgba(11,10,8,.82);backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);border-bottom-color:var(--line)}
.nav__back{font-size:.9rem;font-weight:500;color:var(--cream-dim);transition:color .3s var(--ease)}
.nav__back:hover{color:var(--gold-2)}

.wd{max-width:var(--maxw);margin:0 auto;padding:8.5rem 2rem 2rem}
.wd-hero{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:start}
.wd-figure{position:relative;border:1px solid var(--line);border-radius:18px;overflow:hidden;
  aspect-ratio:4/5;background:var(--bg-2)}
.wd-figure img{transition:transform 1.4s var(--ease)}
.wd-figure:hover img{transform:scale(1.04)}
.wd-figure__badge{position:absolute;top:1.1rem;left:1.1rem;font-size:.64rem;letter-spacing:.2em;
  font-weight:700;color:var(--gold-2);background:rgba(11,10,8,.7);padding:.45rem .9rem;
  border-radius:100px;border:1px solid var(--line);backdrop-filter:blur(6px)}

.wd-info{padding-top:.5rem}
.wd-info .section-tag{margin-bottom:1rem}
.wd-title{font-family:var(--kserif);font-weight:600;font-size:2.5rem;line-height:1.2}
.wd-en{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:1.4rem;margin-top:.3rem}
.wd-lead{font-size:1.06rem;color:var(--cream-dim);line-height:1.8;margin-top:1.6rem;
  padding-top:1.6rem;border-top:1px solid var(--line)}

.wd-specs{list-style:none;margin-top:1.8rem;display:grid;grid-template-columns:1fr 1fr;
  gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.wd-specs li{background:var(--bg);padding:1rem 1.2rem;display:flex;flex-direction:column;gap:.25rem}
.wd-specs dt{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.wd-specs dd{font-size:.98rem;color:var(--cream)}

.wd-tags{list-style:none;display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.6rem}
.wd-tags li{font-size:.74rem;letter-spacing:.06em;color:var(--gold);
  border:1px solid var(--line);border-radius:100px;padding:.4rem .9rem}

.wd-cta{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:2rem}

/* tasting / story body */
.wd-body{max-width:var(--maxw);margin:4.5rem auto 0;padding:0 2rem;
  display:grid;grid-template-columns:1.6fr 1fr;gap:3.5rem}
.wd-notes h2,.wd-aside h2{font-family:var(--kserif);font-weight:600;font-size:1.5rem;
  margin-bottom:1.1rem}
.wd-notes p{color:var(--cream-dim);line-height:1.95;margin-bottom:1.1rem;font-size:1.02rem}
.wd-aside{border:1px solid var(--line);border-radius:16px;padding:1.8rem;height:fit-content;
  background:linear-gradient(180deg,var(--bg-2),var(--bg))}
.wd-aside .pairing{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1.8rem}
.wd-aside .pairing span{font-size:.86rem;color:var(--cream);border:1px solid var(--line);
  border-radius:100px;padding:.4rem .9rem;background:var(--bg)}
.wd-aside .src{font-size:.82rem;color:#6f6a5e;line-height:1.7;padding-top:1.4rem;
  border-top:1px solid var(--line)}
.wd-aside .src a{color:var(--gold);text-decoration:underline;text-underline-offset:2px}

/* prev / next + more */
.wd-more{max-width:var(--maxw);margin:5rem auto 0;padding:2.4rem 2rem 0;
  border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.wd-more a{display:flex;flex-direction:column;gap:.25rem;color:var(--cream-dim);
  transition:color .3s var(--ease)}
.wd-more a:hover{color:var(--cream)}
.wd-more .lbl{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.wd-more .nm{font-family:var(--kserif);font-size:1.1rem}
.wd-more .next{text-align:right;margin-left:auto}

@media (max-width:900px){
  .wd-hero{grid-template-columns:1fr;gap:2rem}
  .wd-figure{aspect-ratio:1/1;max-width:520px}
  .wd-body{grid-template-columns:1fr;gap:2.2rem;margin-top:3rem}
  .wd-title{font-size:2rem}
}
@media (max-width:560px){
  .wd{padding:7rem 1.2rem 1rem}
  .wd-body{padding:0 1.2rem}
  .wd-specs{grid-template-columns:1fr}
  .wd-en{font-size:1.2rem}
}

/* =========================================================
   자연스러운 한글 줄바꿈 (전역) — 어절 단위 줄바꿈 + 균형 잡힌 줄
   ========================================================= */
body{word-break:keep-all;overflow-wrap:break-word}
h1,h2,h3,h4,h5,h6,
.hero__title,.wd-title,.wd-en,.signature__title,.collection__title,
.card__body h3,.section-title,.intro__title,.story__title,.terroir__title,
.heritage__title,.quote__text,.contact__title,.gmap__title{
  text-wrap:balance;
}
p,.wd-lead,.card__note,.hero__sub,.collection__lead,.contact__lead{
  text-wrap:pretty;
}

/* =========================================================
   WINE TYPE (스파클링/화이트/로제/레드) + COLLECTION FILTER
   ========================================================= */
.card__type{position:absolute;top:1rem;right:1rem;z-index:2;display:inline-flex;align-items:center;
  gap:.45em;font-size:.62rem;font-weight:700;letter-spacing:.12em;color:var(--cream);
  background:rgba(11,10,8,.62);border:1px solid var(--line);backdrop-filter:blur(6px);
  padding:.36rem .7rem;border-radius:100px}
.card__type::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--gold-2)}
.card__type--sparkling::before{background:#e9d49a;box-shadow:0 0 7px rgba(233,212,154,.9)}
.card__type--white::before{background:#dfe1a6;box-shadow:0 0 7px rgba(223,225,166,.85)}
.card__type--rose::before{background:#e6a6b6;box-shadow:0 0 7px rgba(230,166,182,.85)}
.card__type--red::before{background:#bf4d57;box-shadow:0 0 7px rgba(191,77,87,.9)}

.cfilter{display:flex;justify-content:center;flex-wrap:wrap;gap:.6rem;
  max-width:var(--maxw);margin:0 auto 2.6rem}
.cfilter__btn{font-family:var(--sans);font-size:.84rem;font-weight:600;letter-spacing:.01em;
  color:var(--cream-dim);background:transparent;border:1px solid var(--line);
  padding:.55rem 1.25rem;border-radius:100px;cursor:pointer;
  transition:color .35s var(--ease),background .35s var(--ease),border-color .35s var(--ease)}
.cfilter__btn:hover{color:var(--cream);border-color:rgba(200,169,106,.55)}
.cfilter__btn.is-active{background:linear-gradient(135deg,var(--gold-2),var(--gold));
  color:#1c1304;border-color:transparent;box-shadow:0 6px 20px rgba(200,169,106,.22)}
.card.is-hidden{display:none}

/* =========================================================
   MAP — golden trade-route arcs + brighter dotted map
   ========================================================= */
.gmap__img{filter:brightness(1.38) saturate(1.12) drop-shadow(0 0 16px rgba(200,169,106,.16))}
.gmap__arcs{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1;overflow:visible}
.gmap__arc{fill:none;stroke-linecap:round}
.gmap__arc--base{stroke:rgba(200,169,106,.16);stroke-width:.7}
.gmap__arc--flow{stroke:url(#vbArcGrad);stroke-width:1.5;
  filter:drop-shadow(0 0 2.5px rgba(227,201,143,.65));
  stroke-dasharray:4 7;animation:arcflow 5.5s linear infinite}
@keyframes arcflow{to{stroke-dashoffset:-110}}
@media (prefers-reduced-motion:reduce){.gmap__arc--flow{animation:none}}

/* stronger, gently pulsing pins */
.pinm__dot{animation:pinglow 2.8s ease-in-out infinite}
@keyframes pinglow{
  0%,100%{box-shadow:0 0 0 3px rgba(200,169,106,.16),0 0 9px rgba(200,169,106,.55)}
  50%{box-shadow:0 0 0 5px rgba(200,169,106,.10),0 0 18px rgba(227,201,143,.9)}}
.pinm--flag .pinm__dot,.pinm--home .pinm__dot{animation:pinglowflag 2.4s ease-in-out infinite}
@keyframes pinglowflag{
  0%,100%{box-shadow:0 0 0 4px rgba(200,169,106,.34),0 0 16px rgba(227,201,143,.8)}
  50%{box-shadow:0 0 0 7px rgba(200,169,106,.2),0 0 26px rgba(227,201,143,1)}}

/* =========================================================
   WINE DETAIL — type pill next to country tag
   ========================================================= */
.wd-type{display:inline-flex;align-items:center;gap:.5em;margin-left:.7rem;vertical-align:middle;
  font-size:.7rem;font-weight:700;letter-spacing:.1em;color:var(--cream);
  background:rgba(255,255,255,.04);border:1px solid var(--line);
  padding:.32rem .75rem;border-radius:100px}
.wd-type::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--gold-2)}
.wd-type--sparkling::before{background:#e9d49a;box-shadow:0 0 8px rgba(233,212,154,.9)}
.wd-type--white::before{background:#dfe1a6;box-shadow:0 0 8px rgba(223,225,166,.85)}
.wd-type--rose::before{background:#e6a6b6;box-shadow:0 0 8px rgba(230,166,182,.85)}
.wd-type--red::before{background:#bf4d57;box-shadow:0 0 8px rgba(191,77,87,.9)}
