:root{
  --green-1:#34A762; --green-2:#129949; --green-3:#067D36; --green-4:#006429; --green-5:#00461C;
  --amber-1:#EFD4A7; --amber-2:#D4A362; --amber-3:#8E5A17; --amber-4:#654110; --amber-5:#4A2E0B; 
  --magenta-1:#AF368B; --magenta-2:#A11376; --magenta-3:#83065E; --magenta-4:#6A004A; --magenta-5:#490033;
  --gray-1:#FFFFFF; --gray-2:#B8BCB6; --gray-3:#A7A9AC; --gray-4:#4F5557; --ink:#1A1A1A;
  --glass: rgba(255,255,255,.18); --glass-strong: rgba(255,255,255,.28); --glass-border: rgba(255,255,255,.45);

  /* NEW NEUTRAL */
  --neutral-bg:#F0EDF3;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Noto Sans',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink);
  background:var(--neutral-bg);
  line-height:1.65;
}
h1,h2,h3{font-family:'Playfair Display',serif;margin:.15em 0}
h1{font-weight:800;font-size:clamp(2rem,4.5vw,3.25rem)}
h2{font-weight:700;font-size:clamp(1.4rem,2.5vw,2rem)}
h3{font-weight:700;font-size:1.15rem}
a{color:inherit}

/* Make the HTML hidden attribute always win */
[hidden]{display:none !important}

/* HERO */
.hero{position:relative;min-height:92vh;display:grid;place-items:center;overflow:hidden}
.hero__image{position:absolute;inset:0;background:url("./assets/hero.jpg") center/cover no-repeat}
.hero__shade{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.25) 0%,rgba(0,0,0,.20) 40%,rgba(0,0,0,.12) 70%,rgba(255,255,255,0) 100%)}
.hero__content{position:relative;z-index:2;text-align:center;padding:1rem;max-width:980px;color:#fff}
.hero .lede{max-width:70ch;margin:.6rem auto 1.1rem;color:#f3f6f5}
.btn{display:inline-block;padding:.75rem 1.1rem;border-radius:.75rem;font-weight:600;text-decoration:none;transition:transform .06s,box-shadow .2s,background .2s,border-color .2s}
.btn-primary{background:var(--green-3);color:#fff}
.btn-primary:hover{background:var(--green-4)}
.btn-ghost{border:2px solid #fff;color:#fff;margin-left:.5rem}
.btn-ghost:hover{background:var(--glass-strong)}

/* NAV BOX (glass over hero) */
.nav-box{
  position:absolute;left:50%;top:18px;transform:translateX(-50%);z-index:3;
  display:flex;align-items:center;gap:.6rem;padding:.6rem .7rem;border-radius:14px;
  background:var(--glass);backdrop-filter:saturate(1.2) blur(16px);
  border:1px solid var(--glass-border);
  max-width:min(1000px,92vw);
}
.brand{display:flex;align-items:center;gap:.55rem;text-decoration:none}
.logo{display:block}
.brand-text{font-family:'Playfair Display',serif;font-weight:800;letter-spacing:.2px;color:#fff}
.site-nav{display:flex;gap:.4rem;align-items:center;margin-left:.4rem}
.nav-link{color:#fff;text-decoration:none;padding:.42rem .65rem;border-radius:.6rem;transition:background .2s}
.nav-link:hover{background:rgba(255,255,255,.14)}
.nav-link.is-active{background:var(--green-3)}
#nav-toggle{display:none}
.hamburger{display:none;cursor:pointer;margin-left:auto}
.hamburger span{display:block;width:24px;height:2px;margin:5px 0;background:#fff;border-radius:2px}

/* FEATURED (Index/About cards grid + thumbs) */
.intro{padding:2.6rem 1rem 3rem;max-width:1100px;margin:0 auto;text-align:center}
.intro-copy{max-width:80ch;margin:.2rem auto 1.3rem;color:#3b3b3b}

.cards{display:grid;gap:1.1rem;grid-template-columns:repeat(3,1fr)}
.card{
  border:1px solid rgba(0,0,0,0.06);
  border-radius:16px;
  background:#fff;
  overflow:hidden;
  text-align:left;
  padding:1rem 1rem 1.1rem;
  box-shadow:0 2px 10px rgba(0,0,0,.05);
}
.card .thumb{
  aspect-ratio:4/3;overflow:hidden;border-radius:12px;margin-bottom:.8rem;
  background:#f3f3f3;box-shadow:0 2px 8px rgba(0,0,0,.05);
}
.card .thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .25s ease}
.card .thumb:hover img{transform:scale(1.03)}
.card p{margin:.2rem 0 .7rem;color:#424242}
.card .link{color:var(--green-3);text-decoration:none;font-weight:600}
.card .link:hover{text-decoration:underline}

/* Color tones */
.card.tone-green .thumb{
  background:linear-gradient(180deg, color-mix(in srgb, var(--green-3) 18%, #fff 82%) 0%, #ffffff 100%);
  border-color:color-mix(in srgb, var(--green-4) 24%, #ffffff 76%);
}
.card.tone-amber .thumb{
  background:linear-gradient(180deg, color-mix(in srgb, var(--amber-3) 18%, #fff 82%) 0%, #ffffff 100%);
  border-color:color-mix(in srgb, var(--amber-4) 24%, #ffffff 76%);
}
.card.tone-magenta .thumb{
  background:linear-gradient(180deg, color-mix(in srgb, var(--magenta-3) 18%, #fff 82%) 0%, #ffffff 100%);
  border-color:color-mix(in srgb, var(--magenta-4) 24%, #ffffff 76%);
}
.card.tone-green{
  background:linear-gradient(180deg, color-mix(in srgb, var(--green-3) 18%, #fff 82%) 0%, #ffffff 100%);
  border-color:color-mix(in srgb, var(--green-4) 24%, #ffffff 76%);
}
.card.tone-magenta{
  background:linear-gradient(180deg, color-mix(in srgb, var(--magenta-3) 18%, #fff 82%) 0%, #ffffff 100%);
  border-color:color-mix(in srgb, var(--magenta-4) 24%, #ffffff 76%);
}
.card.tone-amber{
  background:linear-gradient(180deg, color-mix(in srgb, var(--amber-2) 18%, #fff 82%) 0%, #ffffff 100%);
  border-color:color-mix(in srgb, var(--amber-4) 24%, #ffffff 76%);
}


/* Underline accent */
.card h2{position:relative;padding-bottom:.25rem;margin-bottom:.5rem}
.card.tone-green h2::after,
.card.tone-magenta h2::after,
.card.tone-amber h2::after{content:"";position:absolute;left:0;bottom:0;width:56px;height:3px;border-radius:2px}
.card.tone-green h2::after{background:linear-gradient(90deg,var(--green-3),var(--green-2))}
.card.tone-magenta h2::after{background:linear-gradient(90deg,var(--magenta-3),var(--magenta-1))}
.card.tone-amber h2::after{background:linear-gradient(90deg,var(--amber-5),var(--amber-3))}

/* FOOTER */
.site-footer{padding:1.25rem 1rem;text-align:center;color:#555}

/* RESPONSIVE */
@media (max-width:980px){.cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width:760px){
  .brand-text{display:none}
  .site-nav{
    position:absolute;right:.6rem;top:58px;width:min(260px,86vw);
    background:var(--glass);backdrop-filter:saturate(1.2) blur(16px);
    border:1px solid var(--glass-border);border-radius:14px;padding:.5rem;
    display:none;flex-direction:column;
  }
  .nav-link{color:#1a1a1a;background:#fff;margin:.2rem 0}
  .nav-link.is-active{background:var(--green-3);color:#fff}
  .hamburger{display:block}
  #nav-toggle:checked~.site-nav{display:flex}
  .cards{grid-template-columns:1fr}
  .hero{min-height:78vh}
}

/* === PORTFOLIO DROPDOWN FIX === */
.submenu-toggle{display:none}
@media (max-width:760px){
  .submenu-toggle{
    display:inline-flex;align-items:center;justify-content:center;
    width:30px;height:30px;margin-left:.25rem;border-radius:8px;
    background:#fff;border:1px solid rgba(0,0,0,.12);cursor:pointer;
  }
  .submenu-toggle:after{
    content:"";width:0;height:0;
    border-left:6px solid transparent;border-right:6px solid transparent;
    border-top:7px solid #1a1a1a;
  }
}

/* ABOUT / SHARED */
.hero--sm{min-height:56vh}
.hero__shade--light{background:linear-gradient(180deg,rgba(0,0,0,.18)0%,rgba(0,0,0,.12)35%,rgba(255,255,255,0)85%)}
.hero__content--top{align-self:end;padding-bottom:2.5rem}
.page{padding:2.2rem 1rem 3rem}
.two-col{max-width:1100px;margin:0 auto 2.2rem;display:grid;grid-template-columns:1.1fr 1fr;gap:1.25rem;align-items:start}
.two-col--rev{grid-template-columns:1fr 1.1fr}
.about__media img,.process__media img{width:100%;height:auto;border-radius:14px;display:block;box-shadow:0 2px 10px rgba(0,0,0,.06)}
.about__media figcaption,.process__media figcaption{font-size:.85rem;color:#666;margin-top:.35rem;text-align:center}
.about__copy h2,.process__copy h2,.values h2,.montage h2{text-align:center;margin-bottom:.4rem}
.about__copy p{color:#2d2d2d}
.about__stats{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.9rem}
.pill{background:#fff;border:1px solid #eee;color:#333;padding:.45rem .6rem;border-radius:999px}
.values{max-width:1100px;margin:0 auto 2.2rem;text-align:center}
.steps{max-width:70ch;margin:.25rem auto 0;color:#2d2d2d}
.steps li{margin:.25rem 0}
.montage{max-width:1100px;margin:0 auto}
.strip{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-top:.75rem}
.strip img{width:100%;height:220px;object-fit:cover;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.05)}
@media (max-width:980px){.two-col{grid-template-columns:1fr;gap:1rem}.two-col--rev{grid-template-columns:1fr}.strip{grid-template-columns:1fr 1fr}}
@media (max-width:720px){.strip{grid-template-columns:1fr}.hero--sm{min-height:52vh}}

/* PHOTOGRAPHY GALLERY */
.hero--sm .hero__image{background-image:url("./assets/hero.jpg");background-size:cover;background-position:center}
.gallery-wrap{max-width:1200px;margin:0 auto;padding:2.2rem 1rem 3rem}
.jd-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.jd-item{aspect-ratio:3/2;overflow:hidden;border-radius:12px}
.jd-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .25s ease}
.jd-item:hover img{transform:scale(1.03)}
.jd-overlay{position:fixed;inset:0;z-index:40;display:none;align-items:center;justify-content:center;background:rgba(10,12,12,.92)}
.jd-overlay.is-open{display:flex}
.jd-frame{position:relative;max-width:min(92vw,1200px);max-height:86vh;display:flex;align-items:center;justify-content:center}
.jd-media{max-width:100%;max-height:86vh;border-radius:10px;box-shadow:0 10px 40px rgba(0,0,0,.45)}

.jd-close,.jd-prev,.jd-next{position:absolute;top:12px;width:42px;height:42px;border-radius:10px;display:grid;place-items:center;cursor:pointer;user-select:none;color:#fff;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.28);backdrop-filter:saturate(1.2) blur(8px)}
.jd-close{right:12px}
.jd-prev,.jd-next{top:50%;transform:translateY(-50%);width:48px;height:48px}
.jd-prev{left:12px}
.jd-next{right:12px}
.jd-close:hover,.jd-prev:hover,.jd-next:hover{background:rgba(255,255,255,.2)}
.jd-caption{position:absolute;left:12px;right:12px;bottom:12px;color:#fff;background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.25);backdrop-filter:saturate(1.1) blur(6px);padding:.55rem .8rem;border-radius:10px;font-size:.95rem}
@media (max-width:1100px){.jd-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.jd-grid{grid-template-columns:1fr}}

/* CONTACT */
.contact-section{padding:2.2rem 1rem 3rem}
.contact-layout{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1.2fr;gap:1.25rem;align-items:start}
.contact-head{grid-column:1 / -1;margin-bottom:1rem}
.contact-info h2{margin-top:.25rem}
.contact-cards{display:grid;grid-template-columns:1fr;gap:.6rem;margin:0 0 1rem}
.info-card{border:1px solid rgba(0,0,0,.06);border-radius:12px;padding:.75rem .9rem;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.04)}
.bullets{margin:.8rem 0 0 1.1rem;padding:0}
.contact-card form{margin:.25rem 0 0}
.row.two{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.field label{display:block;font-weight:600;margin:.15rem 0 .35rem}
.field input,.field textarea{width:100%;padding:.7rem .9rem;border:1px solid rgba(0,0,0,.12);border-radius:12px;font:inherit;background:#fff}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--green-3);box-shadow:0 0 0 3px rgba(6,125,54,.15)}
.actions{display:flex;gap:.6rem;align-items:center;margin-top:.6rem}
.form-note{margin-top:.6rem;font-size:.95rem}
.form-note.ok{color:var(--green-4)}
.form-note.err{color:#b00020}
@media (max-width:980px){.contact-layout{grid-template-columns:1fr}}
@media (max-width:560px){.row.two{grid-template-columns:1fr}}

/* MOTION PAGE */
.motion-section{max-width:1200px;margin:0 auto;padding:2.2rem 1rem 3rem}
.video-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.video-card h3{margin-top:.6rem}
.video-card p{margin:.25rem 0 0;color:#2d2d2d}
.video-thumb{width:100%;aspect-ratio:16/9;border-radius:12px;overflow:hidden;border:1px solid rgba(0,0,0,.08);background:
radial-gradient(120% 100% at 10% 10%,rgba(255,255,255,.35)0%,rgba(255,255,255,0)60%),
linear-gradient(135deg,rgba(6,125,54,.15),rgba(175,54,139,.15),rgba(232,173,72,.18));
display:grid;place-items:center;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.05);transition:transform .15s ease,box-shadow .2s ease,border-color .2s ease}
.video-thumb:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.12);border-color:rgba(0,0,0,.12)}
.video-thumb:focus{outline:none;box-shadow:0 0 0 3px rgba(6,125,54,.25)}
.play-icon{font-size:42px;line-height:1;background:rgba(0,0,0,.55);color:#fff;padding:.35rem .55rem;border-radius:12px}

/* Video modal — match photo lightbox sizing */
.vid-overlay{
  position:fixed;
  inset:0;
  z-index:60;
  background:rgba(10,12,12,.92);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:1rem;
}

/* Same max width/height behavior as .jd-frame */
.vid-frame{
  position:relative;
  max-width:min(92vw,1200px);
  max-height:86vh;
  width:100%;
  display:flex;
  flex-direction:column;
  gap:0.75rem;
}

/* Keep the video itself constrained like the photo (.jd-media) */
.vid-embed-wrap{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  max-height:86vh;
}

.vid-embed-wrap iframe{
  width:100%;
  height:100%;
  display:block;
  border-radius:10px;
  box-shadow:0 10px 40px rgba(0,0,0,.45);
}

/* Optional: space and align the “Open on Vimeo” button */
.vid-actions{
  display:flex;
  justify-content:flex-end;
}



/* Motion page responsive fixes */
@media (max-width:980px){
  .video-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width:680px){
  .video-grid {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }
}
