*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --black: #080808;
  --dark: #111010;
  --dark2: #1a1a1a;
  --gold: #c9a96e;
  --gold-light: #e2c897;
  --white: #f5f2ee;
  --muted: #666;
  --mid: #2a2a2a;
  --grey: #2a2a2a;
}

html { scroll-behavior:smooth; }

body {
  background: var(--black);
  color: var(--white);
  font-family: 'Montserrat', sans-serif;
  font-weight: 300;
  overflow-x: hidden;
}

/* ── CURSOR (desktop only) ── */
@media (pointer: fine) {
  #cur, #cur-r { display: block; }
}
#cur {
  display:none;
  width:10px;
  height:10px;
  background:var(--gold);
  border-radius:50%;
  position:fixed;
  top:0;
  left:0;
  pointer-events:none;
  z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .3s,height .3s,transform .2s;
}
#cur-r {
  display:none;
  width:36px;
  height:36px;
  border:1px solid rgba(201,169,110,.4);
  border-radius:50%;
  position:fixed;
  top:0;
  left:0;
  pointer-events:none;
  z-index:9998;
  transform:translate(-50%,-50%);
  transition:width .3s,height .3s;
}

/* ── NAV ── */
nav {
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:200;
  padding:20px 48px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  background:rgba(8,8,8,.97);
  border-bottom:1px solid rgba(255,255,255,.04);
}
.nav-brand {
  text-align:center;
  flex:1;
}
.nav-brand h1 {
  
  font-weight:400;
  font-size:2rem;
  letter-spacing:.4em;
  text-transform:uppercase;
}
.nav-brand p {
  font-size:.8rem;
  letter-spacing:.5em;
  color:#fff;
  text-transform:uppercase;
  margin-top:3px;
}

/* ── HAMBURGER ── */
.hamburger {
  display:none;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
  padding:4px;
  z-index:300;
  background:none;
  border:none;
}
.hamburger span {
  display:block;
  width:22px;
  height:1px;
  background:var(--white);
  transition:all .3s;
}
.hamburger.open span:nth-child(1) { transform:translateY(6px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-6px) rotate(-45deg); }

/* ── DESKTOP MENU ── */
.menu {
  position:fixed;
  top:90px;
  left:0;
  right:0;
  z-index:199;
  display:flex;
  justify-content:center;
  gap:28px;
  padding:12px 24px;
  background:rgba(8,8,8,.95);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(255,255,255,.04);
  flex-wrap:wrap;
}
.menu a {
  font-size:.78rem;
  letter-spacing:.18em;
  color:#fff;
  text-decoration:none;
  text-transform:uppercase;
  transition:color .3s;
  position:relative;
  white-space:nowrap;
}
.menu a::after {
  content:'';
  position:absolute;
  bottom:-4px;
  left:0;
  right:0;
  height:1px;
  background:var(--gold);
  transform:scaleX(0);
  transition:transform .3s;
}
.menu a:hover { color:var(--white); }
.menu a:hover::after { transform:scaleX(1); }
.menu a.active {
  color:var(--gold);
  font-style:italic;
  font-weight:600;
}
.menu a.active::after { transform:scaleX(1); }

/* ── MOBILE MENU OVERLAY ── */
.menu-overlay {
  display:none;
  position:fixed;
  inset:0;
  background:rgba(8,8,8,.98);
  z-index:198;
  flex-direction:column;
}
.menu-overlay.open { display:flex; }

.menu-overlay-close {
  flex-shrink:0;
  display:flex;
  justify-content:flex-end;
  padding:18px 20px 0;
}
.menu-overlay-close button {
  background:none;
  border:none;
  color:rgba(201,169,110,.5);
  font-family:'Montserrat', sans-serif;
  font-size:.52rem;
  letter-spacing:.35em;
  text-transform:uppercase;
  cursor:pointer;
  padding:6px 8px;
  transition:color .3s;
}
.menu-overlay-close button:hover { color:var(--gold); }

.menu-overlay-inner {
  flex:1;
  overflow-y:auto;
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  display:flex;
  flex-direction:column;
  align-items:center;
  padding:12px 0 40px;
  scrollbar-width:thin;
  scrollbar-color:rgba(201,169,110,.2) transparent;
}
.menu-overlay-inner::-webkit-scrollbar { width:3px; }
.menu-overlay-inner::-webkit-scrollbar-track { background:transparent; }
.menu-overlay-inner::-webkit-scrollbar-thumb {
  background:rgba(201,169,110,.2);
  border-radius:2px;
}
.menu-overlay-inner a {
  font-family:'Cormorant Garamond', serif;
  font-size:2rem;
  font-weight:300;
  letter-spacing:.2em;
  color:var(--white);
  text-decoration:none;
  text-transform:uppercase;
  transition:color .3s;
  padding:9px 32px;
  width:100%;
  text-align:center;
  flex-shrink:0;
}
.menu-overlay-inner a:hover,
.menu-overlay-inner a.active {
  color:var(--gold);
}

/* ── PAGE TITLE ── */
.page-title {
  padding-top:125px;
  text-align:center;
  background:var(--black);
}
.page-title h2 {
  
  font-size:2rem;
  font-weight:400;
  letter-spacing:.55em;
  text-transform:uppercase;
  color:var(--white);
  padding:24px 0 20px;
  border-bottom:1px solid rgba(255,255,255,.06);
}

/* ── CONTACT SECTION ── */
.contact-section {
  background:#111;
  border-top:1px solid rgba(255,255,255,.04);
  padding:72px 60px 88px;
  position:relative;
  overflow:hidden;
  text-align:center;
}
.contact-section::before {
  content:'';
  position:absolute;
  top:0;
  left:0;
  width:400px;
  height:400px;
  background:radial-gradient(circle, rgba(201,169,110,.04) 0%, transparent 70%);
  pointer-events:none;
}
.contact-inner {
  max-width:1100px;
  margin:0 auto;
}

.contact-intro { margin-bottom:56px; }
.gold-line {
  width:48px;
  height:1px;
  background:var(--gold);
  margin-bottom:20px;
}
.contact-intro p {
  font-size:.8rem;
  line-height:2;
  color:#fff;
  letter-spacing:.04em;
  max-width:540px;
  margin: 0 auto;
}
.contact-intro p + p { margin-top:10px; }

.lets-chat {
  font-family:'Cormorant Garamond',serif;
  font-size:3rem;
  font-weight:300;
  color:var(--white);
  margin-bottom:52px;
}
.lets-chat em {
  color:var(--gold);
  font-style:italic;
}

.contact-grid {
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:80px;
  align-items:start;
}

.contact-info {
  display:flex;
  flex-direction:column;
  gap:40px;
}
.info-label {
  font-size:.55rem;
  letter-spacing:.35em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:10px;
}
.info-value {
  font-size:.9rem;
  color:var(--white);
  font-weight:400;
  letter-spacing:.05em;
}
.info-value a {
  color:var(--white);
  text-decoration:none;
  transition:color .3s;
}
.info-value a:hover { color:var(--gold); }

.social-icons {
  display:flex;
  gap:10px;
  margin-top:4px;
}
.social-icon {
  width:34px;
  height:34px;
  border:1px solid var(--mid);
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  color:var(--muted);
  font-size:12px;
  transition:all .3s;
}
.social-icon:hover {
  border-color:var(--gold);
  color:var(--gold);
  background:rgba(201,169,110,.05);
}

/* ── FORM ── */
.contact-form {
  display:flex;
  flex-direction:column;
  gap:22px;
}
.form-row {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
.field {
  display:flex;
  flex-direction:column;
  gap:6px;
}
.field label {
  font-size:1rem;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:#fff;
}
.field input,
.field textarea {
  background:transparent;
  border:none;
  border-bottom:1px solid rgba(255,255,255,.1);
  padding:10px 0;
  font-family:'Montserrat',sans-serif;
  font-size:1rem;
  font-weight:300;
  color:var(--white);
  outline:none;
  resize:none;
  transition:border-color .3s;
}
.field input::placeholder,
.field textarea::placeholder { color:#333; }
.field input:focus,
.field textarea:focus { border-bottom-color:var(--gold); }
.field textarea { height:110px; }

.btn-send {
  align-self:flex-end;
  margin-top:4px;
  background:transparent;
  border:1px solid var(--gold);
  color:var(--gold);
  font-family:'Montserrat',sans-serif;
  font-size:.58rem;
  letter-spacing:.3em;
  text-transform:uppercase;
  padding:14px 44px;
  position:relative;
  overflow:hidden;
  transition:color .4s;
  cursor:pointer;
}
.btn-send::before {
  content:'';
  position:absolute;
  inset:0;
  background:var(--gold);
  transform:translateX(-100%);
  transition:transform .4s ease;
  z-index:0;
}
.btn-send:hover::before { transform:translateX(0); }
.btn-send:hover { color:var(--black); }
.btn-send span {
  position:relative;
  z-index:1;
}

/* ── FOOTER ── */
footer {
  background:var(--black);
  padding:48px 8% 32px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  border-top:1px solid rgba(255,255,255,.04);
}
.f-name {
  
  font-size:1.5rem;
  font-weight:400;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--gold);
}
.f-sub {
  font-size:.48rem;
  letter-spacing:.52em;
  text-transform:uppercase;
  color:var(--gold);
  opacity:.7;
}
.f-tag {
  font-size:.48rem;
  letter-spacing:.55em;
  text-transform:uppercase;
  color:var(--muted);
  text-decoration:underline;
  text-underline-offset:4px;
  margin-top:6px;
  transition:color .3s;
}
.f-tag:hover { color:var(--gold); }

/* ── REVEAL ── */
.reveal {
  opacity:0;
  transform:translateY(16px);
  transition:opacity .8s ease, transform .8s ease;
}
.reveal.in {
  opacity:1;
  transform:translateY(0);
}

/* ════════ RESPONSIVE ════════ */
@media (max-width:900px) {
  nav { padding:18px 24px; }
  .nav-brand h1 { font-size:1.1rem; letter-spacing:.3em; }
  .nav-brand p { font-size:.5rem; letter-spacing:.35em; }
  .menu { display:none; }
  .hamburger { display:flex; }
  .page-title { padding-top:72px; }
  .page-title h2 {
    font-size:1.1rem;
    letter-spacing:.4em;
    padding:18px 0 16px;
  }
  .contact-section { padding:52px 32px 64px; }
  .contact-grid { grid-template-columns:1fr; gap:48px; }
  .lets-chat { font-size:2.4rem; margin-bottom:36px; }
}

@media (max-width:540px) {
  nav { padding:14px 16px; }
  .nav-brand h1 { font-size:.95rem; letter-spacing:.25em; }
  .nav-brand p { display:none; }
  .page-title { padding-top:64px; }
  .page-title h2 {
    font-size:.9rem;
    letter-spacing:.35em;
    padding:14px 0 12px;
  }
  .contact-section { padding:40px 20px 56px; }
  .lets-chat { font-size:1.9rem; }
  .form-row { grid-template-columns:1fr; }
  .btn-send { align-self:stretch; text-align:center; }
  footer { padding:36px 16px 24px; }

  .menu-overlay-inner a {
    font-size:1.6rem;
    padding:8px 24px;
  }
}

@media (max-width:360px) {
  .nav-brand h1 { font-size:.82rem; letter-spacing:.18em; }
  .menu-overlay-inner a {
    font-size:1.35rem;
    padding:7px 20px;
  }
}
