/* =====================================================================
   TOM BAKKER DESIGN  —  Premium Design System
   Palette: warm charcoal + brand amber (#F08818) + warm ivory
   Type:    Cormorant Garamond (display serif) + Mulish (body) + Jost (labels)
   Built for clarity (large, readable type) and a luxury, branded feel.
   ===================================================================== */

/* ---------- Design tokens ---------- */
:root{
  /* Brand + neutrals */
  --ink:        #17140F;   /* deep warm charcoal */
  --ink-2:      #211C16;   /* dark panel */
  --ink-3:      #2C261E;   /* raised dark */
  --cream:      #F8F4EC;   /* primary warm ivory background */
  --cream-2:    #F1EADD;   /* deeper warm panel */
  --paper:      #FFFFFF;
  --brand:      #F08818;   /* exact logo amber */
  --brand-deep: #D9740C;   /* hover / pressed */
  --brand-soft: rgba(240,136,24,.12);
  --brand-line: rgba(240,136,24,.35);

  /* Text */
  --text:       #2A251F;   /* body on light */
  --text-muted: #6B6358;   /* secondary on light */
  --text-light: #ECE6DC;   /* body on dark */
  --text-light-muted: #B4AB9C;

  /* Lines */
  --line:       #E3D9C9;
  --line-dark:  rgba(255,255,255,.12);

  /* Type */
  --serif: "Cormorant Garamond", "Times New Roman", Georgia, serif;
  --sans:  "Mulish", -apple-system, "Segoe UI", system-ui, sans-serif;
  --label: "Jost", var(--sans);

  /* Rhythm */
  --container: 1280px;
  --container-wide: 1480px;
  --gutter: clamp(20px, 5vw, 64px);
  --section-y: clamp(72px, 10vw, 152px);
  --radius: 4px;

  /* Motion */
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-soft: cubic-bezier(.4,0,.2,1);

  --shadow-soft: 0 24px 60px -28px rgba(23,20,15,.35);
  --shadow-lift: 0 40px 90px -40px rgba(23,20,15,.55);
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--sans);
  font-size:1.0625rem;        /* 17px base, scales up below */
  line-height:1.8;
  color:var(--text);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
@media (min-width:768px){ body{ font-size:1.125rem; } } /* 18px on desktop */

img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
ul{ margin:0; padding:0; list-style:none; }
::selection{ background:var(--brand); color:#fff; }

/* ---------- Typography ---------- */
h1,h2,h3,h4{ font-family:var(--serif); font-weight:600; color:var(--ink); line-height:1.08; margin:0; letter-spacing:.005em; }
.display{ font-size:clamp(2.9rem, 6.4vw, 6rem); font-weight:600; line-height:1.02; }
h2,.h2{ font-size:clamp(2.1rem, 4.2vw, 3.6rem); }
h3,.h3{ font-size:clamp(1.45rem, 2.4vw, 2rem); }
p{ margin:0 0 1.1em; }
.lead{ font-size:clamp(1.18rem,1.7vw,1.45rem); line-height:1.7; color:var(--text); }
strong{ font-weight:700; }

.eyebrow{
  font-family:var(--label);
  font-size:.78rem;
  font-weight:500;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--brand-deep);
  display:inline-flex; align-items:center; gap:.8em;
  margin:0 0 1.1rem;
}
.eyebrow::before{
  content:""; width:34px; height:1px; background:var(--brand);
  display:inline-block;
}
.eyebrow.center{ justify-content:center; }
.eyebrow.center::after{ content:""; width:34px; height:1px; background:var(--brand); }
.eyebrow.on-dark{ color:var(--brand); }

.script-accent{ font-family:var(--serif); font-style:italic; color:var(--brand-deep); }

/* ---------- Layout ---------- */
.container{ width:100%; max-width:var(--container); margin:0 auto; padding-inline:var(--gutter); }
.container-wide{ max-width:var(--container-wide); }
.section{ padding-block:var(--section-y); }
.section-tight{ padding-block:clamp(48px,6vw,84px); }
.center{ text-align:center; }
.measure{ max-width:62ch; }
.measure-narrow{ max-width:48ch; }
.mx-auto{ margin-inline:auto; }

.section-head{ max-width:780px; margin-bottom:clamp(40px,5vw,68px); }
.section-head.center{ margin-inline:auto; }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--brand); --fg:#fff; --bd:var(--brand);
  position:relative; display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--label); font-weight:500; font-size:.82rem;
  letter-spacing:.16em; text-transform:uppercase;
  padding:1.05em 2.1em; border:1px solid var(--bd); border-radius:var(--radius);
  background:var(--bg); color:var(--fg);
  overflow:hidden; transition:color .45s var(--ease), border-color .45s var(--ease);
  z-index:0;
}
.btn::after{
  content:""; position:absolute; inset:0; z-index:-1;
  background:var(--brand-deep);
  transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease);
}
.btn:hover::after{ transform:scaleX(1); }
.btn .arr{ transition:transform .45s var(--ease); }
.btn:hover .arr{ transform:translateX(5px); }

.btn-ghost{
  --bg:transparent; --fg:var(--ink); --bd:rgba(42,37,31,.28);
}
.btn-ghost::after{ background:var(--ink); }
.btn-ghost:hover{ color:#fff; border-color:var(--ink); }

.btn-ghost.on-dark{ --fg:#fff; --bd:rgba(255,255,255,.32); }
.btn-ghost.on-dark::after{ background:var(--brand); }
.btn-ghost.on-dark:hover{ color:#fff; border-color:var(--brand); }

.link-underline{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--label); font-size:.82rem; font-weight:500;
  letter-spacing:.16em; text-transform:uppercase; color:var(--ink);
  padding-bottom:4px; position:relative;
}
.link-underline::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:100%;
  background:var(--brand); transform:scaleX(.0); transform-origin:right;
  transition:transform .5s var(--ease);
}
.link-underline:hover::after{ transform:scaleX(1); transform-origin:left; }
.link-underline .arr{ transition:transform .4s var(--ease); color:var(--brand-deep); }
.link-underline:hover .arr{ transform:translateX(5px); }
.link-underline.on-dark{ color:#fff; }

/* ---------- Top bar / utility ---------- */
.topbar{
  background:var(--ink); color:var(--text-light-muted);
  font-family:var(--label); font-size:.74rem; letter-spacing:.12em; text-transform:uppercase;
}
.topbar .container{ display:flex; justify-content:space-between; align-items:center; gap:18px; min-height:42px; flex-wrap:wrap; }
.topbar a{ color:var(--text-light-muted); transition:color .3s; }
.topbar a:hover{ color:var(--brand); }
.topbar .tb-left{ display:flex; gap:26px; flex-wrap:wrap; }
.topbar .tb-right{ display:flex; gap:18px; align-items:center; }
@media (max-width:640px){
  .topbar .tb-left{ gap:16px; }
  .topbar .tb-info-hide{ display:none; }
  .topbar .tb-right{ display:none; }
  .topbar .container{ justify-content:flex-start; min-height:38px; }
}

/* ---------- Header / nav ---------- */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:90;
  transition:background .5s var(--ease), box-shadow .5s var(--ease), transform .5s var(--ease);
}
.site-header .nav{
  display:flex; align-items:center; justify-content:space-between;
  min-height:84px; gap:24px;
}
.brand{ display:flex; align-items:center; gap:14px; z-index:2; }
.brand img{ height:42px; width:auto; display:block; transition:height .4s var(--ease); }
@media(min-width:768px){ .brand img{ height:50px; } }
.brand .logo-light{ display:none; }

.nav-links{ display:flex; align-items:center; gap:clamp(20px,2.4vw,40px); }
.nav-links a{
  font-family:var(--label); font-size:.86rem; font-weight:500;
  letter-spacing:.14em; text-transform:uppercase; color:var(--ink);
  position:relative; padding:6px 0; transition:color .35s var(--ease);
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1.5px; width:100%;
  background:var(--brand); transform:scaleX(0); transform-origin:right;
  transition:transform .45s var(--ease);
}
.nav-links a:hover::after,.nav-links a.active::after{ transform:scaleX(1); transform-origin:left; }
.nav-links a.active{ color:var(--brand-deep); }
.nav-cta{ display:flex; align-items:center; gap:18px; }

/* transparent over hero */
.site-header.over-hero{ background:transparent; }
.site-header.over-hero .nav-links a,
.site-header.over-hero .brand-text{ color:#fff; }
.site-header.over-hero .hamburger span{ background:#fff; }
.site-header.over-hero .brand .logo-dark{ display:none; }
.site-header.over-hero .brand .logo-light{ display:block; }

/* scrolled / solid */
.site-header.scrolled{
  background:rgba(248,244,236,.92);
  backdrop-filter:blur(14px) saturate(140%);
  box-shadow:0 1px 0 var(--line), 0 18px 40px -34px rgba(23,20,15,.5);
}
.site-header.scrolled .nav-links a,
.site-header.scrolled .brand-text{ color:var(--ink); }
.site-header.scrolled .brand .logo-dark{ display:block; }
.site-header.scrolled .brand .logo-light{ display:none; }
.site-header.scrolled .hamburger span{ background:var(--ink); }
.site-header.scrolled .nav-links a.active{ color:var(--brand-deep); }
.site-header.hide{ transform:translateY(-100%); }

/* hamburger */
.hamburger{ display:none; flex-direction:column; gap:6px; background:none; border:0; padding:8px; z-index:120; }
.hamburger span{ width:26px; height:2px; background:var(--ink); transition:.4s var(--ease); display:block; }
.nav-open .hamburger span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
.nav-open .hamburger span:nth-child(2){ opacity:0; }
.nav-open .hamburger span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }

/* mobile menu */
.mobile-menu{
  position:fixed; inset:0; z-index:110;
  background:var(--ink); color:#fff;
  display:flex; flex-direction:column; justify-content:center; align-items:center; gap:6px;
  clip-path:circle(0% at calc(100% - 46px) 46px);
  transition:clip-path .7s var(--ease); pointer-events:none;
}
.nav-open .mobile-menu{ clip-path:circle(150% at calc(100% - 46px) 46px); pointer-events:auto; }
.mobile-menu a{
  font-family:var(--serif); font-size:clamp(2rem,8vw,3.2rem); color:#fff;
  padding:.18em 0; opacity:0; transform:translateY(18px);
  transition:opacity .5s var(--ease), transform .5s var(--ease), color .3s;
}
.mobile-menu a:hover{ color:var(--brand); }
.nav-open .mobile-menu a{ opacity:1; transform:none; }
.nav-open .mobile-menu a:nth-child(1){ transition-delay:.18s; }
.nav-open .mobile-menu a:nth-child(2){ transition-delay:.25s; }
.nav-open .mobile-menu a:nth-child(3){ transition-delay:.32s; }
.nav-open .mobile-menu a:nth-child(4){ transition-delay:.39s; }
.nav-open .mobile-menu a:nth-child(5){ transition-delay:.46s; }
.mobile-menu .mm-contact{ margin-top:34px; font-family:var(--label); font-size:.9rem; letter-spacing:.12em; color:var(--text-light-muted); text-transform:uppercase; opacity:0; transition:opacity .5s .55s; }
.nav-open .mobile-menu .mm-contact{ opacity:1; }

@media (max-width:900px){
  .nav-links,.nav-cta .btn{ display:none; }
  .hamburger{ display:flex; }
}

/* ---------- Hero ---------- */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; color:#fff; }
.hero-media{ position:absolute; inset:0; z-index:0; }
.hero-media img{ width:100%; height:100%; object-fit:cover; animation:kenburns 18s var(--ease-soft) forwards; }
.hero-media::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(15,12,8,.46) 0%, rgba(15,12,8,.12) 32%, rgba(15,12,8,.20) 58%, rgba(15,12,8,.82) 100%);
}
@keyframes kenburns{ from{ transform:scale(1.12); } to{ transform:scale(1); } }

.hero-inner{ position:relative; z-index:2; width:100%; padding-bottom:clamp(56px,9vw,120px); padding-top:140px; }
.hero h1{ color:#fff; max-width:16ch; }
.hero .eyebrow{ color:#fff; }
.hero .eyebrow::before{ background:var(--brand); }
.hero-sub{ color:rgba(255,255,255,.9); max-width:46ch; margin-top:1.2rem; font-size:clamp(1.05rem,1.5vw,1.3rem); }
.hero-actions{ display:flex; flex-wrap:wrap; gap:16px; margin-top:2.2rem; }
.hero-scroll{
  position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:2;
  font-family:var(--label); font-size:.7rem; letter-spacing:.24em; text-transform:uppercase; color:rgba(255,255,255,.8);
  display:flex; flex-direction:column; align-items:center; gap:10px;
}
.hero-scroll .bar{ width:1px; height:54px; background:linear-gradient(var(--brand),transparent); position:relative; overflow:hidden; }
.hero-scroll .bar::after{ content:""; position:absolute; top:-50%; left:0; width:100%; height:50%; background:#fff; animation:scrolldown 2.2s var(--ease) infinite; }
@keyframes scrolldown{ 0%{ top:-50%; } 100%{ top:100%; } }
@media (max-width:640px){ .hero-scroll{ display:none; } }

/* page hero (interior pages) */
.page-hero{ position:relative; min-height:62vh; display:flex; align-items:center; color:#fff; overflow:hidden; }
.page-hero .hero-media img{ animation:kenburns 16s var(--ease-soft) forwards; }
.page-hero-inner{ position:relative; z-index:2; padding-top:120px; padding-bottom:48px; }
.page-hero h1{ color:#fff; }
.page-hero .eyebrow{ color:#fff; }
.breadcrumb{ font-family:var(--label); font-size:.76rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.75); margin-top:1.3rem; }
.breadcrumb a:hover{ color:var(--brand); }
.breadcrumb span{ color:var(--brand); }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity 1s var(--ease), transform 1s var(--ease); will-change:opacity,transform; }
.reveal.is-visible{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.1s; } .reveal.d2{ transition-delay:.2s; }
.reveal.d3{ transition-delay:.3s; } .reveal.d4{ transition-delay:.4s; } .reveal.d5{ transition-delay:.5s; }
.reveal-img{ overflow:hidden; }
.reveal-img img{ transform:scale(1.16); transition:transform 1.4s var(--ease); }
.reveal-img.is-visible img{ transform:scale(1); }
@media (prefers-reduced-motion:reduce){
  .reveal,.reveal-img img,.hero-media img{ transition:none!important; animation:none!important; opacity:1!important; transform:none!important; }
}

/* ---------- Intro / welcome ---------- */
.intro{ background:var(--cream); }
.intro-grid{ display:grid; grid-template-columns:1fr; gap:clamp(34px,5vw,72px); align-items:center; }
@media(min-width:900px){ .intro-grid{ grid-template-columns:1.05fr .95fr; } }
.intro-figure{ position:relative; }
.intro-figure .frame{ position:relative; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-soft); }
.intro-figure .frame img{ width:100%; aspect-ratio:4/5; object-fit:cover; }
.intro-figure .badge{
  position:absolute; right:-18px; bottom:-18px; width:clamp(118px,16vw,158px); aspect-ratio:1;
  background:var(--brand); color:#fff; border-radius:50%;
  display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center;
  font-family:var(--label); letter-spacing:.12em; text-transform:uppercase; line-height:1.4;
  box-shadow:var(--shadow-lift);
}
.intro-figure .badge b{ font-family:var(--serif); font-size:1.7rem; letter-spacing:0; text-transform:none; display:block; }
.signature{ font-family:var(--serif); font-style:italic; font-size:1.9rem; color:var(--ink); margin-top:.4rem; }

/* ---------- Stat / promise strip ---------- */
.promise{ background:var(--ink); color:var(--text-light); }
.promise-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line-dark); border:1px solid var(--line-dark); }
@media(min-width:760px){ .promise-grid{ grid-template-columns:repeat(4,1fr); } }
.promise-cell{ background:var(--ink); padding:clamp(28px,3.4vw,46px) clamp(20px,2.6vw,34px); text-align:center; }
.promise-cell .ic{ color:var(--brand); margin-bottom:14px; display:flex; justify-content:center; }
.promise-cell h3{ color:#fff; font-size:1.32rem; margin-bottom:6px; }
.promise-cell p{ color:var(--text-light-muted); font-size:.96rem; margin:0; }

/* ---------- Featured work ---------- */
.work-grid{ display:grid; grid-template-columns:1fr; gap:clamp(20px,2.4vw,30px); }
@media(min-width:680px){ .work-grid{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:1040px){ .work-grid.cols-3{ grid-template-columns:repeat(3,1fr); } }
.work-card{ position:relative; display:block; overflow:hidden; border-radius:var(--radius); background:var(--ink); }
.work-card .ph{ overflow:hidden; }
.work-card img{ width:100%; aspect-ratio:4/3; object-fit:cover; transition:transform 1.1s var(--ease), filter .6s var(--ease); }
.work-card.tall img{ aspect-ratio:3/4; }
.work-card:hover img{ transform:scale(1.07); }
.work-card::after{
  content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(15,12,8,0) 38%, rgba(15,12,8,.86) 100%);
}
.work-card .meta{ position:absolute; z-index:2; left:0; bottom:0; padding:clamp(20px,2.4vw,30px); color:#fff; transform:translateY(8px); transition:transform .6s var(--ease); }
.work-card:hover .meta{ transform:none; }
.work-card .meta .k{ font-family:var(--label); font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--brand); display:block; margin-bottom:8px; }
.work-card .meta h3{ color:#fff; font-size:clamp(1.3rem,1.8vw,1.7rem); }
.work-card .meta .go{ display:inline-flex; align-items:center; gap:.5em; margin-top:10px; font-family:var(--label); font-size:.76rem; letter-spacing:.16em; text-transform:uppercase; color:#fff; opacity:0; transform:translateY(6px); transition:opacity .5s var(--ease) .05s, transform .5s var(--ease) .05s; }
.work-card:hover .meta .go{ opacity:1; transform:none; }

/* ---------- Split feature ---------- */
.split{ display:grid; grid-template-columns:1fr; gap:clamp(34px,5vw,80px); align-items:center; }
@media(min-width:900px){ .split{ grid-template-columns:1fr 1fr; } .split.rev .split-media{ order:2; } }
.split-media{ position:relative; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-soft); }
.split-media img{ width:100%; aspect-ratio:5/4; object-fit:cover; }
.split-media.tall img{ aspect-ratio:4/5; }
.split-body .list{ margin:1.6rem 0 2rem; }
.split-body .list li{ display:flex; gap:14px; padding:14px 0; border-bottom:1px solid var(--line); align-items:flex-start; }
.split-body .list li .n{ font-family:var(--serif); color:var(--brand-deep); font-size:1.4rem; line-height:1; min-width:1.6em; }
.split-body .list li h4{ font-family:var(--sans); font-weight:700; font-size:1.02rem; color:var(--ink); margin:0 0 2px; letter-spacing:.01em; }
.split-body .list li p{ margin:0; color:var(--text-muted); font-size:.98rem; }

/* ---------- Services ---------- */
.svc-grid{ display:grid; grid-template-columns:1fr; gap:clamp(18px,2vw,26px); }
@media(min-width:640px){ .svc-grid{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:1040px){ .svc-grid.cols-4{ grid-template-columns:repeat(4,1fr); } }
.svc-card{
  position:relative; overflow:hidden; border-radius:var(--radius);
  background:var(--paper); border:1px solid var(--line);
  transition:transform .6s var(--ease), box-shadow .6s var(--ease), border-color .6s var(--ease);
  display:flex; flex-direction:column;
}
.svc-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-lift); border-color:transparent; }
.svc-card .svc-ph{ overflow:hidden; }
.svc-card .svc-ph img{ width:100%; aspect-ratio:4/3; object-fit:cover; transition:transform 1.1s var(--ease); }
.svc-card:hover .svc-ph img{ transform:scale(1.08); }
.svc-card .svc-body{ padding:clamp(22px,2.4vw,32px); }
.svc-card .num{ font-family:var(--label); font-size:.74rem; letter-spacing:.2em; color:var(--brand-deep); }
.svc-card h3{ font-size:1.5rem; margin:.4rem 0 .5rem; }
.svc-card p{ color:var(--text-muted); font-size:1rem; margin:0; }
.svc-card .svc-link{ margin-top:1.1rem; display:inline-flex; }

/* feature list, plain icon services (no image) */
.feature-grid{ display:grid; grid-template-columns:1fr; gap:clamp(18px,2vw,28px); }
@media(min-width:760px){ .feature-grid{ grid-template-columns:repeat(3,1fr); } }
.feature{ padding:clamp(26px,2.6vw,38px); background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); transition:transform .5s var(--ease), box-shadow .5s var(--ease); }
.feature:hover{ transform:translateY(-6px); box-shadow:var(--shadow-soft); }
.feature .ic{ width:56px; height:56px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:var(--brand-soft); color:var(--brand-deep); margin-bottom:18px; }
.feature h3{ font-size:1.32rem; margin-bottom:.4rem; }
.feature p{ color:var(--text-muted); font-size:1rem; margin:0; }

/* ---------- Marquee strip ---------- */
.marquee{ background:var(--brand); color:#fff; overflow:hidden; padding:18px 0; }
.marquee .track{ display:flex; gap:60px; width:max-content; animation:marq 28s linear infinite; }
.marquee span{ font-family:var(--serif); font-style:italic; font-size:1.5rem; white-space:nowrap; display:inline-flex; align-items:center; gap:60px; }
.marquee span::after{ content:"✦"; font-style:normal; font-size:.9rem; opacity:.8; }
@keyframes marq{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }

/* ---------- Portfolio gallery ---------- */
.filters{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-bottom:clamp(34px,4vw,56px); }
.filters button{
  font-family:var(--label); font-size:.78rem; letter-spacing:.12em; text-transform:uppercase;
  padding:.7em 1.3em; border:1px solid var(--line); border-radius:100px; background:transparent; color:var(--text-muted);
  transition:.4s var(--ease);
}
.filters button:hover{ color:var(--ink); border-color:var(--ink); }
.filters button.active{ background:var(--ink); color:#fff; border-color:var(--ink); }

.gallery{ columns:1; column-gap:clamp(16px,1.6vw,24px); }
@media(min-width:600px){ .gallery{ columns:2; } }
@media(min-width:1000px){ .gallery{ columns:3; } }
.gal-item{ break-inside:avoid; margin-bottom:clamp(16px,1.6vw,24px); position:relative; overflow:hidden; border-radius:var(--radius); background:var(--ink); cursor:pointer; display:block; }
.gal-item img{ width:100%; height:auto; display:block; transition:transform 1.1s var(--ease), filter .6s; }
.gal-item:hover img{ transform:scale(1.06); }
.gal-item::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(15,12,8,0) 45%,rgba(15,12,8,.8)); opacity:0; transition:opacity .5s var(--ease); }
.gal-item:hover::after{ opacity:1; }
.gal-cap{ position:absolute; left:0; bottom:0; z-index:2; padding:22px; color:#fff; opacity:0; transform:translateY(10px); transition:.5s var(--ease); }
.gal-item:hover .gal-cap{ opacity:1; transform:none; }
.gal-cap .k{ font-family:var(--label); font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; color:var(--brand); display:block; margin-bottom:5px; }
.gal-cap h3{ color:#fff; font-size:1.2rem; }
.gal-item .zoom{ position:absolute; top:16px; right:16px; z-index:2; width:42px; height:42px; border-radius:50%; background:rgba(255,255,255,.16); backdrop-filter:blur(6px); display:flex; align-items:center; justify-content:center; color:#fff; opacity:0; transform:scale(.8); transition:.45s var(--ease); }
.gal-item:hover .zoom{ opacity:1; transform:none; }
.gal-item.is-hidden{ display:none; }

/* project group header in gallery */
.proj-block{ margin-bottom:clamp(54px,7vw,96px); }
.proj-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:20px; flex-wrap:wrap; margin-bottom:clamp(22px,2.6vw,34px); padding-bottom:18px; border-bottom:1px solid var(--line); }
.proj-head .idx{ font-family:var(--serif); font-size:1.1rem; color:var(--brand-deep); }
.proj-head h2{ font-size:clamp(1.7rem,2.8vw,2.5rem); }
.proj-head .tag{ font-family:var(--label); font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--text-muted); }
.proj-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:clamp(14px,1.6vw,22px); }
.proj-grid .gal-item img{ aspect-ratio:4/3; object-fit:cover; height:100%; }
.proj-grid.single{ grid-template-columns:1fr; max-width:760px; }

/* ---------- Lightbox ---------- */
.lightbox{ position:fixed; inset:0; z-index:200; background:rgba(15,12,8,.95); display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity .45s var(--ease); padding:24px; }
.lightbox.open{ opacity:1; pointer-events:auto; }
.lightbox img{ max-width:92vw; max-height:84vh; width:auto; border-radius:3px; box-shadow:0 30px 80px rgba(0,0,0,.6); transform:scale(.96); transition:transform .5s var(--ease); object-fit:contain; }
.lightbox.open img{ transform:scale(1); }
.lb-cap{ position:absolute; bottom:26px; left:0; right:0; text-align:center; color:#fff; font-family:var(--label); font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; }
.lb-cap .k{ color:var(--brand); }
.lb-btn{ position:absolute; top:50%; transform:translateY(-50%); width:54px; height:54px; border-radius:50%; border:1px solid rgba(255,255,255,.25); background:rgba(255,255,255,.06); color:#fff; display:flex; align-items:center; justify-content:center; transition:.35s var(--ease); }
.lb-btn:hover{ background:var(--brand); border-color:var(--brand); }
.lb-prev{ left:18px; } .lb-next{ right:18px; }
.lb-close{ top:20px; right:20px; transform:none; }
@media(max-width:680px){ .lb-prev{ left:6px; } .lb-next{ right:6px; } .lb-btn{ width:46px; height:46px; } }

/* ---------- Contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr; gap:clamp(38px,5vw,76px); }
@media(min-width:920px){ .contact-grid{ grid-template-columns:1fr 1.1fr; } }
.contact-info .ci{ display:flex; gap:18px; padding:22px 0; border-bottom:1px solid var(--line); align-items:flex-start; }
.contact-info .ci .ic{ width:50px; height:50px; flex:none; border-radius:50%; background:var(--brand-soft); color:var(--brand-deep); display:flex; align-items:center; justify-content:center; }
.contact-info .ci .k{ font-family:var(--label); font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--text-muted); display:block; margin-bottom:3px; }
.contact-info .ci a,.contact-info .ci p{ font-size:1.16rem; color:var(--ink); margin:0; font-weight:600; }
.contact-info .ci a:hover{ color:var(--brand-deep); }

.socials{ display:flex; gap:12px; margin-top:26px; }
.socials a{ width:46px; height:46px; border-radius:50%; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; color:var(--ink); transition:.4s var(--ease); }
.socials a:hover{ background:var(--ink); color:#fff; border-color:var(--ink); transform:translateY(-3px); }

.form-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(26px,3.4vw,48px); box-shadow:var(--shadow-soft); }
.field{ margin-bottom:22px; }
.field label{ display:block; font-family:var(--label); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--text-muted); margin-bottom:9px; }
.field input,.field textarea,.field select{
  width:100%; font-family:var(--sans); font-size:1.02rem; color:var(--ink);
  background:var(--cream); border:1px solid var(--line); border-radius:var(--radius);
  padding:14px 16px; transition:border-color .35s, box-shadow .35s; outline:none;
}
.field input:focus,.field textarea:focus,.field select:focus{ border-color:var(--brand); box-shadow:0 0 0 4px var(--brand-soft); background:#fff; }
.field textarea{ min-height:140px; resize:vertical; }
.field-row{ display:grid; grid-template-columns:1fr; gap:0 20px; }
@media(min-width:560px){ .field-row{ grid-template-columns:1fr 1fr; } }
.form-note{ font-size:.86rem; color:var(--text-muted); }
.form-success{ display:none; align-items:center; gap:12px; background:var(--brand-soft); color:var(--brand-deep); border:1px solid var(--brand-line); border-radius:var(--radius); padding:14px 18px; font-weight:600; margin-bottom:20px; }
.form-success.show{ display:flex; }

/* ---------- CTA band ---------- */
.cta-band{ position:relative; overflow:hidden; color:#fff; text-align:center; }
.cta-band .bg{ position:absolute; inset:0; z-index:0; }
.cta-band .bg img{ width:100%; height:100%; object-fit:cover; }
.cta-band .bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(15,12,8,.78),rgba(15,12,8,.86)); }
.cta-band .inner{ position:relative; z-index:2; }
.cta-band h2{ color:#fff; max-width:18ch; margin-inline:auto; }
.cta-band p{ color:rgba(255,255,255,.85); }

/* ---------- Footer ---------- */
.site-footer{ background:var(--ink); color:var(--text-light-muted); }
.footer-top{ display:grid; grid-template-columns:1fr; gap:clamp(34px,4vw,56px); padding-block:clamp(56px,7vw,96px); }
@media(min-width:820px){ .footer-top{ grid-template-columns:1.4fr 1fr 1fr; } }
.footer-brand img{ height:52px; margin-bottom:20px; }
.footer-brand p{ color:var(--text-light-muted); max-width:36ch; }
.footer-col h4{ font-family:var(--label); font-size:.8rem; letter-spacing:.18em; text-transform:uppercase; color:#fff; font-weight:500; margin-bottom:20px; }
.footer-col a,.footer-col li{ color:var(--text-light-muted); padding:7px 0; display:block; transition:color .3s, padding .3s; }
.footer-col a:hover{ color:var(--brand); padding-left:6px; }
.footer-bottom{ border-top:1px solid var(--line-dark); padding-block:26px; display:flex; flex-wrap:wrap; gap:14px; justify-content:space-between; align-items:center; font-size:.82rem; }
.footer-bottom a:hover{ color:var(--brand); }
.footer-socials{ display:flex; gap:10px; }
.footer-socials a{ width:40px; height:40px; border-radius:50%; border:1px solid var(--line-dark); display:flex; align-items:center; justify-content:center; color:var(--text-light-muted); transition:.4s var(--ease); }
.footer-socials a:hover{ background:var(--brand); color:#fff; border-color:var(--brand); transform:translateY(-3px); }

/* back to top + scroll progress */
.scroll-progress{ position:fixed; top:0; left:0; height:3px; width:0; background:var(--brand); z-index:100; transition:width .1s linear; }
.to-top{ position:fixed; right:24px; bottom:24px; z-index:80; width:50px; height:50px; border-radius:50%; background:var(--ink); color:#fff; display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transform:translateY(14px); transition:.45s var(--ease); border:0; }
.to-top.show{ opacity:1; pointer-events:auto; transform:none; }
.to-top:hover{ background:var(--brand); }

/* helpers */
.bg-cream2{ background:var(--cream-2); }
.bg-paper{ background:var(--paper); }
.bg-ink{ background:var(--ink); color:var(--text-light); }
.bg-ink h1,.bg-ink h2,.bg-ink h3{ color:#fff; }
.mt-0{ margin-top:0; } .mb-0{ margin-bottom:0; }
.divider{ width:60px; height:2px; background:var(--brand); margin:1.4rem 0; }
.divider.center{ margin-inline:auto; }
