/* Leo Tech Labs - design system
   Palette: getdesign/Zapier kit (unchanged).
   Type: one strict scale, two letter-spacings, unitless leading.
   Scale: 13 / 14 / 16 / 18 / 20 / 24 / 32 / h2-clamp / h1-clamp. Nothing else. */
:root{
  --primary:#ff4f00;
  --on-primary:#fffefb;
  --ink:#201515;
  --ink-soft:#2f2a26;
  --body:#605d52;
  --body-mid:#939084;
  --mute:#c5c0b1;
  --canvas:#fffefb;
  --canvas-soft:#f8f4f0;
  --hairline:#eee7de;
  --r-sm:6px;
  --r-md:12px;
  --r-pill:9999px;
  --max:1280px;
  /* type scale */
  --text-xs:13px;   /* captions, meta, fineprint */
  --text-sm:14px;   /* labels, eyebrows, chips */
  --text-base:16px; /* UI text: cards, lists, nav */
  --text-md:18px;   /* prose */
  --text-lg:20px;   /* ledes, standfirsts */
  --text-xl:24px;   /* card & row headings */
  --text-2xl:32px;  /* block headings */
  --h2:clamp(30px,3.6vw,42px);
  --h1:clamp(36px,4.6vw,56px);
  /* leading */
  --leading-body:1.6;
  --leading-ui:1.45;
  --leading-sub:1.25;
  --leading-display:1.08;
  /* tracking */
  --track-display:-0.015em;
  --track-label:0.08em;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--canvas);
  color:var(--ink);
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  font-size:var(--text-md);line-height:var(--leading-body);
  -webkit-font-smoothing:antialiased;
}
::selection{background:var(--primary);color:var(--on-primary);}
img{max-width:100%;display:block;}
a{color:inherit;}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px;}

.display{font-family:'Mona Sans','Inter',system-ui,sans-serif;font-weight:500;}
.eyebrow{
  font-family:'Mona Sans','Inter',sans-serif;
  font-size:var(--text-sm);font-weight:600;line-height:var(--leading-ui);
  letter-spacing:var(--track-label);text-transform:uppercase;
  color:var(--body-mid);display:block;
}

/* buttons */
.btn{
  display:inline-block;text-decoration:none;cursor:pointer;
  font-family:'Inter',sans-serif;font-size:var(--text-base);font-weight:600;line-height:var(--leading-ui);
  padding:13px 26px;border-radius:var(--r-md);
  transition:filter .15s, background .15s, transform .12s;
  border:1px solid transparent;
}
.btn:hover{transform:translateY(-1px);}
.btn-primary{background:var(--primary);color:var(--on-primary);}
.btn-primary:hover{filter:brightness(0.94);}
.btn-secondary{background:var(--ink);color:var(--on-primary);}
.btn-tertiary{background:var(--canvas);color:var(--ink);border-color:var(--ink);}
.btn-tertiary:hover{background:var(--canvas-soft);}
.btn.sm{font-size:var(--text-sm);font-weight:600;padding:10px 18px;}

/* nav */
header{
  position:sticky;top:0;z-index:60;
  background:var(--canvas);
  border-bottom:1px solid var(--hairline);
}
.nav{
  max-width:var(--max);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 24px;gap:24px;
}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;}
.brand img{width:38px;height:38px;object-fit:contain;mix-blend-mode:multiply;}
.brand .name{font-family:'Mona Sans',sans-serif;font-weight:600;font-size:var(--text-lg);letter-spacing:var(--track-display);}
.navlinks{display:flex;gap:28px;align-items:center;}
.navlinks a{text-decoration:none;font-size:var(--text-base);line-height:var(--leading-ui);color:var(--ink);}
.navlinks a:not(.btn):hover{color:var(--primary);}
.navlinks a.active{font-weight:600;color:var(--primary);}
.menu-btn{
  display:none;background:none;border:1px solid var(--hairline);
  border-radius:var(--r-sm);padding:8px 12px;font:inherit;font-size:var(--text-sm);cursor:pointer;
}
@media (max-width:880px){
  .menu-btn{display:inline-block;}
  .navlinks{
    display:none;position:absolute;top:100%;left:0;right:0;
    background:var(--canvas);border-bottom:1px solid var(--hairline);
    flex-direction:column;align-items:flex-start;gap:0;padding:8px 24px 16px;
  }
  .navlinks.open{display:flex;}
  .navlinks a{padding:12px 0;width:100%;}
  .navlinks a.btn{width:auto;margin-top:8px;}
}

/* bands & sections */
section{padding:72px 0;}
.band-cream{background:var(--canvas-soft);}
.band-dark{background:var(--ink);color:var(--on-primary);}
.section-head{margin-bottom:48px;max-width:760px;}
.section-head .eyebrow{margin-bottom:16px;}
h1{
  font-family:'Mona Sans','Inter',sans-serif;
  font-size:var(--h1);font-weight:500;
  line-height:var(--leading-display);letter-spacing:var(--track-display);max-width:18ch;
}
h1 em{font-style:normal;color:var(--primary);}
h2{
  font-family:'Mona Sans','Inter',sans-serif;
  font-size:var(--h2);font-weight:500;line-height:var(--leading-display);letter-spacing:var(--track-display);
}
.lede{margin-top:16px;font-size:var(--text-lg);line-height:1.5;color:var(--body);max-width:56ch;}
.band-dark .lede{color:var(--mute);}
@media (max-width:720px){
  section{padding:48px 0;}
}

/* page hero (interior pages) */
.page-hero{padding:80px 0 56px;}
.page-hero .eyebrow{margin-bottom:16px;}

/* home hero */
.hero{padding:96px 0 80px;}
.hero .lede{margin-top:24px;}
.hero-actions{margin-top:40px;display:flex;gap:16px;flex-wrap:wrap;}
.hero-sectors{margin-top:56px;display:flex;gap:8px;flex-wrap:wrap;}
.pill{
  background:var(--canvas-soft);color:var(--body);
  font-size:var(--text-sm);line-height:var(--leading-ui);
  padding:4px 12px;border-radius:var(--r-pill);
}
.band-cream .pill{background:var(--canvas);}

/* cards & grids */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.card{background:var(--canvas-soft);border-radius:var(--r-md);padding:28px;}
.band-cream .card{background:var(--canvas);}
.card h3{font-size:var(--text-xl);font-weight:600;line-height:var(--leading-sub);letter-spacing:var(--track-display);margin-bottom:10px;}
.card p{font-size:var(--text-base);line-height:var(--leading-body);color:var(--body);}
@media (max-width:900px){.grid-3{grid-template-columns:1fr;}}
@media (max-width:760px){.grid-2{grid-template-columns:1fr;}}

/* service rows (home) + service cards (services page) */
.svc-list{border-top:1px solid var(--hairline);max-width:960px;}
.svc-row{
  display:grid;grid-template-columns:1fr 1.1fr;gap:24px;
  padding:26px 0;border-bottom:1px solid var(--hairline);
  align-items:baseline;text-decoration:none;transition:background .15s;
}
a.svc-row:hover .name{color:var(--primary);}
.svc-row .name{font-size:var(--text-xl);font-weight:600;line-height:var(--leading-sub);letter-spacing:var(--track-display);transition:color .15s;}
.svc-row .desc{font-size:var(--text-base);line-height:var(--leading-body);color:var(--body);}
@media (max-width:720px){.svc-row{grid-template-columns:1fr;gap:6px;}}

.svc-detail{border-radius:var(--r-md);padding:32px;background:var(--canvas-soft);}
.svc-detail h3{font-family:'Mona Sans',sans-serif;font-size:var(--text-2xl);font-weight:500;line-height:var(--leading-sub);letter-spacing:var(--track-display);margin-bottom:12px;}
.svc-detail p{font-size:var(--text-base);line-height:var(--leading-body);color:var(--body);}
.svc-detail ul{margin-top:16px;list-style:none;}
.svc-detail li{
  font-size:var(--text-base);line-height:var(--leading-body);color:var(--body);
  padding:8px 0 8px 22px;position:relative;border-top:1px solid var(--hairline);
}
.svc-detail li::before{content:"→";position:absolute;left:0;color:var(--primary);font-weight:600;}
.svc-detail .fit{margin-top:20px;font-size:var(--text-base);line-height:var(--leading-body);font-weight:600;}

/* engagement models */
.model{border-radius:var(--r-md);padding:32px;}
.model.dark{background:var(--ink);color:var(--on-primary);}
.model.light{background:var(--canvas);}
.model .tag{font-size:var(--text-sm);line-height:var(--leading-ui);letter-spacing:var(--track-label);text-transform:uppercase;font-weight:600;color:var(--body-mid);margin-bottom:12px;}
.model h3{font-size:var(--text-2xl);font-weight:500;line-height:var(--leading-sub);letter-spacing:var(--track-display);font-family:'Mona Sans',sans-serif;margin-bottom:12px;}
.model p{font-size:var(--text-base);line-height:var(--leading-body);color:var(--body);}
.model.dark p{color:var(--mute);}
.model .for{margin-top:20px;font-size:var(--text-base);line-height:var(--leading-body);font-weight:600;}

.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:20px;}
.step{
  background:var(--canvas-soft);border-radius:var(--r-md);padding:20px 24px;
  font-size:var(--text-base);line-height:var(--leading-body);font-weight:500;
}
.band-cream .step{background:var(--canvas);}
.step span{display:block;font-size:var(--text-sm);line-height:var(--leading-ui);color:var(--body-mid);font-weight:400;margin-bottom:6px;}
.step h3{font-size:var(--text-base);font-weight:600;line-height:var(--leading-sub);margin-bottom:6px;}
.step p{font-size:var(--text-sm);line-height:var(--leading-body);color:var(--body);font-weight:400;}
@media (max-width:900px){.steps{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.steps{grid-template-columns:1fr;}}

/* case studies */
.cases{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.case{
  background:var(--canvas-soft);border-radius:var(--r-md);padding:32px;
  display:flex;flex-direction:column;gap:10px;text-decoration:none;
  transition:transform .15s;
}
a.case:hover{transform:translateY(-2px);}
.case.dark{background:var(--ink);color:var(--on-primary);grid-column:1 / -1;}
.case .sector{font-size:var(--text-sm);line-height:var(--leading-ui);color:var(--body-mid);}
.case h3{font-size:var(--text-xl);font-weight:600;line-height:var(--leading-sub);letter-spacing:var(--track-display);}
.case.dark h3{font-family:'Mona Sans',sans-serif;font-size:var(--text-2xl);font-weight:500;}
.case p{font-size:var(--text-base);line-height:var(--leading-body);color:var(--body);}
.case.dark p{color:var(--mute);font-size:var(--text-md);max-width:60ch;}
.case .result{margin-top:auto;padding-top:12px;font-size:var(--text-base);line-height:var(--leading-body);font-weight:600;color:var(--ink);}
.case.dark .result{font-size:var(--text-lg);color:var(--on-primary);}
@media (max-width:760px){.cases{grid-template-columns:1fr;}}

/* case study detail blocks */
.cs{border-radius:var(--r-md);background:var(--canvas-soft);padding:40px;margin-bottom:24px;scroll-margin-top:90px;}
.cs .sector{font-size:var(--text-sm);line-height:var(--leading-ui);color:var(--body-mid);}
.cs h2{font-size:var(--text-2xl);line-height:var(--leading-sub);margin-top:6px;}
.cs .cs-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:24px;}
.cs .k{font-size:var(--text-sm);line-height:var(--leading-ui);font-weight:600;letter-spacing:var(--track-label);text-transform:uppercase;color:var(--body-mid);margin-bottom:8px;}
.cs p{font-size:var(--text-base);line-height:var(--leading-body);color:var(--body);}
.cs .outcome{
  margin-top:24px;padding:20px 24px;background:var(--canvas);
  border-radius:var(--r-md);font-size:var(--text-md);line-height:var(--leading-body);font-weight:600;
}
@media (max-width:720px){.cs{padding:28px;}.cs .cs-grid{grid-template-columns:1fr;gap:20px;}}

/* about */
.about-grid{display:grid;grid-template-columns:1.3fr 0.7fr;gap:48px;align-items:start;}
.about-copy p{font-size:var(--text-md);line-height:var(--leading-body);color:var(--body);max-width:58ch;}
.about-copy p+p{margin-top:16px;}
.about-copy .pull{
  margin-top:24px;font-size:var(--text-xl);line-height:var(--leading-sub);font-weight:600;
  letter-spacing:var(--track-display);color:var(--ink);max-width:44ch;
}
.contact-card{background:var(--canvas-soft);border-radius:var(--r-md);padding:32px;}
.band-cream .contact-card{background:var(--canvas);}
.contact-card .role{font-size:var(--text-sm);line-height:var(--leading-ui);color:var(--body-mid);margin-bottom:8px;}
.contact-card .who{font-size:var(--text-xl);font-weight:600;line-height:var(--leading-sub);letter-spacing:var(--track-display);}
.contact-card .title{font-size:var(--text-base);line-height:var(--leading-body);color:var(--body);margin-top:2px;}
.contact-card .btn{margin-top:24px;}
@media (max-width:820px){.about-grid{grid-template-columns:1fr;gap:32px;}}

/* contact form */
.form-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:48px;align-items:start;}
form .field{margin-bottom:20px;}
form label{
  display:block;font-size:var(--text-base);line-height:var(--leading-ui);font-weight:600;margin-bottom:6px;
}
input[type=text],input[type=email],textarea,select{
  width:100%;font:inherit;font-size:var(--text-base);line-height:var(--leading-ui);color:var(--ink);
  background:var(--canvas);border:1px solid var(--mute);
  border-radius:var(--r-sm);padding:12px 16px;
}
input:focus,textarea:focus,select:focus{outline:2px solid var(--primary);outline-offset:1px;border-color:var(--primary);}
textarea{min-height:140px;resize:vertical;}
.form-note{font-size:var(--text-sm);line-height:var(--leading-ui);color:var(--body-mid);margin-top:12px;}
@media (max-width:820px){.form-grid{grid-template-columns:1fr;gap:32px;}}

/* cta band */
.final{padding:96px 0;text-align:center;}
.final h2{max-width:20ch;margin:0 auto;color:var(--on-primary);}
.final .lede{max-width:56ch;margin:20px auto 0;}
.final .btn{margin-top:36px;}
.final .fineprint{margin-top:20px;font-size:var(--text-sm);line-height:var(--leading-ui);color:var(--body-mid);}

/* footer */
footer{background:var(--ink);color:var(--canvas-soft);padding:56px 0 40px;}
.foot-grid{
  display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:40px;
  padding-bottom:40px;border-bottom:1px solid #352a2a;
}
.foot-grid .fbrand{display:flex;align-items:center;gap:10px;font-family:'Mona Sans',sans-serif;font-weight:600;font-size:var(--text-lg);}
.foot-grid .fbrand img{width:34px;height:34px;border-radius:6px;}
.foot-grid p{font-size:var(--text-base);line-height:var(--leading-body);color:var(--body-mid);margin-top:12px;max-width:34ch;}
.foot-grid .fh{font-size:var(--text-sm);line-height:var(--leading-ui);font-weight:600;letter-spacing:var(--track-label);text-transform:uppercase;color:var(--body-mid);margin-bottom:14px;}
.foot-grid ul{list-style:none;}
.foot-grid li{margin-bottom:10px;}
.foot-grid a{text-decoration:none;font-size:var(--text-base);line-height:var(--leading-body);color:var(--canvas-soft);}
.foot-grid a:hover{color:var(--primary);}
.foot-base{
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:12px;padding-top:24px;
  font-size:var(--text-sm);line-height:var(--leading-ui);color:var(--body-mid);
}
.foot-legal a{color:var(--body-mid);text-decoration:none;}
.foot-legal a:hover{color:var(--primary);}
@media (max-width:760px){.foot-grid{grid-template-columns:1fr;gap:28px;}}

/* legal / long-form prose */
.legal{max-width:768px;}
.legal .updated{font-size:var(--text-sm);line-height:var(--leading-ui);color:var(--body-mid);margin-bottom:8px;}
.legal .intro{font-size:var(--text-md);line-height:var(--leading-body);color:var(--body);margin-bottom:32px;}
.legal .toc{background:var(--canvas-soft);border-radius:var(--r-md);padding:20px 24px;margin-bottom:44px;}
.legal .toc .fh{font-size:var(--text-sm);line-height:var(--leading-ui);font-weight:600;letter-spacing:var(--track-label);text-transform:uppercase;color:var(--body-mid);margin-bottom:12px;}
.legal .toc ol{margin:0;padding-left:20px;}
.legal .toc li{margin-bottom:6px;}
.legal .toc a{font-size:var(--text-sm);line-height:var(--leading-ui);color:var(--body);text-decoration:none;}
.legal .toc a:hover{color:var(--primary);}
.legal h2{font-size:var(--text-xl);line-height:var(--leading-sub);letter-spacing:var(--track-display);margin:44px 0 12px;scroll-margin-top:90px;}
.legal h2:first-of-type{margin-top:0;}
.legal h3{font-family:'Inter',sans-serif;font-size:var(--text-md);line-height:var(--leading-sub);font-weight:600;margin:24px 0 8px;}
.legal p{font-size:var(--text-base);line-height:var(--leading-body);color:var(--body);margin-bottom:16px;}
.legal ul{margin:0 0 16px;padding-left:22px;}
.legal li{font-size:var(--text-base);line-height:var(--leading-body);color:var(--body);margin-bottom:8px;}
.legal a{color:var(--primary);text-decoration:underline;text-underline-offset:2px;}
.legal strong{color:var(--ink-soft);font-weight:600;}

/* motion */
.reveal{opacity:0;transform:translateY(12px);transition:opacity .5s ease,transform .5s ease;}
.reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;scroll-behavior:auto!important;}
  .reveal{opacity:1;transform:none;}
}
a:focus-visible,button:focus-visible{outline:2px solid var(--primary);outline-offset:3px;}

/* ===================== Blog ===================== */
/* Shared meta + chips */
.post-chip{
  display:inline-block;font-family:'Mona Sans',sans-serif;
  font-size:var(--text-sm);font-weight:600;line-height:var(--leading-ui);letter-spacing:var(--track-label);
  text-transform:uppercase;color:var(--primary);
}
.post-meta{font-size:var(--text-xs);line-height:var(--leading-ui);color:var(--body-mid);}
.post-meta .dot{margin:0 8px;color:var(--mute);}

/* Blog index hero */
.blog-head{padding:88px 0 40px;}
.blog-head .eyebrow{margin-bottom:16px;}
.blog-head h1{max-width:16ch;}
.blog-head .lede{margin-top:20px;max-width:58ch;}

/* Featured post */
.featured{
  display:block;text-decoration:none;color:var(--on-primary);
  background:var(--ink);border-radius:var(--r-md);
  padding:clamp(32px,5vw,56px);transition:transform .18s ease;
}
.featured:hover{transform:translateY(-3px);}
.featured .post-chip{color:var(--primary);}
.featured h2{
  font-family:'Mona Sans',sans-serif;font-weight:500;
  font-size:var(--h2);line-height:var(--leading-display);letter-spacing:var(--track-display);
  margin:18px 0 16px;max-width:20ch;color:var(--on-primary);
}
.featured p{font-size:var(--text-md);line-height:var(--leading-body);color:var(--mute);max-width:58ch;}
.featured .row{display:flex;align-items:center;gap:14px;margin-top:28px;flex-wrap:wrap;}
.featured .row img{width:40px;height:40px;border-radius:var(--r-pill);background:#2c211f;padding:5px;}
.featured .who{font-size:var(--text-sm);line-height:var(--leading-ui);font-weight:600;color:var(--on-primary);}
.featured .who + .post-meta,.featured .whowrap .post-meta{color:var(--body-mid);}
.featured .more{margin-left:auto;color:var(--primary);font-weight:600;font-size:var(--text-sm);}
@media (max-width:640px){.featured .more{margin-left:0;}}

/* Post grid */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.post-grid.two{grid-template-columns:repeat(2,1fr);}
.post-card{
  display:flex;flex-direction:column;gap:12px;text-decoration:none;
  background:var(--canvas);border:1px solid var(--hairline);
  border-radius:var(--r-md);padding:28px;
  transition:transform .18s ease,border-color .18s ease;
}
.post-card:hover{transform:translateY(-3px);border-color:var(--body-mid);}
.post-card h3{
  font-family:'Mona Sans',sans-serif;font-weight:500;
  font-size:var(--text-xl);line-height:var(--leading-sub);letter-spacing:var(--track-display);color:var(--ink);
}
.post-card p{font-size:var(--text-base);line-height:var(--leading-body);color:var(--body);flex:1;}
.post-card .post-meta{margin-top:2px;}
@media (max-width:920px){.post-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:640px){.post-grid,.post-grid.two{grid-template-columns:1fr;}}

/* Article header */
.article-head{padding:76px 0 36px;}
.article-head .wrap{max-width:820px;}
.article-head .post-chip{margin-bottom:18px;}
.article-head h1{
  font-size:var(--h1);line-height:var(--leading-display);letter-spacing:var(--track-display);max-width:22ch;
}
.article-head .standfirst{
  margin-top:22px;font-size:var(--text-lg);line-height:1.5;color:var(--body);max-width:60ch;
}
.article-byline{display:flex;align-items:center;gap:12px;margin-top:32px;}
.article-byline img{width:44px;height:44px;border-radius:var(--r-pill);background:var(--canvas-soft);padding:5px;}
.article-byline .who{font-size:var(--text-sm);line-height:var(--leading-ui);font-weight:600;color:var(--ink);}
.article-byline .post-meta{margin-top:2px;}

/* Article body */
.post-wrap{padding:8px 0 8px;}
.post-body{max-width:720px;margin:0 auto;}
.post-body>p:first-of-type{font-size:var(--text-lg);line-height:1.55;color:var(--ink-soft);}
.post-body h2{
  font-family:'Mona Sans',sans-serif;font-weight:500;
  font-size:var(--text-2xl);line-height:var(--leading-sub);letter-spacing:var(--track-display);color:var(--ink);
  margin:48px 0 14px;scroll-margin-top:90px;
}
.post-body h3{font-size:var(--text-lg);line-height:var(--leading-sub);font-weight:600;color:var(--ink-soft);margin:30px 0 8px;}
.post-body p{font-size:var(--text-md);line-height:var(--leading-body);color:var(--body);margin-bottom:18px;}
/* Blog articles (not case studies/offer pages, which use .post-body.wide) read better justified. */
.post-body:not(.wide) p{text-align:justify;-webkit-hyphens:auto;hyphens:auto;}
@media (max-width:560px){.post-body:not(.wide) p{text-align:left;}}
.post-body ul{margin:4px 0 20px;padding:0;list-style:none;}
.post-body ul li{
  position:relative;padding:8px 0 8px 26px;font-size:var(--text-base);line-height:var(--leading-body);color:var(--body);
  border-top:1px solid var(--hairline);
}
.post-body ul li:last-child{border-bottom:1px solid var(--hairline);}
.post-body ul li::before{content:"\2192";position:absolute;left:0;color:var(--primary);font-weight:600;}
.post-body a{color:var(--primary);text-decoration:underline;text-underline-offset:2px;}
.post-body strong{color:var(--ink-soft);font-weight:600;}
.post-body blockquote{
  margin:32px 0;padding:2px 0 2px 24px;border-left:3px solid var(--primary);
  font-family:'Mona Sans',sans-serif;font-weight:500;
  font-size:var(--text-xl);line-height:1.4;letter-spacing:var(--track-display);color:var(--ink);
}
.post-body blockquote p{font-size:inherit;line-height:inherit;color:inherit;margin:0;}

/* Callout box (key takeaways / at a glance) */
.callout{background:var(--canvas-soft);border-radius:var(--r-md);padding:28px 32px;margin:36px 0;}
.callout .k{
  font-family:'Mona Sans',sans-serif;font-size:var(--text-sm);font-weight:600;
  letter-spacing:var(--track-label);text-transform:uppercase;color:var(--body-mid);margin-bottom:14px;
}
.callout ul{margin:0;}
.callout ul li{border-top:1px solid var(--hairline);}
.callout ul li:last-child{border-bottom:none;}

/* Article footer: author bio + back link */
.article-foot{max-width:720px;margin:0 auto;padding-top:32px;border-top:1px solid var(--hairline);}
.author-bio{display:flex;gap:16px;align-items:flex-start;}
.author-bio img{width:54px;height:54px;border-radius:var(--r-pill);background:var(--canvas-soft);padding:6px;flex:none;}
.author-bio .who{font-weight:600;color:var(--ink);font-size:var(--text-base);line-height:var(--leading-ui);}
.author-bio .role{font-size:var(--text-xs);color:var(--body-mid);margin-bottom:6px;}
.author-bio p{font-size:var(--text-sm);line-height:var(--leading-body);color:var(--body);max-width:56ch;}
.back-blog{display:inline-block;margin-top:28px;font-size:var(--text-sm);font-weight:600;color:var(--primary);text-decoration:none;}

/* Read next */
.readnext{margin-top:8px;}
.readnext .fh{
  font-size:var(--text-sm);font-weight:600;letter-spacing:var(--track-label);text-transform:uppercase;
  color:var(--body-mid);margin-bottom:18px;
}

/* ===================== Case study detail ===================== */
.post-body.wide{max-width:900px;}
.cs-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:36px 0 12px;}
.cs-stat{background:var(--canvas);border:1px solid var(--hairline);border-radius:var(--r-md);padding:20px 22px;}
.band-cream .cs-stat{background:var(--canvas);}
.cs-stat .label{font-family:'Mona Sans',sans-serif;font-size:var(--text-xs);font-weight:600;letter-spacing:var(--track-label);text-transform:uppercase;color:var(--body-mid);}
.cs-stat .value{font-family:'Mona Sans',sans-serif;font-weight:500;font-size:var(--text-xl);line-height:var(--leading-sub);letter-spacing:var(--track-display);color:var(--ink);margin-top:8px;}
.cs-stat .sub{font-size:var(--text-xs);line-height:var(--leading-ui);color:var(--body-mid);margin-top:4px;}
@media (max-width:820px){.cs-stats{grid-template-columns:1fr 1fr;}}
@media (max-width:460px){.cs-stats{grid-template-columns:1fr;}}

.post-figure{margin:34px 0;}
.post-figure img{width:100%;display:block;border:1px solid var(--hairline);border-radius:var(--r-md);background:var(--canvas-soft);}
.post-figure svg{width:100%;height:auto;display:block;border:1px solid var(--hairline);border-radius:var(--r-md);background:var(--canvas);}
.post-figure figcaption{font-size:var(--text-xs);line-height:var(--leading-ui);color:var(--body-mid);text-align:center;margin-top:10px;}
.figure-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:34px 0;}
.figure-grid .post-figure{margin:0;}
@media (max-width:640px){.figure-grid{grid-template-columns:1fr;}}

/* ===================== Bento grid (home) ===================== */
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.tile{
  background:var(--canvas);border:1px solid var(--hairline);
  border-radius:var(--r-md);padding:28px;
  display:flex;flex-direction:column;text-decoration:none;
  transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease;
}
a.tile:hover{transform:translateY(-3px);border-color:var(--body-mid);box-shadow:0 12px 32px rgba(32,21,21,0.06);}
.tile .t-label{
  font-family:'Mona Sans',sans-serif;font-size:var(--text-sm);font-weight:600;
  letter-spacing:var(--track-label);text-transform:uppercase;color:var(--body-mid);margin-bottom:14px;
}
.tile h3{font-size:var(--text-xl);font-weight:600;line-height:var(--leading-sub);letter-spacing:var(--track-display);margin-bottom:8px;}
.tile p{font-size:var(--text-base);line-height:var(--leading-body);color:var(--body);}
.tile .t-metric{
  font-family:'Mona Sans',sans-serif;font-weight:500;font-size:var(--text-2xl);
  letter-spacing:var(--track-display);line-height:var(--leading-sub);color:var(--ink);
  margin-top:auto;padding-top:20px;
}
.tile .t-metric span{display:block;font-family:'Inter',sans-serif;font-size:var(--text-sm);font-weight:400;color:var(--body-mid);margin-top:2px;letter-spacing:0;}
.tile .t-more{margin-top:14px;font-size:var(--text-sm);font-weight:600;color:var(--primary);}
.tile-lg{grid-column:span 2;}
.tile-dark{background:var(--ink);border-color:var(--ink);color:var(--on-primary);}
.tile-dark h3{color:var(--on-primary);}
.tile-dark p{color:var(--mute);}
.tile-dark .t-metric{color:var(--on-primary);}
.tile-lg h3{font-family:'Mona Sans',sans-serif;font-weight:500;font-size:var(--text-2xl);}
@media (max-width:880px){.bento{grid-template-columns:1fr 1fr;}.tile-lg{grid-column:span 2;}}
@media (max-width:560px){.bento{grid-template-columns:1fr;}.tile-lg{grid-column:span 1;}}

/* staggered reveals for grid children */
.bento .tile{opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s ease,border-color .18s ease,box-shadow .18s ease;}
.bento.in .tile{opacity:1;transform:none;}
.bento.in .tile:nth-child(2){transition-delay:.07s;}
.bento.in .tile:nth-child(3){transition-delay:.14s;}
.bento.in .tile:nth-child(4){transition-delay:.21s;}
.bento.in .tile:nth-child(5){transition-delay:.28s;}
.bento.in a.tile:hover{transform:translateY(-3px);transition-delay:0s;}
@media (prefers-reduced-motion:reduce){.bento .tile{opacity:1;transform:none;transition:none;}}

/* ===================== Product marquee (home proof) ===================== */
.marquee{
  overflow:hidden;position:relative;padding:8px 0 4px;
  -webkit-mask-image:linear-gradient(to right,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(to right,transparent,#000 8%,#000 92%,transparent);
}
.marquee-track{display:flex;gap:20px;width:max-content;animation:marquee 48s linear infinite;}
.marquee:hover .marquee-track{animation-play-state:paused;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.shot{
  display:block;flex:none;width:min(440px,78vw);text-decoration:none;
  transition:transform .18s ease;
}
.shot:hover{transform:translateY(-4px);}
.shot img{
  width:100%;height:auto;aspect-ratio:8/5;object-fit:cover;object-position:top center;
  border:1px solid var(--hairline);border-radius:var(--r-md);
  background:var(--canvas);box-shadow:0 10px 28px rgba(32,21,21,0.05);
}
.shot .cap{
  display:flex;gap:8px;align-items:baseline;margin-top:10px;padding:0 2px;
  font-size:var(--text-xs);color:var(--body-mid);
}
.shot .cap b{font-size:var(--text-sm);font-weight:600;color:var(--ink);}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none;flex-wrap:wrap;width:auto;}}

/* ===================== Animated service rows (home) ===================== */
.svc-row{position:relative;grid-template-columns:56px 1fr 1.1fr 40px;align-items:baseline;}
.svc-row .num{
  font-family:'Mona Sans',sans-serif;font-size:var(--text-sm);font-weight:600;
  color:var(--body-mid);letter-spacing:var(--track-label);
}
.svc-row .go{
  font-size:var(--text-lg);color:var(--primary);justify-self:end;
  opacity:0;transform:translateX(-8px);transition:opacity .18s ease,transform .18s ease;
}
a.svc-row:hover .go{opacity:1;transform:none;}
a.svc-row:hover{background:linear-gradient(to right,transparent,rgba(255,79,0,0.035),transparent);}
.svc-list .svc-row{opacity:0;transform:translateY(10px);transition:opacity .5s ease,transform .5s ease,background .15s;}
.svc-list.in .svc-row{opacity:1;transform:none;}
.svc-list.in .svc-row:nth-child(2){transition-delay:.06s;}
.svc-list.in .svc-row:nth-child(3){transition-delay:.12s;}
.svc-list.in .svc-row:nth-child(4){transition-delay:.18s;}
.svc-list.in .svc-row:nth-child(5){transition-delay:.24s;}
@media (max-width:720px){.svc-row{grid-template-columns:40px 1fr;} .svc-row .desc{grid-column:2;} .svc-row .go{display:none;}}
@media (prefers-reduced-motion:reduce){.svc-list .svc-row{opacity:1;transform:none;transition:none;}}

/* tile glyphs */
.tile .glyph{width:40px;height:40px;margin-bottom:18px;}
.tile .glyph svg{width:100%;height:100%;display:block;}
