*{margin:0;padding:0;box-sizing:border-box}

:root{
  --pearl:#F8F5F0;
  --ivory:#EDE8E0;
  --teal:#1A7A6E;
  --teal-light:#2CA898;
  --teal-dark:#0F4F47;
  --gold:#C9A84C;
  --gold-light:#E8C97A;
  --charcoal:#1C1C1E;
  --soft:#6B6B6B;
  --white:#FFFFFF;
}

html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--pearl);color:var(--charcoal);overflow-x:hidden}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--ivory)}
::-webkit-scrollbar-thumb{background:var(--teal);border-radius:3px}

/* ── CURSOR ── */
*{cursor:none}
#cursor{position:fixed;width:12px;height:12px;background:var(--teal);border-radius:50%;pointer-events:none;z-index:9999;transition:transform .15s,background .2s;mix-blend-mode:multiply}
#cursor-ring{position:fixed;width:36px;height:36px;border:1.5px solid var(--teal);border-radius:50%;pointer-events:none;z-index:9998;transition:all .25s cubic-bezier(.25,.46,.45,.94);opacity:.6}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:1.2rem 4rem;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(248,245,240,.88);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(26,122,110,.12);
  transition:all .4s
}
.nav-logo{
  font-family:'Cormorant Garamond',serif;
  font-size:1.5rem;font-weight:600;color:var(--teal-dark);
  letter-spacing:.02em;text-decoration:none
}
.nav-logo span{color:var(--gold);font-style:italic}
.nav-links{display:flex;gap:2.5rem;list-style:none}
.nav-links a{
  font-size:.85rem;font-weight:400;color:var(--soft);
  text-decoration:none;letter-spacing:.08em;text-transform:uppercase;
  position:relative;transition:color .3s
}
.nav-links a::after{
  content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;
  background:var(--teal);transition:width .3s
}
.nav-links a:hover{color:var(--teal)}
.nav-links a:hover::after{width:100%}
.nav-links a.active{color:var(--teal)}
.nav-cta{
  padding:.6rem 1.6rem;
  background:var(--teal);color:var(--white);
  font-size:.8rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  border:none;border-radius:2px;text-decoration:none;
  box-shadow:0 6px 0 var(--teal-dark);
  transition:all .15s;display:inline-block
}
.nav-cta:hover{box-shadow:0 3px 0 var(--teal-dark);transform:translateY(3px)}
.nav-cta:active{box-shadow:0 1px 0 var(--teal-dark);transform:translateY(5px)}

/* ── BUTTONS ── */
.btn-primary{
  padding:.9rem 2.2rem;background:var(--teal);color:var(--white);
  font-size:.85rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;
  border:none;border-radius:2px;cursor:none;
  box-shadow:0 8px 0 var(--teal-dark),0 12px 24px rgba(26,122,110,.25);
  transition:all .15s;display:inline-block;text-decoration:none
}
.btn-primary:hover{box-shadow:0 4px 0 var(--teal-dark),0 8px 16px rgba(26,122,110,.2);transform:translateY(4px)}
.btn-secondary{
  font-size:.85rem;color:var(--teal);text-decoration:none;
  display:flex;align-items:center;gap:.5rem;font-weight:400
}
.btn-secondary::before{
  content:'';width:28px;height:1px;background:var(--teal);
  transition:width .3s
}
.btn-secondary:hover::before{width:42px}

/* ── SECTION LAYOUT ── */
section{padding:6rem 4rem}
.section-tag{
  font-size:.72rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;
  color:var(--teal);margin-bottom:1rem;display:block
}
.section-h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,3.5vw,3.2rem);font-weight:300;line-height:1.2;
  color:var(--charcoal);margin-bottom:1rem
}
.section-h2 em{font-style:italic;color:var(--teal)}
.section-sub{font-size:.95rem;font-weight:300;color:var(--soft);line-height:1.8;max-width:500px}

/* ── FOOTER ── */
footer{
  background:var(--charcoal);padding:3rem 4rem;
  display:flex;align-items:center;justify-content:space-between;
  border-top:1px solid rgba(255,255,255,.08)
}
.footer-logo{
  font-family:'Cormorant Garamond',serif;font-size:1.4rem;
  color:var(--white);font-weight:400
}
.footer-logo span{color:var(--gold);font-style:italic}
.footer-links{display:flex;gap:2rem;list-style:none}
.footer-links a{font-size:.78rem;color:rgba(255,255,255,.4);text-decoration:none;letter-spacing:.08em;text-transform:uppercase;transition:color .3s}
.footer-links a:hover{color:var(--teal-light)}
.footer-copy{font-size:.75rem;color:rgba(255,255,255,.25)}

/* ── RESPONSIVE GRID UTILITIES ── */
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2rem; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem; }

/* ── MOBILE MENU ── */
.mobile-menu-btn {
  display: none;
  background: none;
  border: none;
  color: var(--teal-dark);
  font-size: 1.8rem;
  cursor: pointer;
  z-index: 102;
}

/* ── MEDIA QUERIES ── */
@media (max-width: 992px) {
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  section { padding: 5rem 3rem; }
}

@media (max-width: 768px) {
  .mobile-menu-btn { display: block; }
  
  .nav-links {
    position: fixed;
    top: 0;
    right: -100%;
    width: 280px;
    height: 100vh;
    background: var(--pearl);
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 2rem;
    box-shadow: -10px 0 30px rgba(0,0,0,0.1);
    transition: right 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    z-index: 100;
  }
  
  .nav-links.nav-active { right: 0; }
  
  /* Disable custom cursor on mobile */
  #cursor, #cursor-ring { display: none !important; }
  * { cursor: auto !important; }
  
  section { padding: 4rem 1.5rem; }
  nav { padding: 1.2rem 1.5rem; }
  
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; gap: 1.5rem; }
  
  footer { flex-direction: column; text-align: center; gap: 1.5rem; padding: 3rem 1.5rem; }
  .footer-links { flex-direction: column; gap: 1rem; }
  
  .section-h2 { font-size: clamp(2.2rem, 8vw, 2.8rem); }
}

/* ── REVEAL ANIMATIONS ── */
.reveal{opacity:0;transform:translateY(30px) translateZ(-20px);transition:all .7s cubic-bezier(.25,.46,.45,.94)}
.reveal.visible{opacity:1;transform:translateY(0) translateZ(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}

/* ── TILT EFFECT ── */
.tiltable{transform-style:preserve-3d;transition:transform .2s}
