/* ===========================================================
   JB PILON — minimal redesign
   Two typefaces. Two colours. Hairlines instead of shapes.
   =========================================================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#f7f6f3;
  --ink:#111110;
  --mid:#767671;
  --line:rgba(17,17,16,.15);
  --line-strong:rgba(17,17,16,.32);

  --bg-inv:#111110;
  --ink-inv:#f7f6f3;
  --mid-inv:#8f8f8a;
  --line-inv:rgba(247,246,243,.18);

  --accent:#673B2F;
  --accent-light:#8A7560;

  --serif:'Unbounded',Georgia,serif;
  --mono:'Public Sans','Verdana',Tahoma,Geneva,sans-serif;

  --pad:clamp(24px,6vw,80px);
  --sec-y:clamp(88px,13vw,180px);
}

html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--ink);
  font-family:var(--mono);font-size:14px;line-height:1.7;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
::selection{background:var(--ink);color:var(--bg)}

.serif{font-family:var(--serif)}

/* ── micro-labels used everywhere: nav, eyebrows, captions ── */
.mono{
  font-family:var(--mono);font-size:11px;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;
}

/* ── section-header info links: "Buffalo Studio →", "Full details →" ── */
.info-link{font-size:13px}
.info-row{display:flex;align-items:baseline;gap:20px;flex-wrap:wrap}
.info-row p{font-size:13px}
.info-row .u-link{margin-left:auto}

/* ── links: a solid bar slides in from the left; bar and text
   swap to the opposite value (black-on-white / white-on-black)
   depending on which section the link sits in ── */
.u-link{position:relative;display:inline-block;padding:1px 7px;isolation:isolate}
.u-link::before{
  content:'';position:absolute;inset:0;background:var(--ink);z-index:-1;
  transform-origin:left;transform:scaleX(0);
  transition:transform .3s cubic-bezier(.4,0,.2,1);
}
.u-link:hover{color:#fff}
.u-link:hover::before{transform:scaleX(1)}
.sec--inv .u-link::before{background:var(--ink-inv)}
.sec--inv .u-link:hover{color:var(--ink)}
@media(prefers-reduced-motion:reduce){.u-link::before{transition:none}}

/* ===========================================================
   NAV — just a hamburger in a white circle, floating top-right.
   The menu is a full-screen overlay on every screen size.
   =========================================================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:300;
  display:flex;align-items:center;justify-content:flex-end;
  padding:22px var(--pad);
  pointer-events:none;
}
.nav > *{pointer-events:auto}

.nav-toggle{
  width:48px;height:48px;border-radius:50%;background:#fff;
  box-shadow:0 2px 10px rgba(17,17,16,.15);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;
}
.nav-toggle span{display:block;width:18px;height:2px;background:var(--ink);transition:transform .3s ease,opacity .2s ease}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.nav-links{
  position:fixed;inset:0;z-index:290;
  display:flex;flex-direction:column;justify-content:center;align-items:flex-start;
  gap:28px;padding:0 var(--pad);background:var(--bg);
  transform:translateY(-100%);transition:transform .5s cubic-bezier(.4,0,.2,1);
}
.nav-links.open{transform:translateY(0)}
.nav-links a{
  font-family:var(--serif);font-weight:600;font-size:clamp(30px,6vw,58px);
  color:var(--ink);letter-spacing:-.01em;transition:color .2s;
}
.nav-links a:hover{color:var(--accent)}
.nav-links a.active{color:var(--accent)}

@media(max-width:860px){
  .nav-links{gap:18px}
  .nav-links a{font-size:clamp(26px,7vw,40px)}
}

/* ===========================================================
   LAYOUT / SECTIONS
   =========================================================== */
main{padding-top:0}
.sec{padding:var(--sec-y) var(--pad);border-top:1px solid var(--line)}
#contact.sec{position:relative;overflow:hidden}
.sec--inv{background:var(--bg-inv);color:var(--ink-inv);border-top:1px solid var(--line-inv)}
.sec--flush{border-top:none}
.wrap{max-width:1360px;margin:0 auto}

.sec-head{display:flex;align-items:baseline;gap:20px;margin-bottom:72px;position:relative;z-index:1}
.sec-title{font-family:var(--serif);font-weight:800;font-size:clamp(30px,4.4vw,58px);letter-spacing:-.01em;line-height:1.05}
.sec{position:relative}

/* ===========================================================
   HERO — a clean, quiet split: name and photo side by side.
   =========================================================== */
.hero{padding:108px var(--pad) 0}
.hero-top{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;padding-bottom:56px;color:var(--mid)}
.hero-grid{
  display:grid;grid-template-columns:1fr .62fr;gap:0 56px;align-items:end;
  border-top:1px solid var(--line);padding-top:44px;position:relative;
}
.hero-name{font-family:var(--serif);font-weight:800;line-height:.92;letter-spacing:-.02em;position:relative;z-index:1}
.hero-name span{display:block;font-size:clamp(56px,10vw,168px)}
.hero-meta{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-top:56px}
.hero-role{max-width:540px;font-size:16px;line-height:1.7;color:var(--mid)}
.hero-photo-wrap{position:relative;z-index:2;margin-top:clamp(-90px,-7vw,-40px);overflow:hidden}
.hero-photo{aspect-ratio:3/4;overflow:hidden;border:1px solid var(--line);transform:rotate(-1.4deg);box-shadow:0 40px 70px rgba(17,17,16,.2)}
.hero-photo img{width:100%;height:100%;object-fit:cover}

@media(max-width:860px){
  .hero{padding:96px 20px 0}
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .hero-photo-wrap{order:-1;margin-top:0}
  .hero-photo{aspect-ratio:4/3;transform:rotate(-1deg)}
  .hero-meta{margin-top:28px;flex-direction:column;align-items:flex-start;gap:16px}
}

@media(min-width:861px){
  .hero-photo-wrap{margin-right:calc(var(--pad) * -1)}
}

/* ===========================================================
   BIO — shared: homepage About, studio.html, credits.html
   =========================================================== */
.bio-grid{display:grid;grid-template-columns:1.4fr .9fr;gap:80px}
.bio-quote{font-family:var(--serif);font-weight:400;font-size:clamp(16px,1.9vw,25px);line-height:1.7;letter-spacing:0}
.bio-quote strong{font-weight:600}
.stat-row{display:grid;grid-template-columns:1fr 1fr;gap:12px 20px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:14px 0;margin-bottom:20px}
.stat-num{display:block;font-family:var(--serif);font-weight:600;font-size:clamp(20px,2.2vw,28px)}
.stat-label{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--mid);margin-top:2px}
.bio-cta{display:inline-flex;align-items:center;gap:10px;margin-top:32px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase}
.arr{display:inline-block}

/* choreographed reveal: stats count in left to right once the bio is visible */
.stat-row li{opacity:0;transform:translateY(12px);transition:opacity .5s ease,transform .5s ease}
.bio-grid.in .stat-row li{opacity:1;transform:none}
.bio-grid.in .stat-row li:nth-child(1){transition-delay:.05s}
.bio-grid.in .stat-row li:nth-child(2){transition-delay:.14s}
.bio-grid.in .stat-row li:nth-child(3){transition-delay:.23s}
.bio-grid.in .stat-row li:nth-child(4){transition-delay:.32s}
@media(prefers-reduced-motion:reduce){.stat-row li{opacity:1;transform:none;transition:none}}

@media(max-width:860px){.bio-grid{grid-template-columns:1fr;gap:36px}}

/* ===========================================================
   TICKER
   =========================================================== */
.ticker{display:flex;align-items:center;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:26px 0;margin-top:36px;overflow:hidden;gap:28px}
.ticker-label{flex-shrink:0;color:var(--mid);padding-left:var(--pad)}
.ticker-track{overflow:hidden;flex:1;-webkit-mask-image:linear-gradient(to right,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(to right,transparent,#000 6%,#000 94%,transparent)}
.ticker-inner{display:inline-flex;align-items:baseline;white-space:nowrap;animation:tick 42s linear infinite}
.ticker-inner:hover{animation-play-state:paused}
.tick-item{font-family:var(--serif);font-weight:600;font-size:clamp(12px,1.5vw,19px);letter-spacing:-.005em;text-transform:uppercase}
.tick-sep{color:var(--accent);margin:0 22px;font-weight:700;font-family:var(--mono);font-size:13px}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.ticker-inner{animation:none}}

@media(max-width:860px){
  .ticker{padding:22px 0}
  .ticker-label{padding-left:20px}
}

/* ===========================================================
   STATEMENT — one quiet typographic moment over a static photo.
   =========================================================== */
.statement{
  position:relative;overflow:hidden;isolation:isolate;
  min-height:clamp(480px,62vh,660px);display:flex;align-items:center;justify-content:center;
  padding:140px var(--pad);
}
.statement-media{position:absolute;inset:0;z-index:0}
.statement-media img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) brightness(.7)}
.statement-inner{position:relative;z-index:1;max-width:1080px;text-align:center}
.statement-quote{
  font-family:var(--serif);font-weight:300;color:var(--ink-inv);
  font-size:clamp(38px,6.4vw,80px);line-height:1.2;letter-spacing:-.01em;
  text-shadow:0 2px 24px rgba(0,0,0,.55);
}
.statement-quote em{font-style:normal;font-weight:600;color:var(--accent-light)}

@media(max-width:860px){
  .statement{min-height:clamp(320px,50vh,460px);padding:100px 20px}
}

/* ===========================================================
   ROW PRIMITIVES — shared with the FAQ accordion (faq.html uses
   class="faq-item row" so .row / .row-num / .row-plus must stay)
   =========================================================== */
.row{border-bottom:1px solid var(--line)}
.row-num{font-family:var(--mono);font-size:12px;color:var(--mid);width:28px;flex-shrink:0}
.row-plus{font-family:var(--mono);font-size:16px;color:var(--mid);transition:transform .3s,color .3s}
.row.open .row-plus{transform:rotate(45deg);color:var(--accent)}

/* ===========================================================
   SERVICES LIST — a plain, fully static list. Every title and
   description is visible in the markup with no interaction
   required, which is both the simplest reading experience and
   the most crawlable one.
   =========================================================== */
.svc-list{border-top:1px solid var(--line)}
.svc{display:grid;grid-template-columns:70px 1fr;gap:8px 28px;padding:36px 0;border-bottom:1px solid var(--line)}
.svc-num{font-family:var(--mono);font-size:12px;color:var(--mid)}
.svc-title{grid-column:2;font-family:var(--serif);font-weight:700;font-size:clamp(22px,2.7vw,31px);letter-spacing:-.005em;margin-bottom:10px}
.svc-desc{grid-column:2;max-width:640px;font-size:14.5px;line-height:1.85;color:var(--mid)}

.sec--inv .svc-list,.sec--inv .svc{border-color:var(--line-inv)}
.sec--inv .svc-desc{color:var(--mid-inv)}
.sec--inv .svc-num{color:var(--mid-inv)}

@media(max-width:860px){.svc{grid-template-columns:44px 1fr}}

/* ===========================================================
   PAGE HEADER (services / studio / credits / faq)
   =========================================================== */
.page-head{padding:160px var(--pad) var(--sec-y);border-bottom:1px solid var(--line)}
.page-head-eyebrow{color:var(--mid);margin-bottom:28px;display:flex;align-items:center;gap:14px}
.page-head-eyebrow::before{content:'';width:30px;height:1px;background:var(--line-strong)}
.page-head h1{font-family:var(--serif);font-weight:800;font-size:clamp(38px,6.4vw,86px);line-height:1.02;letter-spacing:-.01em;max-width:900px}
.page-head h1 em{font-style:normal;color:var(--accent)}
.page-head.sec--inv h1 em{color:var(--accent-light)}
.page-head-sub{margin-top:32px;max-width:560px;color:var(--mid);font-size:13px;line-height:1.9}

/* ===========================================================
   SERVICE ARTICLES (full services page)
   =========================================================== */
.article{max-width:1360px;margin:0 auto;padding:84px var(--pad);border-bottom:1px solid var(--line)}
.article:last-child{border-bottom:none}
.art-head{display:flex;gap:24px;align-items:baseline;margin-bottom:24px}
.art-num{font-family:var(--mono);font-size:12px;color:var(--mid);flex-shrink:0}
.art-title{font-family:var(--serif);font-weight:800;font-size:clamp(22px,3vw,38px);letter-spacing:-.005em;line-height:1.1}
.art-sub{font-family:var(--mono);font-size:12px;color:var(--mid);margin-top:8px;letter-spacing:.04em;text-transform:none}
.art-body{font-size:13px;line-height:1.9;color:var(--mid);max-width:680px;padding-left:44px;margin-bottom:32px}
.art-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;padding-left:44px;border-top:1px solid var(--line);padding-top:26px}
.art-tag{color:var(--mid);margin-bottom:8px;display:block}
.art-desc{font-size:12.5px;line-height:1.75;color:var(--mid)}

@media(max-width:860px){
  .art-body,.art-cols{padding-left:0}
  .art-cols{grid-template-columns:1fr;gap:20px}
}

/* ===========================================================
   GALLERY
   =========================================================== */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
.gal-fig{position:relative;cursor:zoom-in;background:var(--bg)}
.gal-fig.wide{grid-column:span 2}
.gal-fig img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .5s}
.gal-fig.wide img{aspect-ratio:8/3}
.gal-fig:hover img{transform:scale(1.04) rotate(-0.6deg)}
.gal-cap{position:absolute;left:0;bottom:0;right:0;padding:10px 14px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:linear-gradient(to top,rgba(0,0,0,.55),transparent);opacity:0;transition:opacity .3s}
.gal-fig:hover .gal-cap{opacity:1}

/* choreographed reveal: the grid sweeps in column by column */
.gallery .gal-fig{opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s ease}
.gallery.in .gal-fig{opacity:1;transform:none}
.gallery.in .gal-fig:nth-child(4n+1){transition-delay:.04s}
.gallery.in .gal-fig:nth-child(4n+2){transition-delay:.1s}
.gallery.in .gal-fig:nth-child(4n+3){transition-delay:.16s}
.gallery.in .gal-fig:nth-child(4n+4){transition-delay:.22s}

@media(max-width:860px){
  .gallery{grid-template-columns:repeat(2,1fr)}
  .gal-fig.wide{grid-column:span 2}
  .gallery.in .gal-fig:nth-child(2n+1){transition-delay:.04s}
  .gallery.in .gal-fig:nth-child(2n+2){transition-delay:.12s}
}
@media(prefers-reduced-motion:reduce){.gal-fig{opacity:1;transform:none;transition:none}}

/* ── lightbox ── */
.lb{position:fixed;inset:0;background:rgba(17,17,16,.97);z-index:400;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s}
.lb.open{opacity:1;pointer-events:auto}
.lb-img{max-width:88vw;max-height:76vh;object-fit:contain}
.lb-cap{position:absolute;bottom:40px;left:0;right:0;text-align:center;color:var(--mid-inv)}
.lb-close,.lb-prev,.lb-next{position:absolute;color:#fff;font-family:var(--mono);font-size:13px;letter-spacing:.1em}
.lb-close{top:32px;right:var(--pad)}
.lb-prev{left:var(--pad);top:50%;transform:translateY(-50%);font-size:22px}
.lb-next{right:var(--pad);top:50%;transform:translateY(-50%);font-size:22px}

/* ===========================================================
   STUDIO SPECS
   =========================================================== */
.spec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-inv);margin-top:1px}
.spec-cell{background:var(--bg-inv);padding:28px 30px}
.spec-label{color:var(--mid-inv);display:block;margin-bottom:10px}
.spec-val{font-family:var(--serif);font-weight:600;font-size:clamp(15px,1.7vw,20px);line-height:1.4}

@media(max-width:860px){.spec-grid{grid-template-columns:1fr 1fr}}

/* ===========================================================
   CLIENTS — a plain static grid of logo badges on full black.
   =========================================================== */
.clients-grid{display:grid;grid-template-columns:repeat(6,1fr)}
.cl{display:flex;align-items:center;justify-content:center;padding:8px}
.cl img{width:66%;height:auto;margin:0 auto;filter:grayscale(1);transition:transform .3s cubic-bezier(.4,0,.2,1)}
.cl:hover img{transform:scale(1.08)}

@media(max-width:860px){.clients-grid{grid-template-columns:repeat(3,1fr)}}

/* ===========================================================
   CREDITS LIST
   =========================================================== */
.credit-list{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line-inv)}
.credit-item{display:flex;align-items:baseline;gap:14px;padding:20px 26px;border-bottom:1px solid var(--line-inv);border-right:1px solid var(--line-inv)}
.credit-item:nth-child(3n){border-right:none}
.credit-idx{font-family:var(--mono);font-size:11px;color:var(--accent);flex-shrink:0}
.credit-name{font-family:var(--serif);font-weight:600;font-size:clamp(14px,1.4vw,18px);letter-spacing:0}

@media(max-width:860px){
  .credit-list{grid-template-columns:1fr 1fr}
  .credit-item:nth-child(3n){border-right:1px solid var(--line-inv)}
  .credit-item:nth-child(2n){border-right:none}
}
@media(max-width:520px){
  .credit-list{grid-template-columns:1fr}
  .credit-item{border-right:none !important}
}

/* ===========================================================
   FAQ
   =========================================================== */
.faq-row-head{display:flex;align-items:baseline;gap:20px;padding:26px 0;cursor:pointer}
.faq-q{font-family:var(--serif);font-weight:600;font-size:clamp(15px,1.7vw,19px);flex:1;letter-spacing:0}
.faq-a{font-size:13px;line-height:1.85;color:var(--mid);max-width:700px;padding:0 0 28px 42px}
.faq-a a{text-decoration:underline;text-underline-offset:3px;color:var(--ink)}

@media(max-width:860px){.faq-a{padding-left:0}}

/* ===========================================================
   FORM
   =========================================================== */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:8px}
.f-group{
  grid-column:span 1;border:1.5px solid var(--line-inv);padding:14px 18px;
  transition:border-color .2s;
}
.f-group.full{grid-column:1/-1}
.f-group:focus-within{border-color:var(--ink-inv)}
.f-label{color:var(--mid-inv);display:block;margin-bottom:6px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase}
.f-input,.f-select,.f-textarea{
  width:100%;background:none;border:0;color:var(--ink-inv);
  font-family:var(--mono);font-size:15px;font-weight:500;
}
.f-input::placeholder,.f-textarea::placeholder{color:var(--mid-inv);font-family:var(--mono);font-size:13px;font-weight:400}
.f-select{-webkit-appearance:none;appearance:none;cursor:pointer}
.f-select option{background:var(--bg-inv);color:var(--ink-inv)}
.f-textarea{resize:vertical;min-height:64px;line-height:1.6}
.f-input:focus,.f-select:focus,.f-textarea:focus{outline:none}
.form-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px;margin-top:40px}
.gc-note{color:var(--mid-inv);text-align:right;line-height:1.6}
.form-success{display:none;padding:60px 0}
.form-success.show{display:block}
.form-success-title{font-family:var(--serif);font-weight:800;font-size:clamp(20px,2.6vw,28px);margin-bottom:14px}
.form-success-msg{color:var(--mid-inv)}

@media(max-width:860px){.form-grid{grid-template-columns:1fr}}

/* ===========================================================
   CONTACT
   =========================================================== */
.contact-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.2fr .8fr;gap:56px}
.contact-grid > div:nth-child(2){margin-top:64px}
.contact-h2{font-family:var(--serif);font-weight:800;font-size:clamp(28px,4.2vw,52px);line-height:1.15;letter-spacing:-.01em}
.contact-h2 em{font-style:normal;color:var(--accent)}
.c-item{border-bottom:1px solid var(--line);padding:18px 0;display:flex;justify-content:space-between;align-items:baseline}
.c-label{color:var(--mid)}
.c-val{font-family:var(--serif);font-size:17px}
.social-list{margin-top:26px;display:flex;gap:26px}
.social-list a{color:var(--mid)}

@media(max-width:860px){
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .contact-grid > div:nth-child(2){margin-top:0}
}

/* ===========================================================
   CTA BAND
   =========================================================== */
.cta-band{padding:var(--sec-y) var(--pad);text-align:center}
.cta-band h2{font-family:var(--serif);font-weight:800;font-size:clamp(24px,3.6vw,40px);margin-bottom:18px;letter-spacing:-.01em;line-height:1.15}
.cta-band p{color:var(--mid-inv);margin-bottom:32px}

/* ===========================================================
   BUTTONS — same serif and size as the menu links, so the whole
   site speaks in one typographic voice. On hover the whole button
   leans into italics — a quick, springy skew, not a static flip.
   =========================================================== */
.cta-btn,.form-submit,.nav-links a.nav-cta{
  font-family:var(--serif);font-weight:600;font-size:clamp(30px,6vw,58px);letter-spacing:-.01em;
  display:inline-flex;align-items:center;gap:.18em;
  background:var(--accent);color:#fff;
  padding:.32em .55em;border:1.5px solid var(--accent);
  transition:background .15s,color .15s,border-color .15s,transform .2s cubic-bezier(.34,1.56,.64,1);
  cursor:pointer;
}
.cta-btn:hover,.nav-links a.nav-cta:hover{
  background:var(--ink);border-color:var(--ink);color:#fff;
  transform:skewX(-8deg);
}
.form-submit:hover{
  background:#fff;border-color:var(--ink-inv);color:var(--ink);
  transform:skewX(-8deg);
}
.cta-btn:hover .arr,.form-submit:hover .arr{transform:skewX(8deg);display:inline-block}
.form-submit{font-size:clamp(15px,3vw,29px)}
.form-submit:disabled{opacity:.6;cursor:default}
@media(max-width:860px){
  .cta-btn,.form-submit,.nav-links a.nav-cta{font-size:clamp(24px,7vw,40px)}
  .form-submit{font-size:clamp(12px,3.5vw,20px)}
}
@media(prefers-reduced-motion:reduce){.cta-btn,.form-submit,.nav-links a.nav-cta{transition:background .15s,color .15s,border-color .15s}
  .cta-btn:hover,.form-submit:hover,.nav-links a.nav-cta:hover{transform:none}}

/* ===========================================================
   FOOTER
   =========================================================== */
.footer{padding:36px var(--pad);border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.footer-links{display:flex;gap:24px;flex-wrap:wrap}
.footer-links a{color:var(--mid)}
.footer-links a:hover{color:var(--ink)}
.footer-copy{color:var(--mid)}
.footer-top{color:var(--mid)}
.footer-top:hover{color:var(--ink)}

@media(max-width:860px){.footer{flex-direction:column;align-items:flex-start}}

/* ===========================================================
   REVEAL
   =========================================================== */
.reveal{opacity:0;transform:translateY(56px) scale(.975);transition:opacity .85s cubic-bezier(.16,1,.3,1),transform .85s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
@media(max-width:860px){.reveal{transform:translateY(34px) scale(.98)}}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* directional variants — things arriving from the side, not just fading up */
.reveal.reveal-l{transform:translateX(-90px)}
.reveal.reveal-r{transform:translateX(90px)}
.reveal.reveal-l.in,.reveal.reveal-r.in{transform:none}
@media(max-width:860px){
  .reveal.reveal-l,.reveal.reveal-r{transform:translateY(34px) scale(.98)}
}
@media(prefers-reduced-motion:reduce){.reveal-l,.reveal-r{transform:none}}

/* ===========================================================
   CLIENTS — full black band
   =========================================================== */
.clients-black{background:#000;color:var(--ink-inv);border-top:1px solid var(--line-inv)}
.clients-black .sec-num{color:var(--mid-inv)}

/* utility */
.mt-0{margin-top:0}
