/* ============================================================
   GreenVitali — Shared design system (Apple HIG + Untitled UI)
   The home (index.html) keeps its inline CSS for now.
   This file mirrors the home tokens exactly.
============================================================ */

/* Material Symbols Outlined — variable font.
   Light weight (300) + opsz 24 to match Untitled UI aesthetic. */
@import url('https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@24,300,0,0&display=swap');

.material-symbols-outlined{
  font-family:'Material Symbols Outlined';
  font-weight:normal;
  font-style:normal;
  line-height:1;
  letter-spacing:normal;
  text-transform:none;
  display:inline-block;
  white-space:nowrap;
  word-wrap:normal;
  direction:ltr;
  -webkit-font-smoothing:antialiased;
  font-variation-settings:'FILL' 0,'wght' 300,'GRAD' 0,'opsz' 24;
  user-select:none;
  vertical-align:middle;
}

:root{
  /* Typography */
  --f-sans:-apple-system,BlinkMacSystemFont,'SF Pro Display','SF Pro Text','Inter',system-ui,'Segoe UI',Roboto,sans-serif;
  --f-serif:-apple-system,BlinkMacSystemFont,'SF Pro Display','SF Pro Text','Inter',system-ui,'Segoe UI',Roboto,sans-serif;
  --f-mono:ui-monospace,'SF Mono','Menlo','Monaco',Consolas,monospace;

  --fs-large-title:clamp(2.125rem,4.5vw,3.4rem);
  --fs-title-1:clamp(1.75rem,3vw,2.5rem);
  --fs-title-2:clamp(1.375rem,2vw,1.75rem);
  --fs-title-3:1.25rem;
  --fs-headline:1.0625rem;
  --fs-body:1.0625rem;
  --fs-callout:1rem;
  --fs-subheadline:0.9375rem;
  --fs-footnote:0.8125rem;
  --fs-caption-1:0.75rem;
  --fs-caption-2:0.6875rem;
  --fs-hero:clamp(3rem,7vw,6.5rem);

  --tracking-large-title:-0.022em;
  --tracking-title-1:-0.021em;
  --tracking-title-2:-0.019em;
  --tracking-title-3:-0.017em;
  --tracking-headline:-0.014em;
  --tracking-body:-0.011em;
  --tracking-callout:-0.009em;
  --tracking-subheadline:-0.006em;
  --tracking-footnote:0em;
  --tracking-caption:0.005em;

  --lh-title:1.07;
  --lh-headline:1.29;
  --lh-body:1.41;
  --lh-caption:1.33;

  /* Neutrals */
  --n-25:#fdfdfc;--n-50:#fafaf9;--n-100:#f4f4f2;--n-200:#e7e7e3;
  --n-300:#d1d1cb;--n-400:#a3a39b;--n-500:#76766f;--n-600:#54544f;
  --n-700:#3a3a36;--n-800:#23231f;--n-900:#171714;--n-950:#0e0e0c;

  /* Brand */
  --brand-25:#f0fbf5;--brand-50:#dcf6e6;--brand-100:#b8edd0;--brand-200:#7ddca8;
  --brand-300:#3fc77f;--brand-400:#15b163;--brand-500:#02a350;
  --brand-600:#028744;--brand-700:#036c38;--brand-800:#03552d;--brand-900:#024023;

  /* Semantic Labels */
  --label-primary:rgba(0,0,0,0.92);
  --label-secondary:rgba(60,60,67,0.72);
  --label-tertiary:rgba(60,60,67,0.5);
  --label-quaternary:rgba(60,60,67,0.32);
  --label-primary-dark:rgba(255,255,255,0.97);
  --label-secondary-dark:rgba(235,235,245,0.7);
  --label-tertiary-dark:rgba(235,235,245,0.45);
  --label-quaternary-dark:rgba(235,235,245,0.28);

  --fill-primary:rgba(120,120,128,0.2);
  --fill-secondary:rgba(120,120,128,0.16);
  --fill-tertiary:rgba(118,118,128,0.12);
  --fill-quaternary:rgba(116,116,128,0.08);

  --separator-opaque:#c6c6c8;
  --separator-non-opaque:rgba(60,60,67,0.18);
  --separator-on-dark:rgba(84,84,88,0.65);

  --bg-primary:#ffffff;
  --bg-secondary:#f2f2f7;
  --bg-grouped-primary:#f2f2f7;
  --bg-grouped-secondary:#ffffff;
  --bg-dark:#0e1411;
  --bg-dark-secondary:#161d19;
  --bg-dark-tertiary:#1d2622;

  --bg:var(--bg-primary);
  --bg-soft:var(--n-50);
  --text:var(--label-primary);
  --text-body:var(--label-secondary);
  --text-muted:var(--label-tertiary);
  --text-on-dark:var(--label-primary-dark);
  --text-body-on-dark:var(--label-secondary-dark);
  --text-muted-on-dark:var(--label-tertiary-dark);
  --border:var(--separator-non-opaque);
  --border-strong:var(--separator-opaque);
  --border-on-dark:var(--separator-on-dark);

  --primary:var(--brand-500);
  --primary-hover:var(--brand-600);
  --primary-soft:rgba(2,163,80,0.10);
  --primary-tint:rgba(2,163,80,0.16);

  /* Spacing 4pt */
  --sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;
  --sp-6:24px;--sp-8:32px;--sp-10:40px;--sp-12:48px;--sp-16:64px;
  --sp-20:80px;--sp-24:96px;--sp-32:128px;--sp-40:160px;
  --sp-section:clamp(80px,12vh,140px);

  /* Radii — Untitled UI scale (tighter, more crisp) */
  --r-xs:4px;       /* tags, badges */
  --r-sm:6px;       /* small chips, toggles */
  --r-md:8px;       /* default buttons, inputs */
  --r-lg:10px;      /* small cards, icons */
  --r-xl:12px;      /* medium cards, panels */
  --r-2xl:16px;     /* large cards */
  --r-3xl:20px;     /* extra-large cards, sheets */
  --r-4xl:24px;     /* hero cards, modal containers */
  --r-pill:9999px;
  --r-full:9999px;

  /* Untitled UI grid system tokens */
  --grid-cols-desktop:12;
  --grid-cols-tablet:8;
  --grid-cols-mobile:4;
  --grid-gap:24px;            /* default column gap */
  --grid-gap-lg:32px;         /* spacious sections */
  --container-narrow:768px;
  --container-default:1216px;
  --container-wide:1280px;

  /* Elevation */
  --el-1:0 1px 2px rgba(0,0,0,0.04),0 0 0 0.5px rgba(0,0,0,0.04);
  --el-2:0 1px 3px rgba(0,0,0,0.06),0 4px 12px rgba(0,0,0,0.04);
  --el-3:0 2px 4px rgba(0,0,0,0.06),0 12px 24px rgba(0,0,0,0.06);
  --el-4:0 4px 8px rgba(0,0,0,0.06),0 24px 48px rgba(0,0,0,0.10);
  --el-5:0 8px 16px rgba(0,0,0,0.08),0 32px 64px rgba(0,0,0,0.14);
  --el-floating:0 0.5px 1.5px rgba(0,0,0,0.07),0 6px 12px rgba(0,0,0,0.08),0 20px 32px rgba(0,0,0,0.06);

  /* Motion */
  --ease-out:cubic-bezier(0.25,0.46,0.45,0.94);
  --ease-out-expo:cubic-bezier(0.16,1,0.3,1);
  --ease-out-quart:cubic-bezier(0.25,1,0.5,1);
  --ease-in-out:cubic-bezier(0.42,0,0.58,1);
  --d-instant:0.1s;--d-fast:0.18s;--d-base:0.28s;--d-slow:0.5s;--d-reveal:0.8s;

  --max-w:1280px;
  --max-w-prose:720px;
  --gutter:clamp(20px,4vw,40px);
  --tap-min:44px;

  color-scheme:light;
}

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:auto;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility}
body{
  font-family:var(--f-sans);
  font-size:var(--fs-body);
  font-weight:400;
  line-height:var(--lh-body);
  letter-spacing:var(--tracking-body);
  color:var(--label-primary);
  background:var(--bg-primary);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-feature-settings:"ss01","cv01","cv11";
  overflow-x:hidden;
}
img,video,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent}
::selection{background:var(--brand-200);color:var(--n-900)}

h1,h2,h3,h4{font-family:var(--f-sans);font-weight:600;color:var(--label-primary)}
h1{font-size:var(--fs-large-title);line-height:var(--lh-title);letter-spacing:var(--tracking-large-title);font-weight:700}
h2{font-size:var(--fs-title-1);line-height:var(--lh-title);letter-spacing:var(--tracking-title-1)}
h3{font-size:var(--fs-title-2);line-height:1.15;letter-spacing:var(--tracking-title-2)}
h4{font-size:var(--fs-title-3);line-height:1.2;letter-spacing:var(--tracking-title-3)}

.serif-em{
  color:var(--primary);
}

.eyebrow{
  font-family:var(--f-sans);
  font-size:var(--fs-footnote);
  font-weight:600;
  color:var(--primary);
  letter-spacing:0.012em;
  line-height:1.3;
  display:inline-block;
}
.eyebrow.on-dark{color:var(--brand-300)}

/* Icons */
svg[stroke]{stroke-linecap:round;stroke-linejoin:round}

/* Focus ring HIG */
*:focus-visible{
  outline:none;
  box-shadow:0 0 0 4px var(--primary-tint),0 0 0 2px var(--primary);
  border-radius:6px;
}
:focus:not(:focus-visible){outline:none;box-shadow:none}
.skip{
  position:absolute;top:-100%;left:20px;
  background:var(--primary);color:#fff;
  padding:10px 16px;border-radius:var(--r-md);
  font-weight:600;z-index:9999;transition:top .2s;
}
.skip:focus{top:20px}
.sr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

/* ============================================================
   ANNOUNCE + NAV
============================================================ */
.announce{
  background:var(--bg-dark);
  color:var(--label-secondary-dark);
  padding:10px var(--gutter);
  font-size:var(--fs-footnote);
  text-align:center;
  letter-spacing:var(--tracking-footnote);
  border-bottom:0.5px solid var(--border-on-dark);
}
.announce strong{color:var(--label-primary-dark);font-weight:600}
.announce a{
  color:var(--brand-300);text-decoration:none;font-weight:500;
  margin-left:8px;display:inline-flex;align-items:center;gap:4px;
  transition:color var(--d-fast) var(--ease-out);
}
.announce a:hover{color:var(--brand-200)}
.announce a::after{content:'›';font-size:1.1em;transition:transform var(--d-base) var(--ease-out-expo);margin-left:2px}
.announce a:hover::after{transform:translateX(3px)}

/* NAV — full-width fixed top bar (mirrors homepage) */
.nav{
  position:fixed;top:0;left:0;right:0;
  z-index:80;
  pointer-events:none;
}
.nav-inner{
  pointer-events:auto;
  display:flex;align-items:center;justify-content:space-between;
  gap:var(--sp-6);
  height:64px;
  width:100%;
  padding:0 var(--gutter);
  background:rgba(255,255,255,0.85);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  border-bottom:0.5px solid var(--separator-non-opaque);
  transition:background var(--d-base) var(--ease-out),border-color var(--d-base);
}
.nav.on-dark-hero .nav-inner{
  background:rgba(14,20,17,0.55);
  border-bottom-color:rgba(255,255,255,0.08);
}
.nav.on-dark-hero .nav-link,
.nav.on-dark-hero .nav-login{color:var(--label-secondary-dark)}
.nav.on-dark-hero .nav-link:hover,
.nav.on-dark-hero .nav-login:hover{color:var(--label-primary-dark)}
.nav.on-dark-hero .nav-link:hover{background:rgba(255,255,255,0.08)}
.nav.on-dark-hero .nav-link.is-current{
  color:var(--label-primary-dark);
  background:rgba(255,255,255,0.10);
}
.nav.on-dark-hero .nav-logo-mark{filter:brightness(0) invert(1)}
.nav.on-dark-hero .nav-logo-text{color:var(--label-primary-dark)}

.nav-left{display:flex;align-items:center;gap:var(--sp-8)}
.nav-logo{
  display:inline-flex;align-items:center;
  text-decoration:none;color:inherit;
  transition:transform var(--d-fast) var(--ease-out);
}
.nav-logo:active{transform:scale(0.97)}
.nav-logo-mark{
  height:34px;width:auto;display:block;
  filter:brightness(0);
  transition:filter var(--d-base) var(--ease-out);
}
.nav.on-dark-hero .nav-logo-mark{filter:none}

.nav-links{display:flex;align-items:center;gap:2px}
.nav-link{
  font-size:var(--fs-footnote);font-weight:500;
  letter-spacing:var(--tracking-footnote);
  color:var(--label-secondary);
  padding:8px 14px;
  border-radius:var(--r-pill);
  transition:color var(--d-fast) var(--ease-out),background var(--d-fast) var(--ease-out);
}
.nav-link:hover{color:var(--label-primary);background:var(--fill-quaternary)}
.nav-link.is-current{color:var(--label-primary);background:var(--fill-quaternary)}
.nav-link:active{transform:scale(0.97)}

.nav-right{display:flex;align-items:center;gap:6px}
.nav-login{
  font-size:var(--fs-footnote);font-weight:500;
  color:var(--label-secondary);
  padding:8px 12px;
  border-radius:var(--r-pill);
  transition:color var(--d-fast) var(--ease-out),background var(--d-fast) var(--ease-out);
}
.nav-login:hover{color:var(--label-primary);background:var(--fill-quaternary)}

.nav-cta{
  background:var(--label-primary);color:var(--bg-primary);
  padding:10px 16px;
  border-radius:var(--r-pill);
  font-size:var(--fs-footnote);font-weight:600;
  letter-spacing:var(--tracking-footnote);
  transition:background var(--d-fast) var(--ease-out),transform var(--d-fast) var(--ease-out),box-shadow var(--d-base);
  white-space:nowrap;
  height:40px;display:inline-flex;align-items:center;
  box-shadow:inset 0 0.5px 0 rgba(255,255,255,0.16);
}
.nav-cta:hover{background:var(--primary)}
.nav-cta:active{transform:scale(0.96)}
.nav.on-dark-hero .nav-cta{background:var(--bg-primary);color:var(--label-primary)}
.nav.on-dark-hero .nav-cta:hover{background:var(--primary);color:#fff}

@media(max-width:900px){
  .nav-links{display:none}
  .nav-login{display:none}
  .nav-inner{height:56px}
  .nav-cta{padding:8px 14px}
}

/* ============================================================
   BUTTONS — Sistema unificado (3 níveis)
   1. PRIMARY    — ação principal (verde sólido)
   2. SECONDARY  — ação alternativa (auto-adapta light/dark via contexto)
   3. TERTIARY   — ação de baixa ênfase (transparente, link-like)
   Modificadores: .btn-lg, .btn-sm
   Contexto dark: descendente de [data-dark-hero] / .section-dark
                  OU classe .on-dark no próprio botão
============================================================ */

/* Base compartilhada */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:var(--tap-min);
  padding:11px 18px;
  border-radius:var(--r-pill);
  font-family:var(--f-sans);
  font-size:var(--fs-callout);
  font-weight:600;
  letter-spacing:var(--tracking-callout);
  line-height:1.2;
  border:0.5px solid transparent;
  white-space:nowrap;
  cursor:pointer;
  text-decoration:none;
  position:relative;
  transition:
    background var(--d-fast) var(--ease-out),
    color var(--d-fast) var(--ease-out),
    transform var(--d-fast) var(--ease-out),
    box-shadow var(--d-fast) var(--ease-out),
    border-color var(--d-fast) var(--ease-out);
}
.btn:active{transform:scale(0.96)}
.btn-lg{min-height:50px;padding:14px 22px;font-size:var(--fs-headline)}
.btn-sm{min-height:36px;padding:8px 14px;font-size:var(--fs-footnote)}

/* 1. PRIMARY */
.btn-primary{
  background:var(--primary);
  color:#fff;
  box-shadow:
    inset 0 0.5px 0 rgba(255,255,255,0.22),
    inset 0 -0.5px 0 rgba(0,0,0,0.08),
    0 1px 2px rgba(0,0,0,0.06);
}
.btn-primary:hover{
  background:var(--primary-hover);
  transform:translateY(-1px);
  box-shadow:
    inset 0 0.5px 0 rgba(255,255,255,0.22),
    inset 0 -0.5px 0 rgba(0,0,0,0.08),
    0 6px 16px rgba(2,163,80,0.28);
}

/* 2. SECONDARY — light context default */
.btn-secondary{
  background:var(--bg-primary);
  color:var(--label-primary);
  border-color:var(--separator-opaque);
  box-shadow:var(--el-1);
}
.btn-secondary:hover{
  background:var(--n-50);
  border-color:var(--n-400);
  transform:translateY(-1px);
}
/* SECONDARY — dark context (auto + alias retrocompat .btn-ghost-dark) */
[data-dark-hero] .btn-secondary,
.section-dark .btn-secondary,
.btn-secondary.on-dark,
.btn-ghost-dark{
  background:rgba(255,255,255,0.08);
  color:var(--text-on-dark);
  border-color:rgba(255,255,255,0.14);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  box-shadow:none;
}
[data-dark-hero] .btn-secondary:hover,
.section-dark .btn-secondary:hover,
.btn-secondary.on-dark:hover,
.btn-ghost-dark:hover{
  background:rgba(255,255,255,0.14);
  border-color:rgba(255,255,255,0.22);
  transform:translateY(-1px);
}

/* 3. TERTIARY — light context */
.btn-tertiary{
  background:transparent;
  color:var(--primary);
  padding:11px 12px;
  border-color:transparent;
}
.btn-tertiary:hover{
  background:var(--primary-soft);
  color:var(--primary-hover);
}
/* TERTIARY — dark context */
[data-dark-hero] .btn-tertiary,
.section-dark .btn-tertiary,
.btn-tertiary.on-dark{
  color:var(--brand-300);
}
[data-dark-hero] .btn-tertiary:hover,
.section-dark .btn-tertiary:hover,
.btn-tertiary.on-dark:hover{
  background:rgba(63,199,127,0.12);
  color:var(--brand-200);
}

/* Arrow icon shared */
.btn .arrow{transition:transform var(--d-base) var(--ease-out-expo)}
.btn:hover .arrow{transform:translateX(3px)}

/* ============================================================
   SECTIONS / UTILITIES
============================================================ */
.section{padding:var(--sp-section) var(--gutter)}
.section-inner{max-width:var(--max-w);margin:0 auto}
.section-soft{background:var(--bg-soft)}
.section-dark{background:var(--bg-dark);color:var(--text-on-dark)}

/* ============================================================
   GRID SYSTEM — Untitled UI 12-column
============================================================ */
.container{
  max-width:var(--container-default);
  margin:0 auto;
  padding-left:var(--gutter);
  padding-right:var(--gutter);
}
.container-narrow{max-width:var(--container-narrow);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter)}
.container-wide{max-width:var(--container-wide);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter)}

.grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:var(--grid-gap);
}
.grid-lg{gap:var(--grid-gap-lg)}
.grid-tight{gap:16px}

/* Column spans (desktop) */
.col-1{grid-column:span 1}
.col-2{grid-column:span 2}
.col-3{grid-column:span 3}
.col-4{grid-column:span 4}
.col-5{grid-column:span 5}
.col-6{grid-column:span 6}
.col-7{grid-column:span 7}
.col-8{grid-column:span 8}
.col-9{grid-column:span 9}
.col-10{grid-column:span 10}
.col-11{grid-column:span 11}
.col-12{grid-column:span 12}
.col-full{grid-column:1 / -1}

@media(max-width:960px){
  .grid{grid-template-columns:repeat(8,1fr)}
  .col-md-2{grid-column:span 2}
  .col-md-4{grid-column:span 4}
  .col-md-6{grid-column:span 6}
  .col-md-8{grid-column:span 8}
  /* Auto-collapse common spans on tablet */
  .col-4{grid-column:span 4}
  .col-6{grid-column:span 8}
  .col-8{grid-column:span 8}
}
@media(max-width:640px){
  .grid{grid-template-columns:repeat(4,1fr);gap:16px}
  .col-sm-2{grid-column:span 2}
  .col-sm-4{grid-column:span 4}
  /* Auto-collapse */
  .col-4,.col-6,.col-8,.col-12{grid-column:span 4}
}

/* Reveals */
[data-reveal]{opacity:0;will-change:transform,opacity;transition:opacity 1s var(--ease-out-expo),transform 1s var(--ease-out-expo)}
[data-reveal="up"]{transform:translateY(36px)}
[data-reveal="left"]{transform:translateX(-32px)}
[data-reveal="right"]{transform:translateX(32px)}
[data-reveal="scale"]{transform:scale(0.96)}
[data-reveal].is-visible{opacity:1;transform:none}
[data-reveal-delay="1"]{transition-delay:.08s}
[data-reveal-delay="2"]{transition-delay:.16s}
[data-reveal-delay="3"]{transition-delay:.24s}

/* Char split */
.char{display:inline-block;opacity:0;transform:translateY(110%);transition:opacity 1s var(--ease-out-expo),transform 1s var(--ease-out-expo)}
.is-visible .char{opacity:1;transform:translateY(0)}

/* Final CTA stripe */
.cta-stripe{
  background:var(--bg-dark);color:var(--text-on-dark);
  padding:32px var(--gutter);
  border-top:1px solid var(--border-on-dark);
}
.cta-stripe-inner{
  max-width:var(--max-w);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:var(--sp-6);
  flex-wrap:wrap;
}
.cta-stripe-title{
  font-size:var(--fs-title-2);font-weight:600;
  letter-spacing:-0.022em;line-height:1.2;
  color:var(--text-on-dark);max-width:32ch;
}
.cta-stripe-title .serif-em{color:var(--brand-300)}

/* ============================================================
   GLOBAL — BREADCRUMB (used by all internal pages)
============================================================ */
.breadcrumb{
  display:inline-flex;align-items:center;gap:8px;
  font-size:var(--fs-footnote);
  color:var(--label-tertiary);
  letter-spacing:var(--tracking-footnote);
}
.breadcrumb a{
  color:var(--label-secondary);
  text-decoration:none;
  transition:color var(--d-fast) var(--ease-out);
}
.breadcrumb a:hover{color:var(--label-primary)}
.breadcrumb svg{
  color:var(--label-quaternary);
  flex-shrink:0;
  opacity:0.7;
}
.breadcrumb [aria-current]{
  color:var(--label-primary);
  font-weight:500;
}
/* On-dark variant — when breadcrumb sits over dark hero */
.dark-hero .breadcrumb,
[data-dark-hero] .breadcrumb{
  color:rgba(235,235,245,0.5);
}
.dark-hero .breadcrumb a,
[data-dark-hero] .breadcrumb a{
  color:rgba(235,235,245,0.7);
}
.dark-hero .breadcrumb a:hover,
[data-dark-hero] .breadcrumb a:hover{color:var(--text-on-dark)}
.dark-hero .breadcrumb svg,
[data-dark-hero] .breadcrumb svg{
  color:rgba(235,235,245,0.35);
}
.dark-hero .breadcrumb [aria-current],
[data-dark-hero] .breadcrumb [aria-current]{
  color:var(--text-on-dark);
}

/* ============================================================
   GLOBAL — DARK PAGE HERO (sobre, servicos, case/service detail)
   Unified ambient gradients + dot grid texture + meta chips
============================================================ */
.page-hero{
  position:relative;
  background:var(--bg-dark);
  color:var(--text-on-dark);
  padding:128px var(--gutter) 88px;
  overflow:hidden;
  isolation:isolate;
}
@media(max-width:900px){.page-hero{padding:96px var(--gutter) 64px}}
.page-hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 70% 60% at 85% 25%,rgba(2,163,80,0.22) 0%,transparent 60%),
    radial-gradient(circle at 8% 85%,rgba(63,199,127,0.10) 0%,transparent 50%);
  z-index:0;
}
.page-hero::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,0.06) 1px,transparent 1px);
  background-size:24px 24px;
  mask-image:radial-gradient(ellipse 80% 70% at 50% 40%,#000 30%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 40%,#000 30%,transparent 75%);
  z-index:0;
}
.page-hero > *{position:relative;z-index:2}
.page-hero-inner{
  position:relative;
  z-index:2;
  max-width:var(--max-w);
  margin:0 auto;
}
.page-hero-top{
  display:flex;
  align-items:center;
  gap:var(--sp-6);
  margin-bottom:var(--sp-8);
  flex-wrap:wrap;
}
.page-hero h1{
  font-size:clamp(2.5rem,5.5vw,4rem);
  line-height:1.04;
  letter-spacing:-0.032em;
  color:var(--text-on-dark);
  font-weight:600;
  max-width:22ch;
  margin:14px 0 var(--sp-5);
}
.page-hero h1 .serif-em,
.page-hero h1 .accent{
  color:var(--brand-300);
  font-weight:400;
  font-style:normal;
}
.page-hero-sub{
  font-size:var(--fs-title-3);
  color:var(--text-body-on-dark);
  max-width:60ch;
  letter-spacing:var(--tracking-title-3);
  line-height:1.5;
  margin-bottom:var(--sp-8);
}

/* Hero chip group (unified across all dark-hero pages) */
.page-hero-meta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:var(--sp-3);
}
.page-hero-chip{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 16px;
  background:rgba(255,255,255,0.04);
  border:0.5px solid rgba(255,255,255,0.10);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border-radius:9999px;
  font-size:var(--fs-footnote);
  color:var(--text-body-on-dark);
  letter-spacing:-0.002em;
  font-weight:500;
  white-space:nowrap;
}
.page-hero-chip svg{
  color:var(--brand-300);
  width:14px;height:14px;
  flex-shrink:0;
}
.page-hero-chip-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--brand-300);
  box-shadow:0 0 12px rgba(63,199,127,0.6);
  animation:pageHeroPulse 2s ease-in-out infinite;
  flex-shrink:0;
}
@keyframes pageHeroPulse{
  0%,100%{opacity:0.6;transform:scale(1)}
  50%{opacity:1;transform:scale(1.4)}
}

/* ============================================================
   GLOBAL — FACTS STRIP (used by case + service detail pages)
============================================================ */
.facts-strip{
  position:relative;z-index:2;
  background:linear-gradient(180deg,rgba(20,22,21,0.55) 0%,rgba(255,255,255,0.94) 18%);
  padding:0 var(--gutter);
}
.facts-strip-inner{
  max-width:var(--max-w);
  margin:0 auto;
  background:var(--bg-primary);
  border-radius:24px;
  box-shadow:
    0 1px 2px rgba(15,23,42,0.04),
    0 12px 32px -6px rgba(15,23,42,0.10),
    inset 0 0 0 0.5px rgba(15,23,42,0.06);
  display:grid;
  grid-template-columns:repeat(4,1fr);
  overflow:hidden;
  position:relative;
  top:-44px;
}
.fact-item{
  padding:24px;
  border-right:0.5px solid var(--separator-non-opaque);
}
.fact-item:last-child{border-right:none}
.fact-label{
  font-size:11px;
  font-weight:600;
  color:var(--label-tertiary);
  letter-spacing:0.10em;
  text-transform:uppercase;
  margin-bottom:6px;
  display:block;
}
.fact-value{
  font-size:var(--fs-headline);
  font-weight:600;
  color:var(--label-primary);
  letter-spacing:var(--tracking-headline);
  line-height:1.3;
}
@media(max-width:900px){
  .facts-strip-inner{grid-template-columns:repeat(2,1fr)}
  .fact-item:nth-child(2){border-right:none}
  .fact-item:nth-child(-n+2){border-bottom:0.5px solid var(--separator-non-opaque)}
}
@media(max-width:520px){
  .facts-strip-inner{grid-template-columns:1fr}
  .fact-item{border-right:none;border-bottom:0.5px solid var(--separator-non-opaque)}
  .fact-item:last-child{border-bottom:none}
}

/* Footer */
.footer{background:var(--bg);padding:var(--sp-20) var(--gutter) var(--sp-6);border-top:1px solid var(--border)}
.footer-inner{max-width:var(--max-w);margin:0 auto}
.footer-top{
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:var(--sp-8);
  padding-bottom:var(--sp-16);border-bottom:1px solid var(--border);
}
.footer-brand-logo{display:inline-flex;align-items:center;margin-bottom:var(--sp-4);text-decoration:none;transition:opacity var(--d-fast) var(--ease-out)}
.footer-brand-logo:hover{opacity:0.7}
.footer-brand-logo img{height:32px;width:auto;display:block;filter:brightness(0)}
.footer-brand p{color:var(--text-body);font-size:var(--fs-footnote);max-width:30ch;line-height:1.55;margin-bottom:var(--sp-6)}
.footer-newsletter{display:flex;gap:var(--sp-2);max-width:320px}
.footer-newsletter input{
  flex:1;padding:11px 14px;border:0.5px solid var(--separator-opaque);
  border-radius:var(--r-md);font:inherit;font-size:var(--fs-footnote);
  color:var(--label-primary);background:var(--bg-primary);
  transition:border-color var(--d-fast),box-shadow var(--d-fast);min-height:var(--tap-min);
}
.footer-newsletter input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-tint)}
.footer-newsletter button{
  padding:0 16px;border-radius:var(--r-md);background:var(--primary);color:#fff;
  font-size:var(--fs-footnote);font-weight:600;letter-spacing:var(--tracking-footnote);
  min-height:var(--tap-min);
  transition:background var(--d-fast) var(--ease-out),transform var(--d-fast) var(--ease-out);
  box-shadow:inset 0 0.5px 0 rgba(255,255,255,0.22);
}
.footer-newsletter button:hover{background:var(--primary-hover)}
.footer-newsletter button:active{transform:scale(0.97)}
.footer-col h4{font-size:var(--fs-footnote);font-weight:600;color:var(--label-primary);margin-bottom:var(--sp-4);letter-spacing:-0.005em}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col a{color:var(--text-body);font-size:var(--fs-footnote);transition:color var(--d-fast)}
.footer-col a:hover{color:var(--label-primary)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:var(--sp-6);gap:var(--sp-4);flex-wrap:wrap;font-size:0.8125rem;color:var(--label-tertiary)}
.footer-socials{display:flex;gap:var(--sp-3)}
.footer-social{
  width:32px;height:32px;border-radius:50%;
  border:1px solid var(--separator-opaque);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-body);
  transition:background var(--d-fast),border-color var(--d-fast),color var(--d-fast);
}
.footer-social:hover{background:var(--primary);border-color:var(--primary);color:#fff}

/* ============================================================
   FOOTER POWERED-BY stripe — Grupo MW7 credit band
   Breaks out of parent footer's gutter + bottom padding
   to achieve a true full-width edge-to-edge stripe.
============================================================ */
.footer-powered{
  background:var(--n-100);
  border-top:0.5px solid var(--separator-non-opaque);
  padding:14px var(--gutter);
  margin:var(--sp-6) calc(var(--gutter) * -1) calc(var(--sp-6) * -1);
}
.footer-powered-inner{
  max-width:var(--max-w);
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  flex-wrap:wrap;
}
.footer-powered-label{
  font-size:11px;
  font-weight:500;
  color:var(--label-tertiary);
  letter-spacing:0.10em;
  text-transform:uppercase;
}
.footer-powered-logos{
  display:inline-flex;
  align-items:center;
  gap:24px;
  flex-wrap:wrap;
  justify-content:center;
}
.footer-powered-link{
  display:inline-flex;
  align-items:center;
  text-decoration:none;
  color:var(--label-primary);
  transition:
    color 0.35s cubic-bezier(0.16,1,0.3,1),
    transform 0.35s cubic-bezier(0.16,1,0.3,1);
}
.footer-powered-link:hover{
  transform:translateY(-1px);
}
.footer-powered-mark{
  display:block;
  height:18px;
  width:auto;
  opacity:0.85;
  transition:opacity 0.35s cubic-bezier(0.16,1,0.3,1);
}
/* Logos com aspect ratio mais largo (4:1) precisam de altura ligeiramente menor */
.footer-powered-mark--wide{height:14px}
.footer-powered-link:hover .footer-powered-mark{
  opacity:1;
}
@media(max-width:520px){
  .footer-powered-inner{flex-direction:column;gap:10px}
  .footer-powered-logos{gap:18px}
}
@media(max-width:900px){
  .footer-top{grid-template-columns:1fr 1fr;gap:var(--sp-8)}
  .footer-brand{grid-column:1/-1}
}

/* WhatsApp float */
.wa-float{
  position:fixed;bottom:20px;right:20px;
  width:56px;height:56px;border-radius:50%;
  background:#25d366;color:#fff;
  display:flex;align-items:center;justify-content:center;z-index:90;
  box-shadow:0 4px 12px rgba(0,0,0,0.15),0 1px 2px rgba(0,0,0,0.10);
  transition:transform .35s var(--ease-out-expo),box-shadow .35s;
}
.wa-float:hover{transform:scale(1.08);box-shadow:0 8px 24px rgba(0,0,0,0.20),0 2px 4px rgba(0,0,0,0.12)}
.wa-float svg{width:26px;height:26px}
.wa-float::before{
  content:'';position:absolute;inset:-4px;border-radius:50%;
  border:2px solid #25d366;opacity:0.6;animation:waPulse 2.5s ease-out infinite;
}
@keyframes waPulse{0%{transform:scale(0.95);opacity:0.6}100%{transform:scale(1.5);opacity:0}}

/* ============================================================
   GLOBAL OVERRIDES — Unify case/service detail pages
   (case-hero, sd-hero — preserve background image but elevate craft)
============================================================ */

/* Adjust hero top padding to fit under the 64px full-width fixed nav */
.case-hero,
.sd-hero{
  padding-top:120px!important;
}
.cases-hero{
  padding-top:96px!important;
}
@media(max-width:900px){
  .case-hero,.sd-hero{padding-top:88px!important}
  .cases-hero{padding-top:80px!important}
}

/* Reduce oversized hero titles (was --fs-hero clamp 3rem,7vw,6.5rem) */
.case-hero h1,
.sd-hero h1{
  font-size:clamp(2.5rem,5.5vw,4rem)!important;
  font-weight:600!important;
  letter-spacing:-0.032em!important;
  line-height:1.04!important;
  max-width:22ch!important;
}
.case-hero h1 .serif-em,
.case-hero h1 .accent,
.sd-hero h1 .serif-em,
.sd-hero h1 .accent{
  color:var(--brand-300)!important;
  font-weight:400!important;
  font-style:normal!important;
}

/* Unify hero chips across case/service detail pages → match .page-hero-chip */
.case-hero-chip,
.sd-hero-chip{
  display:inline-flex!important;
  align-items:center!important;
  gap:10px!important;
  padding:10px 16px!important;
  background:rgba(255,255,255,0.04)!important;
  border:0.5px solid rgba(255,255,255,0.12)!important;
  backdrop-filter:blur(20px) saturate(180%)!important;
  -webkit-backdrop-filter:blur(20px) saturate(180%)!important;
  border-radius:9999px!important;
  font-size:var(--fs-footnote)!important;
  color:var(--text-body-on-dark)!important;
  letter-spacing:-0.002em!important;
  font-weight:500!important;
  text-transform:none!important;
  white-space:nowrap!important;
}
.case-hero-chips,
.sd-hero-chips{
  gap:10px!important;
  margin-bottom:32px!important;
}

/* Improve hero background overlay (better legibility + brand-tinted vignette) */
.case-hero,
.sd-hero{
  isolation:isolate;
}
.case-hero::before,
.sd-hero::before{
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:1;
  background:
    radial-gradient(ellipse 70% 60% at 85% 25%,rgba(2,163,80,0.18) 0%,transparent 60%),
    radial-gradient(circle at 8% 85%,rgba(63,199,127,0.10) 0%,transparent 50%);
}
.case-hero-bg img,
.sd-hero-bg img{
  opacity:0.40!important;
  filter:saturate(1.05);
}
.case-hero-bg::after,
.sd-hero-bg::after{
  background:linear-gradient(180deg,rgba(14,20,17,0.20) 0%,rgba(14,20,17,0.55) 45%,rgba(14,20,17,0.95) 100%)!important;
}

/* Refine sub text */
.case-hero-sub,
.sd-hero-sub{
  font-size:var(--fs-title-3);
  line-height:1.5;
  max-width:60ch;
}

/* Refine FACTS strip (case-facts, sd-facts → unified visual) */
.case-facts-inner,
.sd-facts-inner{
  border-radius:24px!important;
  border:none!important;
  box-shadow:
    0 1px 2px rgba(15,23,42,0.04),
    0 12px 32px -6px rgba(15,23,42,0.10),
    inset 0 0 0 0.5px rgba(15,23,42,0.06)!important;
}

/* Refine case-quote: replace serif weight 300 with sans 600 (was already patched in inline CSS) */
.case-quote q{
  font-family:var(--f-sans)!important;
  font-weight:500!important;
  font-style:normal!important;
}
.case-metric-value{
  font-family:var(--f-sans)!important;
  font-weight:600!important;
}
.case-metric-value em{
  font-style:normal!important;
  font-weight:600!important;
}

/* Improve generic .case-component and .sd-component shadow */
.case-component,
.sd-component{
  border:none!important;
  box-shadow:
    0 1px 2px rgba(15,23,42,0.04),
    0 6px 16px -2px rgba(15,23,42,0.05),
    inset 0 0 0 0.5px rgba(15,23,42,0.06)!important;
  transition:
    transform 0.5s cubic-bezier(0.16,1,0.3,1),
    box-shadow 0.5s cubic-bezier(0.16,1,0.3,1)!important;
}
.case-component:hover,
.sd-component:hover{
  transform:translateY(-4px)!important;
  box-shadow:
    0 2px 4px rgba(15,23,42,0.04),
    0 24px 48px -10px rgba(15,23,42,0.12),
    0 8px 20px -6px rgba(2,163,80,0.08)!important;
}

/* Refine sd-segment and related cards */
.sd-segment,
.sd-related-card,
.case-related-card{
  border:none!important;
  box-shadow:
    0 1px 2px rgba(15,23,42,0.04),
    0 4px 12px -2px rgba(15,23,42,0.05),
    inset 0 0 0 0.5px rgba(15,23,42,0.06)!important;
  transition:
    transform 0.5s cubic-bezier(0.16,1,0.3,1),
    box-shadow 0.5s cubic-bezier(0.16,1,0.3,1)!important;
}
.sd-segment:hover,
.sd-related-card:hover,
.case-related-card:hover{
  transform:translateY(-4px)!important;
  box-shadow:
    0 2px 4px rgba(15,23,42,0.04),
    0 20px 40px -10px rgba(15,23,42,0.12)!important;
}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:0.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:0.01ms!important;
  }
  [data-reveal]{opacity:1!important;transform:none!important}
  .char{opacity:1!important;transform:none!important}
}


/* ============================================================
   MATERIAL SYMBOLS sizing rules per container
============================================================ */
/* Pillars on home + sobre */
.pilar-card-icon .material-symbols-outlined,
.sb-pillar-icon .material-symbols-outlined{
  font-size:22px;
  font-variation-settings:'FILL' 0,'wght' 350,'GRAD' 0,'opsz' 24;
}
/* Differential cards on sobre */
.sb-diff-icon .material-symbols-outlined{
  font-size:22px;
  font-variation-settings:'FILL' 0,'wght' 350,'GRAD' 0,'opsz' 24;
}
/* Service detail components */
.sd-component-icon .material-symbols-outlined{
  font-size:24px;
  font-variation-settings:'FILL' 0,'wght' 350,'GRAD' 0,'opsz' 24;
}
/* Service detail segments + Servicos page segments */
.sd-segment-icon .material-symbols-outlined,
.svc-segment-icon .material-symbols-outlined{
  font-size:22px;
  font-variation-settings:'FILL' 0,'wght' 350,'GRAD' 0,'opsz' 24;
}
/* Service card items (feature lists) */
.svc-card-items li .material-symbols-outlined{
  font-size:16px;
  color:var(--primary);
  flex-shrink:0;
  font-variation-settings:'FILL' 1,'wght' 400,'GRAD' 0,'opsz' 20;
}
/* Page hero chips */
.page-hero-chip .material-symbols-outlined,
.ct-hero-chip .material-symbols-outlined,
.case-hero-chip .material-symbols-outlined,
.sd-hero-chip .material-symbols-outlined{
  font-size:16px;
  color:var(--brand-300);
  font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 20;
}
/* Arrow in buttons (preserve translate animation via class .arrow) */
.btn .material-symbols-outlined.arrow,
.material-symbols-outlined.arrow{
  font-size:18px;
  vertical-align:middle;
  font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 20;
  transition:transform var(--d-base) var(--ease-out-expo);
}
.btn:hover .material-symbols-outlined.arrow{transform:translateX(3px)}
/* CTA arrows inside cards */
.svc-card-cta-arrow .material-symbols-outlined,
.service-card-cta-arrow .material-symbols-outlined,
.case-card-cta .material-symbols-outlined,
.case-featured-cta .material-symbols-outlined{
  font-size:14px;
  font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 20;
}
/* Breadcrumb chevrons */
.breadcrumb .material-symbols-outlined{
  font-size:14px;
  color:var(--label-quaternary);
  font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 20;
}

/* ============================================================
   GLOBAL RESPONSIVE REFINEMENTS — bulletproof cross-device fixes
   Breakpoints: 1200 / 960 / 760 / 600 / 420
============================================================ */

/* === SAFETY: prevent horizontal scroll & images overflow === */
html,body{overflow-x:hidden;max-width:100vw}
img,video,iframe,svg{max-width:100%}
.section-divider-video,.intro-split-video{max-width:none}

/* === TOUCH DEVICES: disable hover-stuck states === */
@media(hover:none) and (pointer:coarse){
  .svc-card:hover,.sb-diff-card:hover,.sb-cert:hover,.sb-pillar:hover,
  .ct-info-card:hover,.svc-segment:hover,.sd-process-step:hover,
  .ct-faq-item:hover,.svc-step:hover,.sd-component:hover,.sd-segment:hover,
  .sd-related-card:hover,.case-related-card:hover,.case-component:hover,
  .sb-editorial-side .eyebrow:hover,
  .service-card:hover,
  .security-badge:hover{
    transform:none!important;
  }
  /* Force show interactive state on first tap, hide on outside tap */
  .svc-card-cta-arrow,.service-card-cta-arrow,
  .svc-segment,.sb-diff-card,.sb-cert{
    -webkit-tap-highlight-color:transparent;
  }
}

/* === TAP TARGETS: ensure 44x44 minimum on all interactive === */
.nav-link,.nav-login,.nav-cta,
.footer-col a,.footer-social,
.breadcrumb a{
  min-height:36px;
  display:inline-flex;
  align-items:center;
}
@media(max-width:600px){
  .nav-link,.nav-login,.footer-col a{min-height:44px}
}

/* === PAGE HERO: bulletproof scaling === */
@media(max-width:760px){
  .page-hero{padding:88px var(--gutter) 56px}
  .page-hero h1{
    font-size:clamp(1.875rem,7vw,2.5rem)!important;
    max-width:none!important;
    margin:10px 0 var(--sp-4);
  }
  .page-hero-sub{
    font-size:var(--fs-body);
    margin-bottom:var(--sp-6);
  }
  .page-hero-meta{gap:8px}
  .page-hero-chip{
    padding:8px 12px;
    font-size:12px;
    gap:8px;
  }
}
@media(max-width:480px){
  .page-hero{padding:80px 16px 48px}
  .page-hero h1{font-size:clamp(1.625rem,8vw,2.125rem)!important}
  .page-hero-sub{font-size:var(--fs-callout);line-height:1.5}
  /* Chips wrap to 1 per row if too narrow */
  .page-hero-chip{font-size:11px;padding:7px 11px}
}

/* === CASE/SERVICE DETAIL HERO === */
@media(max-width:760px){
  .case-hero,.sd-hero{padding:88px var(--gutter) 0!important}
  .case-hero h1,.sd-hero h1{
    font-size:clamp(1.875rem,7vw,2.5rem)!important;
    max-width:none!important;
  }
  .case-hero-sub,.sd-hero-sub{
    font-size:var(--fs-body)!important;
  }
  .case-hero-chip,.sd-hero-chip{
    padding:8px 12px!important;
    font-size:11px!important;
    gap:8px!important;
  }
  .case-hero-bg img,.sd-hero-bg img{opacity:0.30!important}
  .case-hero-inner,.sd-hero-inner{padding-bottom:48px!important}
}

/* === BREADCRUMB: wrap gracefully === */
.breadcrumb{flex-wrap:wrap;row-gap:4px}
@media(max-width:480px){
  .breadcrumb{font-size:12px}
  .breadcrumb svg{width:10px;height:10px}
}

/* === FACTS STRIP (global) — responsive collapse === */
@media(max-width:760px){
  .facts-strip-inner,.case-facts-inner,.sd-facts-inner{
    grid-template-columns:repeat(2,1fr)!important;
    top:-32px!important;
  }
  .fact-item,.case-fact,.sd-fact{padding:18px 20px!important}
  .fact-value,.case-fact-value,.sd-fact-value{font-size:0.875rem!important}
}
@media(max-width:480px){
  .facts-strip-inner,.case-facts-inner,.sd-facts-inner{
    grid-template-columns:1fr!important;
    border-radius:16px!important;
  }
  .fact-item,.case-fact,.sd-fact{
    border-right:none!important;
    border-bottom:0.5px solid var(--separator-non-opaque);
  }
  .fact-item:last-child,.case-fact:last-child,.sd-fact:last-child{
    border-bottom:none!important;
  }
}

/* === CASE/SD BLOCK editorial: sticky on desktop, static mobile === */
@media(max-width:900px){
  .case-block-grid,.sd-block-grid,.sd-process-inner{
    grid-template-columns:1fr!important;
    gap:32px!important;
  }
  .case-block-side,.sd-block-side,.sd-process-side{
    position:static!important;
  }
}

/* === SD-COMPONENTS / SD-SEGMENTS grids === */
@media(max-width:760px){
  .sd-components-grid{grid-template-columns:1fr!important;gap:14px!important}
  .sd-segments-grid{grid-template-columns:repeat(2,1fr)!important;gap:14px!important}
  .case-solution-grid{grid-template-columns:1fr!important;gap:14px!important}
  .case-related-grid{grid-template-columns:1fr!important;gap:14px!important}
}
@media(max-width:480px){
  .sd-segments-grid{grid-template-columns:1fr!important}
}

/* === CASE SHOWCASE images (horizontal) === */
@media(max-width:900px){
  .case-showcase-grid{
    grid-template-columns:1fr!important;
    height:auto!important;
  }
  .case-showcase-main{height:280px}
  .case-showcase-stack{flex-direction:row!important;gap:14px!important}
  .case-showcase-stack > div{height:180px}
}
@media(max-width:520px){
  .case-showcase-stack{flex-direction:column!important}
  .case-showcase-stack > div{height:160px}
}

/* === FOOTER GRID: graceful 5 → 2 → 1 columns === */
@media(max-width:760px){
  .footer-top{
    grid-template-columns:1fr 1fr!important;
    gap:32px!important;
    padding-bottom:48px;
  }
  .footer-brand{grid-column:1 / -1}
  .footer-brand p{max-width:none}
  .footer{padding:64px var(--gutter) 24px!important}
}
@media(max-width:480px){
  .footer-top{grid-template-columns:1fr!important;gap:28px!important}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:14px}
  .footer-powered{padding:12px 16px}
  .footer-powered-inner{gap:10px}
}

/* === CTA STRIPE: stack on small screens === */
@media(max-width:700px){
  .cta-stripe-inner{
    flex-direction:column!important;
    align-items:flex-start!important;
    text-align:left!important;
    gap:20px!important;
  }
  .cta-stripe-title{font-size:1.375rem!important;max-width:none!important}
  .cta-stripe-inner > div{width:100%}
  .cta-stripe-inner .btn{flex:1;justify-content:center}
}
@media(max-width:480px){
  .cta-stripe{padding:24px 16px!important}
  .cta-stripe-inner .btn{width:100%}
}

/* === WHATSAPP FLOAT positioning === */
@media(max-width:600px){
  .wa-float{
    bottom:16px;right:16px;
    width:52px;height:52px;
  }
  .wa-float svg{width:24px;height:24px}
}

/* === BODY base font-size: minimum 16px on mobile (browser zoom prevention) === */
@media(max-width:760px){
  body{font-size:16px}
  input,textarea,select{font-size:16px!important}
}

/* === REMOVE unwanted horizontal scroll on long content === */
.case-block-body p,.sd-block-body p,.sb-editorial-body p{
  overflow-wrap:break-word;
  word-wrap:break-word;
  hyphens:none;
}
