/* ============================================================
   Steven Howard Photography, styles.css
   Cinematic, gallery-dark. The work is the color; the UI is the frame.
   ============================================================ */

:root{
  --ink:#0E0E0D;
  --char:#1A1A18;
  --bone:#EDE8DD;
  --ash:#8A8A82;
  --brass:#B0843B;
  --pine:#243029;

  --serif:"Fraunces", Georgia, serif;
  --sans:"Hanken Grotesk", system-ui, sans-serif;
  --mono:"Space Mono", ui-monospace, monospace;

  --maxw:1320px;
  --pad:clamp(1.25rem, 4vw, 3.5rem);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--bone);
  font-family:var(--sans);
  font-size:clamp(1rem,1.05vw,1.075rem);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
::selection{background:var(--brass);color:var(--ink)}

/* ---------- header / nav ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.15rem var(--pad);
  transition:background .4s ease, padding .4s ease;
}
.site-header.scrolled{background:rgba(14,14,13,.82);backdrop-filter:blur(10px);padding:.8rem var(--pad)}
.wordmark{
  font-family:var(--serif);font-weight:400;font-size:1.3rem;letter-spacing:.02em;
  color:var(--bone);
}
.site-nav{display:flex;gap:1.6rem;align-items:center}
.site-nav a{
  font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ash);
  transition:color .25s ease;position:relative;padding:.2rem 0;
}
.site-nav a:hover,.site-nav a:focus-visible{color:var(--bone)}
.site-nav a[aria-current="page"]{color:var(--bone)}
.site-nav a[aria-current="page"]::after{
  content:"";position:absolute;left:0;right:0;bottom:-3px;height:1px;background:var(--brass);
}
.nav-cta{color:var(--brass)!important}
.nav-toggle{display:none}

:focus-visible{outline:2px solid var(--brass);outline-offset:3px}

/* ---------- slideshow / hero ---------- */
.slideshow{position:relative;width:100%;height:100vh;height:100svh;overflow:hidden;background:var(--ink)}
.slide{
  position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.2s ease;will-change:opacity,transform;
}
.slide.active{opacity:1}
.slide.kenburns{animation:kenburns 10s ease-out forwards}
@keyframes kenburns{from{transform:scale(1.04)}to{transform:scale(1.12)}}

/* placeholder frames (replaced by real images) */
.slide--ph::after{
  content:"placeholder, drop image in media/hero/";
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  font-family:var(--mono);font-size:.7rem;color:rgba(237,232,221,.25);letter-spacing:.1em;
}
.ph-1{background:linear-gradient(135deg,#1c2620,#0e0e0d)}
.ph-2{background:linear-gradient(135deg,#2a1f16,#0e0e0d)}
.ph-3{background:linear-gradient(135deg,#1a1a18,#0e0e0d)}
.ph-4{background:linear-gradient(135deg,#241c12,#0e0e0d)}
.ph-5{background:linear-gradient(135deg,#15201c,#0e0e0d)}
.ph-6{background:linear-gradient(135deg,#1f2418,#0e0e0d)}

/* dark vignette so text reads */
.slideshow::before{
  content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,rgba(14,14,13,.45) 0%,rgba(14,14,13,.05) 35%,rgba(14,14,13,.15) 60%,rgba(14,14,13,.85) 100%);
}

.hero-overlay{
  position:absolute;inset:0;z-index:3;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:var(--pad);padding-bottom:clamp(3rem,7vh,5rem);
  pointer-events:none;
}
.hero-lead{max-width:34ch}
.hero-eyebrow{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brass);margin-bottom:1.1rem;
}
.hero-title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(3rem,8vw,6.5rem);line-height:.98;letter-spacing:-.01em;
  margin-bottom:1.1rem;
}
.hero-sub{color:var(--bone);opacity:.82;font-size:clamp(1rem,1.4vw,1.15rem);max-width:46ch}

.hero-meta{
  position:absolute;right:var(--pad);bottom:clamp(3rem,7vh,5rem);
  display:flex;flex-direction:column;align-items:flex-end;gap:.4rem;text-align:right;
}
.slide-caption,.slide-counter{font-family:var(--mono);font-size:.74rem;letter-spacing:.12em;color:var(--ash)}
.slide-counter{color:var(--brass)}

.slide-progress{
  position:absolute;left:0;bottom:0;z-index:4;height:2px;background:var(--brass);width:0;
  transition:width .2s linear;opacity:.7;
}

/* scroll cue */
.scroll-cue{
  position:absolute;left:50%;bottom:1.4rem;transform:translateX(-50%);z-index:40;
  display:flex;flex-direction:column;align-items:center;gap:.35rem;
  font-family:var(--mono);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ash);
  animation:bob 2.6s ease-in-out infinite;
}
.scroll-cue:hover{color:var(--bone)}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(5px)}}

/* ---------- genre / gallery pages ---------- */
.is-page{padding-top:0}
.page-hero{
  min-height:60vh;display:flex;flex-direction:column;justify-content:flex-end;
  padding:var(--pad);padding-bottom:clamp(2rem,5vh,3.5rem);
  border-bottom:1px solid rgba(237,232,221,.08);
}
.page-eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);margin-bottom:1rem}
.page-title{font-family:var(--serif);font-weight:300;font-size:clamp(2.6rem,6vw,5rem);line-height:1;margin-bottom:1rem}
.page-intro{color:var(--ash);max-width:52ch;font-size:clamp(1rem,1.3vw,1.12rem)}

.gallery{
  display:grid;gap:clamp(.5rem,1.2vw,1rem);padding:clamp(.5rem,1.2vw,1rem);
  grid-template-columns:repeat(12,1fr);
}
/* cinematic mixed layout, vary spans for rhythm */
.gallery figure{position:relative;overflow:hidden;background:var(--char);grid-column:span 6;opacity:0;transform:translateY(24px)}
.gallery figure.reveal{opacity:1;transform:none;transition:opacity .9s ease,transform .9s ease}
.gallery figure.wide{grid-column:span 12}
.gallery figure.tall{grid-column:span 6;aspect-ratio:4/5}
.gallery figure img{width:100%;height:100%;object-fit:cover;transition:transform .9s ease}
.gallery figure:hover img{transform:scale(1.03)}
.gallery figcaption{
  position:absolute;left:0;bottom:0;right:0;padding:1rem;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;color:var(--bone);
  background:linear-gradient(0deg,rgba(14,14,13,.7),transparent);
  opacity:0;transition:opacity .35s ease;
}
.gallery figure:hover figcaption{opacity:1}
.gallery figure.ph{aspect-ratio:3/2;display:flex;align-items:center;justify-content:center}
.gallery figure.ph::after{content:attr(data-ph);font-family:var(--mono);font-size:.7rem;color:rgba(237,232,221,.25);letter-spacing:.1em}

/* ---------- footer ---------- */
.site-footer{
  padding:clamp(3rem,8vh,6rem) var(--pad) 2.5rem;
  border-top:1px solid rgba(237,232,221,.08);margin-top:2rem;
}
.footer-grid{display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between;align-items:flex-end;max-width:var(--maxw);margin:0 auto}
.footer-mark{font-family:var(--serif);font-size:1.6rem}
.footer-links{display:flex;gap:1.4rem;flex-wrap:wrap;font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ash)}
.footer-links a:hover{color:var(--bone)}
.footer-fine{margin-top:2rem;font-family:var(--mono);font-size:.68rem;color:var(--ash);letter-spacing:.08em;max-width:var(--maxw);margin-left:auto;margin-right:auto}

/* ---------- contact ---------- */
.contact-wrap{min-height:80vh;display:flex;flex-direction:column;justify-content:center;padding:var(--pad);max-width:var(--maxw);margin:0 auto}
.contact-wrap h1{font-family:var(--serif);font-weight:300;font-size:clamp(2.6rem,7vw,5.5rem);line-height:1;margin-bottom:1.5rem}
.contact-wrap .lead{color:var(--ash);max-width:46ch;margin-bottom:2.5rem;font-size:1.15rem}
.contact-links a{display:inline-block;font-family:var(--mono);font-size:.95rem;letter-spacing:.06em;border-bottom:1px solid var(--brass);padding-bottom:2px;margin-right:2rem}

/* ---------- responsive ---------- */
@media (max-width:760px){
  .nav-toggle{display:flex;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;z-index:60}
  .nav-toggle span{width:26px;height:2px;background:var(--bone);transition:.3s}
  .site-nav{
    position:fixed;inset:0;background:var(--ink);flex-direction:column;justify-content:center;
    gap:1.6rem;transform:translateX(100%);transition:transform .4s ease;
  }
  .site-nav.open{transform:none}
  .site-nav a{font-size:1.1rem}
  .gallery figure,.gallery figure.tall{grid-column:span 12}
  .hero-meta{position:static;align-items:flex-start;text-align:left;margin-top:1.5rem}
  .hero-overlay{justify-content:flex-end}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:opacity .3s ease!important}
  .slide.kenburns{animation:none}
  .scroll-cue{animation:none}
}

/* ============================================================
   Landing, below the fold (manifesto · the work · contact)
   ============================================================ */

/* film grain, sells "shot by a filmmaker"; very subtle */
.grain{
  position:fixed;inset:0;z-index:70;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* manifesto */
.intro{max-width:var(--maxw);margin:0 auto;padding:clamp(5rem,13vh,9rem) var(--pad);border-bottom:1px solid rgba(237,232,221,.08)}
.intro .eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);display:block;margin-bottom:1.6rem}
.intro .statement{font-family:var(--serif);font-weight:300;font-size:clamp(1.6rem,3.4vw,2.6rem);line-height:1.32;letter-spacing:-.01em;color:var(--bone);max-width:24ch}
.intro .statement em{font-style:italic;color:var(--brass)}
.intro .sub{font-family:var(--sans);font-size:1.05rem;color:var(--ash);max-width:54ch;margin-top:1.8rem}

/* the work, genre tiles */
.work{max-width:var(--maxw);margin:0 auto;padding:clamp(3rem,7vh,5rem) var(--pad) clamp(4rem,10vh,7rem)}
.work .head{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:1.6rem}
.work .head h2{font-family:var(--serif);font-weight:300;font-size:clamp(2rem,4vw,3rem)}
.work .head .label{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ash)}
.work-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:clamp(.5rem,1vw,.9rem)}
.tile{position:relative;overflow:hidden;background:var(--char);grid-column:span 2;aspect-ratio:3/4;display:block;color:var(--bone)}
.tile.wide{grid-column:span 3;aspect-ratio:16/10}
.tile .img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .8s ease}
.tile:hover .img{transform:scale(1.05)}
.tile:hover{outline:1px solid rgba(176,132,59,.45);outline-offset:-1px}
.tile .lab{position:absolute;inset:auto 0 0 0;z-index:2;padding:1.1rem 1.2rem;background:linear-gradient(0deg,rgba(14,14,13,.8),rgba(14,14,13,0))}
.tile .lab .m{font-family:var(--mono);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brass);display:block;margin-bottom:.2rem}
.tile .lab .g{font-family:var(--serif);font-weight:400;font-size:1.35rem;line-height:1.1;display:block}

/* home contact */
.home-contact{text-align:center;padding:clamp(5rem,13vh,9rem) var(--pad);border-top:1px solid rgba(237,232,221,.08)}
.home-contact .eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);display:block;margin-bottom:1.4rem}
.home-contact h2{font-family:var(--serif);font-weight:300;font-size:clamp(2.4rem,5.5vw,4.2rem);line-height:1.04;margin-bottom:2rem}
.ulink{font-family:var(--mono);font-size:.92rem;letter-spacing:.06em;color:var(--bone);border-bottom:1px solid var(--brass);padding-bottom:3px}
.ulink:hover{color:var(--brass)}

@media (max-width:760px){
  .tile,.tile.wide{grid-column:span 6;aspect-ratio:3/2}
  .is-landing .site-header{background:rgba(14,14,13,.5)}
}


/* ---------- about ---------- */
.about{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);max-width:var(--maxw);margin:0 auto;padding:clamp(2rem,5vh,4rem) var(--pad) clamp(4rem,9vh,7rem);align-items:start}
.about .portrait{aspect-ratio:4/5;background:var(--char);position:relative;overflow:hidden}
.about .portrait img{width:100%;height:100%;object-fit:cover;object-position:center}
.about .portrait.ph::after{content:attr(data-ph);position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:.7rem;color:rgba(237,232,221,.25);letter-spacing:.08em;text-align:center;padding:1.5rem}
.about .prose .lead{font-family:var(--serif);font-weight:300;font-size:clamp(1.5rem,2.6vw,2rem);line-height:1.32;color:var(--bone);margin-bottom:1.6rem}
.about .prose p{color:var(--bone);opacity:.85;margin-bottom:1.2rem;font-size:1.08rem;max-width:54ch}
.about .prose .lead{opacity:1}
@media(max-width:760px){.about{grid-template-columns:1fr}}

/* ---------- film reel ---------- */
.reel-wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(.5rem,1.2vw,1rem)}
.reel{position:relative;aspect-ratio:16/9;background:var(--char);overflow:hidden}
.reel iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.reel.ph::after{content:attr(data-ph);position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:.72rem;color:rgba(237,232,221,.3);letter-spacing:.1em}

/* keep nav legible over bright slideshow frames */
.is-landing .site-header::before{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(180deg,rgba(14,14,13,.55),rgba(14,14,13,0));
}
.is-landing .site-header.scrolled::before{opacity:0}

/* ---------- film page: editorial alternating film pieces ---------- */
.films{max-width:var(--maxw);margin:0 auto;padding:1.5rem clamp(1.25rem,5vw,4rem) 5.5rem;display:flex;flex-direction:column;gap:clamp(3.5rem,7vw,6rem)}
.film-piece{display:flex;align-items:center;gap:clamp(1.75rem,5vw,4.5rem)}
.film-piece:nth-child(even){flex-direction:row-reverse}
.film-frame{flex:0 0 clamp(240px,26vw,320px);position:relative;aspect-ratio:9/16;background:var(--char);border:1px solid rgba(237,232,221,.08);overflow:hidden}
.film-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.film-text{flex:1 1 auto;max-width:34rem}
.film-idx{display:inline-block;font-family:var(--mono);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);padding-bottom:.7rem;border-bottom:1px solid rgba(176,132,59,.35);margin-bottom:1.15rem}
.film-title{font-family:var(--serif);font-weight:300;font-size:clamp(2.2rem,4.5vw,3.4rem);line-height:1.02;color:var(--bone);margin:0 0 1rem}
.film-desc{font-family:var(--sans);font-size:1.02rem;line-height:1.55;color:var(--bone);opacity:.82;max-width:30rem;margin:0 0 1.15rem}
.film-meta{font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ash);margin:0}
@media (max-width:680px){
  .film-piece,.film-piece:nth-child(even){flex-direction:column;align-items:flex-start;gap:1.35rem}
  .film-frame{flex-basis:auto;width:100%;max-width:300px;align-self:center}
  .film-text{max-width:none}
}


/* ---------- menu / price list (dark, cinematic) ---------- */
.menu-wrap{max-width:800px;margin:0 auto;padding:0 var(--pad)}
.menu-index{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;max-width:660px;margin:clamp(2rem,5vw,3rem) auto 0;text-align:center}
.menu-index h4{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--bone);font-size:1.12rem;margin-bottom:.5rem}
.menu-index .ix{font-family:var(--mono);font-size:.63rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ash);display:block;line-height:1.9}

.menu-group{padding-top:clamp(2.8rem,5vw,3.8rem)}
.menu-group .eyebrow{font-family:var(--mono);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--brass);display:block;margin-bottom:.8rem}
.menu-group h2{font-family:var(--serif);font-weight:300;color:var(--bone);font-size:clamp(2rem,4.5vw,2.9rem);line-height:1.04}
.menu-group .gsub{color:var(--ash);font-style:italic;margin:.55rem 0 0}
.menu-group .gline{height:1px;background:linear-gradient(90deg,var(--brass),rgba(176,132,59,0));margin:1.3rem 0 0}

.cat{padding:2.5rem 0;border-bottom:1px solid rgba(237,232,221,.09)}
.cat .top{display:flex;justify-content:space-between;align-items:baseline;gap:1rem}
.cat h3{font-family:var(--serif);font-weight:400;color:var(--bone);font-size:1.6rem}
.cat .label{font-family:var(--mono);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);white-space:nowrap}
.cat .desc{color:var(--ash);font-style:italic;font-size:.95rem;margin:.45rem 0 1.5rem;max-width:48em}
.line{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;padding:.78rem 0;border-top:1px solid rgba(237,232,221,.07)}
.line:first-of-type{border-top:0}
.line .nm{color:var(--bone);font-weight:500}
.line .nm small{font-weight:400;color:var(--ash);font-family:var(--sans);font-size:.86em}
.line .price{font-family:var(--serif);font-weight:400;color:var(--brass);font-size:1.3rem;white-space:nowrap}
.line.add{padding:.55rem 0 .55rem 1.2rem;border-top:1px dashed rgba(237,232,221,.1)}
.line.add .nm{font-weight:400;font-size:.94rem;color:var(--bone);opacity:.9}
.line.add .nm b{font-weight:600;opacity:1}
.line.add .price{font-size:1.05rem}
.note{color:var(--ash);font-style:italic;font-size:.82rem;margin-top:1.1rem;line-height:1.65}
.note b{color:var(--bone);font-style:normal}
.todo{color:var(--brass);border-bottom:1px dotted var(--brass);font-style:normal}

/* good to know, deep pine panel for a dramatic break */
.gtk{background:var(--pine);margin-top:clamp(3rem,6vw,5rem)}
.gtk-inner{max-width:800px;margin:0 auto;padding:clamp(3rem,6vw,4.5rem) var(--pad)}
.gtk h2{font-family:var(--serif);font-weight:300;color:var(--bone);font-size:clamp(1.9rem,4vw,2.5rem)}
.gtk .gline{height:1px;width:48px;background:var(--brass);margin:1.4rem 0 2.2rem}
.gtk .grid{display:grid;grid-template-columns:1fr 1fr;gap:1.9rem 2.8rem}
.gtk .label{font-family:var(--mono);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);display:block;margin-bottom:.45rem}
.gtk .grid p{color:rgba(237,232,221,.8);font-size:.95rem}
.gtk hr{border:0;border-top:1px solid rgba(237,232,221,.16);margin:2.6rem 0 1.6rem}
.gtk .fine{color:var(--ash);font-style:italic;font-size:.85rem}
.gtk .sig{font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brass);margin-top:1.2rem;line-height:2.1}
.gtk .sig a:hover{color:var(--bone)}
@media(max-width:620px){.menu-index,.gtk .grid{grid-template-columns:1fr}.line{flex-wrap:wrap}.cat .top{flex-wrap:wrap}}
