/* Minimal, bold typography and grid system */
:root {
  --bg: #0a0a0a;
  --text: #ffffff;
  --muted: #b3b3b3;
  --accent: #e6e6e6;
  --border: rgba(255,255,255,0.08);
  --border-light: rgba(255,255,255,0.06);
  --gap-sm: 12px;
  --gap: 24px;
  --gap-lg: 40px;
  --max: 1200px;
  --brand-weight: 800;
}

[data-theme="light"] {
  --bg: #ffffff;
  --text: #0a0a0a;
  --muted: #666666;
  --accent: #1a1a1a;
  --border: rgba(0,0,0,0.08);
  --border-light: rgba(0,0,0,0.06);
}

html, body { height: 100%; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Inter, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}

/* Hide scrollbars globally */
::-webkit-scrollbar {
  display: none;
}

* {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.container {
  width: 100%;
  padding: 0 var(--gap);
  margin: 0 auto;
  box-sizing: border-box;
}
.container--xl {
  max-width: var(--max);
}

/* Better mobile container behavior */
@media (max-width: 768px) {
  .container {
    padding: 0 var(--gap-sm);
    margin-left: auto;
    margin-right: auto;
  }

  .container--xl {
    max-width: 100%;
  }
}

/* Extra small screens - ensure proper centering */
@media (max-width: 480px) {
  .container {
    padding: 0 16px;
  }

  .grid--masonry {
    max-width: 100%;
    margin: 0 auto;
  }

  .grid--masonry figure {
    margin: 0 auto;
    max-width: 100%;
  }
}

/* Mobile Navigation */
.mobile-nav-controls {
  display: none;
  align-items: center;
  gap: var(--gap);
}

.hamburger {
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  width: 32px;
  height: 32px;
  align-items: center;
  justify-content: center;
}

.hamburger span {
  width: 18px;
  height: 2px;
  background: var(--text);
  transition: all 0.3s ease;
  border-radius: 1px;
}

.hamburger.active span:nth-child(1) {
  transform: rotate(45deg) translate(5px, 5px);
}

.hamburger.active span:nth-child(2) {
  opacity: 0;
}

.hamburger.active span:nth-child(3) {
  transform: rotate(-45deg) translate(7px, -6px);
}

.mobile-nav-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: var(--bg);
  z-index: 999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

.mobile-nav-overlay.active {
  opacity: 1;
  visibility: visible;
}

.mobile-nav-content {
  display: flex;
  flex-direction: column;
  gap: var(--gap-lg);
  text-align: center;
}

.mobile-nav-link {
  color: var(--text);
  text-decoration: none;
  font-size: 24px;
  font-weight: 600;
  padding: var(--gap);
  transition: opacity 0.25s ease;
}

.mobile-nav-link:hover {
  opacity: 0.7;
}

.mobile-nav-link[aria-current="page"] {
  opacity: 1;
  text-decoration: underline;
}

/* Hide mobile controls on desktop - mobile controls are defined above */

/* Hide desktop navigation and show mobile controls on mobile */
@media (max-width: 768px) {
  .nav .nav-tabs {
    display: none !important;
  }

  .spark--desktop {
    display: none !important;
  }

  .mobile-nav-controls {
    display: flex;
  }
}
.section--spaced { margin-top: var(--gap-lg); margin-bottom: var(--gap-lg); }

/* Type scale & rhythm */
.eyebrow { text-transform: uppercase; letter-spacing: .08em; font-size: 12px; color: var(--muted); margin-bottom: var(--gap-sm); display: inline-block; }
.lede { font-size: clamp(18px, 2.2vw, 22px); line-height: 1.4; color: var(--text); max-width: 62ch; }
.meta { color: var(--muted); font-size: 14px; display: grid; gap: 6px; }
.meta span { display: block; }
.meta--inline { display: block; }
.project-hero__aside { align-self: end; }
.project-hero__aside .meta { text-align: left; }
.project-hero__aside .contact-image { margin-bottom: var(--gap); }
.project-hero__aside .rule { margin-top: var(--gap); }
.rule { height: 2px; background: var(--border); margin: var(--gap) 0; }
.space-sm { height: var(--gap-sm); }
.space { height: 0; }
@media (min-width: 900px) { .space { height: var(--gap); } }
.space-lg { height: var(--gap-lg); }

/* Header */
.site-header { position: sticky; top: 0; z-index: 100; background: var(--bg); }
.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 64px; border-bottom: 2px solid var(--border-light);
}
.brand-container { display: flex; flex-direction: column; align-items: flex-start; gap: 0; line-height: 1.2; }
.brand { color: var(--text); text-decoration: none; font-weight: var(--brand-weight); font-size: 28px; letter-spacing: 1px; white-space: nowrap; line-height: 1; }
.brand-subtitle { display: block; font-size: 11px; line-height: 1.2; opacity: 0.8; font-weight: normal; letter-spacing: 0.5px; margin-top: 2px; }

@media (min-width: 900px) {
  .brand-container { flex-direction: row; align-items: center; gap: 8px; }
  .brand-subtitle { font-size: inherit; line-height: inherit; }
  .brand-subtitle:before { content: "/ "; }
}
.nav { display: flex; align-items: center; gap: var(--gap); }
.nav-tabs { position: relative; display: grid; grid-auto-flow: column; gap: var(--gap); align-items: center; }
.nav-link { color: var(--text); text-decoration: none; opacity: .7; padding: 6px 2px; transition: opacity .25s ease; }
.nav-link[aria-current="page"], .nav-link:hover { opacity: 1; }
.nav-indicator { position: absolute; bottom: 0; height: 2px; background: var(--text); border-radius: 2px; transition: transform .35s cubic-bezier(.2,.8,.2,1), width .35s cubic-bezier(.2,.8,.2,1); transform: translateX(0); width: 0; }
.spark { background: transparent; border: 0; color: var(--text); font-size: 18px; cursor: pointer; }

/* Desktop spark button - explicitly show on desktop */
.spark--desktop {
  display: inline-block;
}

/* Grid */
.grid { display: grid; }
.grid--gap { gap: var(--gap); }
.grid--middle { align-items: center; }
.grid--gap-lg { gap: var(--gap-lg); }
.grid--2 { grid-template-columns: 1fr; }
@media (min-width: 900px) { .grid--2 { grid-template-columns: 1fr 1fr; } }

/* Responsive two-column grid */
.grid--2-fixed {
  grid-template-columns: 1fr;
  gap: var(--gap);
}

@media (min-width: 600px) {
  .grid--2-fixed {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Force 2 cols always for specific use (contact header row) */
.grid--2-fixed--always {
  grid-template-columns: 1fr 1fr !important;
}

.grid--masonry {
  grid-template-columns: 1fr;
  gap: var(--gap);
}

@media (min-width: 600px) {
  .grid--masonry {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 900px) {
  .grid--masonry {
    grid-template-columns: repeat(3, 1fr);
  }
}

.tile { display: block; width: 100%; overflow: hidden; background: #111; }
.tile img { width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(.96); }
.tile--xl { border: 8px solid var(--bg); }

/* Ratios */
.ratio-16x9 { aspect-ratio: 16/9; }
.ratio-4x5 { aspect-ratio: 4/5; }
.ratio-3x4 { aspect-ratio: 3/4; }
.ratio-3x2 { aspect-ratio: 3/2; }
.ratio-9x16 { aspect-ratio: 9/16; }
.ratio-1x1 { aspect-ratio: 1/1; }

/* Page */
.page--home { padding-bottom: 60px; }
.page--project { padding-bottom: 0; }

/* Page transitions */
.page { opacity: 0; transform: translateY(6px); transition: opacity .22s ease, transform .22s ease; }
.page.is-visible { opacity: 1; transform: translateY(0); }
.page.is-leaving { opacity: 0; transform: translateY(6px); }

/* Project Layout */
.project-hero { display: grid; grid-template-columns: 1fr; gap: var(--gap-sm); align-items: end; padding-top: var(--gap-lg); }
@media (min-width: 900px) { .project-hero { grid-template-columns: 1.2fr 1fr; gap: var(--gap-lg); } }

.project-title { font-size: clamp(42px, 6vw, 80px); line-height: .95; font-weight: 800; margin: 0; }
.project-summary { color: var(--accent); max-width: 62ch; font-size: 18px; }

.project-grid { margin-top: var(--gap-lg); display: grid; gap: var(--gap-lg); grid-template-columns: 1fr; }
@media (min-width: 900px) { .project-grid { grid-template-columns: repeat(12, 1fr); } }

.span-12 { grid-column: 1 / -1; }
.span-6 { grid-column: span 6; }
.span-4 { grid-column: span 4; }

.bleed { width: 100vw; margin-left: calc(50% - 50vw); }

figure { margin: 0; }
figure img { width: 100%; height: auto; display: block; }
figure video { width: 100%; height: auto; display: block; }
figcaption { color: var(--muted); font-size: 14px; margin-top: 6px; }

/* Contact page image */
.contact-image {
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
}

@media (min-width: 900px) {
  .contact-image {
    max-width: 420px;
  }
}

/* Contact page hero (two-column on desktop, stacked on mobile) */
.contact-photo { margin: 0; }
.contact-photo img { width: 100%; height: auto; display: block; border-radius: 6px; }

.contact-hero {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  align-items: center;
}

.contact-hero__media { max-width: 520px; margin: 0 auto; }
.contact-hero__main .meta { margin-top: var(--gap); }

@media (min-width: 900px) {
  .contact-hero {
    grid-template-columns: 1.15fr 0.85fr;
  }
  .contact-hero__media { max-width: 420px; margin: 0; justify-self: end; }
}

/* Fine-tune spacing for contact hero elements */
.contact-title { margin-bottom: 0px; }
.contact-icons { margin: 24px 0; }
.contact-lede { margin: 0 0 12px 0; }
.contact-meta { margin-top: 0; margin-bottom: 24px; }

@media (min-width: 900px) {
  .contact-icons { margin: 20px 0 12px 0; }
}



/*
  Mobile-unified project layout
  - Single column media stacks on all project pages
  - 4px horizontal padding, 12px gaps
  - Preserve media aspect ratio (no cropping), center content
*/
@media (max-width: 768px) {
  /* Narrower padding on all project page containers */
  .page--project .container,
  .page--project .container--xl,
  .page--project .container--wide,
  .page--project .container--oxy-wide {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  /* Force all project media collections into a single column with 12px gaps */
  .page--project .project-grid,
  .page--project .grid,
  .page--project .grid--masonry,
  .page--project .grid-3x3,
  .page--project .strip-gallery,
  .page--project .netta-pitch-deck,
  .page--project .oxy-gallery,
  .page--project .oxy-shelf0,
  .page--project .oxy-shelf2,
  .page--project .riunite-shelf1,
  .page--project .riunite-shelf2,
  .page--project .summer-drop-grid,
  .page--project .killer-shelf2,
  .page--project .rohto-gallery,
  .page--project .rohto-shelf2 {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 16px !important;
    align-items: center;
    justify-items: center;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
  }

  /* Normalize the space ONLY for the first media grid after the hero rule */
  .page--project .project-hero + section .grid--masonry,
  .page--project .project-hero + section .project-grid,
  .page--project .project-hero + section .grid-3x3,
  .page--project .project-hero + section .strip-gallery,
  .page--project .project-hero + section .netta-pitch-deck,
  .page--project .project-hero + section .oxy-gallery,
  .page--project .project-hero + section .oxy-shelf0,
  .page--project .project-hero + section .oxy-shelf2,
  .page--project .project-hero + section .riunite-shelf1,
  .page--project .project-hero + section .riunite-shelf2,
  .page--project .project-hero + section .summer-drop-grid,
  .page--project .project-hero + section .killer-shelf1,
  .page--project .project-hero + section .killer-shelf2,
  .page--project .project-hero + section .killer-shelf3,
  .page--project .project-hero + section .rohto-gallery,
  .page--project .project-hero + section .rohto-shelf2 {
    margin-top: 0 !important;
  }

  /* Remove enforced aspect ratios on wrappers; let media dictate height */
  .page--project figure,
  .page--project .oxy-item,
  .page--project .shelf0-item,
  .page--project .shelf1-item,
  .page--project .shelf2-item,
  .page--project .grid-item,
  .page--project .strip-item,
  .page--project .billboard-item,
  .page--project .logo-item,
  .page--project .pitch-slide,
  .page--project .rohto-item {
    width: 100% !important;
    aspect-ratio: auto !important;
  }

  /* Ensure media is centered, fills width, maintains aspect ratio without cropping */
  .page--project figure img,
  .page--project figure video,
  .page--project .shelf0-item img,
  .page--project .shelf1-item img,
  .page--project .shelf2-item img,
  .page--project .shelf2-item video,
  .page--project .oxy-item img,
  .page--project .rohto-item video,
  .page--project .video-container,
  .page--project .video-container video {
    width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    display: block;
    margin: 0 auto;
  }

  /* Video containers should size to content and remain tappable */
  .page--project .video-container {
    height: auto !important;
  }
}

/* Footer */
.site-footer {
  border-top: 2px solid var(--border-light);
  background: var(--bg);
  margin-top: var(--gap-lg);
}
.footer-inner {
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.footer-links {
  display: flex;
  gap: var(--gap);
}

.footer-link {
  color: var(--muted);
  text-decoration: none;
  font-size: 14px;
  opacity: 0.7;
  transition: opacity 0.25s ease;
}

.footer-link:hover {
  opacity: 1;
}

@media (max-width: 600px) {
  .footer-inner {
    flex-direction: column;
    gap: var(--gap-sm);
    height: auto;
    padding: var(--gap) 0;
  }
}

/* Buttons */
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 16px;
  border: 2px solid var(--border);
  color: var(--text);
  background: transparent;
  text-decoration: none;
  font-weight: 700;
  border-radius: 9999px;
  transition: background .2s ease, color .2s ease, border-color .2s ease;
}
.button:hover { border-color: var(--text); background: rgba(255,255,255,0.06); }
[data-theme="light"] .button:hover { background: rgba(0,0,0,0.04); }

.button-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gap);
}

@media (max-width: 600px) {
  .button-row { flex-direction: column; }
  .button-row .button { width: 100%; }
}

/* Icon-only buttons */
.icon-row {
  display: flex;
  align-items: center;
  gap: var(--gap);
}

.icon-row--end { justify-content: flex-end; }

.icon-row--centered {
  justify-content: center;
}

/* Center icons on mobile, left-align on desktop */
.icon-row--mobile-center { justify-content: flex-start; }
@media (max-width: 600px) {
  .icon-row--mobile-center { justify-content: center; }
}

.icon-button {
  width: 48px;
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 2px solid var(--border);
  color: var(--text);
  text-decoration: none;
  background: transparent;
  transition: background .2s ease, border-color .2s ease, transform .1s ease;
}

.icon-button:hover { border-color: var(--text); background: rgba(255,255,255,0.06); }
[data-theme="light"] .icon-button:hover { background: rgba(0,0,0,0.04); }

.icon-button svg { width: 20px; height: 20px; display: block; }

@media (max-width: 600px) {
  .icon-row { gap: 16px; }
}

/* Project Navigation */
.project-nav {
  margin-top: var(--gap-lg);
  padding-top: var(--gap-lg);
  border-top: 2px solid var(--border-light);
  display: flex;
  justify-content: space-between;
  gap: var(--gap);
  max-width: var(--max);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--gap);
  padding-right: var(--gap);
}

.project-nav__btn {
  display: flex;
  align-items: center;
  gap: var(--gap-sm);
  text-decoration: none;
  color: var(--text);
  padding: var(--gap-sm) var(--gap);
  border: 2px solid var(--border);
  border-radius: 8px;
  transition: border-color 0.2s ease, background 0.2s ease;
  min-width: 120px;
}

.project-nav__btn--disabled {
  opacity: 0;
  pointer-events: none;
  border-color: transparent;
}

.project-nav__btn:hover {
  border-color: var(--text);
  background: rgba(255,255,255,0.06);
}

[data-theme="light"] .project-nav__btn:hover {
  background: rgba(0,0,0,0.04);
}

.project-nav__content {
  display: flex;
  flex-direction: column;
}

.project-nav__btn--prev .project-nav__content {
  align-items: flex-start;
}

.project-nav__btn--next .project-nav__content {
  align-items: flex-end;
}

.project-nav__arrow {
  font-size: 18px;
  color: var(--text);
  opacity: 0.8;
}

.project-nav__label {
  font-size: 12px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 4px;
}

.project-nav__title {
  font-weight: 600;
  font-size: 16px;
}

@media (max-width: 768px) {
  .project-nav {
    padding-left: var(--gap-sm);
    padding-right: var(--gap-sm);
    gap: var(--gap-sm);
  }

  .project-nav__btn {
    justify-content: center;
    min-width: auto;
    flex: 1;
  }

  .project-nav__btn--prev .project-nav__content,
  .project-nav__btn--next .project-nav__content {
    align-items: center;
    text-align: center;
  }
}

/* Project Blurb - Shared description style for project sections */
.project-blurb {
  max-width: 800px;
  margin: var(--gap-lg) auto;
  font-size: 1.125rem;
  line-height: 1.6;
  opacity: 0.9;
  text-align: center;
}

@media (max-width: 800px) {
  .project-blurb {
    font-size: 1rem;
    max-width: 90%;
  }
}

/* Text Sections - Detail Section (Summer Drop / FruitFreshers style) */
.summer-drop-header {
  margin-bottom: var(--gap);
  text-align: center;
}

.summer-drop-header .eyebrow {
  display: block;
  margin-bottom: var(--gap-sm);
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  opacity: 0.7;
}

.summer-drop-header h2 {
  font-size: 2rem;
  font-weight: 600;
  margin: 0 0 var(--gap-sm);
}

.summer-drop-description {
  max-width: 600px;
  margin: 0 auto;
  font-size: 1.125rem;
  line-height: 1.6;
  opacity: 0.9;
}

@media (max-width: 800px) {
  .summer-drop-header h2 {
    font-size: 1.75rem;
  }

  .summer-drop-description {
    font-size: 1rem;
    max-width: 90%;
  }
}

/* Text Sections - Eyebrow Section (centered) */
.section-header {
  margin: var(--gap-lg) 0 var(--gap);
  text-align: center;
}

/* Side-by-Side Section (P.R. Box style) */
.pr-box-showcase {
  margin-top: var(--gap-lg);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gap-lg);
  align-items: center;
}

.pr-box-image {
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--bg);
}

.pr-box-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pr-box-content h3 {
  font-size: 1.5rem;
  font-weight: 600;
  margin: 0 0 var(--gap-sm);
}

.pr-box-content p {
  font-size: 1rem;
  line-height: 1.6;
  opacity: 0.9;
}

@media (max-width: 800px) {
  .pr-box-showcase {
    grid-template-columns: 1fr;
    gap: var(--gap);
    text-align: center;
  }
}

/* Section Spacing - Add vertical spacing between all project sections */
.page--project section {
  margin-top: var(--gap-lg);
}

/* First section (hero) doesn't need top margin */
.page--project section:first-of-type {
  margin-top: 0;
}
