/* =====================================================================
   MARCUS R. SMITH — personal site
   Design system: "editorial monograph"
   Warm noir · Didone masthead · antique-brass hairline · portrait-led
   Standalone identity, kin to Sonoma Pictures but its own house.
   ===================================================================== */

:root{
  /* --- color --- */
  --noir:#14110f;          /* warm near-black — the gallery wall */
  --char:#1c1815;          /* raised panels */
  --char2:#241f19;         /* alt band */
  --bone:#ece5d8;          /* warm ivory — the wall label */
  --ash:#a79d8e;           /* secondary text */
  --stone:#6f665b;         /* dim captions */
  --patina:#a58a5c;        /* muted antique brass — used with restraint */
  --patina-lo:#7c6a4a;
  --line:rgba(236,229,216,.13);
  --line-lo:rgba(236,229,216,.06);

  /* --- type --- */
  --display:'Bodoni Moda','Didot','Times New Roman',serif;
  --sans:'Hanken Grotesk',system-ui,-apple-system,sans-serif;

  /* --- rhythm --- */
  --gutter:clamp(22px,5vw,64px);
  --maxw:1200px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--noir);color:var(--bone);
  font-family:var(--sans);font-weight:300;line-height:1.62;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  opacity:0;transition:opacity 1s ease;
  overflow-x:hidden;
}
body.ready{opacity:1}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--patina);color:var(--noir)}

/* --- utilities --- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter)}
.eyebrow{
  font-family:var(--sans);font-weight:600;font-size:11px;
  letter-spacing:.32em;text-transform:uppercase;color:var(--patina);
}
.display{font-family:var(--display);font-weight:500;line-height:.98;letter-spacing:-.005em}
.italic{font-style:italic}
.ash{color:var(--ash)}
.center{text-align:center}

/* ===== masthead / nav ===== */
.mast{
  position:sticky;top:0;z-index:40;
  background:rgba(20,17,15,.72);backdrop-filter:blur(14px) saturate(1.1);
  border-bottom:1px solid var(--line-lo);
}
.mast-inner{
  display:flex;align-items:center;justify-content:space-between;
  max-width:var(--maxw);margin:0 auto;
  padding:16px var(--gutter);
}
.mast-name{
  font-family:var(--sans);font-weight:600;font-size:12.5px;
  letter-spacing:.34em;text-transform:uppercase;color:var(--bone);
  white-space:nowrap;
}
.mast-name b{color:var(--patina);font-weight:600}
.mast-links{display:flex;align-items:center;gap:clamp(16px,3vw,34px)}
.mast-links a{
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  font-weight:500;color:var(--ash);position:relative;padding:4px 0;
  transition:color .3s ease;
}
.mast-links a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;
  background:var(--patina);transition:width .35s ease;
}
.mast-links a:hover,.mast-links a:focus-visible,.mast-links a[aria-current="page"]{color:var(--bone)}
.mast-links a:hover::after,.mast-links a:focus-visible::after,.mast-links a[aria-current="page"]::after{width:100%}
.mast-ig{display:inline-flex;align-items:center;gap:6px}
.mast-ig svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.4}

/* ===== hero ===== */
.hero{
  padding:clamp(48px,9vh,110px) 0 clamp(40px,7vh,80px);
  border-bottom:1px solid var(--line-lo);
}
.hero-grid{
  display:grid;grid-template-columns:0.86fr 1.14fr;
  gap:clamp(28px,5vw,72px);align-items:center;
}
.hero-copy{align-self:center}
.hero-kicker{margin-bottom:22px;display:flex;align-items:center;gap:14px}
.hero-kicker .rule{height:1px;width:44px;background:var(--patina)}
.hero-name{
  font-family:var(--display);font-weight:500;
  font-size:clamp(52px,10vw,124px);line-height:.9;letter-spacing:-.02em;
  color:var(--bone);
}
.hero-name .line{display:block;overflow:hidden}
.hero-name .line span{display:block;transform:translateY(105%);
  transition:transform 1s cubic-bezier(.19,1,.22,1)}
.ready .hero-name .line span{transform:translateY(0)}
.hero-name .line:nth-child(2) span{transition-delay:.09s}
.hero-name em{font-style:italic;color:var(--patina)}
.hero-roles{
  margin-top:26px;display:flex;flex-wrap:wrap;gap:10px 0;
  font-size:13.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ash);font-weight:500;
  opacity:0;transform:translateY(12px);
  transition:opacity .8s ease .5s,transform .8s ease .5s;
}
.ready .hero-roles{opacity:1;transform:none}
.hero-roles span{white-space:nowrap}
.hero-roles span::after{content:"·";margin:0 14px;color:var(--patina-lo)}
.hero-roles span:last-child::after{content:""}
.hero-lede{
  margin-top:28px;max-width:44ch;font-size:16.5px;line-height:1.72;
  color:var(--ash);font-weight:300;
  opacity:0;transform:translateY(12px);
  transition:opacity .8s ease .62s,transform .8s ease .62s;
}
.ready .hero-lede{opacity:1;transform:none}
.hero-cta{
  margin-top:34px;display:flex;gap:14px;flex-wrap:wrap;
  opacity:0;transition:opacity .8s ease .74s;
}
.ready .hero-cta{opacity:1}

/* portrait frame */
.portrait{
  position:relative;aspect-ratio:3/4;width:100%;
  background:linear-gradient(150deg,#2a231c 0%,#191512 60%,#221a12 100%);
  border:1px solid var(--line);overflow:hidden;
  opacity:0;clip-path:inset(0 0 0 0);
  transform:scale(1.02);
  transition:opacity 1.1s ease .15s,transform 1.4s cubic-bezier(.19,1,.22,1) .15s;
}
.ready .portrait{opacity:1;transform:none}
.portrait img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 22%}
.portrait::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(to top,rgba(20,17,15,.55),transparent 42%);
}
.portrait .plc{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:14px;text-align:center;color:var(--stone);
}
.portrait .plc svg{width:34px;height:34px;stroke:var(--patina-lo);fill:none;stroke-width:1;opacity:.75}
.portrait .plc .lab{font-size:10.5px;letter-spacing:.3em;text-transform:uppercase}
.portrait .tag{
  position:absolute;left:16px;bottom:14px;z-index:2;
  font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--bone);
}
.portrait .tag b{color:var(--patina);font-weight:600}

/* buttons */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  padding:13px 22px;border:1px solid var(--line);border-radius:1px;
  color:var(--bone);transition:border-color .35s,background .35s,color .35s,transform .35s;
}
.btn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.5;transition:transform .35s}
.btn:hover,.btn:focus-visible{border-color:var(--patina);color:var(--noir);background:var(--patina)}
.btn:hover svg{transform:translateX(3px)}
.btn.ghost:hover{background:transparent;color:var(--patina);border-color:var(--patina)}

/* ===== section scaffolding ===== */
.section{padding:clamp(64px,11vh,124px) 0;border-bottom:1px solid var(--line-lo)}
.section-head{
  display:flex;align-items:baseline;gap:18px;margin-bottom:clamp(34px,6vh,60px);
}
.section-head .no{
  font-family:var(--display);font-style:italic;font-size:20px;color:var(--patina);
  line-height:1;
}
.section-head h2{
  font-family:var(--display);font-weight:500;letter-spacing:-.01em;
  font-size:clamp(28px,5vw,46px);line-height:1;color:var(--bone);
}
.section-head .flex{flex:1;height:1px;background:var(--line);align-self:center;margin-top:6px}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .9s ease,transform .9s cubic-bezier(.19,1,.22,1)}
.reveal.in{opacity:1;transform:none}

/* ===== selected work — the ledger ===== */
.ledger{border-top:1px solid var(--line)}
.cred{
  display:grid;grid-template-columns:auto 1fr auto;
  gap:clamp(14px,3vw,40px);align-items:center;
  padding:clamp(20px,3.4vh,30px) 4px;border-bottom:1px solid var(--line);
  position:relative;transition:padding-left .4s ease;
}
.cred:hover{padding-left:16px}
.cred::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:2px;
  background:var(--patina);transform:scaleY(0);transform-origin:top;
  transition:transform .4s ease;
}
.cred:hover::before{transform:scaleY(1)}
.cred .cno{
  font-family:var(--display);font-style:italic;font-size:15px;color:var(--stone);
  min-width:26px;transition:color .4s}
.cred:hover .cno{color:var(--patina)}
.cred-mid{min-width:0}
.cred-title{
  font-family:var(--display);font-weight:500;font-size:clamp(22px,3.4vw,34px);
  line-height:1.02;color:var(--bone);letter-spacing:-.01em;
  display:inline-flex;align-items:center;gap:12px;flex-wrap:wrap;
}
.cred-title .role{
  font-family:var(--sans);font-style:normal;font-weight:600;font-size:10.5px;
  letter-spacing:.2em;text-transform:uppercase;color:var(--patina);
  border:1px solid var(--patina-lo);border-radius:100px;padding:4px 11px;
  transform:translateY(-2px);
}
.cred-note{
  margin-top:7px;font-size:13.5px;color:var(--ash);font-weight:300;
  max-height:0;opacity:0;overflow:hidden;
  transition:max-height .45s ease,opacity .45s ease,margin-top .45s ease;
}
.cred:hover .cred-note,.cred:focus-within .cred-note{max-height:60px;opacity:1}
.cred-meta{
  text-align:right;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--stone);white-space:nowrap;line-height:1.7;font-weight:500;
}
.cred-meta b{display:block;color:var(--ash);font-weight:600}
.cred:hover .cred-title{color:#fff}

/* ===== reel ===== */
.reel-frame{
  position:relative;aspect-ratio:16/9;width:100%;background:var(--char);
  border:1px solid var(--line);overflow:hidden;
}
.reel-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.reel-plc{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:16px;text-align:center;color:var(--stone);
  background:radial-gradient(120% 90% at 50% 40%,#211b14,#141110);
}
.reel-plc .play{
  width:66px;height:66px;border:1px solid var(--patina);border-radius:50%;
  display:grid;place-items:center;transition:background .4s,transform .4s}
.reel-plc .play svg{width:22px;height:22px;fill:var(--patina);margin-left:3px}
.reel-plc:hover .play{background:var(--patina);transform:scale(1.05)}
.reel-plc:hover .play svg{fill:var(--noir)}
.reel-plc .lab{font-size:11px;letter-spacing:.3em;text-transform:uppercase}

/* ===== contact sheet / gallery ===== */
.sheet{
  display:grid;grid-template-columns:repeat(3,1fr);gap:2px;
  background:var(--line);border:1px solid var(--line);
}
.frame{
  position:relative;aspect-ratio:4/5;overflow:hidden;
  background:linear-gradient(160deg,#241d16,#171310);
}
.frame img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.19,1,.22,1),filter .6s}
.frame:hover img{transform:scale(1.045)}
.frame .fno{
  position:absolute;top:10px;left:11px;z-index:2;
  font-family:var(--display);font-style:italic;font-size:13px;color:var(--bone);
  text-shadow:0 1px 6px rgba(0,0,0,.6);
}
.frame .plc{
  position:absolute;inset:0;display:grid;place-items:center;color:var(--stone);
}
.frame .plc svg{width:26px;height:26px;stroke:var(--patina-lo);fill:none;stroke-width:1;opacity:.6}
.gallery-more{margin-top:30px;text-align:center}

/* ===== bridge (writer/producer → Sonoma) ===== */
.bridge{background:var(--char);border-radius:2px;overflow:hidden}
.bridge-in{
  display:grid;grid-template-columns:1.2fr 1fr;align-items:center;
  gap:clamp(24px,5vw,60px);padding:clamp(34px,6vw,68px);
}
.bridge h3{
  font-family:var(--display);font-weight:500;font-size:clamp(26px,4.4vw,42px);
  line-height:1.05;color:var(--bone);letter-spacing:-.01em;margin-bottom:18px;
}
.bridge h3 em{font-style:italic;color:var(--patina)}
.bridge p{color:var(--ash);font-size:15.5px;max-width:52ch;margin-bottom:12px}
.bridge-aside{
  border-left:1px solid var(--line);padding-left:clamp(20px,3vw,40px);
}
.bridge-aside .lab{font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--stone);margin-bottom:14px}
.bridge-aside .co{
  font-family:var(--display);font-size:22px;color:var(--bone);margin-bottom:6px;line-height:1.1}
.bridge-aside .films{font-size:13.5px;color:var(--ash);line-height:1.9}
.bridge-aside .films a{color:var(--ash);border-bottom:1px solid var(--line);transition:color .3s,border-color .3s}
.bridge-aside .films a:hover{color:var(--patina);border-color:var(--patina)}

/* ===== contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,6vw,70px);align-items:start}
.contact-lead{
  font-family:var(--display);font-weight:500;font-size:clamp(30px,5.4vw,54px);
  line-height:1.02;letter-spacing:-.01em;color:var(--bone);
}
.contact-lead em{font-style:italic;color:var(--patina)}
.contact-sub{margin-top:20px;color:var(--ash);font-size:15.5px;max-width:40ch}
.contact-reps{margin-top:34px;display:grid;gap:20px}
.rep .lab{font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--stone);margin-bottom:5px}
.rep .val{font-size:15px;color:var(--bone)}
.rep .val a{border-bottom:1px solid var(--line);transition:color .3s,border-color .3s}
.rep .val a:hover{color:var(--patina);border-color:var(--patina)}

form.inq{display:grid;gap:16px}
.fld{display:grid;gap:7px}
.fld label{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--stone);font-weight:500}
.fld input,.fld textarea,.fld select{
  background:var(--char);border:1px solid var(--line);border-radius:1px;
  color:var(--bone);font-family:var(--sans);font-size:15px;font-weight:300;
  padding:13px 15px;width:100%;transition:border-color .3s;
}
.fld input:focus,.fld textarea:focus,.fld select:focus{outline:none;border-color:var(--patina)}
.fld textarea{resize:vertical;min-height:110px}
form.inq .btn{border-color:var(--patina);color:var(--noir);background:var(--patina);justify-content:center;cursor:pointer;width:100%}
form.inq .btn:hover{background:transparent;color:var(--patina)}
.form-note{font-size:12.5px;color:var(--stone)}
#formStatus{font-size:13.5px;min-height:1.2em}

/* ===== résumé / work page ===== */
.res-hero{padding:clamp(56px,10vh,120px) 0 clamp(30px,5vh,60px);border-bottom:1px solid var(--line-lo)}
.res-title{font-family:var(--display);font-weight:500;font-size:clamp(40px,8vw,88px);line-height:.92;letter-spacing:-.02em}
.res-title em{font-style:italic;color:var(--patina)}
.res-block{padding:clamp(44px,7vh,80px) 0;border-bottom:1px solid var(--line-lo)}
.res-block:last-of-type{border-bottom:0}
.res-row{
  display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:clamp(12px,3vw,36px);
  padding:18px 4px;border-bottom:1px solid var(--line);align-items:baseline;
}
.res-row:first-of-type{border-top:1px solid var(--line)}
.res-proj{font-family:var(--display);font-size:clamp(19px,2.6vw,25px);color:var(--bone);line-height:1.1}
.res-proj a{transition:color .3s}
.res-proj a:hover{color:var(--patina)}
.res-role{font-size:13.5px;color:var(--patina);letter-spacing:.06em;font-weight:500;text-transform:uppercase}
.res-meta{font-size:13px;color:var(--ash);text-align:right;line-height:1.5}
.train-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:26px 40px}
.train .name{font-family:var(--display);font-size:20px;color:var(--bone);margin-bottom:4px}
.train .name a{transition:color .3s}
.train .name a:hover{color:var(--patina)}
.train .disc{font-size:13px;color:var(--ash)}
.skill-list{display:flex;flex-wrap:wrap;gap:10px}
.skill-list span{
  font-size:12.5px;letter-spacing:.06em;color:var(--ash);
  border:1px solid var(--line);border-radius:100px;padding:8px 16px;
}

/* ===== photos page ===== */
.pg-hero{padding:clamp(52px,9vh,110px) 0 clamp(28px,4vh,50px)}
.pg-title{font-family:var(--display);font-weight:500;font-size:clamp(40px,8vw,84px);line-height:.92;letter-spacing:-.02em}
.pg-title em{font-style:italic;color:var(--patina)}
.pg-sub{margin-top:18px;color:var(--ash);max-width:48ch;font-size:15.5px}
.masonry{columns:3;column-gap:2px;margin-top:8px}
.masonry .frame{aspect-ratio:auto;margin-bottom:2px;break-inside:avoid;min-height:240px}
.masonry .frame.tall{min-height:420px}
.masonry .frame.wide{min-height:200px}

/* ===== footer ===== */
.foot{padding:clamp(46px,7vh,78px) 0 40px;background:var(--noir)}
.foot-top{
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:30px;flex-wrap:wrap;padding-bottom:36px;border-bottom:1px solid var(--line-lo);
}
.foot-name{font-family:var(--display);font-size:clamp(28px,5vw,44px);line-height:1;letter-spacing:-.01em}
.foot-name em{font-style:italic;color:var(--patina)}
.foot-links{display:flex;gap:26px;flex-wrap:wrap}
.foot-links a{
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;color:var(--ash);
  transition:color .3s;position:relative}
.foot-links a:hover{color:var(--patina)}
.foot-bot{
  display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;
  padding-top:26px;font-size:11.5px;letter-spacing:.1em;color:var(--stone);text-transform:uppercase;
}
.foot-bot a{color:var(--stone);transition:color .3s}
.foot-bot a:hover{color:var(--ash)}

/* ===== dual reel ===== */
.reel-pair{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,3vw,32px)}
.reel-item .reel-cap{
  display:flex;align-items:baseline;gap:12px;margin-bottom:14px;
}
.reel-item .reel-cap .rc-no{font-family:var(--display);font-style:italic;font-size:15px;color:var(--patina)}
.reel-item .reel-cap .rc-lab{font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--ash);font-weight:500}

/* ===== portfolio categories & comp card ===== */
.cat{margin-top:clamp(40px,6vh,72px)}
.cat:first-of-type{margin-top:0}
.cat-head{
  display:flex;align-items:baseline;gap:16px;margin-bottom:22px;
}
.cat-head .no{font-family:var(--display);font-style:italic;font-size:17px;color:var(--patina)}
.cat-head h3{font-family:var(--display);font-weight:500;font-size:clamp(22px,3.4vw,30px);color:var(--bone);line-height:1}
.cat-head .flex{flex:1;height:1px;background:var(--line);align-self:center;margin-top:4px}

.compcard{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));
  gap:1px;background:var(--line);border:1px solid var(--line);margin-top:8px;
}
.compcard .cc{background:var(--noir);padding:18px 18px}
.compcard .cc .k{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--stone);margin-bottom:7px}
.compcard .cc .v{font-family:var(--display);font-size:20px;color:var(--bone);line-height:1}
.compcard .cc .v small{font-family:var(--sans);font-size:12px;color:var(--ash);letter-spacing:.02em}

/* union tag */
.union{
  display:inline-flex;align-items:center;gap:7px;
  font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--patina);
  border:1px solid var(--patina-lo);border-radius:100px;padding:5px 12px;
}

/* ===== responsive ===== */
@media (max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .hero-copy{order:2}
  .portrait{order:1;max-width:340px;margin:0 auto}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .bridge-in{grid-template-columns:1fr;gap:30px}
  .bridge-aside{border-left:0;border-top:1px solid var(--line);padding-left:0;padding-top:26px}
  .sheet{grid-template-columns:repeat(2,1fr)}
  .reel-pair{grid-template-columns:1fr;gap:32px}
  .res-row{grid-template-columns:1fr;gap:6px}
  .res-meta{text-align:left}
  .masonry{columns:2}
}
@media (max-width:560px){
  .mast-links a:not(.mast-cta):not(.mast-ig){display:none}
  .cred{grid-template-columns:auto 1fr;gap:14px}
  .cred-meta{grid-column:2;text-align:left;margin-top:6px}
  .hero-roles{font-size:12px}
  .sheet{grid-template-columns:1fr 1fr}
  .masonry{columns:1}
  .foot-top{align-items:flex-start}
}

/* ===== motion preference ===== */
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;animation:none!important}
  body{opacity:1}
  .hero-name .line span{transform:none}
  .hero-roles,.hero-lede,.hero-cta,.portrait{opacity:1;transform:none}
  .reveal{opacity:1;transform:none}
}
