  :root{
    --ink:#131217;
    --paper:#FAF9F6;
    --coral:#FF3B5C;
    --lime:#D4FF4F;
    --mute:#8A8790;
    --line: rgba(19,18,23,0.12);
    --radius: 2px;
  }
  *{box-sizing:border-box; margin:0; padding:0;}
  html{scroll-behavior:smooth;}
  body{
    background:var(--paper);
    color:var(--ink);
    font-family:'Inter', sans-serif;
    line-height:1.5;
    -webkit-font-smoothing:antialiased;
  }
  .mono{ font-family:'IBM Plex Mono', monospace; }
  .display{ font-family:'Archivo Black', sans-serif; text-transform:uppercase; }
  a{ color:inherit; text-decoration:none; }
  .wrap{ max-width:1160px; margin:0 auto; padding:0 32px; }

  /* NAV */
  header{
    position:fixed; top:0; left:0; right:0; z-index:50;
    background:rgba(250,249,246,0.85);
    backdrop-filter:blur(8px);
    border-bottom:1px solid var(--line);
  }
  nav.wrap{
    display:flex; align-items:center; justify-content:space-between;
    height:76px;
  }
  .brand{ font-family:'Archivo Black', sans-serif; font-size:15px; letter-spacing:0.02em; }
  .nav-links{ display:flex; align-items:center; gap:28px; font-size:13px; }
  .nav-links a.mono{ color:var(--mute); transition:color .2s; }
  .nav-links a.mono:hover{ color:var(--ink); }
  .btn{
    display:inline-flex; align-items:center; gap:8px;
    background:var(--ink); color:var(--paper);
    padding:11px 20px; font-size:13px; font-weight:600;
    border:1px solid var(--ink); border-radius:var(--radius);
    transition:background .2s, color .2s;
  }
  .btn:hover{ background:transparent; color:var(--ink); }
  .btn-outline{
    background:transparent; color:var(--ink); border:1px solid var(--ink);
  }
  .btn-outline:hover{ background:var(--ink); color:var(--paper); }

  /* HERO */
  section.hero{ padding:170px 0 90px; }
  .eyebrow{
    font-size:12px; letter-spacing:0.14em; color:var(--coral);
    margin-bottom:20px; display:flex; align-items:center; gap:10px;
  }
  .eyebrow::before{
    content:''; width:24px; height:1px; background:var(--coral);
  }
  h1.name{
    font-size:clamp(48px, 9vw, 104px);
    line-height:0.94;
    letter-spacing:-0.01em;
    margin-bottom:22px;
  }
  .role{
    font-size:clamp(16px,2.4vw,20px);
    color:var(--ink);
    font-weight:600;
    margin-bottom:26px;
  }
  .role span{ color:var(--mute); font-weight:400; }
  .bio{
    max-width:560px; font-size:16px; color:#3a3840; margin-bottom:40px;
  }
  .hero-ctas{ display:flex; gap:14px; flex-wrap:wrap; margin-bottom:64px; }

  .stats{
    display:grid; grid-template-columns:repeat(3,1fr);
    border-top:1px solid var(--line);
  }
  .stat{ padding:26px 24px 0; border-right:1px solid var(--line); }
  .stat:last-child{ border-right:none; }
  .stat-num{ font-family:'Archivo Black', sans-serif; font-size:26px; margin-bottom:6px; }
  .stat-label{ font-size:12px; color:var(--mute); letter-spacing:0.02em; }

  /* SECTION HEADERS */
  .section-head{ padding:0 0 44px; display:flex; align-items:flex-end; justify-content:space-between; gap:20px; flex-wrap:wrap; }
  .section-title{ font-size:clamp(30px,5vw,46px); letter-spacing:-0.01em; }
  .section-sub{ font-size:14px; color:var(--mute); max-width:340px; }
  .section-num{ font-family:'IBM Plex Mono',monospace; font-size:12px; color:var(--coral); }

  /* SKILLS */
  section.skills{ padding:70px 0; border-top:1px solid var(--line); }
  .tags{ display:flex; flex-wrap:wrap; gap:10px; }
  .tag{
    font-size:13px; font-family:'IBM Plex Mono', monospace;
    padding:9px 16px; border:1px solid var(--line); border-radius:20px;
    transition:border-color .2s, background .2s;
  }
  .tag:hover{ border-color:var(--ink); background:var(--lime); }
  .tools-row{ margin-top:36px; padding-top:28px; border-top:1px solid var(--line); display:flex; gap:14px; flex-wrap:wrap; align-items:center;}
  .tools-row .mono{ font-size:12px; color:var(--mute); }
  .tool-pill{
    font-family:'Archivo Black', sans-serif; font-size:13px;
    padding:8px 14px; background:var(--ink); color:var(--paper);
  }

  /* WORK GRID */
  section.work{ padding:80px 0; border-top:1px solid var(--line); }
  .grid{
    display:grid; grid-template-columns:repeat(2, 1fr); gap:2px;
    background:var(--line);
    border:1px solid var(--line);
  }
  .card{
    background:var(--paper);
    aspect-ratio:1/1;
    position:relative;
    display:flex; flex-direction:column; justify-content:space-between;
    padding:18px;
    overflow:hidden;
  }
  .card-tag{ font-family:'IBM Plex Mono', monospace; font-size:11px; color:var(--mute); display:flex; justify-content:space-between; }
  .placeholder{
    position:absolute; inset:0;
    background:
      repeating-linear-gradient(135deg, transparent, transparent 10px, rgba(19,18,23,0.04) 10px, rgba(19,18,23,0.04) 11px);
    display:flex; align-items:center; justify-content:center;
    flex-direction:column; gap:8px;
    opacity:0.9;
  }
  .placeholder .plus{
    width:34px; height:34px; border:1px solid var(--line); border-radius:50%;
    display:flex; align-items:center; justify-content:center; font-size:16px; color:var(--mute);
    background:var(--paper);
  }
  .placeholder .ph-label{ font-family:'IBM Plex Mono', monospace; font-size:10.5px; color:var(--mute); text-align:center; max-width:150px; }
  .card-info{ position:relative; z-index:2; }
  .card-title{ font-weight:700; font-size:15px; margin-bottom:2px; }
  .card-cat{ font-size:12px; color:var(--mute); }
  .card:hover .placeholder{ background-color: var(--lime); opacity:0.25; }

  .card-img{ position:absolute; inset:0; }
  .card-img img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s ease; }
  .card.has-img:hover .card-img img{ transform:scale(1.05); }
  .card-overlay{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(19,18,23,0) 45%, rgba(19,18,23,0.82) 100%); }
  .card.has-img .card-tag{ color:rgba(250,249,246,0.75); }
  .card.has-img .card-title{ color:var(--paper); }
  .card.has-img .card-cat{ color:rgba(250,249,246,0.65); }
  .card-links{ position:relative; z-index:2; display:flex; gap:8px; flex-wrap:wrap; margin-top:6px; }
  .card-links a{ font-family:'IBM Plex Mono',monospace; font-size:10.5px; color:var(--mute); border-bottom:1px solid var(--line); }
  .card-links a:hover{ color:var(--ink); border-color:var(--ink); }

  /* CINE CLUB FEATURE */
  section.feature{ padding:90px 0; background:var(--ink); color:var(--paper); }
  .feature-inner{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
  .feature .eyebrow{ color:var(--lime); }
  .feature .eyebrow::before{ background:var(--lime); }
  .feature h3{ font-size:clamp(34px,5vw,54px); margin-bottom:20px; letter-spacing:-0.01em; }
  .feature p{ color:rgba(250,249,246,0.7); max-width:440px; margin-bottom:28px; font-size:15px; }
  .feature-visual{
    aspect-ratio:4/5;
    background: repeating-linear-gradient(135deg, rgba(250,249,246,0.05), rgba(250,249,246,0.05) 10px, rgba(250,249,246,0.1) 10px, rgba(250,249,246,0.1) 11px);
    border:1px solid rgba(250,249,246,0.2);
    display:flex; align-items:center; justify-content:center; flex-direction:column; gap:10px;
  }
  .feature-visual .ph-label{ font-family:'IBM Plex Mono', monospace; font-size:11px; color:rgba(250,249,246,0.5); }
  .feature .btn{ background:var(--lime); color:var(--ink); border-color:var(--lime); }
  .feature .btn:hover{ background:transparent; color:var(--lime); }

  /* CONTACT */
  section.contact{ padding:110px 0 80px; text-align:center; }
  section.contact h2{ font-size:clamp(38px,7vw,80px); letter-spacing:-0.01em; margin-bottom:26px; }
  section.contact p{ color:var(--mute); margin-bottom:36px; font-size:15px; }
  .contact-links{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; margin-bottom:70px; }
  footer{ border-top:1px solid var(--line); padding:26px 0; }
  footer .wrap{ display:flex; justify-content:space-between; font-size:12px; color:var(--mute); flex-wrap:wrap; gap:10px; }
  footer .mono{ font-family:'IBM Plex Mono', monospace; }

  .reveal{ opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease; }
  .reveal.in{ opacity:1; transform:translateY(0); }

  @media (max-width: 780px){
    .stats{ grid-template-columns:1fr; }
    .stat{ border-right:none; border-bottom:1px solid var(--line); padding-bottom:20px; margin-bottom:6px; }
    .grid{ grid-template-columns:1fr; }
    .feature-inner{ grid-template-columns:1fr; }
    .nav-links{ display:none; }
  }

/* PROJECT CARD (client) — index grid */
.card.client{ justify-content:flex-end; }
.card-role{ position:relative; z-index:2; font-family:'IBM Plex Mono', monospace; font-size:11px; color:var(--mute); margin-top:4px; }
.card.has-img .card-role{ color:rgba(250,249,246,0.65); }
.card-arrow{ position:absolute; top:16px; right:16px; z-index:3; width:30px; height:30px; border-radius:50%; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; font-size:14px; background:var(--paper); transition:transform .3s ease, background .2s; }
.card.has-img .card-arrow{ background:rgba(250,249,246,0.12); border-color:rgba(250,249,246,0.35); color:var(--paper); backdrop-filter:blur(4px); }
.card:hover .card-arrow{ transform:rotate(45deg); background:var(--lime); border-color:var(--lime); color:var(--ink); }
.card-brand{ position:relative; z-index:2; font-size:20px; font-weight:700; letter-spacing:-0.01em; }
.card.has-img .card-brand{ color:var(--paper); }

/* PROJECT DETAIL PAGE */
.project-hero{ padding:150px 0 60px; border-bottom:1px solid var(--line); }
.back-link{ display:inline-flex; align-items:center; gap:8px; font-family:'IBM Plex Mono',monospace; font-size:12px; color:var(--mute); margin-bottom:36px; }
.back-link:hover{ color:var(--ink); }
.project-meta{ display:flex; gap:32px; flex-wrap:wrap; margin-top:30px; padding-top:26px; border-top:1px solid var(--line); }
.meta-item{ min-width:120px; }
.meta-label{ font-family:'IBM Plex Mono',monospace; font-size:11px; color:var(--mute); margin-bottom:6px; }
.meta-value{ font-size:14px; font-weight:600; }

.project-section{ padding:64px 0; border-bottom:1px solid var(--line); }
.project-section h2{ font-size:clamp(24px,4vw,34px); letter-spacing:-0.01em; margin-bottom:22px; }
.project-section p{ max-width:620px; color:#3a3840; font-size:15.5px; margin-bottom:14px; }
.mission-list{ list-style:none; display:flex; flex-direction:column; gap:14px; max-width:640px; }
.mission-list li{ display:flex; gap:16px; font-size:15px; padding-bottom:14px; border-bottom:1px solid var(--line); }
.mission-list li:last-child{ border-bottom:none; }
.mission-num{ font-family:'IBM Plex Mono',monospace; color:var(--coral); font-size:13px; flex-shrink:0; padding-top:2px; }

.gallery{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.gallery img{ width:100%; height:100%; object-fit:cover; aspect-ratio:4/5; border-radius:var(--radius); }
.gallery.two{ grid-template-columns:repeat(2,1fr); }
.gallery-empty{ aspect-ratio:16/9; border:1px dashed var(--line); display:flex; align-items:center; justify-content:center; }
.gallery-empty .ph-label{ font-family:'IBM Plex Mono',monospace; font-size:11px; color:var(--mute); }

.link-list{ display:flex; flex-direction:column; gap:10px; max-width:480px; }
.link-list a{ display:flex; align-items:center; justify-content:space-between; font-size:14px; padding:14px 18px; border:1px solid var(--line); transition:border-color .2s, background .2s; }
.link-list a:hover{ border-color:var(--ink); background:var(--lime); }
.link-list .mono{ font-size:11px; color:var(--mute); }

.next-project{ padding:70px 0; text-align:center; }
.next-project a{ font-size:clamp(28px,5vw,48px); font-family:'Archivo Black',sans-serif; text-transform:uppercase; }
.next-project .mono{ display:block; font-size:12px; color:var(--mute); margin-bottom:14px; }

/* GALLERY — natural scale, no aggressive cropping (readable screenshots) */
.gallery-fit{ display:flex; flex-direction:column; gap:36px; }
.gallery-block h3{ font-family:'IBM Plex Mono',monospace; font-size:12px; letter-spacing:0.04em; color:var(--mute); margin-bottom:12px; text-transform:uppercase; }
.gallery-block img{ width:100%; height:auto; display:block; border:1px solid var(--line); }
.gallery-pair{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.gallery-pair img{ width:100%; height:auto; display:block; border:1px solid var(--line); }

/* Link-image cards (clickable visuals that lead offsite) */
.link-gallery{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.link-card{ display:block; border:1px solid var(--line); overflow:hidden; transition:border-color .2s; }
.link-card:hover{ border-color:var(--ink); }
.link-card img{ width:100%; height:340px; object-fit:cover; display:block; }
.link-card .link-card-cap{ display:flex; justify-content:space-between; align-items:center; padding:12px 14px; font-family:'IBM Plex Mono',monospace; font-size:11px; color:var(--mute); }
.link-card:hover .link-card-cap{ color:var(--ink); }

/* LOGO ROW */
.logo-row{ display:flex; gap:28px; align-items:center; flex-wrap:wrap; }
.logo-row img{ height:90px; width:auto; }

/* CAROUSEL */
.carousel{ position:relative; border:1px solid var(--line); background:#f2f1ee; overflow:hidden; }
.carousel-track{ display:flex; transition:transform .4s ease; }
.carousel-track img{ width:100%; flex:0 0 100%; height:auto; display:block; }
.carousel-nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:38px; height:38px; border-radius:50%; border:1px solid var(--line);
  background:rgba(250,249,246,0.9); display:flex; align-items:center; justify-content:center;
  cursor:pointer; font-size:15px; color:var(--ink); transition:background .2s;
  user-select:none;
}
.carousel-nav:hover{ background:var(--lime); }
.carousel-prev{ left:14px; }
.carousel-next{ right:14px; }
.carousel-dots{ display:flex; gap:7px; justify-content:center; margin-top:14px; }
.carousel-dot{ width:6px; height:6px; border-radius:50%; background:var(--line); cursor:pointer; }
.carousel-dot.active{ background:var(--coral); }
.carousel-count{ position:absolute; bottom:14px; right:14px; font-family:'IBM Plex Mono',monospace; font-size:11px; color:var(--paper); background:rgba(19,18,23,0.6); padding:4px 9px; border-radius:20px; }

/* VIDEO BLOCKS */
.video-feature{ display:grid; grid-template-columns:1fr 1fr; gap:36px; align-items:center; margin-bottom:44px; }
.video-feature.reverse .video-wrap{ order:2; }
.video-feature.reverse .video-text{ order:1; }
.video-wrap video{ width:100%; height:auto; display:block; border:1px solid var(--line); background:#000; }
.video-text p{ font-size:15px; color:#3a3840; }
.video-trio{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:20px; }
.video-trio video{ width:100%; height:auto; display:block; border:1px solid var(--line); background:#000; }
.video-trio-caption{ max-width:640px; font-size:15px; color:#3a3840; }

/* KEY STATS */
.key-stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.key-stat{ border:1px solid var(--line); padding:26px 20px; text-align:center; }
.key-stat-num{ font-family:'Archivo Black',sans-serif; font-size:32px; color:var(--coral); margin-bottom:8px; }
.key-stat-label{ font-size:13px; color:var(--mute); }

.ig-cta{ margin-top:18px; }
.ig-cta a{ font-family:'IBM Plex Mono',monospace; font-size:12.5px; color:var(--coral); border-bottom:1px solid var(--coral); }

@media (max-width: 780px){
  .video-feature{ grid-template-columns:1fr; }
  .video-feature.reverse .video-wrap{ order:1; }
  .video-feature.reverse .video-text{ order:2; }
  .video-trio{ grid-template-columns:1fr; }
  .key-stats{ grid-template-columns:1fr; }
}

/* REFERENCES — moodboard page */
body.refs-body{ background:var(--ink); color:var(--paper); }
.refs-body header{ background:rgba(19,18,23,0.85); border-bottom:1px solid rgba(250,249,246,0.12); }
.refs-body .brand{ color:var(--paper); }
.refs-body .nav-links a.mono{ color:rgba(250,249,246,0.6); }
.refs-body .nav-links a.mono:hover{ color:var(--paper); }
.refs-body .btn{ background:var(--lime); color:var(--ink); border-color:var(--lime); }
.refs-body .btn:hover{ background:transparent; color:var(--lime); }

.refs-hero{ padding:150px 0 50px; }
.refs-hero .eyebrow{ justify-content:flex-start; }
.refs-hero h1{ font-size:clamp(34px,6vw,58px); letter-spacing:-0.01em; max-width:780px; line-height:1.15; }

.refs-grid{ column-count:3; column-gap:14px; padding-bottom:100px; }
.ref-item{
  position:relative; break-inside:avoid; margin-bottom:14px;
  overflow:hidden; display:block; background:#000;
}
.ref-item img, .ref-item video{ width:100%; height:auto; display:block; }
.ref-caption{
  position:absolute; inset:0; display:flex; align-items:flex-end;
  padding:16px; background:linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(0,0,0,0.85) 100%);
  opacity:0; transition:opacity .25s ease;
}
.ref-item:hover .ref-caption, .ref-item:focus-within .ref-caption{ opacity:1; }
.ref-caption-inner{ display:flex; justify-content:space-between; align-items:center; width:100%; }
.ref-name{ font-family:'IBM Plex Mono',monospace; font-size:12.5px; color:var(--paper); }
.ref-link-icon{ font-family:'IBM Plex Mono',monospace; font-size:12px; color:var(--lime); }

@media (max-width: 900px){ .refs-grid{ column-count:2; } }
@media (max-width: 560px){ .refs-grid{ column-count:1; } }
