/* ============================================================
   GYPSY IN SNEAKERS — design system
   Palette: Linen #F6F1E9 · Deep Earth #2C241C · Sand #D7C8B3
   Clay #A06E4D · Forest #43513E · Ocean #4E6A73 · Gold #C9A66B
   Type: Cormorant Garamond (display) + Inter (body)
   ============================================================ */

:root{
  --linen:#F6F1E9;
  --earth:#2C241C;
  --sand:#D7C8B3;
  --clay:#A06E4D;
  --forest:#43513E;
  --ocean:#4E6A73;
  --gold:#C9A66B;
  --charcoal:#1A1A1A;
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Inter', -apple-system, Helvetica, Arial, sans-serif;
  --ease:cubic-bezier(.25,.1,.25,1);
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--sans);
  background:var(--linen);
  color:var(--earth);
  font-size:16px;
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

/* ---------- typography ---------- */
h1,h2,h3,.serif{font-family:var(--serif);font-weight:500;line-height:1.12;}
h1{font-size:clamp(2.6rem,6vw,5.2rem);letter-spacing:.01em;}
h2{font-size:clamp(2rem,4vw,3.4rem);}
h3{font-size:clamp(1.4rem,2.2vw,1.9rem);}
.eyebrow{
  font-family:var(--sans);
  font-size:.72rem;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--clay);
  margin-bottom:1.4rem;
  display:block;
}
.lead{font-size:1.15rem;line-height:1.9;color:rgba(44,36,28,.85);}
p+p{margin-top:1.2rem;}
.light .eyebrow{color:var(--gold);}
.light{color:var(--linen);}
.light .lead{color:rgba(246,241,233,.85);}

/* ---------- buttons ---------- */
.btn{
  display:inline-block;
  font-family:var(--sans);
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  padding:1.15rem 2.6rem;
  border:1px solid currentColor;
  transition:all .5s var(--ease);
  cursor:pointer;
  background:transparent;
}
.btn:hover{background:var(--earth);color:var(--linen);border-color:var(--earth);}
.btn-solid{background:var(--earth);color:var(--linen);border-color:var(--earth);}
.btn-solid:hover{background:var(--clay);border-color:var(--clay);color:var(--linen);}
.btn-light{color:var(--linen);border-color:rgba(246,241,233,.7);}
.btn-light:hover{background:var(--linen);color:var(--earth);border-color:var(--linen);}
.btn-gold{background:var(--clay);border-color:var(--clay);color:var(--linen);}
.btn-gold:hover{background:var(--earth);border-color:var(--earth);}
.btn-row{display:flex;gap:1.2rem;flex-wrap:wrap;}
.text-link{
  font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
  border-bottom:1px solid var(--clay);padding-bottom:.35rem;
  transition:all .4s var(--ease);
}
.text-link:hover{color:var(--clay);}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.6rem 4vw;
  transition:all .6s var(--ease);
}
.nav.solid,.nav.inner{
  background:rgba(246,241,233,.96);
  backdrop-filter:blur(8px);
  padding:1rem 4vw;
  border-bottom:1px solid rgba(44,36,28,.08);
}
.nav .logo{
  font-family:var(--serif);
  font-size:1.25rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--linen);
  transition:color .6s;
}
.nav.solid .logo,.nav.inner .logo{color:var(--earth);}
.nav-links{display:flex;gap:2rem;list-style:none;align-items:center;}
.nav-links a{
  font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(246,241,233,.92);
  transition:color .4s;
  padding-bottom:.3rem;
  border-bottom:1px solid transparent;
}
.nav.solid .nav-links a,.nav.inner .nav-links a{color:rgba(44,36,28,.8);}
.nav-links a:hover,.nav-links a.active{border-bottom-color:var(--gold);}
.burger{display:none;background:none;border:none;cursor:pointer;z-index:120;}
.burger span{display:block;width:26px;height:1.5px;background:var(--linen);margin:6px 0;transition:all .4s;}
.nav.solid .burger span,.nav.inner .burger span{background:var(--earth);}

@media(max-width:1080px){
  .nav-links{
    position:fixed;inset:0;
    background:var(--earth);
    flex-direction:column;justify-content:center;
    gap:2.2rem;
    transform:translateX(100%);
    transition:transform .6s var(--ease);
  }
  .nav-links.open{transform:translateX(0);}
  .nav-links a{color:var(--linen)!important;font-size:.85rem;}
  .burger{display:block;}
  body.menu-open .burger span{background:var(--linen);}
  body.menu-open .burger span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
  body.menu-open .burger span:nth-child(2){opacity:0;}
  body.menu-open .burger span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}
}

/* ---------- hero ---------- */
.hero{
  position:relative;height:100vh;min-height:620px;
  display:flex;align-items:flex-end;
  overflow:hidden;
  background:var(--charcoal);
}
.hero video,.hero .hero-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;
}
.hero::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(26,26,26,.25) 0%,rgba(26,26,26,0) 35%,rgba(26,26,26,.55) 100%);
}
.hero-content{
  position:relative;z-index:2;
  padding:0 6vw 9vh;
  max-width:880px;
  color:var(--linen);
}
.hero-content .eyebrow{color:var(--gold);}
.hero-content h1{margin-bottom:1.6rem;}
.hero-content p{
  font-size:1.05rem;max-width:540px;margin-bottom:2.6rem;
  color:rgba(246,241,233,.88);
}
.scroll-hint{
  position:absolute;bottom:3vh;left:50%;transform:translateX(-50%);
  z-index:3;width:1px;height:54px;
  background:linear-gradient(var(--linen),transparent);
  opacity:.6;animation:drip 2.6s infinite;
}
@keyframes drip{0%{transform:translateX(-50%) scaleY(0);transform-origin:top}50%{transform:translateX(-50%) scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:translateX(-50%) scaleY(0);transform-origin:bottom}}

/* page hero (inner pages) */
.page-hero{
  position:relative;height:62vh;min-height:440px;
  display:flex;align-items:flex-end;overflow:hidden;
  background:var(--charcoal);
}
.page-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.page-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,26,26,.3),rgba(26,26,26,.55));}
.page-hero .hero-content{padding-bottom:7vh;}

/* ---------- layout ---------- */
.section{padding:9rem 6vw;}
.section-tight{padding:6rem 6vw;}
.wrap{max-width:1280px;margin:0 auto;}
.wrap-narrow{max-width:760px;margin:0 auto;}
.center{text-align:center;}
/* warm sections (formerly dark): clay with linen text */
.dark{background:var(--clay);color:var(--linen);}
.dark .lead{color:rgba(246,241,233,.92);}
.dark .eyebrow{color:#F3E4C9;}
.dark .light .eyebrow{color:#F3E4C9;}
.dark .divider{background:var(--gold);}
.dark .btn-gold{background:var(--earth);border-color:var(--earth);}
.dark .btn-gold:hover{background:var(--charcoal);border-color:var(--charcoal);}
.dark .stat .num{color:var(--linen);}
.dark .stat .label{color:rgba(246,241,233,.8);}
/* quote band: warm sand instead of forest green */
.forest-bg{background:#E5D7BE;color:var(--earth);}
.forest-bg .pull-quote cite{color:var(--clay);}
.sand-bg{background:#EFE6D8;}
.ice-bg{background:#C6D4DA;color:var(--earth);}
.ice-bg .pull-quote cite{color:var(--ocean);}

/* editorial split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center;}
.split.reverse>.split-img{order:2;}
.split-img img{width:100%;height:78vh;min-height:480px;object-fit:cover;}
.split-img.short img{height:60vh;min-height:400px;}
@media(max-width:900px){
  .split{grid-template-columns:1fr;gap:3rem;}
  .split.reverse>.split-img{order:0;}
  .split-img img,.split-img.short img{height:58vh;min-height:340px;}
  .section{padding:5.5rem 6vw;}
}

/* full-bleed band */
.band{
  position:relative;min-height:88vh;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;text-align:center;
}
.band img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.band::after{content:'';position:absolute;inset:0;background:rgba(26,26,26,.45);}
.band-content{position:relative;z-index:2;max-width:740px;padding:6rem 6vw;color:var(--linen);}
.band-content h2{margin-bottom:1.6rem;}
.band-content p{color:rgba(246,241,233,.88);margin-bottom:2.4rem;}

/* manifesto */
.manifesto p{
  font-family:var(--serif);
  font-size:clamp(1.5rem,2.6vw,2.2rem);
  line-height:1.55;
  color:var(--earth);
}
.manifesto em{color:var(--clay);font-style:italic;}

/* ---------- film cards ---------- */
.films-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:3.5rem 3rem;margin-top:4rem;}
@media(max-width:820px){.films-grid{grid-template-columns:1fr;}}
.film-card{display:block;}
.film-card .frame{overflow:hidden;position:relative;}
.film-card img{height:30rem;width:100%;object-fit:cover;transition:transform 1.6s var(--ease);}
.film-card:hover img{transform:scale(1.045);}
.film-card .meta{padding-top:1.4rem;}
.film-card .cat{font-size:.64rem;letter-spacing:.3em;text-transform:uppercase;color:var(--clay);}
.film-card h3{margin:.5rem 0 .4rem;}
.film-card .desc{font-size:.95rem;color:rgba(44,36,28,.7);max-width:480px;}
@media(max-width:820px){.film-card img{height:20rem;}}

/* ---------- gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:3rem;}
.gallery img{width:100%;height:24rem;object-fit:cover;}
.gallery .tall{grid-row:span 2;}
.gallery .tall img{height:100%;min-height:30rem;}
@media(max-width:820px){.gallery{grid-template-columns:1fr 1fr;}.gallery img{height:14rem;}}

/* ---------- video embed ---------- */
.video-embed{position:relative;width:100%;aspect-ratio:16/9;background:var(--charcoal);}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}

/* ---------- click-to-watch video ---------- */
.video-link{position:relative;display:block;width:100%;aspect-ratio:16/9;overflow:hidden;background:var(--charcoal);}
.video-link img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.6s var(--ease);}
.video-link:hover img{transform:scale(1.04);}
.video-link::after{content:'';position:absolute;inset:0;background:rgba(26,26,26,.25);transition:background .6s;}
.video-link:hover::after{background:rgba(26,26,26,.1);}
.video-link .play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:92px;height:92px;border-radius:50%;
  border:1px solid rgba(246,241,233,.85);
  background:rgba(26,26,26,.35);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  z-index:2;transition:all .5s var(--ease);
}
.video-link:hover .play{background:var(--clay);border-color:var(--clay);}
.video-link .play::before{
  content:'';display:block;margin-left:6px;
  border-left:22px solid var(--linen);
  border-top:13px solid transparent;
  border-bottom:13px solid transparent;
}
.video-link .watch-label{
  position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);
  z-index:2;color:var(--linen);
  font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;
}

/* ---------- expedition cards ---------- */
.exped-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.4rem;margin-top:4rem;}
@media(max-width:980px){.exped-grid{grid-template-columns:1fr;}}
.exped-card{position:relative;display:block;overflow:hidden;height:36rem;}
.exped-card img{width:100%;height:100%;object-fit:cover;transition:transform 1.8s var(--ease);}
.exped-card:hover img{transform:scale(1.05);}
.exped-card .overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 30%,rgba(26,26,26,.75));
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:2.4rem;color:var(--linen);
}
.exped-card .overlay .cat{font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:.6rem;}
.exped-card .overlay p{font-size:.9rem;color:rgba(246,241,233,.85);margin-top:.4rem;}
.exped-card .overlay .text-link{color:var(--linen);border-color:var(--gold);margin-top:1.2rem;align-self:flex-start;}

/* ---------- shop ---------- */
.shop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.6rem;margin-top:4rem;}
@media(max-width:980px){.shop-grid{grid-template-columns:1fr;max-width:480px;margin-left:auto;margin-right:auto;}}
.product{background:#fff;border:1px solid rgba(44,36,28,.08);display:flex;flex-direction:column;transition:transform .6s var(--ease),box-shadow .6s var(--ease);}
.product:hover{transform:translateY(-6px);box-shadow:0 30px 60px -30px rgba(44,36,28,.35);}
.product .frame{overflow:hidden;height:22rem;}
.product img{width:100%;height:100%;object-fit:cover;}
.product .body{padding:2rem;display:flex;flex-direction:column;flex:1;}
.product .cat{font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--clay);margin-bottom:.6rem;}
.product h3{font-size:1.5rem;margin-bottom:.6rem;}
.product p{font-size:.92rem;color:rgba(44,36,28,.72);flex:1;}
.product .price{font-family:var(--serif);font-size:1.5rem;margin:1.4rem 0 1.2rem;color:var(--earth);}
.product .price span{font-size:.95rem;color:rgba(44,36,28,.5);text-decoration:line-through;margin-left:.6rem;}

/* ---------- journal ---------- */
.journal-list{margin-top:4rem;display:flex;flex-direction:column;}
.journal-entry{
  display:grid;grid-template-columns:340px 1fr;gap:4rem;
  padding:4.5rem 0;border-top:1px solid rgba(44,36,28,.14);
}
.journal-entry:last-child{border-bottom:1px solid rgba(44,36,28,.14);}
.journal-entry img{width:100%;height:300px;object-fit:cover;}
.journal-entry .date{font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:var(--clay);}
.journal-entry h3{margin:.7rem 0 1rem;}
.journal-entry p{color:rgba(44,36,28,.78);}
@media(max-width:820px){.journal-entry{grid-template-columns:1fr;gap:1.6rem;}}

/* ---------- stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;margin-top:4rem;text-align:center;}
@media(max-width:820px){.stats{grid-template-columns:1fr 1fr;}}
.stat .num{font-family:var(--serif);font-size:clamp(2.4rem,4vw,3.6rem);color:var(--gold);}
.stat .label{font-size:.68rem;letter-spacing:.26em;text-transform:uppercase;color:rgba(246,241,233,.7);margin-top:.4rem;}

/* ---------- quote ---------- */
.pull-quote{
  font-family:var(--serif);
  font-size:clamp(1.6rem,3vw,2.5rem);
  line-height:1.5;font-style:italic;
  max-width:880px;margin:0 auto;text-align:center;
}
.pull-quote cite{
  display:block;font-style:normal;font-family:var(--sans);
  font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;
  margin-top:2rem;color:var(--clay);
}
.dark .pull-quote cite{color:#F3E4C9;}
.forest-bg .pull-quote cite{color:var(--clay);}

/* ---------- footer ---------- */
footer{background:var(--charcoal);color:rgba(246,241,233,.75);padding:6rem 6vw 3rem;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:4rem;max-width:1280px;margin:0 auto;}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr;gap:2.6rem;}}
footer .logo{font-family:var(--serif);font-size:1.4rem;letter-spacing:.12em;text-transform:uppercase;color:var(--linen);margin-bottom:1.2rem;display:block;}
footer h4{font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:1.4rem;font-weight:500;}
footer ul{list-style:none;}
footer li{margin-bottom:.7rem;}
footer a{font-size:.9rem;transition:color .4s;}
footer a:hover{color:var(--gold);}
footer .tagline{font-size:.95rem;max-width:380px;line-height:1.8;}
.footer-bottom{max-width:1280px;margin:4rem auto 0;padding-top:2rem;border-top:1px solid rgba(246,241,233,.12);font-size:.75rem;letter-spacing:.08em;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;color:rgba(246,241,233,.45);}

/* ---------- newsletter ---------- */
.newsletter{
  text-align:center;max-width:680px;margin:0 auto;
}
.newsletter h2{margin-bottom:1.2rem;}
.newsletter p{margin-bottom:2.4rem;}

/* ---------- reveal animations ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1.1s var(--ease),transform 1.1s var(--ease);}
.reveal.visible{opacity:1;transform:none;}
.reveal-slow{transition-duration:1.5s;}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  html{scroll-behavior:auto;}
}

/* ---------- misc ---------- */
.divider{width:64px;height:1px;background:var(--clay);margin:2.4rem 0;}
.center .divider{margin-left:auto;margin-right:auto;}
.note{font-size:.8rem;color:rgba(44,36,28,.55);font-style:italic;}
.breadcrumb{font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:rgba(44,36,28,.5);margin-bottom:2rem;display:block;}
.breadcrumb a:hover{color:var(--clay);}
