/* =====================================================================
   JB-Consulting — landing / site chrome styling
   Ported from the approved HTML mockup. Component (class) selectors are
   left global because the names are unique to this design; bare-element
   selectors are scoped to .jb-head / .jb-lp / .jb-foot so they never leak
   into the WP admin bar, the block editor, or other pages.
   ===================================================================== */

:root{
  --ink:#191919;
  --ink-2:#222222;
  --ink-soft:#2b2b2b;
  --paper:#ffffff;
  --paper-2:#f4f3ef;
  --paper-3:#ecebe6;
  --yellow:#f7cf2a;
  --yellow-deep:#e3b800;
  --muted:#6b6b66;
  --muted-light:#a4a39c;
  --line:#e5e4de;
  --display:"Bricolage Grotesque",sans-serif;
  --body:"Hanken Grotesk",sans-serif;
  --maxw:1140px;
  --r:18px;
}

/* Global typography (cohesive across the whole site) */
body{font-family:var(--body);color:var(--ink);-webkit-font-smoothing:antialiased}
html{scroll-behavior:smooth}

/* Scoped reset so our containers behave like the standalone mockup */
.jb-head,.jb-lp,.jb-foot{box-sizing:border-box}
.jb-head *,.jb-lp *,.jb-foot *{margin:0;padding:0;box-sizing:border-box}
.jb-lp{line-height:1.6;color:var(--ink);background:var(--paper)}
.jb-head h1,.jb-head h2,.jb-head h3,.jb-head h4,
.jb-lp h1,.jb-lp h2,.jb-lp h3,.jb-lp h4,
.jb-foot h1,.jb-foot h2,.jb-foot h3,.jb-foot h4{
  font-family:var(--display);font-weight:700;line-height:1.04;letter-spacing:-.02em;color:var(--ink);
}
.jb-head a,.jb-lp a,.jb-foot a{color:inherit;text-decoration:none}

.jb-lp .wrap,.jb-head .wrap,.jb-foot .wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

.eyebrow{
  font-family:var(--body);font-weight:700;font-size:12.5px;
  letter-spacing:.22em;text-transform:uppercase;color:var(--yellow-deep);
}
.eyebrow.on-dark{color:var(--yellow)}

/* buttons */
.jb-head .btn,.jb-lp .btn,.jb-foot .btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--body);font-weight:700;font-size:15.5px;
  padding:14px 26px;border-radius:12px;cursor:pointer;border:none;
  transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s,background .2s,color .2s;
}
.jb-head .btn-primary,.jb-lp .btn-primary,.jb-foot .btn-primary{background:var(--yellow);color:var(--ink)}
.jb-head .btn-primary:hover,.jb-lp .btn-primary:hover,.jb-foot .btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 28px -12px rgba(227,184,0,.9);color:var(--ink)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.btn-ghost-light{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.35)}
.btn-ghost-light:hover{background:#fff;color:var(--ink);transform:translateY(-2px)}
.btn .arrow{transition:transform .25s}
.btn:hover .arrow{transform:translateX(4px)}

/* header — sticky lives on the template-part wrapper so it sticks
   across the whole page, not just within its own height */
.jb-headwrap{position:sticky;top:0;z-index:50}
.admin-bar .jb-headwrap{top:32px}
.jb-head{
  display:block;
  background:rgba(255,255,255,.82);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.jb-head .nav{display:flex;align-items:center;justify-content:space-between;height:92px}
.jb-head .brand{display:flex;align-items:center}
.jb-head .brand-logo{height:66px;width:auto;display:block}
@media(max-width:600px){.jb-head .nav{height:76px}.jb-head .brand-logo{height:54px}}
.jb-head .nav-links{display:flex;align-items:center;gap:30px}
.jb-head .nav-links a{font-size:15px;font-weight:500;color:var(--ink-soft);transition:color .2s;position:relative}
.jb-head .nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:2px;background:var(--yellow-deep);transition:width .25s}
.jb-head .nav-links a:hover{color:var(--ink)}
.jb-head .nav-links a:hover::after{width:100%}
.jb-head .nav-cta{display:flex;align-items:center;gap:14px}
.jb-head .menu-btn{display:none;background:none;border:none;cursor:pointer;color:var(--ink)}

/* hero */
.jb-lp .hero{
  position:relative;background:var(--ink);color:#fff;overflow:hidden;
  padding:118px 0 0;isolation:isolate;
}
/* background video (sits behind the scrim + content); ink bg shows as fallback */
.jb-lp .hero-video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;z-index:0;border:0;pointer-events:none;
  opacity:.2;
}
.jb-lp .hero::before{
  content:"";position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(70% 62% at 50% 40%,rgba(18,18,18,.28) 0%,transparent 72%),
    linear-gradient(180deg,rgba(18,18,18,.12) 0%,rgba(18,18,18,.28) 100%),
    radial-gradient(900px 460px at 78% -8%,rgba(247,207,42,.14),transparent 60%),
    radial-gradient(700px 500px at 8% 110%,rgba(247,207,42,.07),transparent 55%);
  pointer-events:none;
}
.jb-lp .hero .grain{z-index:1}
.jb-lp .hero > .wrap{position:relative;z-index:2}
/* keep text crisp now that the scrim is lighter */
.jb-lp .hero h1,.jb-lp .hero p.lede,.jb-lp .hero .eyebrow{text-shadow:0 2px 18px rgba(0,0,0,.45)}
/* respect reduced-motion: drop the video, keep the dark hero */
@media(prefers-reduced-motion:reduce){
  .jb-lp .hero-video{display:none}
}
.jb-lp .grain{
  position:absolute;inset:0;opacity:.05;pointer-events:none;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)'/%3E%3C/svg%3E");
}
.jb-lp .hero-inner{position:relative;text-align:center;max-width:840px;margin:0 auto}
.jb-lp .hero .eyebrow{display:block;margin-bottom:22px}
.jb-lp .hero h1{
  font-size:clamp(46px,8vw,92px);font-weight:800;color:#fff;
  letter-spacing:-.035em;margin-bottom:24px;
}
.jb-lp .hero h1 .y{color:var(--yellow)}
.jb-lp .hero p.lede{
  font-size:clamp(17px,2.1vw,21px);color:#c9c8c2;max-width:620px;
  margin:0 auto 38px;line-height:1.55;
}
.jb-lp .hero-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.jb-lp .stats{
  position:relative;margin-top:84px;
  border-top:1px solid rgba(255,255,255,.1);
  display:grid;grid-template-columns:repeat(2,1fr);
}
.jb-lp .stat{padding:40px 18px;text-align:center;border-right:1px solid rgba(255,255,255,.08)}
.jb-lp .stat:last-child{border-right:none}
.jb-lp .stat .num{font-family:var(--display);font-weight:800;font-size:clamp(38px,5vw,54px);color:var(--yellow);line-height:1;letter-spacing:-.03em}
.jb-lp .stat .lbl{font-size:13.5px;color:#9b9a94;margin-top:12px;line-height:1.4}

/* generic section */
.jb-lp section{padding:104px 0}
.jb-lp .sec-head{text-align:center;max-width:680px;margin:0 auto 58px}
.jb-lp .sec-head .eyebrow{display:block;margin-bottom:16px}
.jb-lp .sec-head h2{font-size:clamp(34px,5vw,52px);font-weight:700}
.jb-lp .sec-head p{color:var(--muted);font-size:18px;margin-top:16px}

/* differentiator cards */
.jb-lp .diff-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.jb-lp .diff-card{
  background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);
  padding:34px 30px;transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s,border-color .3s;
}
.jb-lp .diff-num{font-family:var(--display);font-weight:800;font-size:15px;color:var(--yellow-deep);margin-bottom:18px;letter-spacing:.02em}
.jb-lp .diff-card h3{font-size:22px;margin-bottom:14px;font-weight:700}
.jb-lp .diff-card p{color:var(--muted);font-size:15.5px}

/* why us split */
.jb-lp .why{background:var(--paper-2)}
.jb-lp .why-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.jb-lp .why h2{font-size:clamp(36px,4.6vw,54px);font-weight:700;margin:18px 0 22px}
.jb-lp .why .eyebrow{display:block}
.jb-lp .why p.body{color:var(--muted);font-size:17px;max-width:480px;margin-bottom:30px}
.jb-lp .panel{
  background:var(--ink);color:#fff;border-radius:22px;padding:42px 40px;
  position:relative;overflow:hidden;
}
.jb-lp .panel::before{content:"";position:absolute;top:-40px;right:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(247,207,42,.18),transparent 70%)}
.jb-lp .panel h3{color:var(--yellow);font-size:22px;margin-bottom:24px;position:relative}
.jb-lp .panel ul{list-style:none;position:relative}
.jb-lp .panel li{display:flex;gap:14px;align-items:flex-start;padding:13px 0;font-size:16px;color:#ddd;border-bottom:1px solid rgba(255,255,255,.08)}
.jb-lp .panel li:last-child{border-bottom:none}
.jb-lp .panel li svg{flex-shrink:0;margin-top:3px}

/* process */
.jb-lp .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.jb-lp .step{position:relative;padding-top:30px}
.jb-lp .step::before{content:"";position:absolute;top:0;left:0;right:14px;height:3px;background:var(--paper-3);border-radius:3px}
.jb-lp .step.is-on::before{background:var(--yellow)}
.jb-lp .step .snum{font-family:var(--display);font-weight:800;font-size:42px;color:var(--yellow-deep);line-height:1;letter-spacing:-.04em}
.jb-lp .step h3{font-size:19px;margin:14px 0 12px;font-weight:700;line-height:1.15}
.jb-lp .step p{color:var(--muted);font-size:15px}

/* services */
.jb-lp .services{background:var(--ink);color:#fff}
.jb-lp .services .sec-head h2{color:#fff}
.jb-lp .services .sec-head p{color:#a09f99}
.jb-lp .svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:48px}
.jb-lp .svc-card{
  display:flex;flex-direction:column;color:inherit;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r);padding:34px 30px;transition:transform .3s cubic-bezier(.2,.8,.2,1),background .3s,border-color .3s;
}
a.svc-card{cursor:pointer}
.jb-lp .svc-card:hover{transform:translateY(-6px);background:rgba(255,255,255,.07);border-color:rgba(247,207,42,.4)}
.jb-lp .svc-more{margin-top:auto;padding-top:18px;color:var(--yellow);font-weight:600;font-size:14.5px;display:inline-flex;align-items:center;gap:6px}
.jb-lp .svc-more .arrow{transition:transform .25s}
.jb-lp .svc-card:hover .svc-more .arrow{transform:translateX(4px)}
.jb-lp .svc-ico{
  width:54px;height:54px;border-radius:14px;background:rgba(247,207,42,.14);
  display:grid;place-items:center;margin-bottom:22px;color:var(--yellow);
}
.jb-lp .svc-ico svg{width:27px;height:27px}
.jb-lp .svc-card h3{color:#fff;font-size:22px;margin-bottom:13px;font-weight:700}
.jb-lp .svc-card p{color:#b3b2ac;font-size:15.5px}
.jb-lp .svc-cta{text-align:center}

/* testimonials */
.jb-lp .tg{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:48px}
.jb-lp .quote{
  background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);
  padding:34px 30px;display:flex;flex-direction:column;
}
.jb-lp .quote .mark{font-family:var(--display);font-weight:800;font-size:54px;color:var(--yellow);line-height:.6;height:30px}
.jb-lp .quote p{font-style:italic;color:var(--ink-soft);font-size:16px;margin-bottom:24px;flex:1}
.jb-lp .quote .who{font-weight:700;font-size:15px}
.jb-lp .quote .role{color:var(--muted);font-size:14px;margin-top:2px}
.jb-lp .t-cta{text-align:center}

/* final cta */
.jb-lp .final{padding:104px 0}
.jb-lp .final-box{
  background:var(--ink);color:#fff;border-radius:26px;padding:80px 40px;text-align:center;
  position:relative;overflow:hidden;
}
.jb-lp .final-box::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 360px at 50% -20%,rgba(247,207,42,.16),transparent 60%)}
.jb-lp .final-box h2{position:relative;color:#fff;font-size:clamp(34px,5vw,56px);font-weight:800;letter-spacing:-.03em}
.jb-lp .final-box p{position:relative;color:#c9c8c2;font-size:18px;margin:18px auto 34px;max-width:480px}
.jb-lp .final-box .btn{position:relative}

/* footer */
.jb-foot{background:var(--ink);color:#fff;padding:74px 0 0}
.jb-foot .foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1.2fr;gap:48px;padding-bottom:54px}
.jb-foot .foot-brand .brand-name{color:#fff;font-size:22px;font-family:var(--display);font-weight:800}
.jb-foot .foot-brand .yc{color:var(--yellow);font-weight:700;font-size:15px;margin:8px 0 18px;font-family:var(--display)}
.jb-foot .foot-brand p{color:#a3a29c;font-size:15px;max-width:330px;line-height:1.6}
.jb-foot .foot-col h4{color:var(--yellow);font-size:12.5px;letter-spacing:.2em;text-transform:uppercase;font-family:var(--body);font-weight:700;margin-bottom:20px}
.jb-foot .foot-col ul{list-style:none}
.jb-foot .foot-col li{margin-bottom:13px}
.jb-foot .foot-col a{color:#c2c1bb;font-size:15px;transition:color .2s}
.jb-foot .foot-col a:hover{color:var(--yellow)}
.jb-foot .contact-row{display:flex;align-items:center;gap:11px;margin-bottom:13px;color:#c2c1bb;font-size:15px}
.jb-foot .contact-row svg{color:var(--yellow);flex-shrink:0}
.jb-foot .contact-row a:hover{color:var(--yellow)}
.jb-foot .foot-col .btn{margin-top:8px}
.jb-foot .foot-col a.btn-primary,.jb-foot .foot-col a.btn-primary:hover{color:var(--ink)}
.jb-foot .foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding:24px 0;text-align:center;color:#88877f;font-size:13.5px}

/* =====================================================================
   Inner page components (Services / About / Testimonials / Team / Contact)
   ===================================================================== */

/* slim dark hero for inner pages */
.jb-lp .page-hero{position:relative;background:var(--ink);color:#fff;overflow:hidden;padding:142px 0 86px;text-align:center}
.jb-lp .page-hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(820px 420px at 78% -20%,rgba(247,207,42,.16),transparent 60%),radial-gradient(640px 460px at 6% 120%,rgba(247,207,42,.07),transparent 55%);
}
.jb-lp .page-hero .inner{position:relative;max-width:760px;margin:0 auto}
.jb-lp .page-hero .eyebrow{display:block;margin-bottom:18px}
.jb-lp .page-hero h1{font-size:clamp(38px,6vw,64px);font-weight:800;color:#fff;letter-spacing:-.03em}
.jb-lp .page-hero p{color:#c9c8c2;font-size:clamp(16px,2vw,19px);max-width:600px;margin:18px auto 0;line-height:1.6}

/* section background helpers */
.jb-lp .bg-paper{background:var(--paper-2)}

/* readable prose column */
.jb-lp .narrow{max-width:760px;margin:0 auto}
.jb-lp .prose h2{font-size:clamp(26px,3.4vw,34px);font-weight:700;margin:0 0 16px}
.jb-lp .prose h2:not(:first-child){margin-top:46px}
.jb-lp .prose p{color:var(--ink-soft);font-size:17px;line-height:1.75;margin-bottom:16px}
.jb-lp .prose .eyebrow{display:block;margin-bottom:14px}
.jb-lp .prose strong{color:var(--ink)}

/* checkmark bullet list inside light cards */
.jb-lp .card-list{list-style:none;margin-top:18px}
.jb-lp .card-list li{position:relative;padding-left:27px;margin-bottom:11px;color:var(--muted);font-size:15px;line-height:1.5}
.jb-lp .card-list li::before{content:"";position:absolute;left:2px;top:4px;width:13px;height:7px;border-left:2.5px solid var(--yellow-deep);border-bottom:2.5px solid var(--yellow-deep);transform:rotate(-45deg)}

/* services detail cards reuse .diff-grid/.diff-card; tighten heading */
.jb-lp .diff-card .card-list li{font-size:14.5px}

/* 5-step process row */
.jb-lp .steps.s5{grid-template-columns:repeat(5,1fr)}

/* industries band */
.jb-lp .industries{text-align:center;max-width:820px;margin:0 auto}
.jb-lp .industries p{color:var(--ink-soft);font-size:18px;line-height:1.9}
.jb-lp .industries strong{color:var(--ink);font-weight:700}

/* team grid */
.jb-lp .team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.jb-lp .team-card .photo{aspect-ratio:4/5;border-radius:var(--r);overflow:hidden;background:var(--paper-3);margin-bottom:16px;border:1px solid var(--line)}
.jb-lp .team-card .photo img{width:100%;height:100%;object-fit:cover;display:block}
.jb-lp .team-card .tname{font-family:var(--display);font-weight:700;font-size:19px;color:var(--ink)}
.jb-lp .team-card .trole{color:var(--yellow-deep);font-weight:600;font-size:14px;margin-top:3px}
.jb-lp .team-card .tbio{color:var(--muted);font-size:14.5px;margin-top:9px;line-height:1.55}

/* meet-the-team — single founder story */
.jb-lp .founder{display:grid;grid-template-columns:330px 1fr;gap:50px;align-items:start}
.jb-lp .founder-photo img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:var(--r);border:1px solid var(--line);background:var(--paper-3);display:block}
.jb-lp .founder-cap{margin-top:16px}
.jb-lp .founder-cap .fname{display:block;font-family:var(--display);font-weight:700;font-size:22px;color:var(--ink)}
.jb-lp .founder-cap .frole{display:block;color:var(--yellow-deep);font-weight:600;font-size:14px;margin-top:2px}
.jb-lp .founder-body h2{font-size:clamp(26px,3.4vw,34px);margin:8px 0 18px}
.jb-lp .founder-body .btn{margin-top:8px}
@media(max-width:760px){.jb-lp .founder{grid-template-columns:1fr;gap:30px}.jb-lp .founder-photo{max-width:300px}}

/* FAQ accordion */
.jb-lp .faq-list{display:flex;flex-direction:column;gap:12px}
.jb-lp .faq-item{border:1px solid var(--line);border-radius:14px;background:var(--paper-2);overflow:hidden}
.jb-lp .faq-item summary{cursor:pointer;list-style:none;padding:20px 24px;font-family:var(--display);font-weight:700;font-size:18px;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:16px}
.jb-lp .faq-item summary::-webkit-details-marker{display:none}
.jb-lp .faq-item summary::after{content:"+";font-size:28px;color:var(--yellow-deep);font-weight:600;line-height:1;transition:transform .2s}
.jb-lp .faq-item[open] summary::after{transform:rotate(45deg)}
.jb-lp .faq-a{padding:0 24px 22px;color:var(--ink-soft);font-size:15.5px;line-height:1.7}
.jb-lp .faq-a p{margin:0}

/* blog index (home template) */
.jb-lp .blog-list{gap:34px 28px}
.jb-lp .blog-list li{list-style:none}
.jb-lp .blog-list .wp-block-post-title{font-family:var(--display);font-weight:700;line-height:1.18;letter-spacing:-.01em;margin:10px 0 8px}
.jb-lp .blog-list .wp-block-post-title a{color:var(--ink);text-decoration:none}
.jb-lp .blog-list .wp-block-post-title a:hover{color:var(--yellow-deep)}
.jb-lp .blog-list .wp-block-post-date{color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.08em}
.jb-lp .blog-list .wp-block-post-excerpt{color:var(--ink-soft);font-size:15.5px}
.jb-lp .blog-list .wp-block-post-excerpt__more-text a{color:var(--yellow-deep);font-weight:600}
.jb-lp .blog-wrap .wp-block-query-pagination a,.jb-lp .blog-wrap .wp-block-query-pagination span{color:var(--ink-soft);font-weight:600}

/* pricing */
.jb-lp .price-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;max-width:880px;margin:0 auto}
.jb-lp .price-card{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:38px 34px;display:flex;flex-direction:column}
.jb-lp .price-card.dark{background:var(--ink);border-color:transparent;color:#fff}
.jb-lp .price-card .ptag{font-size:12.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--yellow-deep)}
.jb-lp .price-card.dark .ptag{color:var(--yellow)}
.jb-lp .price-card .pamt{font-family:var(--display);font-weight:800;font-size:44px;line-height:1.05;margin:12px 0 8px;letter-spacing:-.03em;color:var(--ink)}
.jb-lp .price-card.dark .pamt{color:#fff}
.jb-lp .price-card .pamt span{font-family:var(--body);font-size:16px;font-weight:500;color:var(--muted)}
.jb-lp .price-card > p{color:var(--muted);font-size:15px;margin-bottom:8px}
.jb-lp .price-card.dark > p{color:#c9c8c2}
.jb-lp .price-card .card-list{flex:1}
.jb-lp .price-card .btn{margin-top:22px;align-self:flex-start}

/* contact layout (core columns get .contact-grid) */
.jb-lp .contact-grid.wp-block-columns{display:grid;grid-template-columns:.85fr 1.15fr;gap:46px;align-items:start}
.jb-lp .contact-grid .wp-block-column{flex-basis:auto}
.jb-lp .contact-info h2{font-size:26px;font-weight:700;margin-bottom:18px}
.jb-lp .contact-line{display:flex;align-items:center;gap:11px;margin-bottom:13px;color:var(--ink-soft);font-size:16px}
.jb-lp .contact-line svg{color:var(--yellow-deep);flex-shrink:0}
.jb-lp .contact-note{color:var(--muted);font-size:14.5px;margin-top:16px}
.jb-lp .form-card{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:32px 30px}
.jb-lp .form-card .form-title{font-family:var(--display);font-weight:700;font-size:22px;margin-bottom:18px;color:var(--ink)}

@media(max-width:860px){
  .jb-lp .team-grid{grid-template-columns:repeat(2,1fr)}
  .jb-lp .price-grid{grid-template-columns:1fr}
  .jb-lp .contact-grid.wp-block-columns{grid-template-columns:1fr;gap:32px}
  .jb-lp .steps.s5{grid-template-columns:repeat(2,1fr);gap:30px 18px}
}
@media(max-width:560px){
  .jb-lp .team-grid{grid-template-columns:1fr}
  .jb-lp .steps.s5{grid-template-columns:1fr}
}

/* reveal animation */
.jb-lp .reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.8,.2,1)}
.jb-lp .reveal.in{opacity:1;transform:none}
html:not(.js) .jb-lp .reveal{opacity:1;transform:none}
.jb-lp .hero .eyebrow,.jb-lp .hero h1,.jb-lp .hero p.lede,.jb-lp .hero-btns,.jb-lp .stat{opacity:0;animation:jbrise .8s cubic-bezier(.2,.8,.2,1) forwards}
.jb-lp .hero h1{animation-delay:.08s}
.jb-lp .hero p.lede{animation-delay:.18s}
.jb-lp .hero-btns{animation-delay:.28s}
.jb-lp .stat:nth-child(1){animation-delay:.36s}.jb-lp .stat:nth-child(2){animation-delay:.44s}
.jb-lp .stat:nth-child(3){animation-delay:.52s}.jb-lp .stat:nth-child(4){animation-delay:.6s}
@keyframes jbrise{to{opacity:1;transform:none}}
html:not(.js) .jb-lp .hero .eyebrow,html:not(.js) .jb-lp .hero h1,html:not(.js) .jb-lp .hero p.lede,html:not(.js) .jb-lp .hero-btns,html:not(.js) .jb-lp .stat{opacity:1;animation:none}

@media(prefers-reduced-motion:reduce){
  .jb-lp .reveal,.jb-lp .hero .eyebrow,.jb-lp .hero h1,.jb-lp .hero p.lede,.jb-lp .hero-btns,.jb-lp .stat{opacity:1!important;transform:none!important;animation:none!important}
}

/* mobile nav dropdown */
.jb-head .nav-links.open{
  display:flex;flex-direction:column;align-items:flex-start;gap:18px;
  position:absolute;top:74px;left:0;right:0;background:#fff;
  padding:22px 28px;border-bottom:1px solid var(--line);box-shadow:0 18px 30px -22px rgba(0,0,0,.4);
}

/* services dropdown in the header nav */
.jb-head .nav-dd{position:relative;display:flex;align-items:center}
.jb-head .nav-dd-top{display:inline-flex;align-items:center;gap:5px}
.jb-head .nav-dd .caret{transition:transform .2s}
.jb-head .nav-dd:hover .caret,.jb-head .nav-dd:focus-within .caret{transform:rotate(180deg)}
.jb-head .nav-sub{
  position:absolute;top:100%;left:50%;margin-top:12px;transform:translateX(-50%) translateY(6px);
  min-width:250px;background:#fff;border:1px solid var(--line);border-radius:14px;
  box-shadow:0 22px 44px -24px rgba(0,0,0,.5);padding:8px;
  display:flex;flex-direction:column;gap:2px;
  opacity:0;visibility:hidden;transition:opacity .2s,transform .2s;z-index:60;
}
.jb-head .nav-sub::before{content:"";position:absolute;top:-12px;left:0;right:0;height:12px}
.jb-head .nav-dd:hover .nav-sub,.jb-head .nav-dd:focus-within .nav-sub{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.jb-head .nav-sub a{font-size:14.5px;font-weight:500;color:var(--ink-soft);padding:10px 14px;border-radius:9px;white-space:nowrap}
.jb-head .nav-sub a::after{display:none}
.jb-head .nav-sub a:hover{background:var(--paper-2);color:var(--ink)}

/* anchor offset so the sticky header doesn't cover targeted sections */
.jb-lp .diff-card[id]{scroll-margin-top:96px}

/* legal / long-form content pages (privacy policy, terms) */
.jb-lp .legal-wrap h1{font-size:clamp(34px,5vw,52px);margin-bottom:26px}
.jb-lp .legal-wrap h2{font-size:24px;margin:38px 0 12px}
.jb-lp .legal-wrap h3{font-size:19px;margin:26px 0 10px}
.jb-lp .legal-wrap p{color:var(--ink-soft);font-size:16.5px;line-height:1.75;margin-bottom:16px}
.jb-lp .legal-wrap ul,.jb-lp .legal-wrap ol{margin:0 0 16px 1.2em;color:var(--ink-soft);font-size:16.5px;line-height:1.7}
.jb-lp .legal-wrap li{margin-bottom:8px}
.jb-lp .legal-wrap a{color:var(--yellow-deep);text-decoration:underline;word-break:break-word}

@media(max-width:960px){
  .jb-head .nav-links,.jb-head .nav-cta .btn{display:none}
  .jb-head .menu-btn{display:block}
  .jb-head .nav-links.open{display:flex}
  .jb-head .nav-links.open .nav-dd{flex-direction:column;align-items:flex-start;gap:14px;width:100%}
  .jb-head .nav-links.open .nav-sub{position:static;opacity:1;visibility:visible;transform:none;margin:4px 0 0;box-shadow:none;border:none;background:transparent;padding:0 0 0 14px;min-width:0;gap:10px}
  .jb-head .nav-links.open .nav-sub::before{display:none}
  .jb-head .nav-links.open .caret{display:none}
  .jb-lp .why-grid{grid-template-columns:1fr;gap:36px}
  .jb-lp .steps{grid-template-columns:repeat(2,1fr);gap:30px 18px}
  .jb-foot .foot-grid{grid-template-columns:1fr 1fr;gap:36px}
}
@media(max-width:680px){
  .jb-lp section{padding:72px 0}
  .jb-lp .diff-grid,.jb-lp .svc-grid,.jb-lp .tg{grid-template-columns:1fr}
  .jb-lp .stats{grid-template-columns:repeat(2,1fr)}
  .jb-lp .stat:nth-child(2){border-right:none}
  .jb-lp .stat{border-bottom:1px solid rgba(255,255,255,.08)}
  .jb-lp .steps{grid-template-columns:1fr}
  .jb-foot .foot-grid{grid-template-columns:1fr}
  .jb-lp .final-box{padding:56px 24px}
  .jb-lp .hero{padding-top:72px}
}

/* ---- Prose blockquote (About motto) ---- */
.jb-lp .prose blockquote{margin:30px 0;padding:20px 26px;border-left:4px solid var(--yellow);background:var(--paper-3);border-radius:0 var(--r) var(--r) 0}
.jb-lp .prose blockquote p{font-family:var(--display);font-size:21px;font-weight:700;font-style:italic;color:var(--ink);margin:0}
.jb-lp .prose blockquote cite{display:block;margin-top:6px;font-style:normal;font-size:14px;color:var(--muted)}

/* ---- Single blog post ---- */
.jb-lp .post-hero{padding:142px 0 70px}
.jb-lp .post-hero .wp-block-post-date{position:relative;color:var(--yellow);font-weight:600;font-size:13px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:18px}
.jb-lp .post-hero h1{font-size:clamp(30px,4.6vw,50px)}
.jb-lp .post-body p{color:var(--ink-soft);font-size:17px;line-height:1.75;margin-bottom:16px}
.jb-lp .post-body h2{font-size:clamp(23px,3vw,29px);font-weight:700;margin:42px 0 14px}
.jb-lp .post-body h3{font-size:20px;margin:30px 0 10px}
.jb-lp .post-body ul,.jb-lp .post-body ol{margin:0 0 16px 1.2em;color:var(--ink-soft);font-size:17px;line-height:1.7}
.jb-lp .post-body li{margin-bottom:8px}
.jb-lp .post-body a{color:var(--yellow-deep);text-decoration:underline}
.jb-lp .post-back{margin-top:38px}
.jb-lp .post-back a{text-decoration:none;font-weight:600;color:var(--ink)}
