
:root{
    --max: 1500px;
    --fg:#111;
    --muted: rgba(0,0,0,.68);
    --line: rgba(0,0,0,.12);
  }
  
  *{ box-sizing:border-box; }
  html,body{ height:100%; }
  
  body{
    margin:0;
    background:#fff;
    color:var(--fg);
    font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  }
  
  /* top */
  .proj-top{
    max-width: var(--max);
    margin: 0 auto;
    padding: 34px 22px 0;
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
  }
  
  .proj-name{
    font-family:"GFS Didot", serif;
    font-size:54px;
    letter-spacing:-0.03em;
    line-height:1;
    text-decoration:none;
    color:inherit;
  }
  
  .proj-nav{
    display:flex;
    gap:60px;
    padding-top: 10px;
  }
  
  .proj-nav a{
    text-decoration:none;
    color:#111;
    font-size:18px;
  }
  
  .proj-nav a:hover{
    text-decoration:underline;
    text-underline-offset:6px;
  }
  
  /* layout */
  .proj-wrap{
    max-width: var(--max);
    margin: 0 auto;
    padding: 46px 22px 70px;
  }
  
  .proj-info{
    display:grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 70px;
    align-items:start;
    margin-bottom: 26px;
  }
  
  .proj-title{
    margin:0;
    font-size:22px;
    font-weight:600;
    letter-spacing:-0.01em;
  }
  
  .proj-date{
    font-size:15px;
    margin-bottom: 10px;
  }
  
  .proj-desc{
    margin:0;
    font-size:15px;
    line-height:1.6;
    color: var(--muted);
  }
  
  /* stage */
  .proj-stage{
    background:#fff;
    padding: 28px 0 8px;
  }
  
  .stage-inner{
    max-width: var(--max);
    margin: 0 auto;
    padding: 0 22px;
  }
  
  /* ===== VIDEO + POSTER GRID ===== */
  .media-grid{
    width: min(1400px, 94vw);
  
    display:grid;
    grid-template-columns: 1.15fr 1.35fr;
    gap: 18px;
    align-items: start;
  }
  
  .tile{
    margin: 0;
    border: none;
    border-radius: 0;
    overflow: hidden;
    background:#fff;
  }
  
  /* keep nice consistent heights */
  .tile-video,
  .tile-poster{
    aspect-ratio: 16 / 9;
  }
  
  /* video */
  .proj-video{
    width:100%;
    height:100%;
    display:block;
    object-fit: cover;
    background:#000;
  }
  
  /* poster */
  .tile-poster img{
    width:100%;
    height:100%;
    display:block;
    object-fit: contain; /* show full poster */
    background:#fff;
  }
  
  /* responsive */
  @media (max-width: 980px){
    .proj-info{ grid-template-columns: 1fr; gap: 18px; }
    .proj-name{ font-size:42px; }
    .proj-nav{ gap:26px; }
  
    .media-grid{
      grid-template-columns: 1fr;
    }
  
    .tile-video,
    .tile-poster{
      aspect-ratio: auto;
    }
  
    .proj-video{
      height:auto;
    }
  
    .tile-poster img{
      height:auto;
    }
  }
  