/* ══════════════════════════════════════════
   Lifestyling NYC — Styles
   ══════════════════════════════════════════ */

@tailwind base;
@tailwind components;
@tailwind utilities;

/* ── Base ── */
html {
  scroll-behavior: smooth;
}

section[id] {
  scroll-margin-top: 80px;
}

/* ══════════════════════════════════════════
   Animations — Scroll Reveal
   ══════════════════════════════════════════ */
.reveal {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

.reveal-left {
  opacity: 0;
  transform: translateX(-60px);
  transition: opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal-left.visible {
  opacity: 1;
  transform: translateX(0);
}

.reveal-right {
  opacity: 0;
  transform: translateX(60px);
  transition: opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal-right.visible {
  opacity: 1;
  transform: translateX(0);
}

/* Stagger delays */
.delay-1 { transition-delay: 0.1s; }
.delay-2 { transition-delay: 0.2s; }
.delay-3 { transition-delay: 0.3s; }

/* ══════════════════════════════════════════
   Animations — Hero Entrance
   ══════════════════════════════════════════ */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(40px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.anim-fade-up {
  animation: fadeUp 1s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.anim-fade-in {
  animation: fadeIn 1s 0.3s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  opacity: 0;
}

.anim-fade-up-delay {
  animation: fadeUp 1s 0.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  opacity: 0;
}

/* ══════════════════════════════════════════
   Navbar
   ══════════════════════════════════════════ */
.navbar.scrolled {
  border-bottom-color: #eee;
  box-shadow: 0 1px 20px rgba(0, 0, 0, 0.04);
}

/* Nav link hover */
.nav-link:hover {
  color: #B6ABEA;
}

/* Mobile nav open state */
.nav-menu.open {
  display: flex !important;
}

/* ══════════════════════════════════════════
   Form
   ══════════════════════════════════════════ */
.form-select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23888' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
}

.form-success {
  display: none;
}

.form-success.show {
  display: block;
}

/* ══════════════════════════════════════════
   Utility
   ══════════════════════════════════════════ */

/* Placeholder images */
.placeholder-img {
  position: relative;
  overflow: hidden;
}

.placeholder-img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, transparent 40%, rgba(255, 255, 255, 0.2) 100%);
}

/* Subtext letter-spacing */
.track-sub {
  letter-spacing: -0.01em;
}
