/* ============================================================
   CAITLIN ROBINSON — Portfolio Website
   styles.css · v3.0 · April 2026
   Clean consolidated — no patches, no conflicts
   ============================================================ */

/* ------------------------------------------------------------
   1. GOOGLE FONTS
   ------------------------------------------------------------ */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800;900&family=Open+Sans:wght@300;400;500;600&display=swap');

/* ------------------------------------------------------------
   2. DESIGN TOKENS
   ------------------------------------------------------------ */
:root {
  /* Colors */
  --color-bg:           #FFFFFF;
  --color-text:         #1A1A1A;
  --color-display:      #000000;
  --color-border:       #EEEEEE;
  --color-meta:         #888888;
  --color-overlay-bg:   rgba(0, 0, 0, 0.95);
  --color-overlay-text: #FFFFFF;

  /* Typography */
  --font-display: 'Montserrat', sans-serif;
  --font-body:    'Open Sans', sans-serif;

  --weight-light:    300;
  --weight-regular:  400;
  --weight-medium:   500;
  --weight-semibold: 600;
  --weight-bold:     700;
  --weight-black:    900;

  --leading-body:  1.65;
  --leading-tight: 1.1;
  --leading-snug:  1.25;

  /* 12-column grid — 20px gutters */
  --col-gutter:  20px;
  --grid-margin: clamp(20px, 4vw, 60px);
  --col-unit:    calc((100vw - (var(--grid-margin) * 2) - (var(--col-gutter) * 11)) / 12);

  /* Column position helpers */
  --col-2-left: calc(var(--grid-margin) + var(--col-unit) + var(--col-gutter));
  --col-8-left: calc(var(--grid-margin) + (var(--col-unit) * 7) + (var(--col-gutter) * 7));

  /* Column widths */
  --col-5-wide: calc((var(--col-unit) * 5) + (var(--col-gutter) * 4));

  /* Section spacing */
  --section-gap: clamp(64px, 8vw, 120px);
  --col-gap:     20px;

  /* Motion */
  --ease-out:        cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out:     cubic-bezier(0.4, 0, 0.2, 1);
  --ease-editorial:  cubic-bezier(0.25, 0.1, 0.25, 1);
  --duration-fast:   180ms;
  --duration-base:   320ms;
  --duration-slow:   600ms;
  --duration-enter:  800ms;
  --duration-hero:   1000ms;

  /* Parallax */
  --parallax-strength: 0.12;   /* 12% offset — subtle */
}

/* ------------------------------------------------------------
   3. RESET & BASE
   ------------------------------------------------------------ */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  overflow-x: hidden; /* prevent horizontal scrollbar sitewide */
}

body {
  font-family: var(--font-body);
  font-size: 17px;
  font-weight: var(--weight-regular);
  line-height: var(--leading-body);
  color: var(--color-text);
  background-color: var(--color-bg);
  /* overflow-x:hidden removed — clips organically shaped hero images.
     Horizontal scroll prevention is handled by html { overflow-x:hidden } */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
/* Skip-to-content link */
.skip-link {
  position: absolute;
  top: -100%;
  left: 16px;
  padding: 8px 16px;
  background: var(--color-display);
  color: var(--color-bg);
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  z-index: 9999;
  border-radius: 0 0 4px 4px;
  transition: top var(--duration-fast);
}

.skip-link:focus {
  top: 0;
}

/* Focus-visible — keyboard navigation indicators */
:focus-visible {
  outline: 2px solid var(--color-display);
  outline-offset: 3px;
}

/* Remove focus ring for mouse users, keep for keyboard */
:focus:not(:focus-visible) {
  outline: none;
}

/* Form fields — enhanced focus state */
.contact__field:focus-visible,
.pw-overlay__input:focus-visible,
.pw-request__email:focus-visible {
  outline: 2px solid var(--color-display);
  outline-offset: 2px;
}

/* Nav links — underline on focus matches hover state */
.nav__link:focus-visible {
  outline: none;
}

.nav__link:focus-visible::after {
  transform: scaleX(1);
}

/* Buttons */
button:focus-visible,
.project-nav__link:focus-visible,
.p-nav__link:focus-visible {
  outline: 2px solid var(--color-display);
  outline-offset: 4px;
  border-radius: 2px;
}



img, video {
  display: block;
  max-width: 100%;
}

a {
  color: inherit;
  text-decoration: none;
}

button {
  font-family: var(--font-display);
  cursor: pointer;
  border: none;
  background: none;
}

ul, ol { list-style: none; }

/* Global project page bullet style — double chevron, consistent across all pages */
.p-body ul li {
  padding-left: 24px;
  position: relative;
  margin-bottom: 0.85em;
}
.p-body ul li::before {
  content: '»';
  position: absolute;
  left: 0;
  color: var(--color-meta);
  font-size: 13px;
  line-height: 1.9;
}
.p-body--white ul li::before { color: rgba(255,255,255,0.5); }
.p-list { list-style: none; padding: 0; margin: 12px 0 0; }
.p-list li {
  font-family: var(--font-body);
  font-size: clamp(15px, 1.4vw, 17px);
  line-height: 1.75;
  padding-left: 24px;
  position: relative;
  margin-bottom: 0.85em;
}
.p-list li::before {
  content: '»';
  position: absolute;
  left: 0;
  color: var(--color-meta);
  font-size: 13px;
  line-height: 1.9;
}
.p-list--black li::before { color: rgba(0,0,0,0.4); }

/* ------------------------------------------------------------
   4. LAYOUT UTILITIES
   ------------------------------------------------------------ */
.section {
  padding: var(--section-gap) 0;
}

.section--flush-top {
  padding-top: 0;
}

.section--flush-bottom {
  padding-bottom: 0;
}

/* Screen-reader only */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
}

/* ------------------------------------------------------------
   5. NAVIGATION
   ------------------------------------------------------------ */
.nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--grid-margin);
  background-color: transparent;
  transition: background var(--duration-slow) var(--ease-out),
              backdrop-filter var(--duration-slow) var(--ease-out);
}

.nav.scrolled {
  background-color: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border-bottom: none;
}

.nav__logo {
  display: flex;
  align-items: center;
}

.nav__logo img {
  height: 56px;
  width: auto;
}

.nav__links {
  display: flex;
  align-items: center;
  gap: 32px;
}

.nav__link {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: var(--weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text);
  position: relative;
  transition: color var(--duration-fast) var(--ease-out);
  white-space: nowrap;
}

.nav__link::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--color-display);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--duration-base) var(--ease-out);
}

.nav__link:hover::after,
.nav__link.active::after {
  transform: scaleX(1);
}

.nav__link.active {
  font-weight: var(--weight-bold);
}

/* Nav spacer — hidden, hero controls its own offset */
.nav-spacer {
  display: none;
  height: 0;
}

/* ------------------------------------------------------------
   6. FOOTER
   ------------------------------------------------------------ */
.footer {
  background: #000000;
  border-top: none;
  padding: 24px var(--grid-margin);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}

.footer__text {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: var(--weight-bold);
  color: rgba(255, 255, 255, 0.85);
  letter-spacing: 0.02em;
}

/* ------------------------------------------------------------
   7. DIVIDER LINE
   ------------------------------------------------------------ */
.divider--arrow {
  padding: 0 var(--grid-margin);
  margin: 0;
}

.divider--arrow img {
  width: 100%;
  height: auto;
  opacity: 0.25;
}

/* ------------------------------------------------------------
   8. MOTION SYSTEM
   ------------------------------------------------------------ */

/* ── Scroll reveal — fade + translate up ──────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity var(--duration-enter) var(--ease-out),
    transform var(--duration-enter) var(--ease-out);
}

.reveal.revealed {
  opacity: 1;
  transform: translateY(0);
}

/* Stagger delays */
.reveal--delay-1 { transition-delay: 100ms; }
.reveal--delay-2 { transition-delay: 200ms; }
.reveal--delay-3 { transition-delay: 300ms; }
.reveal--delay-4 { transition-delay: 400ms; }
.reveal--delay-5 { transition-delay: 500ms; }

/* ── Hero entrance — slower, starts from less distance ────── */
.reveal--hero {
  opacity: 0;
  transform: translateY(16px);
  transition:
    opacity var(--duration-hero) var(--ease-editorial),
    transform var(--duration-hero) var(--ease-editorial);
}

.reveal--hero.revealed {
  opacity: 1;
  transform: translateY(0);
}


/*
   Usage: wrap hero img in 

/* Image — starts at col 2, 5 cols wide */
.hero__image-wrap {
  padding-left: var(--col-2-left);
  margin-bottom: 0;
}

.hero__image {
  width: var(--col-5-wide);
  height: auto;
  object-fit: contain;
  object-position: top left;
  border-radius: 0;
  display: block;
}

/* Name lockup — right-aligned */
.hero__name-wrap {
  padding: 0 var(--grid-margin);
  margin-top: clamp(16px, 2vw, 24px);
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  position: relative;
}

/* Hairline — cols 2–4, bottom-aligned to ROBINSON */
.hero__rule {
  position: absolute;
  bottom: 0;
  left: var(--col-2-left);
  width: calc((var(--col-unit) * 3) + (var(--col-gutter) * 2));
  height: 1px;
  background: var(--color-display);
}

/* CAITLIN ROBINSON */
.hero__name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(52px, 9.5vw, 148px);
  line-height: 0.9;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  text-align: right;
  color: var(--color-display);
  padding-bottom: 2px;
}

/* Scroll arrow — above fold desktop only */
.hero__scroll-arrow {
  display: none;
}

.hero__scroll-arrow img {
  height: 28px;
  width: auto;
  opacity: 0.4;
  animation: bounce 2.4s ease-in-out infinite;
}

@keyframes bounce {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(6px); }
}

/* Hide divider between hero and statement */
.hero + .divider--arrow {
  display: none;
}

/* ------------------------------------------------------------
   9. HOMEPAGE HERO
   ------------------------------------------------------------ */
.hero {
  padding-top: 70px; /* 64px nav + 6px gap */
  padding-bottom: 0;
}

/* Image — starts at col 2, 5 cols wide */
.hero__image-wrap {
  padding-left: var(--col-2-left);
  margin-bottom: 0;
}

.hero__image {
  width: var(--col-5-wide);
  height: auto;
  object-fit: contain;
  object-position: top left;
  border-radius: 0;
  display: block;
}

/* Name lockup — right-aligned */
.hero__name-wrap {
  padding: 0 var(--grid-margin);
  margin-top: clamp(16px, 2vw, 24px);
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  position: relative;
}

/* Hairline — cols 2–4, bottom-aligned to ROBINSON */
.hero__rule {
  position: absolute;
  bottom: 0;
  left: var(--col-2-left);
  width: calc((var(--col-unit) * 3) + (var(--col-gutter) * 2));
  height: 1px;
  background: var(--color-display);
}

/* CAITLIN ROBINSON */
.hero__name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(52px, 9.5vw, 148px);
  line-height: 0.9;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  text-align: right;
  color: var(--color-display);
  padding-bottom: 2px;
}

/* Scroll arrow — above fold desktop only */
.hero__scroll-arrow {
  display: none;
}

.hero__scroll-arrow img {
  height: 28px;
  width: auto;
  opacity: 0.4;
  animation: bounce 2.4s ease-in-out infinite;
}

@keyframes bounce {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(6px); }
}

/* Hide divider between hero and statement */
.hero + .divider--arrow {
  display: none;
}

/* ------------------------------------------------------------
   10. HOMEPAGE STATEMENT
   ------------------------------------------------------------ */
.statement {
  padding: clamp(20px, 2.5vw, 36px) var(--grid-margin) clamp(8px, 1vw, 16px);
  padding-left: calc(var(--grid-margin) + (var(--col-unit) * 4) + (var(--col-gutter) * 4));
  max-width: 100%;
}

.statement p {
  font-family: var(--font-body);
  font-size: clamp(19px, 2vw, 24px);
  font-weight: var(--weight-regular);
  line-height: 1.6;
  color: var(--color-text);
  margin-bottom: 0.6em;
}

.statement p:last-child {
  margin-bottom: 0;
}

/* ------------------------------------------------------------
   11. WORK CAROUSEL (homepage)
   ------------------------------------------------------------ */
.work-section {
  padding: clamp(40px, 5vw, 72px) 0 clamp(48px, 6vw, 80px);
}

.work-section__header {
  padding-left: var(--col-2-left);
  padding-right: var(--grid-margin);
  margin-bottom: clamp(20px, 3vw, 36px);
}

.work-section__header h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(48px, 8vw, 120px);
  line-height: var(--leading-tight);
  color: var(--color-display);
  text-transform: uppercase;
  letter-spacing: -0.02em;
}

.carousel {
  position: relative;
}

.carousel__track-wrap {
  overflow-x: auto;
  /* Do NOT set overflow-y — leaving it at default (visible-equivalent)
     prevents card image curves from being clipped vertically */
  padding-left: var(--col-2-left);
  padding-top: 8px;
  padding-bottom: 8px;
  cursor: grab;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.carousel__track-wrap:active {
  cursor: grabbing;
}

.carousel__track {
  display: flex;
  gap: var(--col-gap);
  /* padding-right creates breathing room after the last card */
  padding-right: var(--grid-margin);
  transition: transform var(--duration-slow) var(--ease-out);
  will-change: transform;
}

/* Carousel arrows — simple chevrons, centered */
.carousel__controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  margin-top: 28px;
  padding: 0;
}

.carousel__btn {
  width: auto;
  height: auto;
  border: none;
  background: transparent;
  font-size: 28px;
  color: rgba(0, 0, 0, 0.35);
  padding: 8px 16px;
  cursor: pointer;
  line-height: 1;
  font-weight: 300;
  transition: color var(--duration-fast);
}

.carousel__btn:hover {
  color: var(--color-display);
}

.carousel__btn:disabled {
  opacity: 0.2;
}

/* ------------------------------------------------------------
   12. PROJECT CARD
   ------------------------------------------------------------ */
.project-card {
  flex: 0 0 calc(25% - (var(--col-gap) * 3 / 4));
  cursor: pointer;
  display: block;
}

.project-card__thumb {
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: transparent;
  margin-bottom: 0;
}

.project-card__thumb img,
.project-card__thumb video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--duration-slow) var(--ease-out);
}

.project-card:hover .project-card__thumb img,
.project-card:hover .project-card__thumb video {
  transform: scale(1.03);
}

.project-card__name {
  font-family: var(--font-body);
  font-size: clamp(19px, 2vw, 24px);
  font-weight: var(--weight-semibold);
  color: var(--color-display);
  margin-top: 14px;
  margin-bottom: 5px;
  letter-spacing: -0.01em;
  line-height: 1.25;
  text-transform: none;
}

.project-card__category {
  font-family: var(--font-body);
  font-size: clamp(14px, 1.4vw, 17px);
  font-weight: var(--weight-light);
  text-transform: capitalize;
  letter-spacing: 0.01em;
  color: #000000;
}

/* Hidden during filter */
.project-card.hidden {
  display: none;
}

/* ------------------------------------------------------------
   13. WORK PAGE — filter bar + grid
   ------------------------------------------------------------ */
.work-filter {
  padding-top: calc(64px + 20px); /* nav + 20px gap */
  padding-bottom: 0;
}

/* Filter bar */
.filter-marquee {
  border-top: none;
  border-bottom: none;
  margin-left: 20px;
  width: calc(100% - 20px);
  padding-left: 0;
  margin-bottom: clamp(32px, 4vw, 56px);
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none;
  -ms-overflow-style: none;
  -webkit-overflow-scrolling: touch;
  white-space: nowrap;
}

.filter-marquee::-webkit-scrollbar {
  display: none;
}

.filter-marquee__inner {
  display: inline-flex;
  align-items: center;
  gap: 0;
  white-space: nowrap;
  padding-left: 0;
}

.filter-btn {
  font-family: var(--font-display);
  font-size: clamp(19px, 2vw, 24px);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #000000;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0 20px;
  transition: opacity var(--duration-fast);
  white-space: nowrap;
  flex-shrink: 0;
  position: relative;
}

/* Bullet separator between buttons */
.filter-btn::after {
  display: none;
}

.filter-btn + .filter-btn::before {
  content: '•';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translate(-50%, -50%);
  color: #000000;
  font-size: 18px;
  line-height: 1;
  pointer-events: none;
}

.filter-btn:hover {
  opacity: 0.5;
}

.filter-btn.active {
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 1.5px;
  opacity: 1;
}

/* Work grid — 4 columns */
.work-grid {
  padding: 0 var(--grid-margin);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(32px, 4vw, 56px) var(--col-gap);
}

.work-grid .project-card {
  flex: none;
}

.work-grid .project-card__thumb {
  aspect-ratio: 1 / 1;
}

/* ------------------------------------------------------------
   14. PASSWORD OVERLAY
   ------------------------------------------------------------ */
.pw-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: var(--color-overlay-bg);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration-base) var(--ease-out);
}

.pw-overlay.active {
  opacity: 1;
  pointer-events: all;
}

.pw-overlay__close {
  position: absolute;
  top: 24px;
  right: 24px;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-overlay-text);
  font-size: 24px;
  cursor: pointer;
  opacity: 0.6;
  transition: opacity var(--duration-fast);
  line-height: 1;
}

.pw-overlay__close:hover {
  opacity: 1;
}

.pw-overlay__inner {
  text-align: center;
  width: 100%;
  max-width: 400px;
  padding: 0 var(--grid-margin);
}

.pw-overlay__title {
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(255,255,255,0.4);
  margin-bottom: 32px;
}

.pw-overlay__input-wrap {
  position: relative;
  margin-bottom: 20px;
}

.pw-overlay__input {
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.3);
  color: var(--color-overlay-text);
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: var(--weight-medium);
  letter-spacing: 0.08em;
  padding: 12px 0;
  text-align: center;
  outline: none;
  transition: border-color var(--duration-fast);
}

.pw-overlay__input::placeholder {
  color: rgba(255,255,255,0.25);
  letter-spacing: 0.12em;
  font-size: 13px;
  text-transform: uppercase;
}

.pw-overlay__input:focus {
  border-color: rgba(255, 255, 255, 0.7);
}

.pw-overlay__input.shake {
  animation: shake 400ms var(--ease-out);
}

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  20%       { transform: translateX(-8px); }
  40%       { transform: translateX(8px); }
  60%       { transform: translateX(-5px); }
  80%       { transform: translateX(5px); }
}

.pw-overlay__submit {
  width: 100%;
  background: var(--color-overlay-text);
  color: var(--color-overlay-bg);
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: var(--weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 14px;
  cursor: pointer;
  border: none;
  transition: opacity var(--duration-fast);
  margin-bottom: 28px;
}

.pw-overlay__submit:hover {
  opacity: 0.85;
}

.pw-request {
  text-align: center;
}

.pw-request__link {
  font-family: var(--font-body);
  font-size: 13px;
  color: rgba(255,255,255,0.4);
  cursor: pointer;
  transition: color var(--duration-fast);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: rgba(255,255,255,0.2);
}

.pw-request__link:hover {
  color: rgba(255,255,255,0.7);
}

.pw-request__form {
  overflow: hidden;
  max-height: 0;
  transition: max-height var(--duration-slow) var(--ease-out),
              opacity var(--duration-base) var(--ease-out);
  opacity: 0;
  margin-top: 16px;
}

.pw-request__form.open {
  max-height: 120px;
  opacity: 1;
}

.pw-request__email {
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(255,255,255,0.25);
  color: var(--color-overlay-text);
  font-family: var(--font-body);
  font-size: 14px;
  padding: 10px 0;
  text-align: center;
  outline: none;
  margin-bottom: 12px;
  transition: border-color var(--duration-fast);
}

.pw-request__email::placeholder {
  color: rgba(255,255,255,0.25);
  font-size: 12px;
  letter-spacing: 0.04em;
}

.pw-request__email:focus {
  border-color: rgba(255,255,255,0.6);
}

.pw-request__send {
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: var(--weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.7);
  background: none;
  border: 1px solid rgba(255,255,255,0.3);
  padding: 8px 24px;
  cursor: pointer;
  transition: border-color var(--duration-fast), color var(--duration-fast);
}

.pw-request__send:hover {
  border-color: rgba(255,255,255,0.7);
  color: var(--color-overlay-text);
}

.pw-request__status {
  font-family: var(--font-body);
  font-size: 13px;
  color: rgba(255,255,255,0.5);
  margin-top: 12px;
  min-height: 20px;
}

/* ------------------------------------------------------------
   15. CONTACT — HOLLA'
   ------------------------------------------------------------ */
.contact-wrap {
  padding: var(--section-gap) var(--grid-margin);
}

/* Row 1: HOLLA' right-aligned */
.contact-header {
  text-align: right;
  margin-bottom: clamp(16px, 2vw, 28px);
}

.contact__headline {
  font-family: var(--font-display);
  font-size: clamp(64px, 9vw, 130px);
  font-weight: 700;
  line-height: 0.88;
  letter-spacing: -0.03em;
  color: #000000;
  text-transform: uppercase;
  display: block;
  text-align: right;
  margin-bottom: 16px;
}

/* Subcopy — right-aligned block, text left-aligned inside */
.contact__sub {
  display: inline-block;
  text-align: left;
  max-width: 460px;
  font-family: var(--font-body);
  font-size: clamp(19px, 2vw, 24px);
  font-weight: var(--weight-regular);
  line-height: 1.6;
  color: var(--color-text);
}

/* Row 2: form — left-aligned to col 2 */
.contact-form-wrap {
  margin-top: clamp(24px, 3vw, 40px);
  padding-left: calc(var(--col-2-left) - var(--grid-margin));
  max-width: calc(calc(var(--col-2-left) - var(--grid-margin)) + 460px);
}

.contact__form {
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: 100%;
}

.contact__field {
  width: 100%;
  border-radius: 10px;
  border: 1px solid #D9D9D9;
  background: #D9D9D9;
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: var(--weight-regular);
  color: #000000;
  padding: 14px 18px;
  outline: none;
  -webkit-appearance: none;
  box-sizing: border-box;
  transition: border-color var(--duration-fast);
}

.contact__field::placeholder {
  color: rgba(0, 0, 0, 0.45);
}

.contact__field:focus {
  border-color: #000000;
}

.contact__textarea {
  min-height: 120px;
  resize: vertical;
}

.contact__submit {
  display: inline-block;
  border-radius: 10px;
  padding: 14px 75px;
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: var(--weight-semibold);
  text-transform: none;
  letter-spacing: 0.02em;
  background: #000000;
  color: #ffffff;
  border: none;
  cursor: pointer;
  transition: opacity var(--duration-fast);
  margin-top: 4px;
}

.contact__submit:hover {
  opacity: 0.75;
}

.contact__status {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--color-meta);
  margin-top: 8px;
}

/* ------------------------------------------------------------
   16. PROJECT DETAIL PAGE
   ------------------------------------------------------------ */
.project-hero {
  width: 100%;
  height: 100vh;
  min-height: 500px;
  position: relative;
  overflow: hidden;
}

.project-hero img,
.project-hero video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.project-meta-bar {
  background: var(--color-display);
  color: var(--color-overlay-text);
  padding: 20px var(--grid-margin);
  display: flex;
  flex-wrap: wrap;
  gap: 8px 40px;
  position: relative;
  z-index: 2; /* ensure meta bar always sits above hero stacking context */
}

.project-meta-bar__item {
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: var(--weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(255,255,255,0.9);
}

.project-meta-bar__item span {
  color: rgba(255,255,255,0.45);
  margin-right: 6px;
}

.project-intro {
  padding: clamp(64px, 8vw, 120px) var(--grid-margin);
}

.project-intro__headline {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(32px, 5vw, 64px);
  line-height: 1.05;
  color: var(--color-display);
  margin-bottom: clamp(32px, 4vw, 56px);
  max-width: 800px;
  letter-spacing: -0.02em;
}

.project-intro__body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 80px);
}

.project-intro__body p {
  margin-bottom: 1.2em;
  line-height: var(--leading-body);
}

.media-full { width: 100%; }
.media-full img,
.media-full video {
  width: 100%;
  height: auto;
  display: block;
}

.media-full--vh {
  height: 80vh;
  overflow: hidden;
}

.media-full--vh img,
.media-full--vh video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.media-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--col-gap);
}

.media-split--60-40 {
  grid-template-columns: 3fr 2fr;
}

.media-split img,
.media-split video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.media-caption {
  padding: 12px var(--grid-margin);
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--color-meta);
}

.project-text-section {
  padding: clamp(48px, 6vw, 96px) var(--grid-margin);
  max-width: 760px;
}

.project-text-section p {
  margin-bottom: 1.2em;
  line-height: var(--leading-body);
}

.project-nav {
  border-top: 1px solid var(--color-border);
  padding: 32px var(--grid-margin);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.project-nav__link {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-display);
  display: flex;
  align-items: center;
  gap: 8px;
  transition: gap var(--duration-fast) var(--ease-out);
}

.project-nav__link:hover {
  gap: 14px;
}

.project-nav__center {
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-meta);
  border-bottom: 1px solid var(--color-border);
  padding-bottom: 2px;
  transition: color var(--duration-fast);
}

.project-nav__center:hover {
  color: var(--color-display);
}

/* ------------------------------------------------------------
   17. ABOUT PAGE
   ------------------------------------------------------------ */
.about-body {
  padding: clamp(40px, 5vw, 72px) var(--grid-margin);
  padding-left: var(--col-2-left);
  max-width: calc(var(--col-2-left) + (var(--col-unit) * 7) + (var(--col-gutter) * 6));
}

.about-body p {
  font-family: var(--font-body);
  font-size: clamp(17px, 1.6vw, 20px);
  font-weight: var(--weight-regular);
  line-height: 1.7;
  color: var(--color-text);
  margin-bottom: 1.3em;
}

.about-body p:last-of-type {
  margin-bottom: 0;
}

.about-linkedin-logo {
  display: inline-block;
  margin-top: 32px;
}

.about-linkedin-logo img {
  width: 48px;
  height: 48px;
  display: block;
  transition: opacity var(--duration-fast);
}

.about-linkedin-logo:hover img {
  opacity: 0.75;
}

/* ------------------------------------------------------------
   18. LEGACY PARALLAX (homepage carousel)
   ------------------------------------------------------------ */
.parallax-wrap {
  overflow: hidden;
  position: relative;
}

.parallax-img {
  will-change: transform;
  transform: scale(1.08);
}

/* ------------------------------------------------------------
   19. RESPONSIVE — TABLET (≤ 1024px)
   ------------------------------------------------------------ */
@media (max-width: 1024px) {
  .work-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .project-card {
    flex: 0 0 calc(50% - var(--col-gap) / 2);
  }

  .project-intro__body {
    grid-template-columns: 1fr;
  }

  .media-split {
    grid-template-columns: 1fr;
  }
}

/* ------------------------------------------------------------
   20. RESPONSIVE — MOBILE (≤ 767px)
   ------------------------------------------------------------ */
@media (max-width: 767px) {
  .divider-desktop { display: none; }
  .divider-mobile  { display: block; }

  /* Work section header — align with grid-margin on mobile */
  .work-section__header {
    padding-left: var(--grid-margin);
  }

  :root {
    --col-unit: calc((100vw - 40px - (var(--col-gutter) * 4)) / 5);
    --col-2-left: calc(20px + var(--col-unit) + var(--col-gutter));
    --grid-margin: 20px;
  }

  /* Nav */
  .nav__logo img {
    height: 48px;
    width: 48px;
  }

  /* Hero */
  .hero {
    padding-top: 74px;
  }

  .hero__image-wrap {
    padding-left: var(--grid-margin);
    padding-right: var(--grid-margin);
    display: flex;
    justify-content: center;
  }

  .hero__image {
    width: 100%;
    max-width: 100%;
  }

  .hero__name {
    font-size: clamp(44px, 13vw, 80px);
  }

  .hero__rule {
    left: var(--grid-margin);
    width: 30%;
  }

  .hero__scroll-arrow {
    display: none;
  }

  /* Statement */
  .statement {
    padding: clamp(16px, 3vw, 24px) var(--grid-margin) clamp(8px, 1vw, 12px);
    padding-left: var(--grid-margin);
    max-width: 100%;
    text-align: left;
  }

  /* Carousel */
  .carousel__track-wrap {
    overflow-x: auto;
    padding-left: var(--grid-margin);
    padding-top: 8px;
    padding-bottom: 8px;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .carousel__track {
    padding-right: var(--grid-margin);
  }

  .carousel__track-wrap::-webkit-scrollbar {
    display: none;
  }

  .carousel__track {
    transition: none;
  }

  .carousel__controls {
    display: none;
  }

  .project-card {
    flex: 0 0 75vw;
  }

  /* Work page */
  .work-filter {
    padding-top: calc(64px + 16px);
  }

  .filter-marquee {
    margin-left: 20px;
    width: calc(100% - 20px);
  }

  .work-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 24px 12px;
  }

  /* Contact */
  .contact-header {
    text-align: left;
  }

  .contact__headline {
    text-align: left;
    font-size: clamp(52px, 14vw, 80px);
  }

  .contact__sub {
    max-width: 100%;
  }

  .contact-form-wrap {
    padding-left: 0;
    max-width: 100%;
    padding-top: clamp(32px, 5vw, 48px); /* space between HOLLA subcopy and fields on mobile */
  }

  .contact__submit {
    width: 100%;
    padding: 14px 20px;
    text-align: center;
  }

  /* About */
  .about-body {
    padding-left: var(--grid-margin);
    max-width: 100%;
  }

  /* Footer */
  .footer {
    flex-direction: column;
    text-align: center;
    gap: 6px;
  }



  /* Project page title — increase leading on mobile */
  .p-title { line-height: 1.2; }

  /* Project detail */
  .project-intro__body {
    grid-template-columns: 1fr;
  }

  .project-meta-bar {
    gap: 6px 24px;
  }

  .project-nav {
    flex-direction: column;
    gap: 20px;
    text-align: center;
  }
}

/* ------------------------------------------------------------
   21. PRINT
   ------------------------------------------------------------ */
@media print {
  .nav, .pw-overlay { display: none; }
}
/* First filter button — no left padding so text aligns to grid edge */
.filter-marquee__inner .filter-btn:first-child {
  padding-left: 0;
}

/* Filter bar — align to logo right edge (logo is 56px + 20px margin = 76px, 
   minus the button's own padding gives clean visual alignment) */
.filter-marquee {
  margin-left: calc(var(--grid-margin) + 56px) !important;
  width: calc(100% - var(--grid-margin) - 56px) !important;
}

@media (max-width: 767px) {
  .filter-marquee {
    margin-left: calc(var(--grid-margin) + 48px) !important;
    width: calc(100% - var(--grid-margin) - 48px) !important;
  }
}