/* JonGoodwin.com galleries — matches the Goodwin Publii theme */
@font-face{
  font-family:"Domine";
  src:url("/branding/fonts/domine.woff2") format("woff2");
  font-weight:400 700; font-style:normal; font-display:swap;
}
:root{
  --ink:#1a1a1a; --muted:#6b7280; --paper:#fafaf9; --line:#e7e5e4; --accent:#2563eb;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --display:"Domine",Georgia,"Times New Roman",serif;
}
*,*::before,*::after{box-sizing:border-box;}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);
  line-height:1.6;font-size:17px;display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;}
img{max-width:100%;height:auto;display:block;}
a{color:var(--accent);}
/* deter casual image saving (drag-to-save, long-press, selection) */
img,.cover__img,.lb__img{-webkit-user-drag:none;user-select:none;-webkit-touch-callout:none;}

.band{background:#000;color:#fff;flex:0 0 auto;}
.band--top{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;
  gap:.6rem 1.4rem;padding:1.3rem clamp(1.2rem,4vw,2.4rem);}
.band--bottom{padding:1.2rem clamp(1.2rem,4vw,2.4rem);margin-top:auto;text-align:center;}
.brand{font-family:var(--display);font-weight:700;font-size:1.25rem;letter-spacing:.01em;
  text-decoration:none;color:#fff;}
.nav__list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.2rem 1.3rem;}
.nav__link{text-decoration:none;color:#fff;font-size:.95rem;opacity:.9;padding:.15rem 0;
  border-bottom:1px solid transparent;transition:opacity .15s,border-color .15s;}
.nav__link:hover{opacity:1;border-bottom-color:currentColor;}
.copyright{margin:0;font-size:.82rem;letter-spacing:.02em;opacity:.92;}
.copyright a{color:#fff;}

.gallery-main{flex:1 0 auto;width:100%;max-width:1180px;margin:0 auto;
  padding:2.4rem clamp(1.2rem,4vw,2rem) 3.5rem;}
.gallery-head{margin-bottom:1.6rem;}
.gallery-head__back{margin:0 0 .6rem;font-size:.9rem;}
.gallery-head__back a{text-decoration:none;color:var(--muted);}
.gallery-head__back a:hover{color:var(--ink);}
.gallery-head__title{font-family:var(--display);font-weight:700;font-size:2.1rem;
  letter-spacing:-.02em;margin:0;}
.gallery-head--center{text-align:center;}
.gallery-head__desc{color:var(--muted);margin:.5rem 0 0;max-width:680px;}

/* photo grid — masonry; preserves each photo's proportions, sharp corners */
.grid{column-width:250px;column-gap:.6rem;}
.grid__item{display:block;margin:0 0 .6rem;overflow:hidden;background:#eee;
  break-inside:avoid;cursor:zoom-in;}
.grid__item img{width:100%;height:auto;display:block;transition:transform .4s ease;}
.grid__item:hover img{transform:scale(1.04);}

/* index — one representative photo per gallery; title overlays on hover, sharp corners.
   Portrait tiles, capped at 4 across (3 on tablet, 2 on phone). */
.covers{display:grid;gap:.5rem;grid-template-columns:repeat(2,1fr);}
@media(min-width:640px){.covers{grid-template-columns:repeat(3,1fr);}}
@media(min-width:980px){.covers{grid-template-columns:repeat(4,1fr);}}
.cover{position:relative;display:block;overflow:hidden;aspect-ratio:3/4;background:#eee;
  text-decoration:none;}
.cover__img{position:absolute;inset:0;background:center center/cover no-repeat;
  transition:transform .5s ease;}
.cover:hover .cover__img{transform:scale(1.05);}
.cover::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,0);transition:background .3s ease;}
.cover:hover::after{background:rgba(0,0,0,.42);}
.cover__cap{position:absolute;left:0;right:0;bottom:0;z-index:2;
  text-align:center;padding:.85rem 1rem 1rem;color:#fff;font-size:.95rem;font-weight:400;
  letter-spacing:.03em;opacity:0;transform:translateY(6px);
  transition:opacity .3s ease,transform .3s ease;text-shadow:0 1px 14px rgba(0,0,0,.6);}
.cover:hover .cover__cap{opacity:1;transform:none;}

/* lightbox */
.lb{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;
  background:rgba(0,0,0,.92);}
.lb.is-open{display:flex;}
.lb__img{max-width:92vw;max-height:88vh;object-fit:contain;
  box-shadow:0 10px 40px rgba(0,0,0,.5);}
.lb__btn{position:absolute;top:50%;transform:translateY(-50%);background:none;border:0;
  color:#fff;font-size:2.6rem;line-height:1;cursor:pointer;padding:.4rem .8rem;opacity:.8;}
.lb__btn:hover{opacity:1;}
.lb__prev{left:.3rem;} .lb__next{right:.3rem;}
.lb__close{position:absolute;top:.5rem;right:.8rem;font-size:2rem;background:none;border:0;
  color:#fff;cursor:pointer;opacity:.8;} .lb__close:hover{opacity:1;}
.lb__count{position:absolute;bottom:1rem;left:0;right:0;text-align:center;color:#fff;
  font-size:.85rem;opacity:.8;}
@media (max-width:560px){
  .band--top{flex-direction:column;align-items:flex-start;}
  .lb__btn{font-size:2rem;}
}
