:root {
  --ntav-bg: #0b0b0b;
  --ntav-bg-soft: #101010;
  --ntav-surface: #151515;
  --ntav-surface-2: #1b1b1b;
  --ntav-border: rgba(196, 160, 58, 0.28);
  --ntav-border-soft: rgba(255, 255, 255, 0.12);
  --ntav-text: #f5f4f1;
  --ntav-muted: #b9b6ae;
  --ntav-accent: #c4a03a;
  --ntav-accent-soft: #d9bb63;
  --ntav-shadow: 0 24px 52px -36px rgba(0, 0, 0, 0.9);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: "Outfit", "Plus Jakarta Sans", "Segoe UI", sans-serif;
  background:
    radial-gradient(1200px 600px at 85% -10%, rgba(196, 160, 58, 0.08), transparent 60%),
    radial-gradient(900px 600px at -5% 20%, rgba(255, 255, 255, 0.03), transparent 65%),
    var(--ntav-bg);
  color: var(--ntav-text);
  letter-spacing: 0.003em;
  line-height: 1.65;
  overflow-x: hidden;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "Outfit", "Montserrat", "Segoe UI", sans-serif;
  letter-spacing: -0.015em;
}

a {
  transition: color 0.24s ease, opacity 0.24s ease;
}

.nav-glass {
  background: color-mix(in srgb, var(--ntav-bg) 86%, transparent);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid color-mix(in srgb, var(--ntav-accent) 20%, white 10%);
  box-shadow: 0 14px 36px -30px rgba(0, 0, 0, 0.95);
  transition: background-color 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}

.nav-glass.scrolled {
  background: color-mix(in srgb, var(--ntav-bg) 92%, transparent);
  border-bottom-color: color-mix(in srgb, var(--ntav-accent) 40%, white 4%);
}

header.nav-glass > div {
  min-height: 5.3rem;
  padding-top: 0.3rem !important;
  padding-bottom: 0.3rem !important;
}

header.nav-glass > div > a.flex.items-center {
  padding-top: 0;
  padding-bottom: 0;
}

.nav-logo {
  height: 5rem;
  width: auto;
  display: block;
}

nav a[data-nav-link] {
  position: relative;
  color: #d6d2ca;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.74rem;
}

nav a[data-nav-link]:hover {
  color: #ffffff;
}

nav a[data-nav-link]::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -6px;
  width: 100%;
  height: 2px;
  border-radius: 999px;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.24s ease;
  background: var(--ntav-accent);
}

nav a[data-nav-link]:hover::after,
.active-nav::after {
  transform: scaleX(1);
}

.active-nav {
  color: #fff !important;
}

.glass {
  background:
    linear-gradient(165deg, rgba(255, 255, 255, 0.04), rgba(8, 8, 8, 0.55)),
    var(--ntav-surface);
  border: 1px solid var(--ntav-border);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08), var(--ntav-shadow);
  backdrop-filter: blur(8px);
}

.footer-logo {
  width: min(390px, 100%);
  height: auto;
  display: block;
}

.section-title {
  font-size: clamp(2.2rem, 1.2rem + 2.8vw, 4rem);
  line-height: 1.03;
  letter-spacing: -0.03em;
  max-width: 14ch;
}

.muted {
  color: var(--ntav-muted);
  line-height: 1.76;
}

.card-hover {
  transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.3s ease, box-shadow 0.3s ease;
}

.card-hover:hover {
  transform: translateY(-8px);
  border-color: color-mix(in srgb, var(--ntav-accent) 60%, white 8%);
  box-shadow: 0 28px 58px -42px rgba(0, 0, 0, 0.95);
}

.btn-primary,
.btn-secondary {
  border-radius: 999px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  transition: transform 0.24s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.24s ease, background-color 0.24s ease, color 0.24s ease, box-shadow 0.24s ease;
}

.btn-primary {
  background: var(--ntav-accent);
  color: #0d0d0d;
  border: 1px solid color-mix(in srgb, var(--ntav-accent) 65%, white 10%);
}

.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 28px -18px rgba(196, 160, 58, 0.65);
}

.btn-secondary {
  border: 1px solid color-mix(in srgb, var(--ntav-accent) 55%, white 12%);
  color: #efdfb3;
  background: color-mix(in srgb, var(--ntav-accent) 12%, transparent);
}

.btn-secondary:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--ntav-accent) 80%, white 16%);
  color: #fff;
  background: color-mix(in srgb, var(--ntav-accent) 20%, transparent);
}

.btn-primary:focus-visible,
.btn-secondary:focus-visible,
a[data-nav-link]:focus-visible,
.form-input:focus-visible,
.form-select:focus-visible,
.form-textarea:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--ntav-accent) 85%, white 10%);
  outline-offset: 2px;
}

.form-input,
.form-select,
.form-textarea {
  width: 100%;
  border: 1px solid var(--ntav-border-soft);
  background: color-mix(in srgb, var(--ntav-bg-soft) 92%, transparent);
  color: var(--ntav-text);
  border-radius: 0.85rem;
  padding: 0.82rem 0.95rem;
  outline: none;
  transition: border-color 0.25s ease, box-shadow 0.25s ease, background-color 0.25s ease;
}

.form-input::placeholder,
.form-textarea::placeholder {
  color: #89847a;
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  border-color: color-mix(in srgb, var(--ntav-accent) 75%, white 10%);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--ntav-accent) 24%, transparent);
  background: color-mix(in srgb, var(--ntav-bg-soft) 80%, transparent);
}

.reveal {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 0.45s ease, transform 0.45s cubic-bezier(0.16, 1, 0.3, 1);
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.reveal[data-stagger] {
  transition-delay: var(--stagger-delay, 0ms);
}

.gallery-item img {
  transition: transform 0.42s cubic-bezier(0.16, 1, 0.3, 1), filter 0.3s ease;
}

.gallery-item:hover img {
  transform: scale(1.06);
  filter: brightness(1.08) contrast(1.04);
}

.gallery-item .overlay {
  opacity: 0;
  transition: opacity 0.32s ease;
}

.gallery-item:hover .overlay {
  opacity: 1;
}

.lightbox {
  background: rgba(0, 0, 0, 0.84);
  backdrop-filter: blur(10px);
}

.back-to-top {
  position: fixed;
  right: 1rem;
  bottom: calc(1rem + env(safe-area-inset-bottom, 0px));
  z-index: 30;
  width: 2.85rem;
  height: 2.85rem;
  border-radius: 999px;
  border: 1px solid var(--ntav-border-soft);
  background: color-mix(in srgb, var(--ntav-surface) 90%, transparent);
  color: #ece7da;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(8px);
  box-shadow: 0 14px 28px -20px rgba(0, 0, 0, 0.8);
  opacity: 0;
  pointer-events: none;
  transform: translateY(8px);
  transition: opacity 0.24s ease, transform 0.24s ease, border-color 0.24s ease;
}

.back-to-top.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.back-to-top:hover {
  border-color: color-mix(in srgb, var(--ntav-accent) 72%, white 12%);
}

.quote-form,
.quote-form fieldset,
.quote-form .grid,
.quote-form label {
  min-width: 0;
}

.quote-form fieldset {
  overflow: hidden;
  min-inline-size: 0;
}

.quote-form .form-input,
.quote-form .form-select,
.quote-form .form-textarea {
  display: block;
  width: 100%;
  inline-size: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.quote-form input:not([type="radio"]):not([type="checkbox"]),
.quote-form select,
.quote-form textarea {
  min-width: 0;
  max-width: 100%;
  width: 100%;
  box-sizing: border-box;
  appearance: none;
}

.quote-form legend {
  max-width: 100%;
  white-space: normal;
  line-height: 1.35;
}

.quote-form label.inline-flex {
  white-space: normal;
  align-items: flex-start;
  line-height: 1.35;
}

.masonry-grid {
  column-count: 1;
  column-gap: 1.25rem;
}

.masonry-item {
  break-inside: avoid;
  margin-bottom: 1.25rem;
}

.masonry-item img {
  width: 100%;
  height: auto;
  display: block;
}

@media (max-width: 768px) {
  .nav-logo {
    height: 4.25rem;
  }

  header.nav-glass > div {
    min-height: 4.7rem;
    padding-top: 0.22rem !important;
    padding-bottom: 0.22rem !important;
  }

  .section-title {
    max-width: 100%;
  }

  .quote-form fieldset {
    padding: 1rem;
  }

  .quote-form .grid {
    grid-template-columns: 1fr !important;
  }
}

@media (min-width: 640px) {
  .masonry-grid {
    column-count: 2;
  }
}

@media (min-width: 1024px) {
  .masonry-grid {
    column-count: 3;
    column-gap: 1.5rem;
  }

  .masonry-item {
    margin-bottom: 1.5rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* Brand color overrides for utility classes used in page content */
.text-amber-300 { color: #c4a03a !important; }
.text-amber-200 { color: #dfc16c !important; }
.hover\:text-amber-200:hover { color: #dfc16c !important; }
.hover\:text-cyan-200:hover { color: #dfc16c !important; }
.border-blue-400\/40 { border-color: rgba(196, 160, 58, 0.4) !important; }
.bg-blue-500\/10 { background-color: rgba(196, 160, 58, 0.1) !important; }
