/* JK Pro — shared stylesheet
   Direction A "Fresh & Trustworthy" — navy + gold, matched to logo */

@import url('https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@400;500;600;700;800&family=Space+Mono:wght@400;700&display=swap');

:root{
  --ink:oklch(0.27 0.02 260);
  --ink-soft:oklch(0.46 0.02 260);
  --paper:oklch(0.995 0.003 255);
  --line:oklch(0.90 0.008 255);
  --navy:oklch(0.42 0.11 258);
  --navy-deep:oklch(0.31 0.085 260);
  --gold:oklch(0.74 0.12 82);
  --gold-ink:oklch(0.55 0.09 76);
  --tint:oklch(0.96 0.018 255);
  --maxw:1200px;
  --pad:64px;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--paper);color:var(--ink);
  font-family:'Hanken Grotesk',system-ui,sans-serif;
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);}
.section{padding:72px 0;}
.kicker{font-family:'Space Mono',monospace;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-ink);font-weight:700;}
h1,h2,h3{letter-spacing:-0.02em;line-height:1.1;}
h1{font-size:55px;line-height:1.05;letter-spacing:-0.025em;font-weight:800;text-wrap:balance;}
h2{font-size:38px;font-weight:800;}
h3{font-size:22px;font-weight:800;letter-spacing:-0.01em;}
.lead{font-size:19px;color:var(--ink-soft);}
em{font-style:normal;color:var(--navy);}

/* buttons */
.btn{font-family:inherit;font-weight:600;font-size:15.5px;border-radius:10px;padding:12px 22px;border:none;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:transform .12s ease,filter .12s ease;}
.btn:hover{filter:brightness(0.94);}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--navy);color:#fff;}
.btn-gold{background:var(--gold);color:var(--navy-deep);}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line);}

/* nav */
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px var(--pad);border-bottom:1px solid var(--line);position:sticky;top:0;background:rgba(255,255,255,.88);backdrop-filter:saturate(140%) blur(10px);z-index:50;}
.nav .logo{height:46px;width:auto;}
.navlinks{display:flex;gap:34px;align-items:center;font-weight:500;font-size:15.5px;color:var(--ink-soft);list-style:none;}
.navlinks a{text-decoration:none;padding:4px 0;border-bottom:2px solid transparent;}
.navlinks a:hover,.navlinks a.active{color:var(--ink);border-bottom-color:var(--gold);}
.nav-right{display:flex;align-items:center;gap:18px;}
.nav-toggle{display:none;background:none;border:1px solid var(--line);border-radius:9px;width:42px;height:42px;cursor:pointer;align-items:center;justify-content:center;}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:"";display:block;width:18px;height:2px;background:var(--ink);position:relative;transition:.2s;}
.nav-toggle span::before{position:absolute;top:-6px;}
.nav-toggle span::after{position:absolute;top:6px;}

/* hero */
.hero{display:grid;grid-template-columns:1.05fr 0.95fr;gap:56px;align-items:center;padding:76px 0 64px;}
.pill{display:inline-flex;align-items:center;gap:8px;background:var(--tint);color:var(--navy);font-weight:600;font-size:13.5px;padding:7px 14px;border-radius:999px;}
.pill .dot{width:7px;height:7px;border-radius:50%;background:var(--gold);}
.hero h1{margin:22px 0 20px;}
.hero .lead{max-width:30em;}
.cta-row{display:flex;gap:14px;margin-top:32px;align-items:center;flex-wrap:wrap;}
.media{border-radius:14px;overflow:hidden;border:1px solid var(--line);}
.media img{width:100%;height:100%;object-fit:cover;}
.heroimg{height:430px;}
.trust{display:flex;gap:36px;margin-top:40px;padding-top:28px;border-top:1px solid var(--line);flex-wrap:wrap;}
.trust .n{font-size:30px;font-weight:800;letter-spacing:-0.02em;color:var(--navy);}
.trust .l{font-size:13.5px;color:var(--ink-soft);font-weight:500;}

/* page banner (interior pages) */
.banner{background:var(--tint);border-bottom:1px solid var(--line);}
.banner .wrap{padding-top:56px;padding-bottom:56px;}
.banner h1{font-size:46px;}
.banner .lead{max-width:34em;margin-top:14px;}
.crumbs{font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:18px;}
.crumbs a{text-decoration:none;color:var(--gold-ink);}

/* section heads */
.shead{max-width:34em;margin-bottom:44px;}
.shead h2{margin-top:12px;}
.shead p{color:var(--ink-soft);margin-top:14px;}
.center{text-align:center;margin-left:auto;margin-right:auto;}

/* service cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.card{border:1px solid var(--line);border-radius:18px;padding:30px 28px 32px;background:#fff;display:flex;flex-direction:column;transition:box-shadow .15s ease,transform .15s ease;}
.card:hover{box-shadow:0 12px 30px -18px oklch(0.31 0.085 260 / .4);transform:translateY(-3px);}
.card .cimg{height:148px;width:calc(100% + 56px);margin:-30px -28px 24px;object-fit:cover;border-radius:18px 18px 0 0;border-bottom:1px solid var(--line);background:var(--tint);}
.card .tag{font-family:'Space Mono',monospace;font-size:13px;color:var(--gold-ink);font-weight:700;}
.card h3{margin:8px 0 12px;}
.card p{color:var(--ink-soft);font-size:16px;flex:1;}
.card .more{margin-top:20px;font-weight:600;color:var(--navy);font-size:15px;text-decoration:none;display:inline-flex;gap:6px;}
.card .more:hover{gap:10px;}

/* editorial service rows (services page) */
.srow{display:grid;grid-template-columns:0.95fr 1.05fr;gap:56px;align-items:center;padding:54px 0;border-top:1px solid var(--line);}
.srow.flip .txt{order:2;}
.srow .simg{height:340px;border-radius:14px;}
.srow .num{font-family:'Space Mono',monospace;font-size:14px;color:var(--gold-ink);font-weight:700;letter-spacing:.06em;}
.srow h2{margin:8px 0 16px;}
.srow p{color:var(--ink-soft);max-width:34em;}
.srow ul{list-style:none;margin-top:22px;display:grid;gap:11px;}
.srow li{display:flex;gap:12px;align-items:flex-start;font-weight:500;font-size:16px;}
.check{width:21px;height:21px;flex:0 0 21px;color:var(--navy);margin-top:2px;}

/* why band */
.why{background:var(--tint);}
.whygrid{display:grid;grid-template-columns:0.9fr 1.1fr;gap:56px;align-items:center;}
_reasons{display:grid;grid-template-columns:1fr 1fr;gap:18px 28px;}
_reason{display:flex;gap:13px;align-items:flex-start;font-weight:600;font-size:16.5px;}
.whyimg{height:340px;}

/* values (about) */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.value{border:1px solid var(--line);border-radius:16px;padding:28px;background:#fff;}
.value .vn{font-family:'Space Mono',monospace;font-size:13px;color:var(--gold-ink);font-weight:700;}
.value h3{font-size:20px;margin:10px 0 10px;}
.value p{color:var(--ink-soft);font-size:15.5px;}

/* mission */
.mission{text-align:center;}
.mission .q{font-size:30px;line-height:1.32;font-weight:600;letter-spacing:-0.015em;max-width:21em;margin:18px auto 0;text-wrap:balance;}
.mission .q b{color:var(--navy);font-weight:800;}

/* contact */
.contact{background:var(--navy-deep);color:#fff;border-radius:26px;padding:56px 60px;display:grid;grid-template-columns:1fr 0.9fr;gap:54px;align-items:start;}
.contact h2{color:#fff;}
.contact .kicker{color:var(--gold);}
.contact .lead{color:rgba(255,255,255,.82);}
.contact .clist{list-style:none;margin-top:26px;display:grid;gap:16px;}
.contact .clist li{display:flex;gap:14px;align-items:flex-start;}
.contact .clist .ic{width:22px;height:22px;flex:0 0 22px;color:var(--gold);margin-top:2px;}
.contact .clist b{display:block;font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--gold);}
.contact .clist span{color:rgba(255,255,255,.9);}
.contact .clist a{text-decoration:none;}
.contact .clist a:hover{text-decoration:underline;}
form.quote{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:18px;padding:26px;display:grid;gap:13px;}
form.quote .hp-field{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;}
form.quote .row{display:grid;grid-template-columns:1fr 1fr;gap:13px;}
form.quote label{font-size:13px;font-weight:600;color:rgba(255,255,255,.8);display:block;margin-bottom:5px;}
form.quote input,form.quote textarea,form.quote select{width:100%;background:rgba(255,255,255,.96);border:none;border-radius:10px;padding:13px 15px;color:var(--ink);font-size:15px;font-family:inherit;}
form.quote textarea{resize:vertical;min-height:96px;}
form.quote .btn-gold{justify-content:center;padding:15px;font-size:16px;}
.formnote{font-size:13px;color:rgba(255,255,255,.6);text-align:center;}
.formstatus{font-size:14px;font-weight:600;text-align:center;padding:12px;border-radius:8px;display:none;margin-bottom:16px;}
.formstatus.ok{display:block;background:#16a34a;color:#fff;}
.formstatus.error{display:block;background:oklch(0.58 0.19 25 / .25);color:#fff;}

/* footer */
.foot{border-top:1px solid var(--line);}
.foot .wrap{display:flex;justify-content:space-between;align-items:center;gap:24px;padding-top:30px;padding-bottom:30px;flex-wrap:wrap;color:var(--ink-soft);font-size:14.5px;}
.foot .logo{height:34px;width:auto;}
.foot nav{display:flex;gap:22px;flex-wrap:wrap;}
.foot nav a{text-decoration:none;}
.foot nav a:hover{color:var(--ink);}

/* gallery */
.gallery-trust{margin-top:36px;padding-top:24px;}
.gallery-trust .n{color:var(--gold-ink);}
.gallery-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-auto-flow:dense;gap:22px;}
.gallery-card{position:relative;display:block;width:100%;background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 10px 26px -20px oklch(0.31 0.085 260 / .45);padding:0;cursor:pointer;font:inherit;transition:box-shadow .2s ease,transform .2s ease;}
.gallery-card:hover{box-shadow:0 16px 34px -16px oklch(0.31 0.085 260 / .5);transform:translateY(-3px);}
.gallery-card img{width:100%;height:280px;object-fit:cover;display:block;opacity:0;transition:transform .35s ease,opacity .4s ease;}
.gallery-card img.is-loaded{opacity:1;}
.gallery-card:hover img{transform:scale(1.06);}
.gallery-card.is-featured{grid-column:span 2;grid-row:span 2;}
.gallery-card.is-featured img{height:100%;min-height:380px;}
.gallery-card .gallery-zoom{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,oklch(0.27 0.02 260 / 0) 50%,oklch(0.27 0.02 260 / .55) 100%);opacity:0;transition:opacity .2s ease;}
.gallery-card:hover .gallery-zoom{opacity:1;}
.gallery-card .gallery-zoom svg{width:30px;height:30px;color:#fff;}

/* gallery CTA */
.gallery-cta-inner{align-items:center;grid-template-columns:1.3fr 0.7fr;}
.gallery-cta-inner .btn{justify-self:end;}

/* lightbox */
.lightbox{position:fixed;inset:0;background:oklch(0.15 0.01 260 / .92);display:none;align-items:center;justify-content:center;z-index:200;padding:40px;}
.lightbox.open{display:flex;}
.lightbox-figure{display:flex;flex-direction:column;align-items:center;gap:14px;}
.lightbox-img{max-width:min(90vw,1100px);max-height:80vh;object-fit:contain;border-radius:10px;box-shadow:0 20px 60px -10px rgba(0,0,0,.5);}
.lightbox-count{font-family:'Space Mono',monospace;font-size:13px;letter-spacing:.1em;color:rgba(255,255,255,.7);}
.lightbox-close{position:absolute;top:22px;right:28px;background:none;border:none;color:#fff;font-size:38px;line-height:1;cursor:pointer;}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;width:48px;height:48px;border-radius:50%;font-size:26px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease;}
.lightbox-nav:hover{background:rgba(255,255,255,.24);}
.lightbox-prev{left:24px;}
.lightbox-next{right:24px;}
@media (max-width:880px){
  .gallery-card.is-featured{grid-column:span 1;grid-row:span 1;}
  .gallery-card.is-featured img{height:280px;min-height:0;}
  .gallery-cta-inner{grid-template-columns:1fr;text-align:center;}
  .gallery-cta-inner .btn{justify-self:center;}
}
@media (max-width:600px){
  .lightbox-nav{width:40px;height:40px;font-size:22px;}
  .lightbox-prev{left:8px;}
  .lightbox-next{right:8px;}
  .lightbox-close{top:12px;right:14px;font-size:32px;}
}

/* responsive */
@media (max-width:880px){
  :root{--pad:28px;}
  h1{font-size:40px;}
  .banner h1{font-size:34px;}
  h2{font-size:30px;}
  .nav-toggle{display:flex;}
  .navlinks{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:#fff;border-bottom:1px solid var(--line);padding:8px 28px 18px;}
  .navlinks.open{display:flex;}
  .navlinks li{width:100%;border-top:1px solid var(--line);}
  .navlinks a{display:block;padding:14px 0;border-bottom:none;}
  .nav .quote-btn{display:none;}
  .hero,.whygrid,.contact,.srow,.srow.flip{grid-template-columns:1fr;gap:32px;}
  .srow.flip .txt{order:0;}
  .cards,.values,.gallery-grid{grid-template-columns:1fr;}
  .reasons{grid-template-columns:1fr;}
  .heroimg,.whyimg,.srow .simg{height:260px;}
  .contact{padding:36px 26px;}
  form.quote .row{grid-template-columns:1fr;}
  .mission .q{font-size:24px;}
}
