/* ═══════════════════════════════════════════════
   CHILL TREE CAFÉ — BASE STYLES
   ═══════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Jost:wght@200;300;400&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; cursor: none !important; }
html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: 'Jost', sans-serif;
  font-weight: 300;
  background: #fbf7f2;
  color: #3d2c22;
  overflow-x: hidden;
}
img { display: block; width: 100%; }
a { text-decoration: none; color: inherit; }

:root {
  --beige:  #f6efe6;
  --cream:  #fbf7f2;
  --coffee: #5c4033;
  --latte:  #c7a27c;
  --green:  #7a9a6d;
  --dark:   #2a1f17;
  --text:   #4a3728;
  --t: 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* ── GRAIN ── */
body::before {
  content: ''; position: fixed; inset: 0; z-index: 9000;
  pointer-events: none; opacity: .022;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 200px;
}

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width: 3px; }
::-webkit-scrollbar-track { background: var(--cream); }
::-webkit-scrollbar-thumb { background: var(--latte); border-radius: 2px; }

/* ── CURSOR ── */
#cursor-arrow {
  position: fixed; z-index: 99999; pointer-events: none;
  top: 0; left: 0; width: 28px; height: 28px;
  transition: opacity .3s;
  will-change: transform;
}
#cursor-arrow svg {
  width: 100%; height: 100%;
  filter: drop-shadow(1px 2px 3px rgba(42,31,23,.35));
  transition: transform .25s cubic-bezier(.34,1.56,.64,1), filter .25s;
}
body.hovering #cursor-arrow svg {
  transform: scale(1.32);
  filter: drop-shadow(1px 3px 6px rgba(92,64,51,.5));
}
#cursor-dot {
  position: fixed; z-index: 99998; pointer-events: none;
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--latte); opacity: .55;
  will-change: transform; transition: opacity .3s;
}
body.hovering #cursor-dot { opacity: 0; }

/* ── NAVBAR ── */
nav {
  position: fixed; top: 0; left: 0; width: 100%; z-index: 1000;
  padding: 2rem 4rem;
  display: flex; align-items: center; justify-content: space-between;
  transition: background .6s, padding .5s, border-color .6s;
  border-bottom: 1px solid transparent;
}
nav.stuck {
  background: rgba(251,247,242,.94);
  backdrop-filter: blur(20px);
  padding: 1.1rem 4rem;
  border-color: rgba(199,162,124,.18);
}
nav.dark-nav { }
nav.dark-nav .logo { color: var(--cream); }
nav.dark-nav .nav-center a { color: rgba(251,247,242,.75); }
nav.dark-nav .nav-ig { color: rgba(251,247,242,.75); }
nav.dark-nav .nav-cta { border-color: var(--latte); color: var(--latte); }
nav.dark-nav.stuck .logo { color: var(--coffee); }
nav.dark-nav.stuck .nav-center a { color: var(--text); }
nav.dark-nav.stuck .nav-ig { color: var(--text); }
nav.dark-nav.stuck .nav-cta { border-color: var(--coffee); color: var(--coffee); }

.logo {
  font-family: 'Playfair Display', serif;
  font-size: 1.25rem; font-weight: 400;
  letter-spacing: .04em; color: var(--coffee);
}
.logo sup {
  font-family: 'Jost', sans-serif; font-size: .5rem;
  font-weight: 300; letter-spacing: .15em;
  text-transform: uppercase; vertical-align: super;
  color: var(--green); margin-left: 3px;
}
.nav-center { display: flex; gap: 2.8rem; align-items: center; }
.nav-center a {
  font-size: .72rem; font-weight: 300;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--text); position: relative; transition: color .3s;
}
.nav-center a::after {
  content:''; position:absolute; bottom:-2px; left:0;
  width:0; height:1px; background: var(--latte); transition: width .4s;
}
.nav-center a:hover { color: var(--coffee); }
.nav-center a:hover::after, .nav-center a.active::after { width: 100%; }
.nav-center a.active { color: var(--coffee); }

.nav-right { display: flex; align-items: center; gap: 1.8rem; }
.nav-ig {
  display: flex; align-items: center; gap: .45rem;
  font-size: .72rem; letter-spacing: .12em;
  text-transform: uppercase; color: var(--text); transition: color .3s;
}
.nav-ig:hover { color: var(--green); }
.nav-cta {
  font-size: .68rem; font-weight: 400;
  letter-spacing: .14em; text-transform: uppercase;
  padding: .6rem 1.6rem;
  border: 1px solid var(--coffee); border-radius: 60px;
  color: var(--coffee); transition: background .35s, color .35s;
}
.nav-cta:hover { background: var(--coffee); color: var(--cream); }

/* burger */
.burger { display: none; flex-direction: column; gap: 5px; }
.burger span { width: 22px; height: 1px; background: var(--coffee); display: block; transition: .3s; }
.mob-menu {
  display: none; position: fixed; inset: 0; z-index: 999;
  background: var(--cream); flex-direction: column;
  align-items: center; justify-content: center; gap: 2rem;
}
.mob-menu.open { display: flex; }
.mob-menu a { font-family:'Playfair Display',serif; font-size:2.2rem; font-style:italic; color:var(--coffee); }

/* ── REVEAL ── */
.r { opacity:0; transform:translateY(28px); transition: opacity 1s ease, transform 1s ease; }
.r.on { opacity:1; transform:translateY(0); }
.r.d1{transition-delay:.1s} .r.d2{transition-delay:.22s} .r.d3{transition-delay:.34s} .r.d4{transition-delay:.46s}

/* ── BUTTONS ── */
.btn-dark {
  font-size:.7rem; font-weight:400; letter-spacing:.16em; text-transform:uppercase;
  padding:.9rem 2.4rem; background:var(--coffee); color:var(--cream);
  border-radius:60px; transition:background .35s, transform .25s; display:inline-block;
}
.btn-dark:hover { background:var(--dark); transform:translateY(-2px); }
.btn-ghost {
  font-size:.7rem; font-weight:400; letter-spacing:.16em; text-transform:uppercase;
  padding:.9rem 2.4rem; border:1px solid var(--coffee); border-radius:60px;
  color:var(--coffee); transition:background .35s,color .35s,transform .25s; display:inline-block;
}
.btn-ghost:hover { background:var(--coffee); color:var(--cream); transform:translateY(-2px); }

/* ── LABEL ── */
.label {
  font-size:.65rem; font-weight:300; letter-spacing:.25em;
  text-transform:uppercase; color:var(--green);
}

/* ── TICKER ── */
.ticker-wrap { background:var(--coffee); overflow:hidden; padding:.75rem 0; white-space:nowrap; }
.ticker-inner { display:inline-flex; animation:ticker 28s linear infinite; }
.ticker-item { font-size:.65rem; font-weight:300; letter-spacing:.22em; text-transform:uppercase; color:var(--latte); padding:0 3rem; }
.ticker-dot { color:rgba(199,162,124,.4); }
@keyframes ticker { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ── PAGE HEADER (inner pages) ── */
.page-hero {
  position:relative; min-height:52vh;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; overflow:hidden;
}
.page-hero-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  transform:scale(1.04);
}
.page-hero-veil {
  position:absolute; inset:0;
  background:linear-gradient(170deg,rgba(42,31,23,.72) 0%,rgba(42,31,23,.45) 100%);
}
.page-hero-inner { position:relative; z-index:2; padding:0 2rem; }
.page-hero-inner .label { color:var(--latte); margin-bottom:1rem; display:block; }
.page-hero-inner h1 {
  font-family:'Playfair Display',serif;
  font-size:clamp(2.8rem,6vw,5.5rem); font-weight:300;
  line-height:1.08; color:var(--cream); letter-spacing:-.02em;
}
.page-hero-inner h1 em { font-style:italic; color:var(--latte); }

/* ── FOOTER ── */
footer { background:var(--dark); padding:4.5rem 4rem 2rem; }
.foot-grid {
  max-width:1280px; margin:0 auto 3.5rem;
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:3rem;
}
.foot-brand .logo { color:var(--cream); font-size:1.4rem; display:block; margin-bottom:1rem; }
.foot-tagline { font-size:.82rem; font-weight:200; line-height:1.75; color:rgba(251,247,242,.4); max-width:260px; margin-bottom:1.8rem; }
.foot-socials { display:flex; gap:.9rem; }
.f-soc {
  width:34px; height:34px; border-radius:50%;
  border:1px solid rgba(199,162,124,.2);
  display:flex; align-items:center; justify-content:center;
  color:rgba(199,162,124,.6); transition:border-color .3s,color .3s;
}
.f-soc:hover { border-color:var(--latte); color:var(--latte); }
.foot-col h5 { font-size:.6rem; letter-spacing:.22em; text-transform:uppercase; color:var(--latte); margin-bottom:1.3rem; }
.foot-col ul { list-style:none; display:flex; flex-direction:column; gap:.65rem; }
.foot-col ul li a { font-size:.82rem; font-weight:200; color:rgba(251,247,242,.5); transition:color .3s; }
.foot-col ul li a:hover { color:var(--cream); }
.foot-bottom {
  max-width:1280px; margin:0 auto; padding-top:2rem;
  border-top:1px solid rgba(199,162,124,.08);
  display:flex; justify-content:space-between; align-items:center;
  font-size:.7rem; font-weight:200; color:rgba(251,247,242,.25);
  flex-wrap:wrap; gap:.5rem;
}

/* ── RESPONSIVE ── */
@media (max-width:1024px) {
  nav { padding:1.5rem 2rem; }
  nav.stuck { padding:1rem 2rem; }
  .nav-center { display:none; }
  .burger { display:flex; }
  .foot-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:640px) {
  nav { padding:1.2rem 1.5rem; }
  nav.stuck { padding:.9rem 1.5rem; }
  .nav-right .nav-cta { display:none; }
  body, *, *::before, *::after { cursor:auto !important; }
  #cursor-arrow, #cursor-dot { display:none; }
  .foot-grid { grid-template-columns:1fr; }
}
