/* Chris Kilkus Photography — minimal editorial portfolio */
@font-face{
  font-family:"Cormorant Garamond";font-style:normal;font-weight:500;
  font-display:swap;src:url("/assets/fonts/cormorant-garamond-500.woff2") format("woff2");
}
@font-face{
  font-family:"Cormorant Garamond";font-style:normal;font-weight:600;
  font-display:swap;src:url("/assets/fonts/cormorant-garamond-600.woff2") format("woff2");
}
:root{
  --ink:#141414;
  --muted:#6b6b6b;
  --line:#e6e6e6;
  --bg:#ffffff;
  --max:1280px;
  --gap:clamp(10px,1.6vw,20px);
  --serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Helvetica Neue",Arial,sans-serif;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-size:17px;line-height:1.7;
  font-weight:400;-webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--max);margin:0 auto;padding:0 clamp(18px,4vw,48px)}

/* ---- header ---- */
.site-header{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:18px clamp(18px,4vw,48px);
  background:rgba(255,255,255,.9);backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--line);
}
.brand{
  font-family:var(--sans);font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;font-size:15px;white-space:nowrap;
}
.site-nav{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:clamp(12px,1.5vw,22px)}
.site-nav a{
  font-size:11.5px;letter-spacing:.13em;text-transform:uppercase;white-space:nowrap;
  color:var(--muted);padding:4px 0;border-bottom:1px solid transparent;
  transition:color .2s,border-color .2s;
}
.site-nav a:hover,.site-nav a[aria-current=page]{color:var(--ink);border-color:var(--ink)}
.nav-toggle{
  display:none;background:none;border:1px solid var(--line);border-radius:2px;
  font:inherit;font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  padding:7px 12px;cursor:pointer;color:var(--ink);
}

/* ---- hero ---- */
.hero{
  position:relative;min-height:84vh;display:grid;place-items:center;
  text-align:center;color:#fff;overflow:hidden;background:#111;
}
.hero-bg{position:absolute;inset:0;z-index:0;display:block}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center top}
.hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.25),rgba(0,0,0,.45))}
.hero-inner{position:relative;z-index:2;padding:24px}
.hero h1{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(3rem,9vw,7rem);line-height:.95;margin:0;
  letter-spacing:.01em;text-shadow:0 2px 30px rgba(0,0,0,.35);
}
.tagline{
  margin:18px 0 28px;font-size:clamp(.8rem,1.6vw,1rem);
  letter-spacing:.28em;text-transform:uppercase;font-weight:400;opacity:.95;
}

/* ---- buttons ---- */
.btn{
  display:inline-block;font-size:12px;letter-spacing:.2em;text-transform:uppercase;
  padding:14px 30px;border:1px solid currentColor;border-radius:2px;
  transition:background .25s,color .25s;
}
.hero .btn{color:#fff}
.hero .btn:hover{background:#fff;color:#111}
.btn.ghost{color:var(--ink)}
.btn.ghost:hover,.article .btn:hover{background:var(--ink);color:#fff}

/* ---- sections ---- */
.intro{max-width:760px;text-align:center;margin:clamp(48px,8vw,96px) auto}
.intro p{font-family:var(--serif);font-size:clamp(1.4rem,3vw,2rem);line-height:1.4;color:var(--ink)}
.section-title{
  font-family:var(--sans);font-size:12px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--muted);text-align:center;margin:0 0 clamp(20px,3vw,36px);font-weight:600;
}

/* disciplines */
.disciplines{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap);margin-bottom:clamp(60px,9vw,110px)}
.disc{
  border:1px solid var(--line);aspect-ratio:3/2;display:grid;place-items:center;
  transition:background .25s,color .25s,border-color .25s;
}
.disc span{font-family:var(--serif);font-size:clamp(1.4rem,2.6vw,2.2rem)}
.disc:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ---- gallery grid ---- */
.grid{
  columns:3;column-gap:var(--gap);
}
.tile{display:block;margin:0 0 var(--gap);break-inside:avoid;overflow:hidden;background:#f3f3f3}
.tile picture{display:block}
.tile img{width:100%;height:auto;transition:transform .6s ease,filter .4s ease;filter:saturate(.96)}
.tile:hover img{transform:scale(1.04);filter:saturate(1.05)}
.work{margin:0 0 clamp(60px,9vw,110px)}
.more{text-align:center;margin-top:clamp(28px,4vw,48px)}

/* ---- article / text pages ---- */
.page-head{text-align:center;margin:clamp(50px,8vw,96px) auto clamp(28px,4vw,44px);max-width:820px}
.page-head h1{font-family:var(--serif);font-weight:500;font-size:clamp(2.4rem,5.5vw,4rem);line-height:1.04;margin:0}
.page-head .kicker,.kicker{margin-top:14px;color:var(--muted);font-size:12px;letter-spacing:.22em;text-transform:uppercase}
.article{max-width:760px;margin:0 auto clamp(48px,7vw,90px)}
.article p{margin:0 0 1.3em;color:#2a2a2a}
.article .grid{columns:2}

/* about */
.about-grid{max-width:1100px;display:grid;grid-template-columns:0.9fr 1.1fr;gap:clamp(28px,5vw,64px);align-items:start}
.about-photo picture{display:block}
.about-photo img{width:100%;height:auto;border-radius:2px}
.client-list{font-size:.95rem;color:var(--muted);border-top:1px solid var(--line);padding-top:1.1em;margin-top:1.4em}

/* contact */
.contact-block{text-align:center}
.contact-line{margin:28px 0 40px}
.contact-meta{list-style:none;padding:0;margin:0 auto;max-width:520px;text-align:left}
.contact-meta li{display:flex;gap:18px;padding:16px 0;border-top:1px solid var(--line)}
.contact-meta li strong{flex:0 0 110px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600;padding-top:3px}
.contact-meta a{border-bottom:1px solid var(--line)}
.contact-meta a:hover{border-color:var(--ink)}

/* ---- footer ---- */
.site-footer{
  border-top:1px solid var(--line);margin-top:clamp(40px,6vw,80px);
  padding:clamp(40px,6vw,70px) clamp(18px,4vw,48px);text-align:center;color:var(--muted);
}
.foot-social{display:flex;gap:24px;justify-content:center;margin-bottom:18px}
.foot-social a{font-size:12px;letter-spacing:.18em;text-transform:uppercase}
.foot-social a:hover{color:var(--ink)}
.site-footer p{font-size:13px;margin:0;max-width:640px;margin:0 auto;line-height:1.6}

/* ---- lightbox ---- */
.lb{position:fixed;inset:0;z-index:100;background:rgba(12,12,12,.94);display:none;place-items:center;padding:4vmin}
.lb.open{display:grid}
.lb img{max-width:94vw;max-height:90vh;width:auto;height:auto;box-shadow:0 10px 60px rgba(0,0,0,.5)}
.lb-close,.lb-nav{position:absolute;background:none;border:none;color:#fff;cursor:pointer;font-size:30px;line-height:1;opacity:.8;transition:opacity .2s}
.lb-close{top:18px;right:26px;font-size:34px}
.lb-nav{top:50%;transform:translateY(-50%);font-size:48px;padding:10px 20px}
.lb-prev{left:10px}.lb-next{right:10px}
.lb-close:hover,.lb-nav:hover{opacity:1}

/* ---- responsive ---- */
@media(max-width:900px){
  .grid{columns:2}
  .about-grid{grid-template-columns:1fr}
  .disciplines{grid-template-columns:1fr 1fr 1fr}
}
@media(max-width:640px){
  body{font-size:16px}
  .nav-toggle{display:block}
  .site-nav{
    display:none;position:absolute;top:100%;left:0;right:0;
    flex-direction:column;gap:0;background:#fff;border-bottom:1px solid var(--line);
    padding:6px 0;
  }
  .site-nav.open{display:flex}
  .site-nav a{padding:13px clamp(18px,4vw,48px);border-bottom:1px solid var(--line)}
  .grid,.article .grid{columns:1}
  .disciplines{grid-template-columns:1fr}
  .disc{aspect-ratio:5/2}
  .contact-meta li{flex-direction:column;gap:4px}
  .contact-meta li strong{flex:none}
}
