/* ──────────────────────────────────────────────────────────
   Plum Networks — shared site styles
   Loaded by every page. Page-specific bits stay inline.
   ────────────────────────────────────────────────────────── */

:root{
  --bg: #ffffff;
  --bg-2: #f7f6f2;
  --bg-3: #efece5;
  --ink: #14131a;
  --ink-2: #34323d;
  --ink-3: #6b6875;
  --line: #e6e3da;
  --plum: #5b2a6b;
  --plum-2: #6f3681;
  --plum-soft: #f3e9f6;
  --amber: #f5b13d;
  --lime: #c9e265;
  --sky: #9ad4e8;
  --coral: #ef7a6a;
  --max: 1280px;
  --serif: "Inter Tight", Arial, Helvetica, sans-serif;
  --sans: "Inter Tight", Arial, Helvetica, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, SFMono-Regular, monospace;
}

/* Wider container on large screens — stops everything looking islanded on 1920+ monitors */
@media (min-width: 1600px){
  :root { --max: 1440px; }
}
@media (min-width: 1920px){
  :root { --max: 1520px; }
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  font-size:17px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
::selection{background:var(--plum);color:var(--bg)}
a{color:inherit}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;letter-spacing:-0.025em;line-height:1.05;margin:0}
p{margin:0}

.wrap{max-width:var(--max);margin:0 auto;padding:0 32px}

.eyebrow{
  font-family:var(--mono);
  font-size:11px;
  font-weight:500;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-3);
}
.eyebrow .dot{
  display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--amber);margin-right:8px;vertical-align:middle;
  transform:translateY(-1px);
}

/* ─── NAV ─── */
.nav{
  position:sticky;top:0;z-index:50;
  background:color-mix(in oklch, var(--bg) 88%, transparent);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid color-mix(in oklch, var(--line) 60%, transparent);
}
.nav-inner{
  max-width:var(--max);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 32px;gap:24px;
}
.brand{
  display:flex;align-items:center;gap:10px;
  font-family:var(--sans);font-size:20px;font-weight:600;letter-spacing:-0.02em;
  text-decoration:none;color:var(--ink);
  flex-shrink:0;
}
.brand img{height:72px;width:auto;display:block}
.brand-foot img{height:48px;width:auto;display:block}

.nav-list{
  display:flex;gap:4px;list-style:none;margin:0;padding:0;align-items:center;
}
.nav-list > li{position:relative}
.nav-list a, .nav-trigger{
  display:inline-flex;align-items:center;gap:6px;
  text-decoration:none;color:var(--ink-2);font-size:14px;
  font-weight:450;padding:8px 14px;border-radius:8px;
  background:transparent;border:0;cursor:pointer;font-family:inherit;
  transition:background .15s, color .15s;
}
.nav-list a:hover, .nav-trigger:hover, .nav-list li:hover .nav-trigger{
  color:var(--plum);background:var(--bg-2);
}
.nav-list a[aria-current="page"]{
  color:var(--plum);font-weight:500;
}
.nav-list a[aria-current="page"]::after{
  content:"";position:absolute;bottom:2px;left:14px;right:14px;
  height:2px;background:var(--plum);border-radius:1px;
}

/* dropdown */
.nav-drop{
  position:absolute;top:calc(100% + 4px);left:0;
  background:var(--bg);
  border:1px solid var(--line);border-radius:14px;
  padding:18px;min-width:520px;
  display:grid;grid-template-columns:1fr 1fr;gap:18px;
  box-shadow:0 24px 48px -16px rgba(20,19,26,.12), 0 8px 16px -8px rgba(20,19,26,.06);
  opacity:0;visibility:hidden;transform:translateY(-4px);
  transition:opacity .15s, transform .15s, visibility .15s;
  z-index:60;
}
.nav-list li:hover .nav-drop,
.nav-list li:focus-within .nav-drop,
.nav-list li.open .nav-drop{
  opacity:1;visibility:visible;transform:none;
}
.nav-list li.open .nav-trigger{color:var(--plum);background:var(--bg-2)}
.nav-drop h5{
  font-family:var(--mono);font-size:10px;font-weight:500;
  letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-3);
  margin:0 0 8px 8px;
}
.nav-drop ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:0}
.nav-drop ul a{
  display:block;padding:8px 8px;border-radius:8px;
  font-size:14px;color:var(--ink);font-weight:450;line-height:1.3;
}
.nav-drop ul a span{display:block;color:var(--ink-3);font-size:12px;font-weight:400;margin-top:2px}
.nav-drop ul a:hover{background:var(--bg-2);color:var(--plum)}

.nav .cta{
  background:var(--ink);color:var(--bg);
  padding:9px 16px;border-radius:999px;
  font-size:13.5px;font-weight:500;text-decoration:none;
  flex-shrink:0;
  transition:background .2s;
}
.nav .cta:hover{background:var(--plum)}

.nav-mobile{display:none;background:none;border:0;font-size:22px;cursor:pointer;padding:4px 8px;color:var(--ink)}
@media (max-width: 980px){
  .nav-list{display:none}
  .nav-mobile{display:inline-flex}
  .nav-list.open{
    display:flex;flex-direction:column;align-items:stretch;
    position:absolute;top:100%;left:0;right:0;
    background:var(--bg);border-bottom:1px solid var(--line);
    padding:14px 24px 22px;gap:2px;
  }
  .nav-list.open .nav-drop{
    position:static;opacity:1;visibility:visible;transform:none;
    min-width:0;display:block;box-shadow:none;border:0;padding:8px 12px;
    background:var(--bg-2);margin:6px 0 12px;
  }
  .nav-list.open .nav-drop h5{margin-top:8px}
}

/* ─── BUTTONS ─── */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:999px;
  font-size:15px;font-weight:500;
  text-decoration:none;border:1px solid transparent;
  transition:transform .2s ease, background .2s, color .2s, border-color .2s;
  cursor:pointer;font-family:inherit;
}
.btn-primary{background:var(--ink);color:var(--bg)}
.btn-primary:hover{background:var(--plum)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink);background:var(--bg-2)}
.btn .arr{transition:transform .2s ease}
.btn:hover .arr{transform:translateX(3px)}

/* ─── SECTIONS ─── */
.section{padding:120px 0;position:relative;background:var(--bg)}
.section.tone-2{background:var(--bg-2)}
.section.tone-3{background:var(--bg-3)}
.section.tone-ink{background:var(--ink);color:var(--bg)}
.section.tone-ink .eyebrow{color:color-mix(in oklch, var(--bg) 55%, transparent)}

.section-head{
  display:grid;grid-template-columns: 1fr 1.2fr;gap:48px;
  align-items:end;margin-bottom:64px;
}
@media (max-width:880px){.section-head{grid-template-columns:1fr;gap:24px}}
.section-head h2{
  font-size:clamp(44px, 6vw, 80px);letter-spacing:-0.02em;
}
.section-head h2 i{color:var(--plum); font-style:italic}
.section-lede{
  color:var(--ink-2);font-size:19px;line-height:1.5;text-wrap:pretty;
  max-width:520px;
}

/* ─── PAGE HEADER (sub-pages) ─── */
.page-head{
  padding:80px 0 64px;position:relative;overflow:hidden;
  background:linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 100%);
}
.page-head::before{
  content:"";position:absolute;top:40px;right:-100px;
  width:280px;height:280px;border-radius:50%;background:var(--amber);opacity:.7;
}
.page-head .wrap{position:relative;z-index:1}
.crumbs{
  font-family:var(--mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--ink-3);margin-bottom:18px;
}
.crumbs a{color:var(--ink-3);text-decoration:none}
.crumbs a:hover{color:var(--plum)}
.crumbs span{margin:0 8px;color:var(--ink-3);opacity:.5}
.page-head h1{
  font-size:clamp(48px, 7vw, 96px);
  line-height:0.98;letter-spacing:-0.035em;
  max-width:18ch;
  font-weight:600;
}
.page-head h1 i{color:var(--plum); font-style:italic; font-weight:700}
.page-head .lede{
  margin-top:24px;max-width:620px;
  font-size:20px;line-height:1.5;color:var(--ink-2);text-wrap:pretty;
}
.page-head-cta{display:flex;gap:12px;margin-top:32px;flex-wrap:wrap}

/* ─── FOOTER ─── */
footer{border-top:1px solid var(--line);padding:48px 0 36px;background:var(--bg)}
.foot-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:32px;
}
@media (max-width:980px){.foot-grid{grid-template-columns:1fr 1fr;gap:24px}}
.foot-col h4{font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.foot-col ul{list-style:none;padding:0;margin:14px 0 0;display:flex;flex-direction:column;gap:10px;font-size:14px}
.foot-col a{text-decoration:none;color:var(--ink-2)}
.foot-col a:hover{color:var(--plum)}
.foot-bot{
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  border-top:1px solid var(--line);margin-top:48px;padding-top:24px;
  font-size:12px;color:var(--ink-3);font-family:var(--mono);
  flex-wrap:wrap;
}

/* ─── REVEAL ─── */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* ─── GRAIN ─── */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;mix-blend-mode:multiply;
  background-image:
    radial-gradient(circle at 1px 1px, oklch(0.18 0.02 320 / 0.06) 1px, transparent 0);
  background-size:3px 3px;
}
main{position:relative;z-index:1}

/* ─── SERVICE PAGE: feature grid ─── */
.feature-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:24px;
}
@media (max-width:880px){.feature-grid{grid-template-columns:1fr}}
.feature{
  background:var(--bg);border:1px solid var(--line);border-radius:20px;
  padding:32px;display:flex;flex-direction:column;gap:14px;
  transition:border-color .2s;
}
.feature:hover{border-color:var(--ink-2)}
.feature .f-num{font-family:var(--mono);font-size:11px;letter-spacing:0.14em;color:var(--ink-3)}
.feature h3{font-size:24px;letter-spacing:-0.02em;margin:0;font-weight:600}
.feature p{color:var(--ink-2);font-size:15.5px;line-height:1.55}
.feature ul{
  list-style:none;padding:0;margin:6px 0 0;
  display:flex;flex-direction:column;gap:8px;
  font-size:14px;color:var(--ink-2);
}
.feature ul li{padding-left:18px;position:relative;line-height:1.45}
.feature ul li::before{
  content:"";position:absolute;left:0;top:8px;
  width:8px;height:8px;border-radius:2px;background:var(--plum);
}

/* ─── PROCESS / STEPS ─── */
.steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:step;
}
@media (max-width:880px){.steps{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.steps{grid-template-columns:1fr}}
.step{
  background:var(--bg);border:1px solid var(--line);border-radius:16px;
  padding:28px 24px;position:relative;
}
.step .n{
  font-family:var(--mono);font-size:11px;letter-spacing:0.14em;color:var(--plum);
  font-weight:500;
}
.step h4{font-size:18px;margin:10px 0 8px;letter-spacing:-0.02em;font-weight:600}
.step p{font-size:14px;color:var(--ink-3);line-height:1.5}

/* ─── PRICING BAND ─── */
.pricing-band{
  background:var(--ink);color:var(--bg);
  border-radius:24px;padding:48px;
  display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:center;
}
@media (max-width:880px){.pricing-band{grid-template-columns:1fr;padding:32px}}
.pricing-band .eyebrow{color:color-mix(in oklch, var(--bg) 55%, transparent)}
.pricing-band h3{font-size:36px;letter-spacing:-0.02em;margin-top:12px;font-weight:600;line-height:1.1}
.pricing-band h3 i{color:var(--amber);font-style:italic}
.pricing-band p{color:color-mix(in oklch, var(--bg) 75%, transparent);margin-top:14px;font-size:15px}
.pricing-band .price-card{
  background:color-mix(in oklch, var(--bg) 10%, transparent);
  border:1px solid color-mix(in oklch, var(--bg) 20%, transparent);
  border-radius:16px;padding:24px;
}
.pricing-band .price-card .from{font-family:var(--mono);font-size:11px;letter-spacing:0.14em;color:color-mix(in oklch, var(--bg) 60%, transparent)}
.pricing-band .price-card .amount{
  font-family:var(--sans);font-size:48px;line-height:1;font-weight:600;letter-spacing:-0.03em;
  margin-top:8px;
}
.pricing-band .price-card .amount span{font-size:14px;font-weight:400;color:color-mix(in oklch, var(--bg) 65%, transparent);margin-left:4px}
.pricing-band .price-card .note{margin-top:14px;font-size:13px;color:color-mix(in oklch, var(--bg) 70%, transparent)}

/* ─── QUOTE (inline / single) ─── */
.quote-inline{
  background:var(--plum-soft);border-radius:24px;padding:48px;
  display:grid;grid-template-columns:120px 1fr;gap:32px;align-items:start;
}
@media (max-width:760px){.quote-inline{grid-template-columns:1fr;gap:18px;padding:32px}}
.quote-inline q{
  quotes:"\201C" "\201D";
  font-family:var(--sans);font-weight:500;font-size:28px;line-height:1.3;
  letter-spacing:-0.02em;color:var(--ink);text-wrap:pretty;
}
.quote-inline .who{margin-top:18px;font-size:14px;color:var(--ink-3)}
.quote-inline .who b{color:var(--ink);font-weight:500}
.quote-inline image-slot{display:block;width:120px;height:120px}

/* ─── FAQ ─── */
.faq-list{border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{
  list-style:none;cursor:default;
  display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;
  padding:28px 8px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-q{font-family:var(--sans);font-weight:600;font-size:22px;line-height:1.25;letter-spacing:-0.02em;color:var(--ink);margin:0}
.faq-toggle{
  width:36px;height:36px;border-radius:50%;
  border:1px solid var(--line);
  display:grid;place-items:center;color:var(--ink-2);
  font-family:var(--mono);font-size:18px;
  transition:all .2s;
}
.faq-item[open] .faq-toggle{background:var(--ink);color:var(--bg);border-color:var(--ink);transform:rotate(45deg)}
.faq-a{
  padding: 0 8px 32px;
  color:var(--ink-2);font-size:17px;line-height:1.6;
  max-width:780px;
}
.faq-a strong{color:var(--ink);font-weight:500}

/* ─── FINAL CTA ─── */
.final{padding:140px 0 120px;text-align:center;position:relative;background:var(--bg-2)}
.final h2{
  font-size:clamp(56px, 8vw, 120px);
  line-height:0.95;letter-spacing:-0.025em;
  max-width:14ch;margin:24px auto 0;
}
.final h2 i{color:var(--plum); font-style:italic}
.final .lede{
  margin:28px auto 0;max-width:540px;
  color:var(--ink-2);font-size:18px;
}
.final-cta{display:inline-flex;gap:12px;margin-top:36px;flex-wrap:wrap;justify-content:center}

/* ─── RELATED LINK CARDS ─── */
.related-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:32px;
}
@media (max-width:880px){.related-grid{grid-template-columns:1fr}}
.related-card{
  background:var(--bg);border:1px solid var(--line);border-radius:16px;
  padding:24px;text-decoration:none;color:inherit;
  display:flex;flex-direction:column;gap:8px;
  transition:border-color .2s, transform .2s;
}
.related-card:hover{border-color:var(--ink);transform:translateY(-2px)}
.related-card .tag{font-family:var(--mono);font-size:11px;letter-spacing:0.14em;color:var(--plum);text-transform:uppercase}
.related-card h4{font-size:20px;letter-spacing:-0.02em;font-weight:600;margin:0}
.related-card p{font-size:14px;color:var(--ink-3);line-height:1.45;margin:0}
.related-card .arr{margin-top:auto;font-size:13px;color:var(--ink-2);padding-top:14px}

/* image-slot defaults */
image-slot{background:var(--bg-3);border-radius:16px}

/* ──────────────────────────────────────────────────────────
   v3 — PHOTOGRAPHY
   Branded photo slots + full-width showcase bands. Photos are
   dropped in by the client; the empty state stays tidy, the
   filled state carries a subtle plum treatment so any photo
   sits inside the palette.
   ────────────────────────────────────────────────────────── */

/* Subtle brand treatment on any dropped photo */
image-slot.brand-photo::part(image){ filter:saturate(0.9) contrast(1.03); }
image-slot.brand-photo[data-filled]::after{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(150deg,
    color-mix(in oklch, var(--plum) 30%, transparent) 0%,
    transparent 52%);
  mix-blend-mode:multiply;
}

/* Empty brand-photo slots read as an intentional, captioned frame
   rather than a raw dropzone */
image-slot.brand-photo{
  background:
    radial-gradient(120% 90% at 18% 12%, color-mix(in oklch, var(--plum-soft) 80%, transparent), transparent 60%),
    var(--bg-3);
}

/* Full-width photo showcase band */
.photo-band{ position:relative; }
.photo-band .pb-inner{ position:relative; border-radius:28px; overflow:hidden;
  box-shadow:0 24px 60px -32px color-mix(in oklch, var(--plum) 60%, transparent); }
.photo-band image-slot{ display:block; width:100%; height:auto; aspect-ratio:21/9; border-radius:28px; }
@media (max-width:760px){ .photo-band image-slot{ aspect-ratio:4/3; } }
.photo-band .pb-cap{
  position:absolute; left:0; right:0; bottom:0; z-index:2; pointer-events:none;
  padding:clamp(24px,3.4vw,44px); display:flex; flex-direction:column; gap:8px;
  color:#fff; border-radius:0 0 28px 28px;
  background:linear-gradient(0deg,
    color-mix(in oklch, var(--plum) 82%, #14131a 14%) 0%,
    color-mix(in oklch, var(--plum) 34%, transparent) 46%,
    transparent 100%);
  opacity:0; transition:opacity .35s ease;
}
.photo-band:has(image-slot[data-filled]) .pb-cap{ opacity:1; }
.photo-band .pb-cap .k{
  font-family:var(--mono); font-size:12px; letter-spacing:0.14em;
  text-transform:uppercase; opacity:.85;
}
.photo-band .pb-cap .t{
  font-family:var(--serif); font-size:clamp(22px,2.8vw,38px);
  font-weight:600; letter-spacing:-0.02em; line-height:1.06; max-width:24ch;
}

/* Portrait / inset brand photo (e.g. contact location) */
.photo-inset{ position:relative; }
.photo-inset image-slot{ display:block; width:100%; height:auto; border-radius:20px; }

/* Image-beside-copy row — weaves photography into content instead of
   leaving it in standalone bands. Put .ms-media before or after .ms-copy
   in the markup to flip sides. */
.media-split{
  display:grid; grid-template-columns:1fr 1fr;
  gap:clamp(32px,5vw,64px); align-items:center;
}
@media (max-width:860px){ .media-split{ grid-template-columns:1fr; gap:28px; } }
.media-split .ms-media image-slot{
  display:block; width:100%; height:auto; aspect-ratio:4/3; border-radius:24px;
}
.media-split .ms-copy h2{
  font-size:clamp(30px,3.4vw,46px); line-height:1.05; letter-spacing:-0.03em;
}
.media-split .ms-copy h2 i{ color:var(--plum); font-style:italic; font-weight:700; }
.media-split .ms-copy p{
  margin-top:18px; color:var(--ink-2); font-size:18px; line-height:1.55;
  max-width:46ch; text-wrap:pretty;
}
.media-split .ms-copy .p-cta{
  display:inline-block; margin-top:22px; font-weight:500; color:var(--plum);
  text-decoration:none; border-bottom:2px solid color-mix(in oklch, var(--plum) 35%, transparent);
  padding-bottom:2px;
}
.media-split .ms-copy .p-cta:hover{ border-color:var(--plum); }

/* ──────────────────────────────────────────────────────────
   PRINT STYLES — service pages, blog posts and FAQ should print cleanly
   ────────────────────────────────────────────────────────── */
@media print {
  /* hide all the chrome */
  .nav, footer, .grain, .ticker, .tweaks-panel,
  .nav-mobile, .hero-cta, .page-head-cta,
  .final-cta, .post-cta, .related-grid,
  .reveal{ display: none !important; opacity: 1 !important; transform: none !important; }

  /* remove decorative shapes */
  .hero::before, .hero::after,
  .page-head::before, .post-head::before{ display: none !important; }

  /* general */
  *{ box-shadow: none !important; text-shadow: none !important; }
  body{
    background: white !important; color: black !important;
    font-size: 11pt; line-height: 1.45;
  }
  .wrap{ max-width: 100% !important; padding: 0 !important; }
  .section, .page-head, .post-head, .article, .final,
  .post-hero-img, .post-hero{
    padding: 12pt 0 !important; background: white !important;
  }

  /* type for print */
  h1{ font-size: 28pt !important; line-height: 1.05; margin-bottom: 8pt; }
  h2{ font-size: 18pt !important; line-height: 1.1; margin: 16pt 0 6pt; page-break-after: avoid; }
  h3{ font-size: 13pt !important; margin: 12pt 0 4pt; page-break-after: avoid; }
  p, li{ font-size: 11pt !important; orphans: 3; widows: 3; }
  .hero h1, .page-head h1, .post-head h1{ font-size: 28pt !important; }
  .hero h1 i, .page-head h1 i, .post-head h1 i, h2 i, h3 i{
    color: black !important; font-style: italic; font-weight: 700;
  }

  /* show link URLs after the link text */
  a[href^="http"]::after,
  a[href^="mailto"]::after,
  a[href^="tel"]::after{
    content: " (" attr(href) ")";
    font-size: 9pt; color: #444; font-weight: 400;
  }
  a[href^="#"]::after{ content: ""; }
  a{ color: black !important; text-decoration: underline; }

  /* open all FAQs when printing */
  details{ display: block !important; }
  details > summary{ display: block !important; padding: 0 !important; }
  details > summary::-webkit-details-marker{ display: none; }
  details:not([open]) > summary ~ *{ display: block !important; }
  .faq-toggle{ display: none !important; }
  .faq-q{ font-size: 13pt !important; margin: 12pt 0 4pt; font-weight: 700; }
  .faq-a{ padding: 0 0 8pt !important; }

  /* tighten cards / features */
  .feature, .pillar, .quote, .quote-inline, .step,
  .pricing-band, .compare, .why, .related-card{
    background: white !important; color: black !important;
    border: 1px solid #ccc !important; border-radius: 0 !important;
    padding: 10pt !important; page-break-inside: avoid;
  }
  .pillar.dark, .why, .pricing-band, .post-cta{
    background: white !important; color: black !important;
  }
  .pillar.dark *, .why *, .pricing-band *, .post-cta *{ color: black !important; }

  /* image-slot placeholders — hide if empty, show photo if filled */
  image-slot:not(:has(img)){ display: none !important; }
  image-slot img{ max-width: 100% !important; height: auto !important; page-break-inside: avoid; }

  /* breaks */
  article, section{ page-break-inside: avoid; }
  .post-head, .page-head{ page-break-after: avoid; }
  .post-tldr, .callout{ page-break-inside: avoid; border-radius: 0 !important; }
  .wa-fab{ display: none !important; }
}

/* ─── WHATSAPP FLOATING BUTTON ─── */
.wa-fab{
  position:fixed;right:20px;bottom:20px;z-index:60;
  display:inline-flex;align-items:center;gap:0;
  height:60px;border-radius:999px;
  background:#25D366;color:#fff;text-decoration:none;
  box-shadow:0 8px 24px -6px rgba(37,211,102,.5), 0 4px 12px -4px rgba(0,0,0,.2);
  overflow:hidden;
  transition:box-shadow .25s, transform .2s;
  -webkit-tap-highlight-color:transparent;
}
.wa-fab:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 28px -6px rgba(37,211,102,.6), 0 6px 14px -4px rgba(0,0,0,.25);
}
.wa-icon{
  flex-shrink:0;width:60px;height:60px;
  display:grid;place-items:center;
}
.wa-label{
  max-width:0;opacity:0;white-space:nowrap;
  font-family:var(--sans);font-size:15px;font-weight:600;letter-spacing:-0.01em;
  transition:max-width .3s ease, opacity .2s ease, padding .3s ease;
  padding:0;
}
.wa-fab:hover .wa-label,
.wa-fab:focus-visible .wa-label{
  max-width:160px;opacity:1;padding:0 4px 0 20px;
}
/* gentle attention pulse on first load */
@keyframes wa-pop{
  0%{transform:scale(0) translateY(20px);opacity:0}
  60%{transform:scale(1.1) translateY(0);opacity:1}
  100%{transform:scale(1) translateY(0);opacity:1}
}
.wa-fab{animation:wa-pop .5s cubic-bezier(.3,.7,.4,1.3) .6s both}
@media (max-width:520px){
  .wa-fab{right:16px;bottom:16px;height:54px}
  .wa-icon{width:54px;height:54px}
  /* on small screens keep the label hidden to save space — icon only */
  .wa-fab:hover .wa-label,.wa-fab:focus-visible .wa-label{max-width:0;opacity:0;padding:0}
}
@media (prefers-reduced-motion: reduce){
  .wa-fab{animation:none}
}


/* ─── Monogram avatars — branded placeholders for customer testimonials ─── */
.mono-avatar{
  display:flex;align-items:center;justify-content:center;
  font-family:var(--sans);font-weight:600;letter-spacing:-0.01em;
  line-height:1;user-select:none;flex-shrink:0;text-transform:uppercase;
  overflow:hidden;
}


/* ──────────────────────────────────────────────────────────
   MOBILE POLISH — small-phone refinements
   Tightens container padding, section rhythm, nav logo and touch
   comfort so every page reads cleanly on phones. Shared site-wide.
   ────────────────────────────────────────────────────────── */
@media (max-width:600px){
  .wrap{padding:0 20px}
  .nav-inner{padding:8px 20px;gap:12px}
  .brand img{height:50px}
  .nav .cta{padding:8px 13px;font-size:12.5px}
  .section{padding:72px 0}
  .section-head{margin-bottom:40px}
  .page-head{padding:52px 0 44px}
  .page-head h1{font-size:clamp(38px,10.5vw,58px);max-width:none}
  .page-head .lede{font-size:17px;margin-top:18px}
  .page-head-cta{gap:10px}
  .page-head-cta .btn{width:100%;justify-content:center}
  .section-head h2{font-size:clamp(38px,9vw,60px)}
  .section-lede{font-size:17px}
  .feature{padding:24px}
  .feature h3{font-size:22px}
  .pricing-band{padding:28px 22px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:22px}
  .foot-bot{flex-direction:column;align-items:flex-start;gap:10px}
}
@media (max-width:420px){
  .wrap{padding:0 16px}
  .nav-inner{padding:8px 16px}
  .foot-grid{grid-template-columns:1fr}
}

/* MOBILE POLISH — inline-grid collapses (contact form + case studies) */
@media (max-width:820px){
  .contact-split{grid-template-columns:1fr !important;gap:36px !important}
  .case-study{grid-template-columns:1fr !important;gap:28px !important;padding-bottom:48px !important;margin-bottom:48px !important}
  .case-study .mono-avatar{aspect-ratio:3/2 !important;font-size:64px !important}
}
