:root{
  --sage:#7E8F7A;
  --sage-2:#6E7F6A;
  --sage-glow:#9FB39A;
  --beige:#F3EBDD;
  --beige-2:#EFE3D1;
  --brown:#B08A6A;
  --brown-2:#C79B77;
  --ink:#1B1B1B;
  --ink-2:#2C2C2C;
  --white:#FFFFFF;
  --radius:22px;
  --shadow: 0 20px 60px rgba(27,27,27,.14);
  --shadow-soft: 0 16px 40px rgba(27,27,27,.10);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}

/* Ensure native [hidden] always wins (prevents accidental overlays) */
[hidden]{display:none !important}

body{
  margin:0;
  color:var(--ink);
  background:
    radial-gradient(1200px 600px at 18% -10%, rgba(159,179,154,.34), transparent 68%),
    radial-gradient(1000px 520px at 92% 2%, rgba(199,155,119,.26), transparent 66%),
    radial-gradient(900px 520px at 70% 110%, rgba(126,143,122,.18), transparent 60%),
    linear-gradient(180deg, #FBF7F1, #FFFFFF 58%, #F2E9DA);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  line-height:1.45;
}

/* subtle paper grain */
body:before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 20% 30%, rgba(27,27,27,.06) 0 1px, transparent 2px) 0 0/22px 22px;
  mix-blend-mode:multiply;
  opacity:.08;
}

img{max-width:100%; display:block}

.container{width:min(1120px, calc(100% - 40px)); margin:0 auto}

.skip{
  position:absolute; left:-999px; top:10px;
  padding:10px 14px; border-radius:999px;
  background:var(--ink); color:#fff; text-decoration:none;
}
.skip:focus{left:16px; z-index:9999}

.sr-only{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0}

/* Header */
.site-header{
  position:sticky; top:0; z-index:60;
  backdrop-filter:saturate(140%) blur(10px);
  background:rgba(243,235,221,.72);
  border-bottom:1px solid rgba(27,27,27,.08);
}
.header-inner{display:flex; align-items:center; justify-content:space-between; gap:18px; padding:14px 0}

.brand{display:flex; align-items:center; gap:12px; text-decoration:none; color:inherit}
.brand-mark{
  width:44px; height:44px; border-radius:14px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, rgba(126,143,122,.16), rgba(176,138,106,.12));
  border:1px solid rgba(27,27,27,.08);
}
.brand-mark svg{width:30px; height:30px}
.brand-text{display:flex; flex-direction:column; gap:1px}
.brand-name{font-family: Fraunces, serif; font-weight:600; font-size:18px; letter-spacing:.2px}
.brand-sub{font-size:12px; color:rgba(27,27,27,.66)}

.nav{display:flex; align-items:center}
.nav-links{display:flex; align-items:center; gap:18px}
.nav-links a{color:rgba(27,27,27,.84); text-decoration:none; font-weight:500; font-size:14px}
.nav-links a:hover{color:var(--ink)}
.nav-links .pill{padding:10px 14px; border-radius:999px; border:1px solid rgba(27,27,27,.14); background:rgba(255,255,255,.5)}

.nav-toggle{
  display:none;
  width:44px; height:44px;
  border-radius:14px;
  border:1px solid rgba(27,27,27,.14);
  background:rgba(255,255,255,.5);
}
.burger{display:block; width:18px; height:2px; background:var(--ink); position:relative; margin:0 auto}
.burger:before,.burger:after{content:""; position:absolute; left:0; width:18px; height:2px; background:var(--ink)}
.burger:before{top:-6px}
.burger:after{top:6px}

/* Hero */
.hero{position:relative; padding:46px 0 34px}
.hero-bg{
  position:absolute; inset:0;
  background:
    radial-gradient(1200px 700px at 15% 0%, rgba(126,143,122,.26), transparent 60%),
    radial-gradient(900px 560px at 92% 30%, rgba(176,138,106,.18), transparent 65%),
    linear-gradient(180deg, rgba(243,235,221,.8), rgba(243,235,221,0));
  pointer-events:none;
}
.hero-inner{display:grid; grid-template-columns: 1.12fr .88fr; gap:26px; align-items:stretch}

.eyebrow{
  display:inline-flex; gap:10px; align-items:center;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.58);
  border:1px solid rgba(27,27,27,.10);
  font-size:12px;
  color:rgba(27,27,27,.72);
  letter-spacing:.12em;
  text-transform:uppercase;
}

h1,h2,h3{margin:0; font-family: Fraunces, serif}
.hero h1{margin-top:14px; font-size: clamp(34px, 4.4vw, 56px); line-height:1.02; letter-spacing:-.02em}
.hero .accent{
  display:block;
  background: linear-gradient(90deg, var(--sage), var(--brown-2));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.lead{font-size:16px; color:rgba(27,27,27,.76); max-width:56ch; margin-top:14px}

.hero-actions{display:flex; flex-wrap:wrap; gap:12px; margin-top:18px}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px;
  padding:12px 16px;
  border-radius:999px;
  border:1px solid rgba(27,27,27,.14);
  text-decoration:none;
  color:var(--ink);
  font-weight:600;
  font-size:14px;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
}

.btn.primary{
  background: linear-gradient(135deg, rgba(126,143,122,.95), rgba(199,155,119,.92));
  color:#fff;
  border:1px solid rgba(255,255,255,.35);
  box-shadow: 0 18px 50px rgba(126,143,122,.20);
}
.btn.primary:hover{transform:translateY(-1px); filter:saturate(1.06) brightness(1.02)}
.btn.ghost:hover{transform:translateY(-1px)}

/* Transition band */
.transition{padding:18px 0 6px; margin-top:-10px}
.transition-line{
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(126,143,122,.55), rgba(199,155,119,.55), transparent);
}
.transition-note{
  margin-top:10px;
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(27,27,27,.55);
}

/* Pigeon flight overlay */
.pigeon-flight{
  position:fixed;
  left:-260px;
  top:22vh;
  z-index:40;
  width:min(260px, 46vw);
  color:rgba(126,143,122,.62);
  opacity:0;
  transform:translate3d(0,0,0) rotate(-2deg);
  pointer-events:none;
}
.pigeon-flight svg{width:100%; height:auto; filter:drop-shadow(0 10px 20px rgba(27,27,27,.10))}
.pigeon-flight.fly{
  opacity:1;
  animation:pigeon-fly 4.2s ease-in-out both;
}
@keyframes pigeon-fly{
  0%{transform:translateX(-40px) translateY(0) rotate(-2deg)}
  30%{transform:translateX(35vw) translateY(-2.2vh) rotate(1deg)}
  70%{transform:translateX(70vw) translateY(1.6vh) rotate(-1deg)}
  100%{transform:translateX(120vw) translateY(-1vh) rotate(2deg); opacity:0}
}

/* Stick insect "walker" */
#critter-layer{position:fixed; inset:0; pointer-events:none; z-index:45}
.critter{
  position:absolute;
  left:-80px;
  width:68px;
  color:rgba(126,143,122,.52);
  opacity:0;
  will-change:transform;
  filter:drop-shadow(0 12px 20px rgba(27,27,27,.10));
}
.critter.run{
  opacity:.75;
  animation:critter-walk var(--dur, 9s) linear both;
}
.critter svg{width:100%; height:auto}
@keyframes critter-walk{
  0%{transform:translateX(-90px) translateY(0) rotate(-1deg)}
  100%{transform:translateX(calc(100vw + 120px)) translateY(0) rotate(1deg); opacity:0}
}

@media (prefers-reduced-motion: reduce){
  .pigeon-flight, .critter{display:none !important}
  *{scroll-behavior:auto}
}

.btn:active{transform: translateY(0)}
.btn.ghost{background:rgba(255,255,255,.62)}

.inline{display:inline-flex; gap:8px; align-items:center; color:var(--ink); text-decoration:none; font-weight:600}
.inline:hover{text-decoration:underline}

.trust{margin-top:22px; display:grid; grid-template-columns: repeat(3, 1fr); gap:12px}
.trust-item{
  border-radius:18px;
  border:1px solid rgba(27,27,27,.10);
  background:rgba(255,255,255,.55);
  padding:12px 12px;
}
.trust-title{display:block; font-size:12px; color:rgba(27,27,27,.62)}
.trust-value{display:block; font-weight:600; margin-top:2px}

.hero-card{
  border-radius:var(--radius);
  overflow:hidden;
  background: linear-gradient(180deg, rgba(255,255,255,.72), rgba(255,255,255,.44));
  border:1px solid rgba(27,27,27,.10);
  box-shadow: var(--shadow);
  display:flex; flex-direction:column;
  position:relative;
}
.hero-card:before{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(600px 220px at 20% 0%, rgba(126,143,122,.24), transparent 55%),
              radial-gradient(500px 220px at 90% 50%, rgba(176,138,106,.22), transparent 58%);
  pointer-events:none;
}
.card-top{display:flex; gap:10px; padding:14px 14px 10px; position:relative; z-index:1}
.chip{font-size:12px; font-weight:700; padding:7px 10px; border-radius:999px; background:rgba(126,143,122,.14); border:1px solid rgba(126,143,122,.20)}
.chip.muted{background:rgba(176,138,106,.14); border-color: rgba(176,138,106,.20)}
.hero-figure{margin:0; position:relative; z-index:1}
.hero-figure img{width:100%; height:340px; object-fit:cover; filter:saturate(1.07) contrast(1.06)}
.card-bottom{padding:14px 14px 16px; position:relative; z-index:1}
.card-note{margin:0 0 10px; color:rgba(27,27,27,.74)}

.scroll-hint{position:absolute; left:50%; bottom:16px; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:8px; opacity:.7}
.scroll-hint .dot{width:8px; height:8px; border-radius:999px; background:var(--ink); animation:bob 1.4s ease-in-out infinite}
.scroll-hint .line{width:1px; height:30px; background:rgba(27,27,27,.28)}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}

/* Sections */
.section{padding:68px 0}
.section-head{max-width:72ch}
.section-head h2{font-size: clamp(28px, 3.1vw, 40px); line-height:1.05; letter-spacing:-.02em}
.section-head p{margin:12px 0 0; color:rgba(27,27,27,.74)}
.section-head.split{display:flex; justify-content:space-between; align-items:flex-end; gap:16px; max-width:unset}
.section-actions{display:flex; gap:12px; align-items:center}

.grid{display:grid; gap:14px}
.features{grid-template-columns: repeat(3, 1fr); margin-top:18px}
.feature{
  border-radius:var(--radius);
  background:rgba(255,255,255,.62);
  border:1px solid rgba(27,27,27,.10);
  padding:18px 18px;
  box-shadow: var(--shadow-soft);
}
.feature h3{font-size:18px}
.feature p{margin:10px 0 0; color:rgba(27,27,27,.74)}

/* Work */
.work{padding-top:34px}
.masonry{margin-top:20px; columns: 3; column-gap:14px}
.tile{
  width:100%;
  display:block;
  border:0;
  padding:0;
  margin:0 0 14px;
  background:transparent;
  text-align:left;
  border-radius:var(--radius);
  overflow:hidden;
  cursor:pointer;
  position:relative;
  box-shadow: var(--shadow-soft);
}
.tile img{width:100%; height:auto; transform:scale(1.02); filter:saturate(1.04) contrast(1.04); transition: transform .35s ease, filter .35s ease}
.tile:after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(0,0,0,.55));
  opacity:.92;
}
.tile-cap{
  position:absolute; left:14px; right:14px; bottom:12px;
  color:#fff;
  font-weight:700;
  z-index:2;
  text-shadow: 0 10px 30px rgba(0,0,0,.35);
}
.tile:hover img{transform:scale(1.06); filter:saturate(1.08) contrast(1.06)}

.note{
  margin-top:14px;
  border-radius:var(--radius);
  background: linear-gradient(135deg, rgba(126,143,122,.16), rgba(176,138,106,.12));
  border:1px solid rgba(27,27,27,.10);
  padding:16px 18px;
}
.note p{margin:0; color:rgba(27,27,27,.78)}

/* About */
.about-wrap{display:grid; grid-template-columns: 1.1fr .9fr; gap:16px; align-items:stretch}
.about-card{
  border-radius: calc(var(--radius) + 6px);
  background:rgba(255,255,255,.62);
  border:1px solid rgba(27,27,27,.10);
  box-shadow: var(--shadow);
  padding:22px 22px;
}
.about-card h2{font-size: clamp(26px, 2.8vw, 36px)}
.about-points{margin-top:14px; display:grid; gap:10px}
.point{display:flex; gap:10px; align-items:flex-start}
.point .dot{width:10px; height:10px; border-radius:999px; margin-top:6px; background: linear-gradient(135deg, var(--sage), var(--brown))}
.point p{margin:0; color:rgba(27,27,27,.74)}
.about-actions{margin-top:16px; display:flex; flex-wrap:wrap; gap:12px}

.about-quote{
  border-radius: calc(var(--radius) + 6px);
  background: radial-gradient(600px 280px at 10% 0%, rgba(126,143,122,.18), transparent 60%),
              radial-gradient(600px 280px at 90% 100%, rgba(176,138,106,.16), transparent 60%),
              rgba(255,255,255,.58);
  border:1px solid rgba(27,27,27,.10);
  box-shadow: var(--shadow-soft);
  overflow:hidden;
  position:relative;
}
.quote-inner{padding:22px 22px; height:100%; display:flex; flex-direction:column; justify-content:space-between; gap:18px}
.quote{margin:0; font-family: Fraunces, serif; font-size:22px; line-height:1.15}
.quote-by{margin:0; font-weight:700; color:rgba(27,27,27,.70)}
.stamp{width:140px; height:140px; color:rgba(27,27,27,.60); align-self:flex-end; opacity:.9}
.stamp text{font-family: Inter, sans-serif; font-size:13px; letter-spacing:.2em; fill: currentColor}

/* Studio */
.studio-grid{grid-template-columns: repeat(3, 1fr); margin-top:18px}
.panel{
  border-radius:var(--radius);
  background:rgba(255,255,255,.62);
  border:1px solid rgba(27,27,27,.10);
  box-shadow: var(--shadow-soft);
  padding:18px 18px;
}
.panel h3{font-size:18px}
.panel p{margin:10px 0 0; color:rgba(27,27,27,.74)}
.bullets{margin:10px 0 0; padding-left:18px; color:rgba(27,27,27,.74)}
.bullets li{margin:6px 0}
.muted{color:rgba(27,27,27,.62)}
.small{font-size:12px}

/* Contact */
.contact-card{
  border-radius: calc(var(--radius) + 10px);
  overflow:hidden;
  border:1px solid rgba(27,27,27,.10);
  background:rgba(255,255,255,.62);
  box-shadow: var(--shadow);
  display:grid;
  grid-template-columns: 1.1fr .9fr;
}
.contact-copy{padding:24px 22px}
.contact-visual{
  position:relative;
  background: radial-gradient(650px 320px at 20% 0%, rgba(126,143,122,.22), transparent 62%),
              radial-gradient(650px 320px at 92% 70%, rgba(176,138,106,.20), transparent 62%),
              linear-gradient(180deg, rgba(243,235,221,.7), rgba(255,255,255,.5));
}
.contact-figure{position:absolute; inset:16px; margin:0; border-radius: calc(var(--radius) + 4px); overflow:hidden; box-shadow: var(--shadow-soft)}
.contact-figure img{width:100%; height:100%; object-fit:cover; filter:saturate(1.07) contrast(1.06)}
.leaf{
  position:absolute; width:220px; height:220px; left:-90px; top:-70px;
  background: conic-gradient(from 180deg, rgba(126,143,122,.34), rgba(176,138,106,.22), rgba(126,143,122,.34));
  border-radius: 60% 40% 60% 40% / 55% 45% 55% 45%;
  filter: blur(.2px);
  opacity:.55;
}
.leaf.two{left:auto; right:-110px; top:auto; bottom:-90px; width:260px; height:260px; opacity:.42}

.contact-actions{display:flex; flex-wrap:wrap; gap:12px; margin-top:18px}
.mini{margin-top:18px; display:grid; grid-template-columns: repeat(3,1fr); gap:12px}
.mini-item{padding:12px 12px; border-radius:18px; border:1px solid rgba(27,27,27,.10); background:rgba(255,255,255,.55)}
.mini-k{display:block; font-size:12px; color:rgba(27,27,27,.62)}
.mini-v{display:block; font-weight:700; margin-top:2px}

/* Footer */
.footer{padding:40px 0 20px; border-top:1px solid rgba(27,27,27,.08)}
.footer-inner{display:flex; justify-content:space-between; align-items:flex-start; gap:16px}
.footer-brand{margin:0; font-family: Fraunces, serif; font-weight:600; font-size:18px}
.footer-links{display:flex; gap:14px; flex-wrap:wrap}
.footer-links a{color:rgba(27,27,27,.74); text-decoration:none; font-weight:600}
.footer-links a:hover{text-decoration:underline}
.footer-bottom{margin-top:10px}

/* Lightbox */
.lightbox{
  position:fixed; inset:0; z-index:100;
  background:rgba(10,10,10,.76);
  display:grid; place-items:center;
  padding:18px;
}
.lightbox-img{
  max-width:min(980px, 100%);
  max-height: 82vh;
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.14);
  box-shadow: 0 30px 90px rgba(0,0,0,.5);
}
.lightbox-close{
  position:absolute; top:14px; right:14px;
  width:46px; height:46px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.10);
  color:#fff;
  font-size:26px;
  cursor:pointer;
}
.lightbox-close:hover{background:rgba(255,255,255,.16)}

/* Reveal */
.reveal{opacity:0; transform:translateY(10px); filter:blur(2px); transition: opacity .7s ease, transform .7s ease, filter .7s ease; transition-delay: var(--delay, 0ms)}
.reveal.is-in{opacity:1; transform:translateY(0); filter:blur(0)}

/* Responsive */
@media (max-width: 980px){
  .hero-inner{grid-template-columns:1fr; gap:16px}
  .hero-figure img{height:320px}
  .trust{grid-template-columns:1fr;}
  .features{grid-template-columns:1fr}
  .about-wrap{grid-template-columns:1fr}
  .studio-grid{grid-template-columns:1fr}
  .contact-card{grid-template-columns:1fr}
  .contact-visual{min-height:320px}
  .masonry{columns:2}
}
@media (max-width: 640px){
  .header-inner{padding:12px 0}
  .brand-sub{display:none}
  .nav-toggle{display:inline-flex; align-items:center; justify-content:center}
  .nav-links{
    position:absolute; right:20px; top:66px;
    background:rgba(243,235,221,.96);
    border:1px solid rgba(27,27,27,.10);
    border-radius: 18px;
    box-shadow: var(--shadow);
    padding:10px;
    display:none;
    flex-direction:column;
    align-items:stretch;
    min-width: 220px;
    gap:8px;
  }
  .nav-links a{padding:10px 12px; border-radius:14px}
  .nav-links a:hover{background:rgba(255,255,255,.6)}
  .nav-links .pill{background:rgba(255,255,255,.6)}
  .nav-links.is-open{display:flex}

  .hero{padding-top:26px}
  .section{padding:52px 0}
  .masonry{columns:1}
  .mini{grid-template-columns:1fr}
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .reveal{transition:none}
  .scroll-hint .dot{animation:none}
  .btn{transition:none}
}
