/* ─── RESET & BASE ─── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  overflow-x: hidden;
  scroll-behavior: smooth;
}
body {
  overflow-x: hidden;
  background: var(--bg);
  color: var(--text);
  font-family: 'Syne', sans-serif;
  font-size: 15px;
  line-height: 1.6;
  cursor: none;
}

/* ─── TOKENS ─── */
:root {
  --bg:     #0a0a0a;
  --bg2:    #111111;
  --bg3:    #181818;
  --border: #2a2a2a;
  --gold:   #c9a84c;
  --text:   #e8e4dc;
  --muted:  #666;
}

/* ─── CUSTOM CURSOR ─── */
@media (pointer:fine) {
  #cur {
    position: fixed;
    width: 6px; height: 6px;
    background: var(--gold);
    border-radius: 50%;
    pointer-events: none;
    z-index: 9999;
    transform: translate(-50%,-50%);
    transition: transform .1s;
  }
  #cur-ring {
    position: fixed;
    width: 32px; height: 32px;
    border: 1px solid rgba(201,168,76,.4);
    border-radius: 50%;
    pointer-events: none;
    z-index: 9998;
    transform: translate(-50%,-50%);
    transition: left .12s ease, top .12s ease;
  }
}
@media (pointer:coarse) {
  #cur, #cur-ring { display: none; }
  body { cursor: auto; }
}

/* ─── NAV ─── */
nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  padding: 28px max(60px, calc((100vw - 1400px) / 2));
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: padding .3s, background .3s, border-color .3s;
  border-bottom: 1px solid transparent;
}
nav.stuck {
  padding: 18px max(60px, calc((100vw - 1400px) / 2));
  background: rgba(10,10,10,.92);
  backdrop-filter: blur(12px);
  border-color: var(--border);
}
.nav-brand {
  display: flex; align-items: center; gap: 10px;
  text-decoration: none;
  font-size: 12px; letter-spacing: .2em; text-transform: uppercase;
  color: var(--text);
}
.nav-logo {
  width: 26px;
  filter: brightness(0) invert(1);
}
.nav-links {
  display: flex; align-items: center; gap: 40px;
}
.nav-links a {
  text-decoration: none;
  font-size: 10px; letter-spacing: .25em; text-transform: uppercase;
  color: var(--muted);
  transition: color .2s;
}
.nav-links a:hover { color: var(--text); }
.nav-links button {
  background: none;
  border: 1px solid var(--border);
  color: var(--muted);
  font-family: 'Syne', sans-serif;
  font-size: 10px; letter-spacing: .2em;
  padding: 6px 14px;
  cursor: none;
  transition: all .2s;
}
.nav-links button:hover { border-color: var(--gold); color: var(--gold); }
.burger {
  display: none;
  flex-direction: column; gap: 5px;
  background: none; border: none; cursor: none; padding: 4px;
}
.burger span {
  width: 22px; height: 1px;
  background: var(--text);
  transition: all .3s;
}

/* ─── MOBILE MENU ─── */
.mob-menu {
  display: none;
  position: fixed;
  inset: 0; z-index: 99;
  background: var(--bg);
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 32px;
}
.mob-menu.open { display: flex; }
.mob-menu a {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(32px, 7vw, 52px);
  font-weight: 300;
  text-decoration: none;
  color: var(--text);
  letter-spacing: .05em;
  transition: color .2s;
}
.mob-menu a:hover { color: var(--gold); }
.mob-menu button {
  background: none; border: 1px solid var(--border);
  color: var(--muted); font-family: 'Syne', sans-serif;
  font-size: 11px; letter-spacing: .2em;
  padding: 8px 18px; cursor: none; transition: all .2s; margin-top: 8px;
}
.mob-menu button:hover { border-color: var(--gold); color: var(--gold); }

/* ─── HERO ─── */
.hero {
  min-height: 100vh;
  padding: 140px max(60px, calc((100vw - 1400px) / 2)) 80px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid var(--border);
}
.hero-hat {
  position: absolute;
  right: max(60px, calc((100vw - 1400px) / 2));
  top: 50%;
  transform: translateY(-50%);
  width: clamp(200px, 28vw, 420px);
  opacity: .06;
  filter: brightness(0) invert(1);
  animation: float 7s ease-in-out infinite;
  pointer-events: none;
  user-select: none;
}
.hero-content { max-width: 700px; }
.hero-eyebrow {
  font-size: 10px; letter-spacing: .35em;
  text-transform: uppercase; color: var(--gold);
  margin-bottom: 28px;
}
.hero h1 {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(72px, 11vw, 148px);
  font-weight: 300; line-height: .92;
  letter-spacing: -.02em; margin-bottom: 36px;
}
.hero h1 em { font-style: italic; color: var(--gold); }
.hero-sub {
  font-size: 14px; color: var(--muted);
  max-width: 460px; line-height: 1.85; letter-spacing: .04em;
}
.hero-scroll {
  position: absolute;
  bottom: 36px;
  left: max(60px, calc((100vw - 1400px) / 2));
  display: flex; align-items: center; gap: 16px;
  font-size: 9px; letter-spacing: .3em;
  text-transform: uppercase; color: var(--muted);
}
.hero-scroll::before {
  content: '';
  width: 36px; height: 1px;
  background: var(--gold);
}

/* ─── ANIMATIONS ─── */
@keyframes float {
  0%,100% { transform: translateY(-50%) translateX(0) rotate(-2deg); }
  50%      { transform: translateY(-54%) translateX(8px) rotate(2deg); }
}
@keyframes slide {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ─── REVEAL ─── */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .7s ease, transform .7s ease;
  transition-delay: var(--d, 0s);
}
.reveal.on { opacity: 1; transform: translateY(0); }

/* ─── SHARED SECTION ─── */
.section {
  padding: 120px max(60px, calc((100vw - 1400px) / 2));
}
.section-alt { background: var(--bg2); }
.s-label {
  display: flex; align-items: center; gap: 16px;
  font-size: 9px; letter-spacing: .4em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 48px;
}
.s-label::before { content:''; width:28px; height:1px; background:var(--gold); }
.s-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(38px, 5vw, 68px);
  font-weight: 300; line-height: 1.05; margin-bottom: 20px;
}
.s-title em { font-style:italic; color:var(--gold); }
.s-body {
  font-size: 14px; color: var(--muted);
  line-height: 1.9; max-width: 520px; margin-bottom: 72px;
}

/* ─── SERVICE TRACKS ─── */
.track-wrap { margin-bottom: 52px; }
.track-cat {
  font-size: 9px; letter-spacing: .35em; text-transform: uppercase;
  color: var(--muted); padding-left: 14px;
  border-left: 2px solid var(--gold); margin-bottom: 18px;
}
.track-outer {
  overflow: hidden;
  position: relative;
}
.track-outer::before,
.track-outer::after {
  content:''; position:absolute; top:0; bottom:0;
  width:80px; z-index:2; pointer-events:none;
}
.track-outer::before { left:0;  background:linear-gradient(90deg,  var(--bg) 40px, transparent); }
.track-outer::after  { right:0; background:linear-gradient(-90deg, var(--bg) 40px, transparent); }
.section-alt .track-outer::before { background:linear-gradient(90deg,  var(--bg2) 40px, transparent); }
.section-alt .track-outer::after  { background:linear-gradient(-90deg, var(--bg2) 40px, transparent); }
.track-inner {
  display: flex; gap: 14px;
  animation: slide 28s linear infinite;
  width: max-content;
  will-change: transform;
}
.track-inner.rev { animation-direction: reverse; }
.track-outer:hover .track-inner,
.track-outer:hover .track-inner.rev { animation-play-state: paused; }
.pill {
  flex-shrink: 0; padding: 18px 26px;
  border: 1px solid var(--border); background: var(--bg3);
  transition: border-color .25s, transform .25s;
  cursor: default; min-width: 190px;
}
.pill:hover { border-color: var(--gold); transform: translateY(-3px); }
.pill-name { font-size: 13px; font-weight: 600; letter-spacing: .04em; display:block; margin-bottom:5px; }
.pill-tag  { font-size: 9px; letter-spacing: .15em; text-transform:uppercase; color:var(--gold); }

/* ─── PORTFOLIO ─── */
.grid-3 {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 2px; margin-top: 60px;
}
.p-card {
  background: var(--bg3); padding: 40px 32px;
  border: 1px solid var(--border);
  transition: border-color .25s, transform .25s;
  cursor: default;
}
.p-card:hover { border-color: var(--gold); transform: translateY(-4px); }
.p-card.wip    { opacity: .45; }
.p-card.coming { opacity: .25; }
.p-tag  { font-size:9px; letter-spacing:.3em; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
.p-name { font-family:'Cormorant Garamond',serif; font-size:22px; font-weight:300; margin-bottom:10px; }
.p-desc { font-size:12px; color:var(--muted); line-height:1.7; }
.p-status {
  display:inline-block; margin-top:14px;
  font-size:8px; letter-spacing:.25em; text-transform:uppercase;
  padding:4px 10px; border:1px solid var(--border); color:var(--muted);
}

/* ─── REVIEWS ─── */
.grid-2 {
  display: grid; grid-template-columns: repeat(2,1fr);
  gap: 2px; margin-bottom: 80px;
}
.review-box {
  background: var(--bg2); padding: 40px;
  border: 1px solid var(--border);
}
.r-stars { color: var(--gold); font-size: 14px; letter-spacing: 3px; margin-bottom: 16px; }
.r-text  { font-family:'Cormorant Garamond',serif; font-size:18px; font-weight:300; line-height:1.6; margin-bottom:20px; }
.r-name  { font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
.review-form {
  display: flex; gap: 12px; margin-bottom: 16px; flex-wrap: wrap;
}
.review-form input, .r-full input, .r-full textarea {
  background: var(--bg2); border: 1px solid var(--border);
  color: var(--text); font-family: 'Syne', sans-serif; font-size: 13px;
  padding: 14px 18px; outline: none; transition: border-color .2s;
}
.review-form input { flex: 1; min-width: 140px; }
.review-form input:focus, .r-full input:focus, .r-full textarea:focus { border-color: var(--gold); }
.review-form button, .r-full button {
  background: var(--gold); border: none; color: #0a0a0a;
  font-family: 'Syne', sans-serif; font-size: 11px;
  font-weight: 700; letter-spacing: .15em; text-transform: uppercase;
  padding: 14px 28px; cursor: none; transition: opacity .2s;
}
.review-form button:hover, .r-full button:hover { opacity: .85; }
.r-msg  { font-size: 12px; color: var(--muted); margin-bottom: 16px; min-height: 18px; }
.r-full { display: flex; flex-direction: column; gap: 12px; max-width: 600px; }
.r-full textarea { resize: none; }
.star-row { display:flex; gap:8px; }
.star-row span {
  font-size: 22px; cursor: none;
  color: var(--border); transition: color .15s;
}
.star-row span.lit { color: var(--gold); }

/* ─── CONTACT / SOC TRACK ─── */
.soc-outer {
  overflow: hidden;
  position: relative;
  padding: 40px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.soc-outer::before,
.soc-outer::after {
  content:''; position:absolute; top:0; bottom:0;
  width:100px; z-index:2; pointer-events:none;
}
.soc-outer::before { left:0;  background:linear-gradient(90deg,  var(--bg2) 40px, transparent); }
.soc-outer::after  { right:0; background:linear-gradient(-90deg, var(--bg2) 40px, transparent); }
.soc-track {
  display: flex; gap: 0;
  animation: slide 20s linear infinite;
  width: max-content;
  will-change: transform;
}
.soc {
  display: flex; flex-direction: column; align-items: center;
  gap: 8px; padding: 0 44px;
  text-decoration: none;
  color: var(--text);
  border-right: 1px solid var(--border);
  position: relative;
  transition: color .2s;
}
.soc:hover { color: var(--gold); }
.soc-icon   { font-size: 22px; transition: opacity .25s; }
.soc-name   { font-size: 8px; letter-spacing: .3em; text-transform: uppercase; color: var(--muted); }
.soc-handle {
  position: absolute; bottom: -24px;
  font-size: 11px; font-weight: 600; color: var(--gold); letter-spacing: .04em;
  opacity: 0; transform: translateY(6px); transition: all .25s;
}
.soc:hover .soc-icon   { opacity: .3; }
.soc:hover .soc-handle { opacity: 1; transform: translateY(0); }

/* ─── FOOTER ─── */
footer {
  background: var(--bg); border-top: 1px solid var(--border);
  padding: 36px max(60px, calc((100vw - 1400px) / 2));
  display: flex; align-items: center; justify-content: space-between;
}
.footer-brand {
  display: flex; align-items: center; gap: 10px;
  opacity: .35; font-size: 11px; letter-spacing: .15em; text-transform: uppercase;
}
.footer-logo { width: 22px; filter: brightness(0) invert(1); }
.footer-copy { font-size: 11px; color: var(--muted); letter-spacing: .1em; }

/* ─── RESPONSIVE ─── */
@media (max-width:768px) {
  nav { padding: 20px 24px; }
  nav.stuck { padding: 14px 24px; }
  .nav-links { display: none; }
  .burger { display: flex; }
  .mob-menu { display: none; }
  .mob-menu.open { display: flex; }

  .hero { padding: 110px 24px 70px; }
  .hero-hat { width: 160px; right: -10px; opacity: .04; }
  .hero-scroll { left: 24px; }

  .section { padding: 80px 24px; }

  .grid-3 { grid-template-columns: repeat(2,1fr); }
  .grid-2 { grid-template-columns: 1fr; }

  .review-box { padding: 32px 20px; }
  footer { flex-direction: column; gap: 14px; text-align: center; padding: 28px 24px; }
}
@media (max-width:480px) {
  .grid-3 { grid-template-columns: 1fr; }
  .hero-hat { display: none; }
}