/* chrishuntstudio.com — Chris Hunt Photography. Clean, premium, image-forward portfolio.
   Light editorial, minimal type, tiled galleries + simple lightbox. */
:root{
  --bg:#ffffff;--ink:#111111;--soft:#555;--muted:#9a9a9a;--line:#ececec;--wash:#f6f6f4;
  --sans:"Helvetica Neue",-apple-system,BlinkMacSystemFont,Arial,sans-serif;--wrap:1600px;--gap:clamp(6px,.7vw,12px);
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.7;font-weight:300;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 clamp(16px,4vw,52px)}
.eyebrow{font-size:10px;letter-spacing:.36em;text-transform:uppercase;color:var(--muted)}

/* header */
header{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:clamp(20px,3vw,34px) clamp(16px,4vw,52px);position:sticky;top:0;z-index:60;background:rgba(255,255,255,.95);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.brand{font-size:clamp(15px,2vw,19px);letter-spacing:.4em;text-transform:uppercase;font-weight:400;white-space:nowrap}
.nav-toggle{display:none;background:none;border:0;font:inherit;font-size:11px;letter-spacing:.2em;text-transform:uppercase;cursor:pointer}
nav{display:flex;align-items:center;gap:clamp(18px,2.4vw,36px)}
nav>a,.sub-toggle{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#444;transition:color .2s;background:none;border:0;font-family:inherit;cursor:pointer;padding:0;white-space:nowrap}
nav>a:hover,nav>a[aria-current=page],.has-sub:hover .sub-toggle,.has-sub.is-active .sub-toggle{color:var(--ink)}
.has-sub{position:relative}
.sub-toggle::after{content:"⌄";margin-left:6px;font-size:14px;position:relative;top:-3px}
.has-sub::after{content:"";position:absolute;top:100%;left:-10px;right:-10px;height:18px}
.submenu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(6px);margin-top:12px;background:#fff;border:1px solid var(--line);box-shadow:0 16px 44px rgba(0,0,0,.1);padding:18px 26px;display:grid;gap:14px;min-width:215px;opacity:0;visibility:hidden;transition:opacity .2s,transform .2s;z-index:70}
.has-sub:hover .submenu,.submenu:hover{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.submenu a{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:#555;white-space:nowrap;transition:color .2s}
.submenu a:hover,.submenu a[aria-current=page]{color:var(--ink)}

@media(max-width:760px){
  header{flex-wrap:wrap}
  .nav-toggle{display:block}
  nav{display:none;flex-basis:100%;flex-direction:column;align-items:flex-start;gap:20px;padding:24px 2px 6px}
  nav.open{display:flex}
  .has-sub{width:100%}
  .submenu{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;border:0;border-left:1px solid var(--line);margin:16px 0 0;padding:0 0 0 18px;min-width:0;display:none}
  .has-sub.expanded .submenu{display:grid}
  .sub-toggle::after{content:"+";float:right;font-size:15px;top:0}
  .has-sub.expanded .sub-toggle::after{content:"–"}
}

/* hero */
.hero{position:relative;height:84vh;min-height:520px;overflow:hidden;background:#eee}
.hero img{width:100%;height:100%;object-fit:cover}
.hero .cap{position:absolute;left:0;right:0;bottom:clamp(28px,5vw,60px);text-align:center;color:#fff;text-shadow:0 2px 28px rgba(0,0,0,.6),0 1px 4px rgba(0,0,0,.4);z-index:2}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.2),transparent 26%,transparent 60%,rgba(0,0,0,.62));z-index:1}
.hero .cap .eyebrow{color:rgba(255,255,255,.9)}
.hero .cap h1{font-weight:200;font-size:clamp(2rem,5vw,3.6rem);letter-spacing:.22em;text-transform:uppercase;margin-top:14px}

/* intro */
.intro{max-width:780px;margin:0 auto;text-align:center;padding:clamp(50px,7vw,96px) 0 clamp(30px,4vw,56px)}
.intro h2{font-weight:200;font-size:clamp(1.4rem,2.8vw,2.1rem);line-height:1.3;letter-spacing:-.01em}
.intro p{color:var(--soft);margin-top:20px}

/* gallery index cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap);padding-bottom:clamp(40px,6vw,80px)}
.card{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--wash);display:block}
.card img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease,opacity .4s}
.card:hover img{transform:scale(1.04);opacity:.9}
.card .lab{position:absolute;inset:0;display:grid;place-items:center;z-index:2}
.card .lab span{color:#fff;font-size:clamp(1rem,1.7vw,1.4rem);letter-spacing:.2em;text-transform:uppercase;font-weight:300;text-shadow:0 1px 16px rgba(0,0,0,.5);text-align:center;padding:0 16px}
.card::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.22);transition:background .3s;z-index:1}
.card:hover::after{background:rgba(0,0,0,.34)}

/* page head */
.page-head{text-align:center;max-width:900px;margin:0 auto;padding:clamp(40px,5vw,72px) 0 clamp(24px,3vw,42px)}
.page-head .eyebrow{display:block;margin-bottom:14px}
.page-head h1{font-weight:200;font-size:clamp(1.9rem,4vw,3rem);letter-spacing:.14em;text-transform:uppercase}
.page-head p{margin:18px auto 0;color:var(--soft);max-width:680px;font-size:1.02rem}

/* tiled gallery (masonry columns) */
.gallery{columns:3;column-gap:var(--gap)}
.gallery button{display:block;width:100%;margin:0 0 var(--gap);break-inside:avoid;overflow:hidden;background:var(--wash);border:0;padding:0;cursor:zoom-in}
.gallery img{width:100%;transition:opacity .3s}
.gallery button:hover img{opacity:.88}

/* prose / SEO text */
.prose{max-width:760px;margin:0 auto;padding:clamp(40px,6vw,80px) 0}
.prose p{margin-bottom:1.25em;color:var(--soft)}
.prose h2{font-weight:300;font-size:clamp(1.2rem,2.2vw,1.6rem);letter-spacing:.06em;text-transform:uppercase;margin:1.8em 0 .6em;color:var(--ink)}
.prose h2:first-child{margin-top:0}
.prose a{color:var(--ink);border-bottom:1px solid var(--ink)}
.client-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;font-size:.92rem;color:var(--soft);border-top:1px solid var(--line);padding-top:24px}
.client-cols h3{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink);margin-bottom:8px}

/* video grid */
.videos{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(14px,2vw,28px);padding-bottom:clamp(50px,7vw,90px)}
.video{position:relative;aspect-ratio:16/9;background:#000;overflow:hidden}
.video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* contact */
.contact{max-width:760px;margin:0 auto;padding-bottom:clamp(50px,7vw,90px)}
.contact .social{display:flex;gap:22px;flex-wrap:wrap;margin:6px 0 30px}
.contact .social a{font-size:11px;letter-spacing:.2em;text-transform:uppercase;border-bottom:1px solid var(--ink);padding-bottom:3px}

/* press */
.press-list{list-style:none;display:grid;margin:1.6em 0}
.press-list li{border-top:1px solid var(--line);padding:26px 0}
.press-list li:last-child{border-bottom:1px solid var(--line)}
.press-pub{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.press-list h2{font-weight:300;font-size:clamp(1.2rem,2.4vw,1.7rem);text-transform:none;letter-spacing:0;margin:0 0 8px}
.press-list h2 a{border:0}
.press-list h2 a:hover{color:var(--soft)}
.press-list p{color:var(--soft);margin:0 0 10px}
.press-link{font-size:11px;letter-spacing:.16em;text-transform:uppercase;border-bottom:1px solid var(--ink);padding-bottom:2px}

/* footer */
footer.site{border-top:1px solid var(--line);padding:clamp(36px,5vw,60px) 0;text-align:center}
footer.site .fb{font-size:14px;letter-spacing:.4em;text-transform:uppercase;margin-bottom:16px}
footer.site nav{justify-content:center;margin-bottom:16px}
footer.site .cr{color:var(--muted);font-size:11px;letter-spacing:.08em}

/* lightbox */
.lb{position:fixed;inset:0;background:rgba(12,12,12,.96);z-index:200;display:none;place-items:center;cursor:zoom-out}
.lb.open{display:grid}
.lb img{max-width:94vw;max-height:92vh;width:auto;height:auto;object-fit:contain}
.lb .x,.lb .nav-btn{position:absolute;background:none;border:0;color:#fff;cursor:pointer;font-size:30px;opacity:.7;transition:opacity .2s;font-weight:200}
.lb .x{top:18px;right:26px}
.lb .nav-btn{top:50%;transform:translateY(-50%);font-size:44px;padding:20px}
.lb .prev{left:8px}.lb .next{right:8px}
.lb .x:hover,.lb .nav-btn:hover{opacity:1}

@media(max-width:900px){.cards,.gallery{grid-template-columns:repeat(2,1fr);columns:2}.videos{grid-template-columns:1fr}.client-cols{grid-template-columns:1fr}}
@media(max-width:560px){.cards{grid-template-columns:1fr}.gallery{columns:1}.lb .nav-btn{font-size:32px;padding:10px}}
