/* Visual layer — photography & glass */

:root {
  --glass-dark: rgba(255, 255, 255, 0.07);
  --glass-dark-border: rgba(255, 255, 255, 0.12);
  --glass-light: rgba(255, 255, 255, 0.78);
  --glass-light-border: rgba(255, 255, 255, 0.9);
  --glass-blur: 24px;
  --overlay-hero: linear-gradient(
    115deg,
    rgba(10, 10, 10, 0.58) 0%,
    rgba(10, 10, 10, 0.28) 45%,
    rgba(10, 10, 10, 0.44) 100%
  );
  --overlay-dark: linear-gradient(
    180deg,
    rgba(10, 10, 10, 0.44) 0%,
    rgba(10, 10, 10, 0.64) 100%
  );
  --overlay-card: linear-gradient(
    180deg,
    transparent 0%,
    rgba(10, 10, 10, 0.32) 100%
  );
}

/* ── Hero full-bleed image ── */

.hero__media {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

.hero__media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
  display: block;
  transform: scale(1.02);
  transition: transform 8s var(--ease-out);
}

.hero:hover .hero__media img,
.hero.is-visible .hero__media img {
  transform: scale(1.06);
}

.hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: var(--overlay-hero, linear-gradient(105deg, rgba(10, 10, 10, 0.75) 0%, rgba(10, 10, 10, 0.35) 50%, rgba(10, 10, 10, 0.6) 100%));
}

.hero__overlay::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 50% at 85% 15%, rgba(120, 120, 120, 0.15) 0%, transparent 55%),
    linear-gradient(180deg, transparent 50%, rgba(10, 10, 10, 0.52) 100%);
}

.hero__bg {
  z-index: 2;
  background: transparent;
  pointer-events: none;
}

.hero__bg::before {
  opacity: 0.35;
}

.hero__bg::after {
  display: none;
}

.hero__inner {
  z-index: 3;
}

.hero__card {
  background: var(--glass-dark);
  border: 1px solid var(--glass-dark-border);
  backdrop-filter: blur(var(--glass-blur)) saturate(1.2);
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(1.2);
  box-shadow:
    0 4px 24px rgba(0, 0, 0, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.hero__card:hover {
  background: rgba(255, 255, 255, 0.11);
  border-color: rgba(255, 255, 255, 0.22);
  box-shadow:
    0 24px 64px rgba(0, 0, 0, 0.4),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

/* ── Page header with image ── */

.page-header--visual {
  position: relative;
  overflow: hidden;
  color: var(--white);
  border-bottom: none;
  background: var(--black);
}

.page-header--visual .eyebrow {
  color: var(--gray-400);
}

.page-header--visual .page-title,
.page-header--visual .lead {
  color: var(--white);
}

.page-header--visual .lead {
  color: rgba(255, 255, 255, 0.65);
}

.page-header__media {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.page-header__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.page-header__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: var(--overlay-dark);
}

.page-header--visual .container,
.page-header--visual .container--wide {
  position: relative;
  z-index: 2;
}

/* ── Split media (text + image) ── */

.split-media {
  display: grid;
  grid-template-columns: 1fr 1.05fr;
  gap: clamp(32px, 6vw, 64px);
  align-items: center;
}

.split-media--reverse {
  grid-template-columns: 1.05fr 1fr;
}

.split-media--reverse .split-media__visual {
  order: -1;
}

.split-media__visual {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  aspect-ratio: 4 / 5;
  max-height: 520px;
  box-shadow: var(--shadow-lg);
}

.split-media__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--duration-slow) var(--ease-out);
}

.split-media__visual:hover img {
  transform: scale(1.04);
}

.split-media__visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 55%, rgba(10, 10, 10, 0.25) 100%);
  pointer-events: none;
}

.split-media__caption {
  position: absolute;
  bottom: 20px;
  left: 20px;
  right: 20px;
  font-size: 0.6875rem;
  color: rgba(255, 255, 255, 0.7);
  letter-spacing: 0.06em;
  z-index: 1;
}

/* ── Visual cards (image + glass body) ── */

.premium-card--visual {
  padding: 0;
  overflow: hidden;
  border: none;
  background: transparent;
  box-shadow: var(--shadow-card);
}

.premium-card--visual:hover {
  box-shadow: var(--shadow-card-hover);
}

.premium-card__visual {
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
}

.premium-card__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--duration-slow) var(--ease-out);
}

.premium-card--visual:hover .premium-card__visual img {
  transform: scale(1.05);
}

.premium-card__visual-overlay {
  position: absolute;
  inset: 0;
  background: var(--overlay-card);
}

.premium-card__body {
  padding: clamp(24px, 4vw, 32px);
}

.premium-card--glass .premium-card__body {
  background: var(--glass-light);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border-top: 1px solid var(--glass-light-border);
  margin-top: -1px;
}

.premium-card--glass {
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

/* ── Section with background image ── */

.section--band {
  position: relative;
  overflow: hidden;
  color: var(--white);
}

.section--band .eyebrow {
  color: var(--gray-400);
}

.section--band .display-sm,
.section--band .lead {
  color: var(--white);
}

.section--band .lead {
  color: rgba(255, 255, 255, 0.7);
}

.section-band__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.section-band__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.section-band__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    105deg,
    rgba(10, 10, 10, 0.62) 0%,
    rgba(10, 10, 10, 0.38) 50%,
    rgba(10, 10, 10, 0.52) 100%
  );
}

.section--band .container {
  position: relative;
  z-index: 2;
}

.section-band__content {
  max-width: 640px;
  padding: clamp(24px, 4vw, 40px) 0;
}

/* ── Dark banner with image ── */

.dark-banner--visual {
  position: relative;
  overflow: hidden;
  min-height: 280px;
  display: flex;
  align-items: flex-end;
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.dark-banner__media {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.dark-banner__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.dark-banner__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    0deg,
    rgba(10, 10, 10, 0.95) 0%,
    rgba(10, 10, 10, 0.5) 50%,
    rgba(10, 10, 10, 0.35) 100%
  );
}

.dark-banner__content {
  position: relative;
  z-index: 2;
  padding: clamp(40px, 6vw, 56px);
  width: 100%;
}

.dark-banner::before {
  display: none;
}

/* ── Service block with accent image ── */

.service-visual {
  display: grid;
  grid-template-columns: minmax(280px, 380px) 1fr;
  gap: clamp(32px, 5vw, 56px);
  align-items: start;
  margin-bottom: 40px;
}

.service-visual__img {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  aspect-ratio: 3 / 4;
  box-shadow: var(--shadow-lg);
}

.service-visual__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.service-visual__img::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(10, 10, 10, 0.35) 0%, transparent 40%);
}

/* ── Philosophy accent strip ── */

.philosophy-visual {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: clamp(64px, 10vw, 96px);
}

.philosophy-visual__item {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 16 / 11;
}

.philosophy-visual__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--duration-slow) var(--ease-out);
}

.philosophy-visual__item:hover img {
  transform: scale(1.04);
}

.philosophy-visual__item::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(10, 10, 10, 0.2);
  transition: background var(--duration) var(--ease-out);
}

.philosophy-visual__item:hover::after {
  background: rgba(10, 10, 10, 0.05);
}

/* ── Company office visual ── */

.company-visual {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: clamp(32px, 5vw, 48px);
  align-items: stretch;
}

.company-visual__map {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  min-height: 320px;
  background: var(--navy-800);
}

.company-visual__map img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  min-height: 320px;
  object-fit: cover;
  display: block;
}

.company-visual__map-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(10, 10, 10, 0.22) 0%, transparent 60%);
}

.company-visual__label {
  position: absolute;
  bottom: 24px;
  left: 24px;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--white);
}

/* ── Image grid accent (TOP) ── */

.visual-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: clamp(48px, 8vw, 72px);
}

.visual-grid__item {
  position: relative;
  border-radius: var(--radius-md);
  overflow: hidden;
  aspect-ratio: 4 / 3;
}

.visual-grid__item:first-child {
  grid-column: span 2;
  aspect-ratio: 16 / 9;
}

.visual-grid__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(15%);
  transition:
    transform var(--duration-slow) var(--ease-out),
    filter var(--duration) var(--ease-out);
}

.visual-grid__item:hover img {
  transform: scale(1.05);
  filter: grayscale(0%);
}

/* ── Glass service items on dark ── */

.service-item--glass {
  background: var(--glass-light);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

/* ── Reveal image scale ── */

.reveal-image {
  opacity: 0;
  transform: translateY(16px);
  transition:
    opacity 0.75s var(--ease-out),
    transform 0.75s var(--ease-out);
}

.reveal-image.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── Unsplash credit (subtle) ── */

.photo-credit {
  font-size: 0.625rem;
  color: var(--gray-500);
  letter-spacing: 0.04em;
  margin-top: 12px;
}

.photo-credit a {
  text-decoration: underline;
  text-underline-offset: 2px;
}

.photo-credit a:hover {
  color: var(--black);
}

/* ── Responsive ── */

@media (max-width: 900px) {
  .split-media,
  .split-media--reverse {
    grid-template-columns: 1fr;
  }

  .split-media--reverse .split-media__visual {
    order: 0;
  }

  .split-media__visual {
    aspect-ratio: 16 / 10;
    max-height: none;
  }

  .service-visual {
    grid-template-columns: 1fr;
  }

  .service-visual__img {
    aspect-ratio: 16 / 9;
    max-height: 280px;
  }

  .philosophy-visual {
    grid-template-columns: 1fr;
  }

  .company-visual {
    grid-template-columns: 1fr;
  }

  .visual-grid {
    grid-template-columns: 1fr 1fr;
  }

  .visual-grid__item:first-child {
    grid-column: span 2;
  }
}

@media (max-width: 768px) {
  .hero__media img {
    object-position: center 40%;
  }

  .page-header--visual {
    min-height: clamp(300px, 52svh, 400px);
    padding-bottom: clamp(40px, 8vw, 56px);
  }

  .page-header__media img {
    object-fit: cover;
    object-position: center 35%;
  }

  .split-media,
  .split-media--reverse {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .split-media--reverse .split-media__visual {
    order: unset;
  }

  .split-media__visual {
    width: 100%;
    max-height: none;
    aspect-ratio: 4 / 5;
    max-height: min(72vw, 420px);
    border-radius: var(--radius-lg);
  }

  .visual-grid {
    grid-template-columns: 1fr;
  }

  .visual-grid__item:first-child {
    grid-column: span 1;
  }

  .company-visual {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .company-visual__map {
    min-height: 200px;
    border-radius: var(--radius-lg);
  }

  .reveal-image {
    opacity: 1;
    transform: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .hero__media img,
  .premium-card__visual img,
  .split-media__visual img {
    transition: none;
  }
}
