/* ===== Isaiah Adeoye — portfolio (rebuilt for Vercel) ===== */
:root{
  --bg:#ffffff;
  --fg:#111111;
  --muted:#7a7a7a;
  --line:#e6e6e6;
  --maxw:1460px;
  --gap:14px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--bg);color:var(--fg);
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Helvetica Neue",Arial,sans-serif;
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(22px,4vw,48px)}
.section{padding-top:30px;padding-bottom:96px}

/* ---------- header (centered serif brand) ---------- */
.site-head{text-align:center;padding:44px 24px 6px}
.brand{display:inline-block}
.brand__name{
  display:block;font-family:var(--serif);font-weight:500;
  font-size:clamp(26px,4.4vw,46px);letter-spacing:.34em;text-indent:.34em;
  text-transform:uppercase;line-height:1.04;
}
.brand__role{
  display:block;margin-top:11px;font-family:var(--serif);font-weight:500;
  font-size:clamp(11px,1.5vw,15px);letter-spacing:.42em;text-indent:.42em;
  text-transform:uppercase;color:var(--muted);
}

/* hamburger — fixed so it's always reachable */
.nav__toggle{
  position:fixed;top:30px;right:28px;z-index:70;
  background:none;border:0;cursor:pointer;padding:8px;
  filter:drop-shadow(0 0 2px rgba(255,255,255,.55));
}
.nav__toggle span{display:block;width:26px;height:1.5px;background:var(--fg);margin:6px 0;transition:.3s var(--ease)}
.nav__toggle.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav__toggle.open span:nth-child(2){opacity:0}
.nav__toggle.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* fullscreen overlay menu */
.nav__menu{
  position:fixed;inset:0;z-index:65;background:rgba(255,255,255,.98);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  opacity:0;visibility:hidden;transition:opacity .35s var(--ease);
}
.nav__menu.open{opacity:1;visibility:visible}
.nav__menu a{
  font-family:var(--serif);font-weight:500;font-size:clamp(30px,5vw,52px);
  letter-spacing:.08em;text-transform:uppercase;color:var(--fg);padding:8px 0;transition:color .2s var(--ease);
}
.nav__menu a:hover,.nav__menu a.is-active{color:var(--muted)}
body.menu-open{overflow:hidden}

/* ---------- inner-page hero ---------- */
.hero{padding:26px 0 6px;text-align:center}
.hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(30px,5vw,52px);letter-spacing:.06em;margin:0;text-transform:uppercase}
.hero p{margin:12px 0 0;color:var(--muted);font-size:13px;letter-spacing:.2em;text-transform:uppercase}

/* ---------- work grid (mosaic) ---------- */
.grid{
  display:grid;gap:var(--gap);
  grid-template-columns:repeat(3,1fr);
  grid-auto-rows:clamp(200px,24vw,380px);
}
.tile{position:relative;grid-column:span 1;cursor:pointer;overflow:hidden;background:#ececec}
.tile--wide{grid-column:span 2}
.tile__media{position:absolute;inset:0;overflow:hidden}
.tile__media img,
.tile__media video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:opacity .5s var(--ease),transform .9s var(--ease);
}
.tile__media .gif{opacity:0}
.tile:hover .tile__media .poster{opacity:0}
.tile:hover .tile__media .gif{opacity:1}
.tile:hover .tile__media img,
.tile:hover .tile__media video{transform:scale(1.03)}

/* title overlay — hover on desktop, always on touch */
.tile__title{
  position:absolute;inset:0;z-index:2;margin:0;padding:20px;
  display:flex;align-items:center;justify-content:center;text-align:center;
  color:#fff;font-size:clamp(13px,1.45vw,19px);font-weight:600;letter-spacing:.15em;text-transform:uppercase;
  background:linear-gradient(180deg,rgba(0,0,0,.10),rgba(0,0,0,.28));
  text-shadow:0 1px 16px rgba(0,0,0,.5);
  opacity:0;transition:opacity .3s var(--ease);pointer-events:none;
}
.tile:hover .tile__title{opacity:1}

/* "coming soon" placeholder tiles (no video) */
.tile--soon{background:#17181b;cursor:default}
.tile--soon .tile__media{position:absolute;inset:0;overflow:hidden}
.tile__soon{
  position:absolute;inset:0;z-index:2;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:11px;
  text-align:center;color:#fff;padding:22px;
  background:linear-gradient(180deg,rgba(0,0,0,.22),rgba(0,0,0,.46));
}
.tile__soon .name{font-size:clamp(10px,1.05vw,12.5px);letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.8);text-shadow:0 1px 12px rgba(0,0,0,.6)}
.tile__soon .label{font-family:var(--serif);font-weight:500;font-size:clamp(19px,2.3vw,30px);letter-spacing:.14em;text-transform:uppercase;text-shadow:0 1px 16px rgba(0,0,0,.55)}

/* touch devices (mobile + tablet): autoplay clip + always show title */
@media (hover:none){
  .tile__media .poster{opacity:0}
  .tile__media .gif{opacity:1}
  .tile__title{opacity:1}
}

/* tablet keeps the mosaic, shorter rows */
@media(max-width:900px){
  .grid{grid-auto-rows:clamp(150px,28vw,300px)}
}
/* mobile: single column, full-width tiles */
@media(max-width:600px){
  .grid{grid-template-columns:1fr;grid-auto-rows:auto;gap:10px}
  .tile,.tile--wide{grid-column:span 1}
  .tile__media{position:relative;inset:auto;aspect-ratio:16/10}
}

/* ---------- photography masonry ---------- */
.masonry{column-count:3;column-gap:var(--gap)}
@media(max-width:900px){.masonry{column-count:2}}
@media(max-width:560px){.masonry{column-count:1}}
.masonry figure{margin:0 0 var(--gap);break-inside:avoid;cursor:pointer;overflow:hidden;background:#f0f0f0}
.masonry img{width:100%;height:auto;transition:transform .8s var(--ease),filter .4s var(--ease)}
.masonry figure:hover img{transform:scale(1.04);filter:brightness(.94)}

/* ---------- about ---------- */
.about{display:grid;grid-template-columns:0.9fr 1.1fr;gap:56px;align-items:start}
@media(max-width:820px){.about{grid-template-columns:1fr;gap:32px}}
.about__photo{width:100%;background:#f0f0f0}
.about h1{font-family:var(--serif);font-size:clamp(30px,4vw,48px);font-weight:500;letter-spacing:.04em;margin:0 0 6px;text-transform:uppercase}
.about .role{color:var(--muted);text-transform:uppercase;letter-spacing:.2em;font-size:12.5px;margin-bottom:26px}
.about p{font-size:17px;line-height:1.75;margin:0 0 20px;color:#222}
.about .meta{margin-top:30px;font-size:14px;color:var(--muted)}
.about .meta a{color:var(--fg);border-bottom:1px solid var(--line)}

/* ---------- contact ---------- */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:56px}
@media(max-width:820px){.contact{grid-template-columns:1fr;gap:36px}}
.contact h1{font-family:var(--serif);font-size:clamp(30px,4vw,48px);font-weight:500;letter-spacing:.04em;margin:0 0 16px;text-transform:uppercase}
.contact .lede{color:#333;font-size:17px;max-width:36ch;margin:0 0 28px}
.contact .direct{font-size:14px;color:var(--muted);line-height:2}
.contact .direct a{color:var(--fg);border-bottom:1px solid var(--line)}
.form{display:grid;gap:16px}
.field{display:grid;gap:7px}
.field label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.field input,.field textarea{
  font:inherit;font-size:15px;color:var(--fg);background:#fafafa;
  border:1px solid var(--line);border-radius:0;padding:13px 14px;width:100%;
  transition:border-color .25s var(--ease),background .25s var(--ease);
}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--fg);background:#fff}
.btn{
  appearance:none;border:1px solid var(--fg);background:var(--fg);color:#fff;
  font:inherit;font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;
  padding:15px 28px;cursor:pointer;transition:.25s var(--ease);justify-self:start;
}
.btn:hover{background:#fff;color:var(--fg)}
.btn:disabled{opacity:.5;cursor:default}
.form__note{font-size:14px;min-height:20px}
.form__note.ok{color:#1a7f37}
.form__note.err{color:#b42318}

/* ---------- footer ---------- */
.footer{border-top:1px solid var(--line);padding:40px 0;margin-top:40px}
.footer__inner{
  max-width:var(--maxw);margin:0 auto;padding:0 clamp(22px,4vw,48px);
  display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
}
.footer .copy{font-size:12px;color:var(--muted);letter-spacing:.06em}
.socials{display:flex;gap:22px}
.socials a{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);transition:color .25s var(--ease)}
.socials a:hover{color:var(--fg)}

/* ---------- lightbox ---------- */
.lb{position:fixed;inset:0;z-index:100;display:none;background:rgba(8,8,8,.94);align-items:center;justify-content:center;padding:24px;opacity:0;transition:opacity .35s var(--ease)}
.lb.open{display:flex;opacity:1}
.lb__close{position:absolute;top:18px;right:22px;background:none;border:0;color:#fff;cursor:pointer;width:40px;height:40px;opacity:.8;transition:opacity .2s}
.lb__close:hover{opacity:1}
.lb__close::before,.lb__close::after{content:"";position:absolute;left:9px;top:19px;width:22px;height:1.5px;background:#fff}
.lb__close::before{transform:rotate(45deg)}
.lb__close::after{transform:rotate(-45deg)}
.lb__stage{width:min(1100px,100%);max-height:86vh}
.lb__video{position:relative;width:100%;aspect-ratio:16/9;background:#000}
.lb__video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.lb__title{color:#eee;text-align:center;margin-top:16px;font-size:12.5px;letter-spacing:.18em;text-transform:uppercase}
.lb__img{max-width:100%;max-height:86vh;margin:0 auto;object-fit:contain}
.lb__nav{position:absolute;top:50%;transform:translateY(-50%);background:none;border:0;color:#fff;font-size:34px;cursor:pointer;opacity:.6;transition:opacity .2s;padding:20px;user-select:none}
.lb__nav:hover{opacity:1}
.lb__nav.prev{left:6px}
.lb__nav.next{right:6px}
@media(max-width:560px){.lb__nav{font-size:26px;padding:10px}}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
