/* Presage NYC site mock — v2 shell */

.nx-skip {
  position: absolute;
  left: -9999px;
  z-index: 9999;
  padding: var(--nx-space-3) var(--nx-space-4);
  background: var(--nx-signal);
  color: var(--nx-signal-text);
  text-decoration: none;
}
.nx-skip:focus {
  left: var(--nx-pad);
  top: var(--nx-space-3);
}

.nx-presage {
  --nx-content-max: 1080px;
  --nx-rail-w: 0px;
  min-height: 100vh;
  padding-bottom: calc(3.75rem + env(safe-area-inset-bottom, 0px));
  background: var(--nx-surface-page);
}
@media (min-width: 900px) {
  .nx-presage { padding-bottom: 0; }
}
@media (min-width: 1100px) {
  .nx-presage { --nx-rail-w: 8.5rem; }
}

.nx-presage .nx-presage-shell {
  box-sizing: border-box;
  width: 100%;
  max-width: calc(var(--nx-content-max) + var(--nx-rail-w) + var(--nx-pad) * 2);
  margin-inline: auto;
  padding-inline: var(--nx-pad);
  padding-left: calc(var(--nx-rail-w) + var(--nx-pad));
}

.nx-presage .nx-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--nx-space-3);
}
.nx-presage-bar__brand {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  min-width: 0;
}
.nx-presage-bar__title {
  margin: 0;
  font-family: var(--nx-font-display);
  font-size: clamp(0.95rem, 2.4vw, 1.15rem);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--nx-smoke);
}
.nx-presage-bar__sub {
  margin: 0;
  font-family: var(--nx-font-mono);
  font-size: var(--nx-text-stamp);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--nx-text-muted);
}
.nx-presage-bar__nexus {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: var(--nx-space-2);
  text-decoration: none;
}
.nx-presage-bar__nexus img {
  height: clamp(2.75rem, 8vw, 4.25rem);
  width: auto;
  max-width: min(42vw, 11rem);
}
.nx-presage-bar__nexus-label {
  font-family: var(--nx-font-mono);
  font-size: var(--nx-text-stamp);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--nx-text-secondary);
  white-space: nowrap;
}
@media (max-width: 699px) {
  .nx-presage-bar__nexus-label { display: none; }
}

.nx-presage-hero {
  position: relative;
  min-height: clamp(420px, 72vh, 640px);
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  scroll-margin-top: var(--nx-bar-h);
  border-bottom: 1px solid var(--nx-border);
}
.nx-presage-hero__media {
  position: absolute;
  inset: 0;
}
.nx-presage-hero__media .nx-ir-frame {
  position: absolute;
  inset: 0;
}
.nx-presage-hero__media .nx-ir-frame__img {
  object-position: 42% 22%;
}
.nx-presage-hero__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: calc(var(--nx-content-max) + var(--nx-rail-w) + var(--nx-pad) * 2);
  margin-inline: auto;
  padding: var(--nx-space-8) var(--nx-pad);
  padding-left: calc(var(--nx-rail-w) + var(--nx-pad));
  --nx-hero-smoke: #c4bbb3;
  --nx-hero-mist: #8a7f78;
  --nx-hero-matrix: #00c98a;
}
.nx-presage-hero .nx-eyebrow { color: var(--nx-hero-matrix); }
.nx-presage-hero .nx-display {
  color: var(--nx-hero-smoke);
  margin: 0 0 var(--nx-space-3);
  max-width: 14ch;
}
.nx-presage-hero .nx-body--primary {
  color: var(--nx-hero-mist);
  max-width: 46ch;
}
.nx-presage-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--nx-space-3);
  margin-top: var(--nx-space-5);
}

.nx-presage-main {
  position: relative;
  z-index: 2;
}
.nx-presage-main .nx-section {
  padding-block: clamp(3.5rem, 7vw, 5rem);
  scroll-margin-top: calc(var(--nx-bar-h) + var(--nx-space-3));
  border-bottom: 1px solid var(--nx-border);
}
.nx-presage-main .nx-section:last-of-type {
  border-bottom: none;
}
.nx-presage-main .nx-section-head {
  display: flex;
  align-items: baseline;
  gap: var(--nx-space-4);
  margin-bottom: var(--nx-space-4);
}
.nx-presage-main .nx-section-head .nx-h1 {
  margin: 0;
}
.nx-presage-main .nx-section-num {
  font-family: var(--nx-font-mono);
  font-size: var(--nx-text-caption);
  color: var(--nx-infrared);
  letter-spacing: 0.1em;
  flex-shrink: 0;
}
.nx-presage-main .nx-section-lead {
  margin: 0 0 var(--nx-space-6);
  max-width: 52ch;
  line-height: 1.65;
  color: var(--nx-text-secondary);
}

.nx-presage-services {
  display: grid;
  gap: var(--nx-space-3);
}
@media (min-width: 700px) {
  .nx-presage-services { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1000px) {
  .nx-presage-services { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
.nx-presage-service {
  padding: var(--nx-space-4);
  background: var(--nx-surface-raised);
  border: 1px solid var(--nx-border);
}
.nx-presage-service .nx-h3 { margin: 0 0 var(--nx-space-2); }
.nx-presage-service .nx-caption { margin: 0; line-height: 1.55; }

.nx-presage-stats {
  display: grid;
  gap: var(--nx-space-3);
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
@media (min-width: 700px) {
  .nx-presage-stats { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
.nx-presage-stat {
  padding: var(--nx-space-4);
  background: var(--nx-surface-raised);
  border: 1px solid var(--nx-border);
}
.nx-presage-stat__val {
  font-family: var(--nx-font-display);
  font-size: clamp(1.25rem, 3.2vw, 1.75rem);
  font-weight: 800;
  color: var(--nx-smoke);
  line-height: 1.1;
  margin-bottom: var(--nx-space-2);
  letter-spacing: 0.02em;
}
.nx-presage-stat__label {
  margin: 0;
  font-size: var(--nx-text-small);
  color: var(--nx-text-secondary);
  line-height: 1.45;
}

.nx-presage-gallery-head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--nx-space-4);
  margin-bottom: var(--nx-space-6);
}
.nx-presage-gallery-head .nx-section-head {
  margin-bottom: var(--nx-space-3);
}
.nx-presage-gallery-head .nx-body {
  margin: 0;
  max-width: 52ch;
  line-height: 1.65;
  color: var(--nx-text-secondary);
}

.nx-presage-grid {
  display: grid;
  gap: 3px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
@media (min-width: 700px) {
  .nx-presage-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
.nx-presage-grid--portfolio {
  grid-template-columns: 1fr;
}
@media (min-width: 700px) {
  .nx-presage-grid--portfolio { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

.nx-presage-shot {
  position: relative;
  display: block;
  overflow: hidden;
  background: var(--nx-void);
  border: 1px solid var(--nx-border);
  aspect-ratio: 4 / 5;
  text-decoration: none;
  color: inherit;
}
.nx-presage-shot--wide { aspect-ratio: 16 / 10; }
.nx-presage-shot img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--nx-duration-slow) var(--nx-ease), filter var(--nx-duration) var(--nx-ease);
  filter: grayscale(0.08) contrast(1.06) brightness(0.88);
}
.nx-presage-shot:hover img,
.nx-presage-shot:focus-visible img {
  transform: scale(1.03);
  filter: grayscale(0) contrast(1.08) brightness(0.96);
}
.nx-presage-shot__cap {
  position: absolute;
  inset: auto 0 0;
  padding: var(--nx-space-3);
  background: linear-gradient(to top, rgba(0, 0, 0, 0.82), transparent);
  font-size: var(--nx-text-stamp);
  color: var(--nx-smoke);
  line-height: 1.45;
  transform: translateY(100%);
  transition: transform var(--nx-duration) var(--nx-ease);
}
.nx-presage-shot:hover .nx-presage-shot__cap,
.nx-presage-shot:focus-visible .nx-presage-shot__cap {
  transform: translateY(0);
}

.nx-presage-nexus {
  display: grid;
  gap: var(--nx-space-5);
  padding: var(--nx-space-6);
  background: var(--nx-surface-raised);
  border: 1px solid var(--nx-border);
}
@media (min-width: 800px) {
  .nx-presage-nexus {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
    align-items: center;
  }
}
.nx-presage-nexus__logo img {
  width: min(100%, 18rem);
  height: auto;
}
.nx-presage-nexus .nx-body { margin: 0; max-width: none; }
.nx-presage-nexus__lead {
  margin-top: var(--nx-space-4);
}
.nx-presage-nexus__actions {
  margin-top: var(--nx-space-4);
  display: flex;
  flex-wrap: wrap;
  gap: var(--nx-space-3);
}
.nx-presage-nexus__frame {
  min-height: 280px;
}

/* Contact — designer footer split (no tier) */
.nx-presage .nx-mock-footer__contact {
  border: 1px solid var(--nx-border-accent);
  background: var(--nx-surface-raised);
  overflow: hidden;
}
.nx-presage .nx-mock-footer__split {
  display: grid;
}
@media (min-width: 900px) {
  .nx-presage .nx-mock-footer__split {
    grid-template-columns: minmax(0, 1fr) minmax(300px, 400px);
  }
}
.nx-presage .nx-mock-footer__hero {
  position: relative;
  min-height: clamp(280px, 42vw, 420px);
  padding: var(--nx-space-6) var(--nx-space-5);
  border-bottom: 1px solid var(--nx-border);
  overflow: hidden;
  display: flex;
  align-items: flex-end;
}
@media (min-width: 900px) {
  .nx-presage .nx-mock-footer__hero {
    min-height: 100%;
    padding: var(--nx-space-8) var(--nx-space-6);
    border-bottom: none;
    border-right: 1px solid var(--nx-border);
  }
}
.nx-presage .nx-mock-footer__hero-media {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.nx-presage .nx-mock-footer__hero-media .nx-ir-frame {
  width: 100%;
  height: 100%;
  pointer-events: auto;
}
.nx-presage .nx-mock-footer__hero-media .nx-ir-frame__img {
  object-position: 72% 38%;
}
.nx-presage .nx-mock-footer__hero-veil {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(to top, var(--nx-void) 18%, transparent 68%),
    linear-gradient(to right, var(--nx-void) 8%, transparent 52%),
    radial-gradient(ellipse 50% 40% at 82% 35%, rgba(30, 74, 56, 0.18), transparent);
}
.nx-presage .nx-mock-footer__hero-copy {
  position: relative;
  z-index: 1;
}
.nx-presage .nx-mock-footer__display {
  font-family: var(--nx-font-display);
  font-size: clamp(1.5rem, 4vw, 2.25rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  margin: var(--nx-space-4) 0 var(--nx-space-4);
  max-width: 14ch;
}
.nx-presage .nx-mock-footer__display em {
  font-style: normal;
  color: var(--nx-matrix);
}
.nx-presage .nx-mock-footer__social {
  margin: var(--nx-space-3) 0 0;
  font-size: var(--nx-text-small);
}
.nx-presage .nx-mock-footer__avail {
  display: flex;
  align-items: center;
  gap: var(--nx-space-3);
  font-size: var(--nx-text-small);
  color: var(--nx-text-secondary);
  margin: 0;
  max-width: 42ch;
}
.nx-presage .nx-mock-footer__form {
  padding: var(--nx-space-6) var(--nx-space-5);
}
@media (min-width: 900px) {
  .nx-presage .nx-mock-footer__form { padding: var(--nx-space-8) var(--nx-space-6); }
}
.nx-presage .nx-mock-footer__form .nx-form-actions {
  margin-top: var(--nx-space-4);
}
.nx-presage .nx-mock-footer__form .nx-form-actions .nx-btn {
  width: 100%;
  justify-content: center;
}

.nx-presage-footer {
  margin-top: var(--nx-space-8);
  padding-block: var(--nx-space-5);
  border-top: 1px solid var(--nx-border);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--nx-space-4);
}
.nx-presage-footer__nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--nx-space-4);
}
.nx-presage-footer__logo {
  height: clamp(3.5rem, 10vw, 6.57rem);
  width: auto;
  max-width: min(100%, 18rem);
}

@media (max-width: 699px) {
  .nx-presage .nx-mock-footer__hero {
    min-height: 240px;
    padding: var(--nx-space-5) var(--nx-space-4);
  }
  .nx-presage .nx-mock-footer__display {
    font-size: clamp(1.25rem, 5.5vw, 1.75rem);
    max-width: none;
  }
  .nx-presage .nx-mock-footer__form {
    padding: var(--nx-space-5) var(--nx-space-4);
  }
}

@media (max-width: 699px) {
  .nx-presage-main .nx-section {
    padding-block: clamp(2.25rem, 6vw, 3rem);
  }
  .nx-presage-main .nx-section-lead {
    margin-bottom: var(--nx-space-5);
    font-size: var(--nx-text-small);
  }
  .nx-presage-gallery-head {
    margin-bottom: var(--nx-space-5);
  }
}