/* ===========================================================
   J. Cloutier Photography — shared stylesheet
   =========================================================== */
:root{
  --ink:#2c2a27;
  --muted:#6f6862;
  --line:#e4ddd4;
  --paper:#fbf9f6;
  --paper-2:#f3eee7;
  --accent:#9a7b4f;        /* warm saddle tan */
  --accent-dark:#7c6340;
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Montserrat', -apple-system, system-ui, sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--sans);color:var(--ink);background:var(--paper);
  line-height:1.7;-webkit-font-smoothing:antialiased;
}
img{display:block;width:100%;height:100%;object-fit:cover;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px;}
.wrap-wide{max-width:1480px;margin:0 auto;padding:0 28px;}

/* ---------- Header ---------- */
header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 40px;transition:background .35s ease,padding .35s ease,box-shadow .35s ease;
}
header.solid,header.scrolled{background:rgba(251,249,246,.96);padding:14px 40px;box-shadow:0 1px 0 var(--line);}
.brand{font-family:var(--serif);font-size:1.45rem;letter-spacing:.02em;color:#fff;transition:color .35s ease;line-height:1.1;}
.brand small{display:block;font-family:var(--sans);font-weight:300;font-size:.6rem;letter-spacing:.42em;text-transform:uppercase;margin-top:3px;opacity:.85;}
header.solid .brand,header.scrolled .brand{color:var(--ink);}
nav{display:flex;gap:34px;}
nav a{font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;font-weight:400;color:#fff;opacity:.92;transition:color .35s ease,opacity .2s;padding-bottom:3px;border-bottom:1px solid transparent;}
header.solid nav a,header.scrolled nav a{color:var(--ink);}
nav a:hover,nav a.active{opacity:1;border-bottom-color:var(--accent);}
.nav-toggle{display:none;}

/* ---------- Buttons / type helpers ---------- */
.eyebrow{font-size:.7rem;letter-spacing:.34em;text-transform:uppercase;color:var(--accent-dark);font-weight:500;}
.sec-title{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,4vw,3rem);line-height:1.1;margin-top:12px;}
.center{text-align:center;}
.lead{max-width:620px;margin:18px auto 0;color:var(--muted);font-weight:300;}
.btn{display:inline-block;padding:15px 34px;border:1px solid var(--accent);color:var(--accent-dark);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;transition:background .3s,color .3s;cursor:pointer;background:none;font-family:var(--sans);}
.btn:hover{background:var(--accent);color:#fff;}
.btn-light{border-color:rgba(255,255,255,.7);color:#fff;}
.btn-light:hover{background:#fff;color:var(--ink);}
.btn-text{display:inline-block;margin-top:26px;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-dark);border-bottom:1px solid var(--accent);padding-bottom:5px;}
.btn-text:hover{color:var(--ink);}
section{padding:110px 0;}

/* ---------- Hero (home) ---------- */
.hero{position:relative;height:100vh;min-height:600px;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden;}
.hero img{position:absolute;inset:0;z-index:-2;}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(0,0,0,.35),rgba(0,0,0,.15) 45%,rgba(0,0,0,.45));}
.hero-inner{padding:0 24px;animation:rise 1.2s ease both;}
.hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(2.6rem,6.4vw,5.4rem);line-height:1.04;letter-spacing:.01em;text-shadow:0 2px 24px rgba(0,0,0,.4);}
.hero .rule{width:64px;height:1px;background:rgba(255,255,255,.8);margin:26px auto 24px;}
.hero p{font-size:.8rem;letter-spacing:.3em;text-transform:uppercase;font-weight:300;opacity:.95;}
.hero .cta{display:inline-block;margin-top:34px;padding:15px 34px;border:1px solid rgba(255,255,255,.7);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;transition:background .3s,color .3s;}
.hero .cta:hover{background:#fff;color:var(--ink);}
.scroll-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;opacity:.8;animation:bob 2.2s infinite;}
@keyframes rise{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:none;}}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0);}50%{transform:translateX(-50%) translateY(7px);}}

/* ---------- Page banner (subpages) ---------- */
.banner{position:relative;height:54vh;min-height:380px;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden;}
.banner img{position:absolute;inset:0;z-index:-2;}
.banner::after{content:"";position:absolute;inset:0;z-index:-1;background:rgba(0,0,0,.4);}
.banner .eyebrow{color:#e6d6bd;}
.banner h1{font-family:var(--serif);font-weight:500;font-size:clamp(2.4rem,5vw,4rem);line-height:1.05;margin-top:10px;text-shadow:0 2px 20px rgba(0,0,0,.4);}
.banner .rule{width:60px;height:1px;background:rgba(255,255,255,.8);margin:22px auto 0;}

/* ---------- About ---------- */
.about{background:var(--paper-2);}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.about-photo{aspect-ratio:4/5;overflow:hidden;box-shadow:0 24px 50px -28px rgba(0,0,0,.45);}
.about-photo img{transition:transform 1.2s ease;}
.about-photo:hover img{transform:scale(1.04);}
.about-text p{margin-top:18px;color:#56504a;font-weight:300;font-size:1.04rem;}
.about-text .sig{font-family:var(--serif);font-size:1.8rem;margin-top:22px;color:var(--ink);}

/* ---------- Collection tiles (home) ---------- */
.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px;}
.tile{position:relative;aspect-ratio:3/4;overflow:hidden;color:#fff;display:block;}
.tile img{transition:transform 1.1s ease;}
.tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.6));transition:background .4s;}
.tile:hover img{transform:scale(1.06);}
.tile:hover::after{background:linear-gradient(180deg,rgba(0,0,0,.15),rgba(0,0,0,.72));}
.tile-label{position:absolute;left:0;right:0;bottom:28px;z-index:2;text-align:center;}
.tile-label small{font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;opacity:.85;font-weight:300;}
.tile-label span{display:block;font-family:var(--serif);font-size:1.7rem;margin-top:4px;}

/* ---------- Featured strip ---------- */
.featured{background:var(--paper-2);}
.strip{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-top:48px;}
.strip a{aspect-ratio:1/1;overflow:hidden;}
.strip img{transition:transform .9s ease,filter .4s;filter:saturate(.96);}
.strip a:hover img{transform:scale(1.08);filter:saturate(1.1);}

/* ---------- Prints CTA band ---------- */
.prints{position:relative;color:#fff;text-align:center;padding:130px 0;overflow:hidden;}
.prints img{position:absolute;inset:0;z-index:-2;}
.prints::after{content:"";position:absolute;inset:0;z-index:-1;background:rgba(20,16,12,.55);}
.prints .sec-title{color:#fff;}
.prints .lead{color:rgba(255,255,255,.9);}

/* ---------- Gallery filter + grid ---------- */
.filterbar{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin:0 0 44px;}
.filterbar button{background:none;border:1px solid var(--line);color:var(--muted);font-family:var(--sans);
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;padding:10px 20px;cursor:pointer;transition:all .25s;}
.filterbar button:hover{border-color:var(--accent);color:var(--accent-dark);}
.filterbar button.active{background:var(--accent);border-color:var(--accent);color:#fff;}
.grid{column-count:3;column-gap:16px;}
.grid .card{break-inside:avoid;margin-bottom:16px;position:relative;overflow:hidden;cursor:pointer;display:block;}
.grid .card img{width:100%;height:auto;transition:transform 1s ease;}
.grid .card::after{content:"View Print";position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:center;
  padding-bottom:18px;color:#fff;font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;
  background:linear-gradient(180deg,rgba(0,0,0,0) 55%,rgba(0,0,0,.55));opacity:0;transition:opacity .35s;}
.grid .card:hover::after{opacity:1;}
.grid .card:hover img{transform:scale(1.05);}

/* ---------- Lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(18,15,12,.92);display:none;align-items:center;justify-content:center;flex-direction:column;padding:30px;}
.lightbox.open{display:flex;}
.lightbox img{max-width:88vw;max-height:74vh;width:auto;height:auto;object-fit:contain;box-shadow:0 30px 80px -20px rgba(0,0,0,.8);}
.lightbox .lb-bar{margin-top:22px;display:flex;gap:16px;align-items:center;}
.lightbox .lb-close{position:absolute;top:24px;right:30px;color:#fff;font-size:2rem;cursor:pointer;line-height:1;opacity:.8;}
.lightbox .lb-close:hover{opacity:1;}
.lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);color:#fff;font-size:2.4rem;cursor:pointer;opacity:.6;padding:10px 18px;user-select:none;}
.lightbox .lb-nav:hover{opacity:1;}
.lightbox .lb-prev{left:10px;}.lightbox .lb-next{right:10px;}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;}
.contact-info p{margin-top:14px;color:#56504a;font-weight:300;}
.contact-info .line{margin-top:22px;}
.contact-info .label{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--accent-dark);}
.contact-info .val{font-family:var(--serif);font-size:1.35rem;margin-top:4px;}
form .field{margin-bottom:20px;}
form label{display:block;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;}
form input,form textarea{width:100%;padding:13px 15px;border:1px solid var(--line);background:#fff;font-family:var(--sans);font-size:.95rem;color:var(--ink);}
form input:focus,form textarea:focus{outline:none;border-color:var(--accent);}
form textarea{min-height:140px;resize:vertical;}

/* ---------- As Seen In ---------- */
.seenin{text-align:center;}
.seenin .logos{display:flex;flex-wrap:wrap;gap:38px;justify-content:center;align-items:center;margin-top:30px;
  font-family:var(--serif);font-size:1.15rem;color:var(--muted);}
.seenin .logos span{opacity:.7;}

/* ---------- Footer ---------- */
footer{background:#23211e;color:#cfc7bd;padding:70px 0 36px;text-align:center;}
footer .fbrand{font-family:var(--serif);font-size:1.6rem;color:#fff;}
footer .fbrand small{display:block;font-family:var(--sans);font-weight:300;font-size:.58rem;letter-spacing:.4em;text-transform:uppercase;margin-top:6px;opacity:.7;}
footer .contact{margin-top:24px;font-size:.92rem;font-weight:300;line-height:2;}
footer .contact a:hover{color:#fff;}
footer .social{margin-top:18px;display:flex;gap:26px;justify-content:center;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;}
footer .social a{border-bottom:1px solid transparent;padding-bottom:3px;}
footer .social a:hover{border-bottom-color:var(--accent);}
footer .fine{margin-top:40px;font-size:.66rem;letter-spacing:.12em;color:#7d756c;}

/* ---------- Responsive ---------- */
@media(max-width:980px){.grid{column-count:2;}}
@media(max-width:860px){
  header{padding:16px 22px;}
  nav{position:fixed;inset:0;background:rgba(251,249,246,.98);flex-direction:column;align-items:center;justify-content:center;gap:30px;transform:translateY(-100%);transition:transform .4s ease;}
  nav.open{transform:none;}
  nav a{color:var(--ink);font-size:.95rem;}
  .nav-toggle{display:flex;flex-direction:column;gap:5px;z-index:60;background:none;border:0;cursor:pointer;}
  .nav-toggle span{width:26px;height:2px;background:#fff;transition:background .35s;}
  header.solid .nav-toggle span,header.scrolled .nav-toggle span{background:var(--ink);}
  .nav-toggle.open span{background:var(--ink);}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:36px;}
  .about-photo{aspect-ratio:4/3;max-height:460px;}
  .tiles{grid-template-columns:1fr;gap:16px;}
  .tile{aspect-ratio:16/10;}
  .strip{grid-template-columns:repeat(3,1fr);}
  section{padding:78px 0;}
}
@media(max-width:560px){.grid{column-count:1;}}
