/* ============================================================
   TOKENS
   ============================================================ */
:root{
  /* Paper neutrals — tinted warm (cohesion with brand) */
  --paper:        oklch(96.5% 0.010 85);
  --paper-2:      oklch(93%   0.014 82);
  --paper-3:      oklch(88%   0.018 78);

  /* Ink neutrals — tinted toward azul */
  --ink:          oklch(18%   0.030 260);
  --ink-2:        oklch(28%   0.030 260);
  --ink-3:        oklch(42%   0.025 260);
  --ink-mute:     oklch(55%   0.018 260);

  /* Brand */
  --azul:         oklch(34%   0.13  262);
  --azul-2:       oklch(26%   0.12  262);
  --azul-3:       oklch(18%   0.09  262);
  --azul-paper:   oklch(93%   0.030 252);

  --vermelho:     oklch(60%   0.220 28);
  --vermelho-2:   oklch(50%   0.200 28);
  --vermelho-ink: oklch(67%   0.210 28);
  --vermelho-soft:oklch(94%   0.035 28);

  /* Lines */
  --linha:        color-mix(in oklch, var(--azul) 18%, transparent);
  --linha-fraca:  color-mix(in oklch, var(--azul) 9%,  transparent);
  --linha-forte:  color-mix(in oklch, var(--azul) 38%, transparent);
  --linha-paper:  color-mix(in oklch, var(--paper) 18%, transparent);

  /* Spacing scale (4pt base) */
  --s-1:  4px;
  --s-2:  8px;
  --s-3:  12px;
  --s-4:  16px;
  --s-5:  24px;
  --s-6:  32px;
  --s-7:  48px;
  --s-8:  64px;
  --s-9:  96px;
  --s-10: 128px;
  --s-11: 160px;

  /* Layout */
  --maxw: 1440px;
  --gutter: clamp(20px, 3.4vw, 56px);
  --radius: 2px;

  /* Type */
  --font-display: 'Bricolage Grotesque', system-ui, sans-serif;
  --font-body:    'Manrope', system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, 'SFMono-Regular', monospace;

  /* Motion */
  --ease-out-quart: cubic-bezier(0.25, 1, 0.5, 1);
  --ease-out-expo:  cubic-bezier(0.16, 1, 0.3, 1);
  --ease-out-quint: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ============================================================
   BASE
   ============================================================ */
*{box-sizing:border-box;margin:0;padding:0}
html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  font-feature-settings:"kern" 1;
  font-kerning:normal;
}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:16px;
  font-weight:400;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea,button{font-family:inherit}
::selection{background:var(--vermelho);color:var(--paper)}

:focus{outline:none}
:focus-visible{
  outline:2px solid var(--vermelho);
  outline-offset:3px;
  border-radius:1px;
}

.container{
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 var(--gutter);
  position:relative;
}

.rubrica{
  font-family:var(--font-mono);
  font-size:11px;
  font-weight:500;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--ink-mute);
  display:inline-flex;
  align-items:center;
  gap:12px;
}
.rubrica::before{
  content:"";
  width:32px;
  height:1px;
  background:var(--vermelho);
  flex-shrink:0;
}
.rubrica.on-ink{color:color-mix(in oklch, var(--paper) 55%, transparent)}
.rubrica.on-vermelho{color:color-mix(in oklch, var(--paper) 75%, transparent)}
.rubrica.on-vermelho::before{background:var(--paper)}

h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:600;
  line-height:0.96;
  letter-spacing:-0.025em;
  text-wrap:balance;
}

/* ============================================================
   TOP STRIP
   ============================================================ */
.topstrip{
  background:var(--ink);
  color:color-mix(in oklch, var(--paper) 60%, transparent);
  font-family:var(--font-mono);
  font-size:11px;
  font-weight:500;
  letter-spacing:0.1em;
  text-transform:uppercase;
}
.topstrip .container{
  display:flex;
  justify-content:space-between;
  align-items:center;
  height:38px;
  gap:24px;
}
.topstrip .dot{
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--vermelho);
  display:inline-block;
  margin-right:10px;
  vertical-align:middle;
  box-shadow:0 0 0 3px color-mix(in oklch, var(--vermelho) 22%, transparent);
}
@media (prefers-reduced-motion: no-preference){
  .topstrip .dot{animation:pulseDot 2.2s var(--ease-out-quart) infinite}
}
.topstrip a{
  color:var(--paper);
  transition:color .2s var(--ease-out-quart);
}
.topstrip a:hover{color:var(--vermelho-ink)}
.topstrip .sep{
  opacity:.35;
  margin:0 10px;
}
@media (max-width:780px){
  .topstrip{display:none !important;height:0 !important;margin:0 !important;padding:0 !important;border:0 !important}
  body{margin-top:0 !important;padding-top:0 !important}
  body > nav.main:first-of-type,
  body > nav.main{margin-top:0 !important}
}

@keyframes pulseDot{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.45;transform:scale(.85)}
}

/* ============================================================
   NAV
   ============================================================ */
nav.main{
  position:sticky;
  top:0;
  z-index:100;
  background:var(--paper);
  border-bottom:1px solid var(--linha);
}
nav.main::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-1px;
  height:2px;
  background:linear-gradient(90deg, var(--vermelho) 0%, var(--vermelho-2) 35%, var(--azul-2) 65%, var(--azul) 100%);
  pointer-events:none;
}
nav.main .container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:82px;
  gap:24px;
}

.brand{
  display:flex;
  align-items:center;
  gap:16px;
  flex-shrink:0;
}
.brand-logo{
  height:44px;
  width:auto;
  max-width:100%;
  display:block;
  flex-shrink:0;
}
.brand-tag{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:0.20em;
  color:var(--ink-mute);
  font-weight:500;
  text-transform:uppercase;
  border-left:1px solid var(--linha-forte);
  padding-left:14px;
  line-height:1.4;
  max-width:140px;
}
.brand-tag b{
  display:block;
  color:var(--ink);
  font-weight:600;
  font-size:10px;
  letter-spacing:0.16em;
}
@media (max-width:680px){.brand-tag{display:none}}

nav.main ul{
  list-style:none;
  display:flex;
  gap:36px;
  align-items:center;
}
nav.main ul a{
  font-family:var(--font-display);
  font-size:15px;
  font-weight:500;
  color:var(--ink-2);
  position:relative;
  padding:10px 0;
  transition:color .2s var(--ease-out-quart);
}
nav.main ul a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:4px;
  width:0;
  height:2px;
  background:var(--vermelho);
  transition:width .35s var(--ease-out-quart);
}
nav.main ul a:hover{color:var(--ink)}
nav.main ul a:hover::after,
nav.main ul a:focus-visible::after,
nav.main ul a[aria-current="true"]::after{width:100%}

/* Submenu (desktop) */
nav.main ul li.has-sub{position:relative}
nav.main ul li.has-sub > a{display:inline-flex;align-items:center;gap:6px}
nav.main ul li.has-sub > a .chev{
  width:12px;height:12px;
  transition:transform .25s var(--ease-out-quart);
}
nav.main ul li.has-sub:hover > a .chev,
nav.main ul li.has-sub:focus-within > a .chev{transform:rotate(180deg)}
nav.main ul li.has-sub .submenu{
  position:absolute;
  top:calc(100% + 4px);
  left:50%;
  transform:translate(-50%, -6px);
  min-width:240px;
  background:var(--paper);
  border:1px solid var(--linha);
  box-shadow:0 18px 40px -20px color-mix(in oklch, var(--ink) 35%, transparent),
             0 2px 6px -2px color-mix(in oklch, var(--ink) 20%, transparent);
  padding:8px;
  display:flex;
  flex-direction:column;
  gap:2px;
  opacity:0;
  visibility:hidden;
  transition:opacity .25s var(--ease-out-quart), transform .25s var(--ease-out-quart), visibility .25s;
  z-index:50;
  list-style:none;
}
nav.main ul li.has-sub:hover .submenu,
nav.main ul li.has-sub:focus-within .submenu{
  opacity:1;
  visibility:visible;
  transform:translate(-50%, 0);
}
nav.main ul li.has-sub .submenu li{display:block}
nav.main ul li.has-sub .submenu a{
  display:block;
  text-align:center;
  padding:12px 18px;
  border-radius:2px;
  font-size:14px;
  color:var(--ink);
  transition:background .2s var(--ease-out-quart);
}
nav.main ul li.has-sub .submenu a::after{display:none}
nav.main ul li.has-sub .submenu a:hover{background:color-mix(in oklch, var(--ink) 6%, transparent)}
nav.main ul li.has-sub .submenu .sub-name{
  font-family:var(--font-display);
  font-weight:500;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 22px;
  min-height:44px;
  font-family:var(--font-display);
  font-weight:600;
  font-size:13px;
  letter-spacing:0.04em;
  background:var(--vermelho);
  color:var(--paper);
  border-radius:var(--radius);
  transition:background .2s var(--ease-out-quart), transform .15s var(--ease-out-quart);
  position:relative;
  white-space:nowrap;
}
.btn:hover{background:var(--vermelho-2)}
.btn:active{transform:scale(.98)}
.btn svg{
  width:14px;
  height:14px;
  transition:transform .25s var(--ease-out-quart);
}
.btn:hover svg{transform:translateX(3px)}

.btn-ghost{
  background:transparent;
  color:var(--ink);
  border:1px solid var(--ink);
}
.btn-ghost:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}

.menu-toggle{
  display:none;
  width:44px;
  height:44px;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:5px;
}
.menu-toggle span{
  display:block;
  width:22px;
  height:2px;
  background:var(--ink);
  transition:transform .3s var(--ease-out-quart), opacity .3s var(--ease-out-quart);
}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:980px){
  nav.main > .container > ul,
  nav.main .btn-nav{display:none}
  .menu-toggle{display:flex !important}
  nav.main .container{height:64px;gap:12px}
  .brand-logo{height:34px}

  .nav-drawer{
    position:fixed;
    top:64px;
    left:0;
    right:0;
    bottom:0;
    background:var(--paper);
    z-index:98;
    padding:32px var(--gutter) 48px;
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transform:translateY(-12px);
    transition:opacity .35s var(--ease-out-quart), transform .35s var(--ease-out-quart), visibility .35s;
    overflow-y:auto;
  }
  .nav-drawer[data-open="true"]{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transform:translateY(0);
  }
  .nav-drawer{padding:32px var(--gutter) 40px}
  .nav-drawer ul{
    display:flex;
    flex-direction:column;
    gap:4px;
    list-style:none;
  }
  .nav-drawer > ul > li{position:relative}
  .nav-drawer ul a{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:14px;
    font-family:var(--font-display);
    font-weight:600;
    font-size:20px;
    letter-spacing:-0.015em;
    color:var(--ink);
    padding:14px 6px;
    line-height:1;
    text-align:center;
    transition:color .2s var(--ease-out-quart), background .2s var(--ease-out-quart);
    border-radius:6px;
  }
  .nav-drawer ul a .ico{
    width:22px;
    height:22px;
    flex-shrink:0;
    color:var(--ink-2);
    transition:color .2s var(--ease-out-quart);
  }
  .nav-drawer ul a span{text-align:left}
  .nav-drawer > ul > li > a:hover,
  .nav-drawer > ul > li > a[aria-current="true"]{
    color:var(--vermelho);
    background:color-mix(in oklch, var(--vermelho) 6%, transparent);
  }
  .nav-drawer > ul > li > a:hover .ico,
  .nav-drawer > ul > li > a[aria-current="true"] .ico{color:var(--vermelho)}
  .nav-drawer .btn{
    margin-top:32px;
    width:100%;
    padding:18px;
    font-size:14px;
  }

  /* Submenu - drawer group */
  .nav-drawer .drawer-sub-toggle{
    width:100%;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:14px;
    background:transparent;
    border:0;
    padding:14px 6px;
    font-family:var(--font-display);
    font-weight:600;
    font-size:20px;
    letter-spacing:-0.015em;
    color:var(--ink);
    line-height:1;
    cursor:pointer;
    text-align:center;
    border-radius:6px;
    transition:color .2s, background .2s;
  }
  .nav-drawer .drawer-sub-toggle .ico{
    width:22px;
    height:22px;
    flex-shrink:0;
    color:var(--ink-2);
    transition:color .2s;
  }
  .nav-drawer .drawer-sub-toggle span{text-align:left}
  .nav-drawer .drawer-sub-toggle .chev{
    width:18px;
    height:18px;
    transition:transform .3s var(--ease-out-quart), color .2s;
    flex-shrink:0;
    color:var(--ink-mute);
  }
  .nav-drawer .drawer-sub-toggle[aria-expanded="true"]{
    color:var(--vermelho);
    background:color-mix(in oklch, var(--vermelho) 6%, transparent);
  }
  .nav-drawer .drawer-sub-toggle[aria-expanded="true"] .ico,
  .nav-drawer .drawer-sub-toggle[aria-expanded="true"] .chev{color:var(--vermelho)}
  .nav-drawer .drawer-sub-toggle[aria-expanded="true"] .chev{transform:rotate(180deg)}
  .nav-drawer .drawer-sub{
    list-style:none;
    margin:4px 0 4px 38px;
    padding:4px 0 8px;
    border-left:2px solid color-mix(in oklch, var(--vermelho) 50%, transparent);
  }
  .nav-drawer .drawer-sub[hidden]{display:none !important}
  .nav-drawer .drawer-sub li{border:none}
  .nav-drawer .drawer-sub a{
    display:block !important;
    padding:10px 0 10px 18px !important;
    font-family:var(--font-body) !important;
    font-size:15px !important;
    font-weight:500 !important;
    color:var(--ink-2) !important;
    letter-spacing:-0.005em !important;
    text-align:left !important;
    line-height:1.3 !important;
    transition:color .2s, padding-left .2s !important;
  }
  .nav-drawer .drawer-sub a:hover,
  .nav-drawer .drawer-sub a[aria-current="true"]{
    color:var(--vermelho) !important;
    padding-left:24px !important;
  }
}
@media (min-width:981px){
  .nav-drawer{display:none}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  background:var(--paper);
  position:relative;
}
.hero-dark{
  background:var(--ink);
  color:var(--paper);
  padding:clamp(28px, 5vw, 48px) 0 clamp(40px, 7vw, 96px);
  position:relative;
  isolation:isolate;
  overflow:hidden;
}
.hero-dark::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("banner-fund.jpg");
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  filter:saturate(.9) contrast(1.08) brightness(.85);
  opacity:.5;
  z-index:-2;
  pointer-events:none;
}
.hero-dark::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse at 20% 40%, color-mix(in oklch, var(--ink) 30%, transparent) 0%, transparent 60%),
    linear-gradient(180deg, color-mix(in oklch, var(--ink) 50%, transparent) 0%, color-mix(in oklch, var(--ink) 30%, transparent) 50%, color-mix(in oklch, var(--ink) 70%, transparent) 100%);
  z-index:-1;
  pointer-events:none;
}
.hero-light{
  background:var(--paper);
  color:var(--ink);
  padding:clamp(40px, 6vw, 80px) 0 0;
}
.hero-meta{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  padding:18px 0;
  border-bottom:1px solid color-mix(in oklch, var(--paper) 22%, transparent);
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:color-mix(in oklch, var(--paper) 60%, transparent);
  gap:24px;
  flex-wrap:wrap;
}
.hero-meta b{color:var(--paper);font-weight:600}
.hero-meta .pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:var(--paper);
}
.hero-meta .pill::before{
  content:"";
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--vermelho);
  display:inline-block;
}
@media (prefers-reduced-motion: no-preference){
  .hero-meta .pill::before{animation:pulseDot 2.2s var(--ease-out-quart) infinite}
}

.hero-block{
  padding:clamp(56px, 9vw, 128px) 0 0;
  display:grid;
  grid-template-columns:minmax(0, 1fr);
  gap:clamp(40px, 5vw, 64px);
}

.hero-headline{
  font-family:var(--font-display);
  font-weight:700;
  font-style:normal;
  line-height:0.86;
  letter-spacing:-0.05em;
  color:var(--paper);
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:0;
}
.hero-headline span{display:block;overflow:hidden}
.hero-headline .hl-3{overflow:visible}
.hero-headline .hl-1{
  font-size:clamp(32px, 6.4vw, 104px);
  font-weight:700;
  letter-spacing:-0.045em;
  line-height:0.95;
}
.hero-headline .hl-2{
  font-size:clamp(32px, 6vw, 100px);
  font-weight:500;
  font-style:italic;
  letter-spacing:-0.03em;
  line-height:0.95;
  color:color-mix(in oklch, var(--paper) 85%, transparent);
  margin-top:-0.08em;
}
.hero-headline .hl-2 em{font-style:italic;font-weight:500}
.hero-headline .hl-3{
  font-size:clamp(14px, 1.6vw, 24px);
  font-weight:500;
  letter-spacing:-0.012em;
  line-height:1.3;
  color:color-mix(in oklch, var(--paper) 85%, transparent);
  margin-top:clamp(18px, 2vw, 28px);
  white-space:nowrap;
  width:max-content;
  max-width:none;
}
@media (max-width:680px){
  .hero-headline .hl-3{white-space:normal;text-wrap:balance;max-width:48ch;width:auto}
}
.hero-headline .hl-3 .azul{color:oklch(78% 0.14 252)}
.hero-headline .hl-3 mark{
  background:transparent;
  color:var(--vermelho);
  position:relative;
  padding:0 0.04em;
  font-style:italic;
  font-weight:700;
}
.hero-headline .hl-3 mark::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0.08em;
  height:0.1em;
  background:var(--vermelho);
}

.hero-headline > span > span{
  display:block;
  max-width:100%;
}
.hero-headline .hl-3 > span{
  white-space:nowrap;
  max-width:none;
  overflow:visible;
}
@media (max-width:680px){
  .hero-headline .hl-3 > span{white-space:normal}
}
@media (max-width:780px){
  .hero-dark .container{text-align:center}
  .hero-headline{align-items:center;text-align:center}
  .hero-headline .hl-1{font-size:clamp(56px, 14vw, 96px)}
  .hero-headline .hl-2{font-size:clamp(48px, 12vw, 84px)}
  .hero-headline .hl-3{max-width:none;white-space:normal;font-size:clamp(18px, 4.8vw, 26px);margin-top:clamp(20px, 4vw, 32px)}
  .hero-headline .hl-3 > span{white-space:normal;max-width:none}
  .hero-meta{justify-content:center;text-align:center}
}
@media (max-width: 480px){
  .hero-cta{justify-content:center;gap:10px}
  .hero-cta .btn{padding:12px 18px;font-size:12px;min-height:40px;flex:0 1 auto}
}
@media (prefers-reduced-motion: no-preference){
  .hero-headline > span > span{
    transform:translateY(110%);
    animation:rise .95s var(--ease-out-quart) both;
  }
  .hero-headline .hl-1 > span{animation-delay:.05s}
  .hero-headline .hl-2 > span{animation-delay:.18s}
  .hero-headline .hl-3 > span{animation-delay:.30s}
}
@keyframes rise{to{transform:translateY(0)}}

.hero-foot{
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:clamp(32px, 5vw, 96px);
  align-items:end;
  padding-top:clamp(24px, 4vw, 56px);
  border-top:1px solid var(--linha);
}
.hero-foot .lead{
  font-size:clamp(16px, 1.3vw, 19px);
  line-height:1.55;
  color:var(--ink-2);
  max-width:62ch;
}
.hero-foot .lead strong{font-weight:600;color:var(--ink)}
.hero-cta{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
@media (max-width:780px){
  .hero-light{background:var(--paper);padding:0}
  .hero-light .hero-foot{
    grid-template-columns:1fr;
    text-align:center;
    padding:clamp(28px, 5vw, 48px) var(--gutter);
    margin:0 calc(var(--gutter) * -1);
    border-top:1px solid color-mix(in oklch, var(--paper) 22%, transparent);
    background:var(--ink);
    color:var(--paper);
    position:relative;
    isolation:isolate;
    overflow:hidden;
  }
  .hero-light .hero-foot::before{
    content:"";
    position:absolute;
    inset:0;
    background-image:url("banner-fund.jpg");
    background-size:cover;
    background-position:center;
    background-repeat:no-repeat;
    filter:saturate(.9) contrast(1.08) brightness(.85);
    opacity:.5;
    z-index:-1;
    pointer-events:none;
  }
  .hero-light .hero-foot::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(180deg, color-mix(in oklch, var(--ink) 65%, transparent) 0%, color-mix(in oklch, var(--ink) 80%, transparent) 100%);
    z-index:-1;
    pointer-events:none;
  }
  .hero-light .hero-foot .lead{margin:0 auto;color:color-mix(in oklch, var(--paper) 82%, transparent)}
  .hero-light .hero-foot .lead strong{color:var(--paper)}
  .hero-cta{justify-content:center;gap:10px}
  .hero-cta .btn{padding:12px 18px;font-size:12px;min-height:40px;flex:0 1 auto}
  .hero-cta .btn-ghost{color:var(--paper);border-color:color-mix(in oklch, var(--paper) 55%, transparent)}
  .hero-cta .btn-ghost:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
}

/* Hero spec ledger + schematic */
.hero-rail{
  display:grid;
  grid-template-columns:1.15fr 1fr;
  gap:0;
  border-top:1px solid var(--ink);
  border-bottom:1px solid var(--ink);
  margin-top:clamp(20px, 2.5vw, 36px);
  color:var(--ink);
}
@media (max-width:960px){
  .hero-rail{grid-template-columns:1fr}
}
.hero-rail .ledger{
  padding:clamp(28px, 3vw, 48px) clamp(28px, 3vw, 48px) clamp(28px, 3vw, 48px) 0;
  border-right:1px solid var(--ink);
  position:relative;
}
@media (max-width:960px){
  .hero-rail .ledger{border-right:none;border-bottom:1px solid var(--ink)}
}
.hero-rail .ledger-head{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  margin-bottom:clamp(20px, 2.5vw, 40px);
  gap:24px;
}
.hero-rail .ledger-head h3{
  font-size:clamp(22px, 2.2vw, 32px);
  font-weight:600;
  line-height:1.05;
  letter-spacing:-0.02em;
  max-width:18ch;
}
.hero-rail .ledger-head .code{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.16em;
  color:var(--ink-mute);
  text-transform:uppercase;
  white-space:nowrap;
}
.hero-rail .ledger ol{
  list-style:none;
  display:grid;
  grid-template-columns:1fr;
}
.hero-rail .ledger ol li{
  display:grid;
  grid-template-columns:min-content 1fr auto;
  gap:24px;
  align-items:baseline;
  padding:18px 0;
  border-top:1px solid var(--linha);
}
.hero-rail .ledger ol li:last-child{border-bottom:1px solid var(--linha)}
.hero-rail .ledger .idx{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.12em;
  color:var(--vermelho);
  font-weight:500;
}
.hero-rail .ledger .label{
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:0.10em;
  text-transform:uppercase;
  color:var(--ink-mute);
}
.hero-rail .ledger .value{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(22px, 2.4vw, 32px);
  letter-spacing:-0.02em;
  color:var(--ink);
  white-space:nowrap;
  font-variant-numeric:tabular-nums;
}
.hero-rail .ledger .value small{
  font-family:var(--font-mono);
  font-size:0.42em;
  font-weight:500;
  color:var(--vermelho);
  margin-left:6px;
  letter-spacing:0.04em;
  vertical-align:0.4em;
}
.hero-rail .schema{
  padding:clamp(28px, 3vw, 48px) 0 clamp(28px, 3vw, 48px) clamp(28px, 3vw, 48px);
  display:flex;
  flex-direction:column;
  gap:24px;
  position:relative;
}
.hero-rail .schema-head{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:16px;
}
.hero-rail .schema-head h4{
  font-family:var(--font-mono);
  font-weight:500;
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--ink-mute);
}
.hero-rail .schema-head .ref{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:0.16em;
  color:var(--vermelho);
  text-transform:uppercase;
}
.hero-rail .schema svg{
  width:100%;
  height:auto;
  max-height:280px;
  display:block;
}
.hero-rail .schema-foot{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:16px;
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--ink-mute);
}
.hero-rail .schema-foot div{
  border-top:1px solid var(--linha);
  padding-top:10px;
}
.hero-rail .schema-foot b{
  display:block;
  color:var(--ink);
  font-weight:600;
  font-size:13px;
  letter-spacing:0.06em;
  margin-top:2px;
}
@media (max-width:960px){
  .hero-rail .ledger{border-right:none;border-bottom:1px solid var(--ink);padding-right:0}
  .hero-rail .schema{padding-left:0;padding-top:clamp(28px, 5vw, 48px)}
}

/* ============================================================
   SECTORS INDEX
   ============================================================ */
.sectors{
  background:var(--ink);
  color:var(--paper);
  padding:0;
  border-top:1px solid var(--ink);
  border-bottom:1px solid var(--ink);
  position:relative;
  overflow:hidden;
}
.sectors::before{
  content:"";
  position:absolute;
  top:0;
  left:-100%;
  width:100%;
  height:2px;
  background:linear-gradient(90deg, transparent, var(--vermelho), transparent);
  animation:sectorsScan 6s linear infinite;
  pointer-events:none;
  z-index:2;
}
@keyframes sectorsScan{
  0%   {left:-100%}
  100% {left:100%}
}
.sectors .container{
  display:grid;
  grid-template-columns:auto 1fr;
  align-items:stretch;
  gap:0;
}
.sectors .lead{
  padding:32px clamp(20px, 3vw, 40px) 32px 0;
  border-right:1px solid color-mix(in oklch, var(--paper) 18%, transparent);
  display:flex;
  align-items:center;
  gap:10px;
}
.sectors .lead::before{
  content:"";
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--vermelho);
  box-shadow:0 0 0 0 color-mix(in oklch, var(--vermelho) 60%, transparent);
  animation:sectorsPulse 2s var(--ease-out-quart) infinite;
  flex-shrink:0;
}
@keyframes sectorsPulse{
  0%   {box-shadow:0 0 0 0 color-mix(in oklch, var(--vermelho) 70%, transparent)}
  70%  {box-shadow:0 0 0 10px color-mix(in oklch, var(--vermelho) 0%, transparent)}
  100% {box-shadow:0 0 0 0 color-mix(in oklch, var(--vermelho) 0%, transparent)}
}
.sectors .lead span{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:color-mix(in oklch, var(--paper) 55%, transparent);
  white-space:nowrap;
}
.sectors ol{
  list-style:none;
  display:grid;
  grid-template-columns:repeat(6, 1fr);
  align-items:stretch;
}
.sectors ol li{
  padding:24px clamp(12px, 1.6vw, 28px);
  border-right:1px solid color-mix(in oklch, var(--paper) 12%, transparent);
  display:flex;
  flex-direction:column;
  gap:6px;
  justify-content:center;
  position:relative;
  cursor:default;
  transition:background-color .35s var(--ease-out-quart), transform .35s var(--ease-out-quart);
  overflow:hidden;
  opacity:0;
  transform:translateY(8px);
  animation:sectorsIn .6s var(--ease-out-quart) forwards;
}
.sectors ol li:nth-child(1){animation-delay:.05s}
.sectors ol li:nth-child(2){animation-delay:.12s}
.sectors ol li:nth-child(3){animation-delay:.19s}
.sectors ol li:nth-child(4){animation-delay:.26s}
.sectors ol li:nth-child(5){animation-delay:.33s}
.sectors ol li:nth-child(6){animation-delay:.40s}
@keyframes sectorsIn{
  to{opacity:1;transform:translateY(0)}
}
.sectors ol li::before{
  content:"";
  position:absolute;
  left:0;
  bottom:0;
  width:100%;
  height:2px;
  background:var(--vermelho);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .45s var(--ease-out-quart);
}
.sectors ol li:hover{
  background:color-mix(in oklch, var(--paper) 6%, transparent);
}
.sectors ol li:hover::before{
  transform:scaleX(1);
}
.sectors ol li:hover .code{
  color:var(--paper);
}
.sectors ol li:hover .name{
  transform:translateX(2px);
}
.sectors ol li:last-child{border-right:none}
.sectors ol li .code{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:0.16em;
  color:var(--vermelho-ink);
  text-transform:uppercase;
  font-weight:500;
  transition:color .3s var(--ease-out-quart), letter-spacing .3s var(--ease-out-quart);
}
.sectors ol li:hover .code{
  letter-spacing:0.22em;
}
.sectors ol li .name{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(15px, 1.3vw, 19px);
  letter-spacing:-0.015em;
  color:var(--paper);
  line-height:1.05;
  transition:transform .35s var(--ease-out-quart);
}
@media (prefers-reduced-motion: reduce){
  .sectors::before,
  .sectors .lead::before{animation:none}
  .sectors ol li{opacity:1;transform:none;animation:none}
}
@media (max-width:980px){
  .sectors .container{grid-template-columns:1fr}
  .sectors .lead{border-right:none;border-bottom:1px solid color-mix(in oklch, var(--paper) 12%, transparent);padding:20px 0}
  .sectors ol{grid-template-columns:repeat(3, 1fr)}
  .sectors ol li{padding:20px clamp(12px, 2vw, 20px)}
  .sectors ol li:nth-child(3){border-right:none}
  .sectors ol li:nth-child(-n+3){border-bottom:1px solid color-mix(in oklch, var(--paper) 12%, transparent)}
}
@media (max-width:540px){
  .sectors ol{grid-template-columns:repeat(2, 1fr)}
  .sectors ol li:nth-child(2n){border-right:none}
  .sectors ol li:nth-child(odd){border-right:1px solid color-mix(in oklch, var(--paper) 12%, transparent)}
  .sectors ol li:nth-child(-n+4){border-bottom:1px solid color-mix(in oklch, var(--paper) 12%, transparent)}
}

/* ============================================================
   SECTION FRAME
   ============================================================ */
section{
  padding:clamp(96px, 12vw, 180px) 0;
  position:relative;
}
.section-head{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:clamp(40px, 6vw, 96px);
  align-items:end;
  margin-bottom:clamp(64px, 9vw, 120px);
}
@media (max-width:900px){
  .section-head{grid-template-columns:1fr;gap:32px;align-items:start;margin-bottom:64px}
}
.section-head h2{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(48px, 8.5vw, 132px);
  letter-spacing:-0.045em;
  line-height:0.9;
  text-wrap:balance;
}
.section-head h2 em{font-style:normal;color:var(--vermelho);font-weight:700}
.section-head h2 .azul{color:var(--azul)}
.section-head .lead{
  color:var(--ink-2);
  max-width:54ch;
  font-size:clamp(15px, 1.2vw, 18px);
  line-height:1.6;
  padding-bottom:14px;
}
.section-head .seq{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--ink-mute);
  margin-bottom:20px;
  display:flex;
  align-items:center;
  gap:12px;
}
.section-head .seq::before{
  content:"";
  width:36px;
  height:1px;
  background:var(--vermelho);
}

/* ============================================================
   ABOUT
   ============================================================ */
.about{background:var(--paper)}
.about-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:clamp(40px, 6vw, 96px);
  align-items:start;
}
@media (max-width:980px){
  .about-grid{grid-template-columns:1fr;gap:48px}
}

.about-copy p{
  font-size:clamp(16px, 1.2vw, 18px);
  line-height:1.65;
  color:var(--ink-2);
  margin-bottom:24px;
  max-width:62ch;
  text-wrap:pretty;
}
.about-copy p:first-of-type::first-letter{
  font-family:var(--font-display);
  font-weight:700;
  font-size:5.2em;
  line-height:0.82;
  float:left;
  padding:8px 16px 0 0;
  color:var(--vermelho);
  font-style:italic;
}
.about-copy p strong{color:var(--ink);font-weight:600}

.about-index{
  margin-top:40px;
  border-top:1px solid var(--ink);
  border-bottom:1px solid var(--ink);
}
.about-index .head{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--ink-mute);
  padding:14px 0;
  border-bottom:1px solid var(--linha);
}
.about-index ol{
  list-style:none;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
}
.about-index ol li{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:18px clamp(12px, 1.6vw, 24px);
  border-right:1px solid var(--linha);
  border-bottom:1px solid var(--linha);
}
.about-index ol li:first-child,
.about-index ol li:nth-child(3n+1){padding-left:0}
.about-index ol li:nth-child(3n){border-right:none}
.about-index ol li:nth-last-child(-n+3){border-bottom:none}
.about-index .idx{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:0.14em;
  color:var(--vermelho);
  font-weight:500;
}
.about-index .name{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(17px, 1.4vw, 21px);
  letter-spacing:-0.015em;
  color:var(--ink);
  line-height:1.1;
}
@media (max-width:640px){
  .about-index ol{grid-template-columns:repeat(2, 1fr)}
  .about-index ol li{border-right:1px solid var(--linha);border-bottom:1px solid var(--linha);padding-left:clamp(12px, 1.6vw, 24px)}
  .about-index ol li:nth-child(3n+1){padding-left:clamp(12px, 1.6vw, 24px)}
  .about-index ol li:nth-child(odd){padding-left:0}
  .about-index ol li:nth-child(3n){border-right:1px solid var(--linha)}
  .about-index ol li:nth-child(2n){border-right:none}
  .about-index ol li:nth-last-child(-n+3){border-bottom:1px solid var(--linha)}
  .about-index ol li:last-child{border-bottom:none}
}

.about-facts{
  display:grid;
  grid-template-columns:1fr;
  border-top:2px solid var(--ink);
}
.about-facts > div{
  display:grid;
  grid-template-columns:clamp(140px, 16vw, 220px) 1fr;
  gap:clamp(12px, 1.6vw, 24px);
  align-items:center;
  padding:clamp(24px, 3vw, 36px) 0;
  border-bottom:1px solid var(--linha);
}
@media (max-width:640px){
  .about-facts > div{
    grid-template-columns:clamp(120px, 30vw, 180px) 1fr;
    gap:14px;
  }
}
.about-facts .num{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(56px, 7vw, 88px);
  letter-spacing:-0.05em;
  line-height:0.85;
  color:var(--ink);
  font-variant-numeric:tabular-nums;
  display:flex;
  align-items:baseline;
  gap:6px;
}
.about-facts .num small{
  font-family:var(--font-mono);
  font-size:0.30em;
  color:var(--vermelho);
  font-weight:500;
  letter-spacing:0.04em;
  vertical-align:0.55em;
}
.about-facts .meta{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.about-facts .meta .key{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-mute);
}
.about-facts .meta .desc{
  font-family:var(--font-body);
  font-size:15px;
  line-height:1.5;
  color:var(--ink-2);
  max-width:46ch;
}

/* ============================================================
   PRODUCTS — drenched ink
   ============================================================ */
.products{
  background:var(--ink);
  color:var(--paper);
  overflow:hidden;
}
.products .section-head h2{color:var(--paper)}
.products .section-head h2 em{color:var(--vermelho-ink)}
.products .section-head .lead{color:color-mix(in oklch, var(--paper) 72%, transparent)}
.products .section-head .seq{color:color-mix(in oklch, var(--paper) 55%, transparent)}

.products-grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:clamp(14px, 1.2vw, 20px);
}
.prod{
  position:relative;
  isolation:isolate;
  display:flex;
  flex-direction:column;
  min-height:300px;
  background:var(--ink-2);
  overflow:hidden;
  text-decoration:none;
  color:inherit;
  transition:transform .5s var(--ease-out-quart);
}
.prod:hover{transform:translateY(-4px)}
.prod .image{
  position:absolute;
  inset:0;
  z-index:0;
}
.prod .image img{
  width:100%;
  height:100%;
  object-fit:cover;
  filter:grayscale(.45) brightness(.78) contrast(1.06) saturate(.55);
  transition:filter .6s var(--ease-out-quart), transform .8s var(--ease-out-quart);
  transform:scale(1.02);
}
.prod:hover .image img{
  filter:grayscale(.25) brightness(.88) contrast(1.08) saturate(.7);
  transform:scale(1.05);
}
.prod .image::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,
    color-mix(in oklch, var(--ink) 22%, transparent) 0%,
    color-mix(in oklch, var(--ink) 10%, transparent) 30%,
    color-mix(in oklch, var(--ink) 78%, transparent) 92%);
}
.prod .body{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  height:100%;
  padding:clamp(18px, 1.8vw, 28px);
  gap:14px;
}
.prod .code{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--paper);
  padding:6px 10px;
  background:var(--vermelho);
  align-self:flex-start;
  font-weight:500;
}
.prod h3{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(28px, 3.2vw, 48px);
  letter-spacing:-0.035em;
  line-height:0.94;
  color:var(--paper);
  margin-top:auto;
  text-wrap:balance;
}
.prod p{
  font-size:clamp(14px, 1vw, 16px);
  line-height:1.55;
  color:color-mix(in oklch, var(--paper) 75%, transparent);
  max-width:46ch;
}
.prod .specs{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:10px 20px;
  padding-top:14px;
  border-top:1px solid color-mix(in oklch, var(--paper) 18%, transparent);
}
.prod .specs div{display:flex;flex-direction:column;gap:2px}
.prod .specs .k{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:color-mix(in oklch, var(--paper) 50%, transparent);
}
.prod .specs .v{
  font-family:var(--font-display);
  font-weight:600;
  font-size:14px;
  color:var(--paper);
  letter-spacing:-0.005em;
  font-variant-numeric:tabular-nums;
}
.prod .arrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--paper);
  transition:gap .25s var(--ease-out-quart), color .2s var(--ease-out-quart);
}
.prod .arrow svg{width:14px;height:14px;transition:transform .25s var(--ease-out-quart)}
.prod:hover .arrow{color:var(--vermelho-ink);gap:16px}
.prod:hover .arrow svg{transform:translateX(4px)}

.prod-1{grid-column:1 / 8;grid-row:1 / 3;min-height:500px}
.prod-2{grid-column:8 / 13;grid-row:1 / 2}
.prod-3{grid-column:8 / 13;grid-row:2 / 3}
@media (max-width:900px){
  .prod-1,.prod-2,.prod-3{
    grid-column:1 / -1;
    grid-row:auto;
    min-height:340px;
  }
}

/* ============================================================
   SERVICES
   ============================================================ */
.services{background:var(--paper)}
.services .section-head h2 em{color:var(--vermelho)}

.services-list{
  border-top:2px solid var(--ink);
}
.svc{
  position:relative;
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:clamp(20px, 3vw, 56px);
  align-items:baseline;
  padding:clamp(28px, 3.5vw, 48px) 0;
  border-bottom:1px solid var(--linha);
  cursor:pointer;
  transition:background .35s var(--ease-out-quart);
}
.svc:hover,
.svc:focus-within{background:var(--vermelho-soft)}
.svc .seq{
  font-family:var(--font-mono);
  font-size:13px;
  font-weight:500;
  letter-spacing:0.12em;
  color:var(--vermelho);
  min-width:64px;
}
.svc .main{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
.svc h3{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(28px, 3.2vw, 48px);
  letter-spacing:-0.025em;
  line-height:1;
  color:var(--ink);
  transition:color .3s var(--ease-out-quart);
}
.svc:hover h3{color:var(--vermelho)}
.svc .desc{
  color:var(--ink-2);
  font-size:clamp(14px, 1.1vw, 16px);
  line-height:1.6;
  max-width:62ch;
}
/* metadata row reveals via grid rows (NOT padding/height animation) */
.svc .meta{
  display:grid;
  grid-template-rows:0fr;
  transition:grid-template-rows .45s var(--ease-out-quart);
}
.svc .meta-inner{
  overflow:hidden;
  display:grid;
  grid-template-columns:repeat(3, auto);
  gap:24px 40px;
  padding-top:0;
  transition:padding-top .35s var(--ease-out-quart);
}
.svc:hover .meta,
.svc:focus-within .meta{grid-template-rows:1fr}
.svc:hover .meta-inner,
.svc:focus-within .meta-inner{padding-top:16px}

.svc .meta-inner div{
  display:flex;
  flex-direction:column;
  gap:3px;
}
.svc .meta-inner .k{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--ink-mute);
}
.svc .meta-inner .v{
  font-family:var(--font-display);
  font-weight:600;
  font-size:14px;
  color:var(--ink);
  letter-spacing:-0.005em;
}
.svc .open{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--ink-mute);
  display:inline-flex;
  align-items:center;
  gap:10px;
  white-space:nowrap;
  transition:color .25s var(--ease-out-quart), transform .25s var(--ease-out-quart);
}
.svc .open svg{width:20px;height:20px;transition:transform .3s var(--ease-out-quart)}
.svc:hover .open{color:var(--vermelho)}
.svc:hover .open svg{transform:translateX(6px)}

@media (max-width:780px){
  .svc{grid-template-columns:auto 1fr;gap:18px}
  .svc .open{grid-column:1 / -1;justify-content:flex-end;margin-top:8px}
  .svc .meta-inner{grid-template-columns:repeat(2, 1fr)}
}

/* ============================================================
   CTA — drenched red
   ============================================================ */
.cta{
  background:var(--vermelho);
  color:var(--paper);
  padding:clamp(96px, 12vw, 160px) 0;
  position:relative;
  overflow:hidden;
}
.cta::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(to right, color-mix(in oklch, var(--paper) 9%, transparent) 1px, transparent 1px),
    linear-gradient(to bottom, color-mix(in oklch, var(--paper) 9%, transparent) 1px, transparent 1px);
  background-size:80px 80px;
  -webkit-mask-image:linear-gradient(180deg, transparent, black 25%, black 75%, transparent);
  mask-image:linear-gradient(180deg, transparent, black 25%, black 75%, transparent);
  pointer-events:none;
}
.cta .container{position:relative;z-index:1}
.cta .seq{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:color-mix(in oklch, var(--paper) 75%, transparent);
  display:inline-flex;
  align-items:center;
  gap:12px;
  margin-bottom:24px;
}
.cta .seq::before{
  content:"";
  width:36px;
  height:1px;
  background:var(--paper);
}
.cta h2{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(48px, 9vw, 156px);
  letter-spacing:-0.05em;
  line-height:0.92;
  color:var(--paper);
  max-width:14ch;
  text-wrap:balance;
}
.cta h2 em{font-style:italic;font-weight:600;color:var(--ink)}
.cta-grid{
  display:grid;
  grid-template-columns:1.6fr 1fr;
  gap:clamp(40px, 6vw, 96px);
  align-items:end;
}
@media (max-width:900px){
  .cta-grid{grid-template-columns:1fr}
}
.cta-grid p{
  font-size:clamp(16px, 1.3vw, 19px);
  line-height:1.55;
  max-width:46ch;
  margin-top:32px;
  color:color-mix(in oklch, var(--paper) 92%, transparent);
}
.cta-actions{
  display:flex;
  flex-direction:column;
  gap:14px;
  align-items:stretch;
}
.cta-actions .btn{
  background:var(--ink);
  color:var(--paper);
  padding:20px 24px;
  font-size:14px;
  letter-spacing:0.06em;
}
.cta-actions .btn:hover{background:var(--paper);color:var(--ink)}
.cta-actions .btn:hover svg{transform:translateX(3px)}
.cta-actions .ph{
  display:flex;
  align-items:center;
  gap:16px;
  padding:18px 22px;
  background:color-mix(in oklch, var(--ink) 22%, transparent);
  border:1px solid color-mix(in oklch, var(--paper) 22%, transparent);
  border-radius:var(--radius);
  transition:background .25s var(--ease-out-quart), transform .15s var(--ease-out-quart);
  min-height:64px;
}
.cta-actions .ph:hover{background:color-mix(in oklch, var(--ink) 35%, transparent)}
.cta-actions .ph:active{transform:scale(.99)}
.cta-actions .ph .icon{
  width:44px;
  height:44px;
  border-radius:50%;
  background:var(--paper);
  color:var(--vermelho);
  display:grid;
  place-items:center;
  flex-shrink:0;
}
.cta-actions .ph .icon svg{width:20px;height:20px}
.cta-actions .ph .text{display:flex;flex-direction:column;gap:2px}
.cta-actions .ph .label{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:color-mix(in oklch, var(--paper) 80%, transparent);
}
.cta-actions .ph .num{
  font-family:var(--font-display);
  font-weight:600;
  font-size:20px;
  letter-spacing:-0.015em;
  color:var(--paper);
  font-variant-numeric:tabular-nums;
}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{background:var(--paper)}
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(40px, 5vw, 80px);
}
@media (max-width:900px){
  .contact-grid{grid-template-columns:1fr;gap:56px}
}

.info-ledger{
  border-top:2px solid var(--ink);
}
.info-row{
  display:grid;
  grid-template-columns:48px 1fr;
  gap:18px;
  align-items:start;
  padding:24px 0;
  border-bottom:1px solid var(--linha);
}
.info-row:last-child{border-bottom:none}
.info-row .icon{
  width:44px;
  height:44px;
  border-radius:50%;
  background:var(--ink);
  color:var(--paper);
  display:grid;
  place-items:center;
  flex-shrink:0;
}
.info-row .icon svg{width:20px;height:20px}
.info-row .key{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--ink-mute);
  margin-bottom:6px;
}
.info-row .val{
  font-family:var(--font-display);
  font-weight:500;
  font-size:17px;
  letter-spacing:-0.005em;
  color:var(--ink);
  line-height:1.4;
  display:block;
}
.info-row a.val{transition:color .2s var(--ease-out-quart)}
.info-row a.val:hover{color:var(--vermelho)}
.info-row .val.alt{color:var(--vermelho);font-size:15px;font-weight:500;margin-top:4px}

.hours{
  display:grid;
  grid-template-columns:1fr auto;
  gap:6px 24px;
  font-family:var(--font-mono);
  font-size:13px;
  font-variant-numeric:tabular-nums;
  margin-top:6px;
}
.hours .day{color:var(--ink-mute);letter-spacing:0.06em;text-transform:uppercase;font-size:11px;align-self:center}
.hours .time{color:var(--ink);font-weight:500;letter-spacing:0.04em}

form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:560px){.form-row{grid-template-columns:1fr}}
.field{position:relative}
.field label{
  position:absolute;
  top:18px;
  left:18px;
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-mute);
  transition:top .2s var(--ease-out-quart), font-size .2s var(--ease-out-quart), color .2s var(--ease-out-quart);
  pointer-events:none;
}
.field input,
.field textarea,
.field select{
  width:100%;
  font:inherit;
  font-family:var(--font-body);
  background:var(--paper-2);
  border:1px solid var(--linha-forte);
  padding:34px 18px 14px;
  border-radius:var(--radius);
  font-size:15px;
  color:var(--ink);
  transition:border-color .2s var(--ease-out-quart), background .2s var(--ease-out-quart);
  min-height:62px;
}
.field textarea{min-height:160px;padding-top:42px;resize:vertical}
.field select{appearance:none;background-image:linear-gradient(45deg, transparent 50%, var(--ink) 50%),linear-gradient(135deg, var(--ink) 50%, transparent 50%);background-position:calc(100% - 22px) 32px, calc(100% - 16px) 32px;background-size:6px 6px;background-repeat:no-repeat}
.field input:focus,
.field textarea:focus,
.field select:focus{
  outline:none;
  border-color:var(--ink);
  background:var(--paper);
}
.field input:focus + label,
.field input:not(:placeholder-shown) + label,
.field textarea:focus + label,
.field textarea:not(:placeholder-shown) + label,
.field select:focus + label,
.field select.has-value + label{
  top:10px;
  font-size:9px;
  color:var(--vermelho);
}
.field .err{
  display:none;
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--vermelho);
  margin-top:6px;
  padding-left:18px;
}
.field.has-error input,
.field.has-error textarea,
.field.has-error select{
  border-color:var(--vermelho);
  background:color-mix(in oklch, var(--vermelho-soft) 60%, var(--paper));
}
.field.has-error .err{display:block}
.btn-submit{
  background:var(--ink);
  color:var(--paper);
  padding:20px 28px;
  font-family:var(--font-display);
  font-weight:600;
  font-size:14px;
  letter-spacing:0.06em;
  border-radius:var(--radius);
  transition:background .2s var(--ease-out-quart), transform .15s var(--ease-out-quart);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  min-height:52px;
  margin-top:8px;
}
.btn-submit:hover{background:var(--vermelho)}
.btn-submit:active{transform:scale(.99)}
.btn-submit svg{width:16px;height:16px;transition:transform .25s var(--ease-out-quart)}
.btn-submit:hover svg{transform:translateX(3px)}
.form-status{
  display:none;
  align-items:center;
  gap:12px;
  padding:14px 18px;
  margin-bottom:4px;
  background:var(--ink);
  color:var(--paper);
  border-radius:var(--radius);
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:0.08em;
  text-transform:uppercase;
}
.form-status.is-visible{display:flex}
.form-status .dot{
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--vermelho-ink);
  display:inline-block;
  flex-shrink:0;
}

/* ============================================================
   FOOTER
   ============================================================ */
footer{
  background:var(--ink);
  color:var(--paper);
  padding:clamp(64px, 8vw, 96px) 0 30px;
  position:relative;
  border-top:1px solid color-mix(in oklch, var(--paper) 12%, transparent);
}
.foot-grid{
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1.2fr;
  gap:48px;
  padding-bottom:48px;
  border-bottom:1px solid color-mix(in oklch, var(--paper) 12%, transparent);
}
@media (max-width:900px){.foot-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media (max-width:560px){.foot-grid{grid-template-columns:1fr}}
.foot-brand p{
  color:color-mix(in oklch, var(--paper) 72%, transparent);
  max-width:34ch;
  margin-top:20px;
  font-size:14px;
  line-height:1.65;
}
.foot-brand .logo-plate{
  display:inline-flex;
  align-items:center;
  gap:14px;
  background:transparent;
  padding:0;
  border-radius:0;
}
.foot-brand .logo-plate .brand-logo-foot{
  height:42px;
  width:auto;
  display:block;
  filter:
    drop-shadow(0 0 1px color-mix(in oklch, var(--paper) 90%, transparent))
    drop-shadow(0 0 2px color-mix(in oklch, var(--paper) 60%, transparent));
}
.foot-brand .logo-plate .tag{
  font-family:var(--font-mono);
  font-size:9.5px;
  letter-spacing:0.20em;
  text-transform:uppercase;
  color:color-mix(in oklch, var(--paper) 60%, transparent);
  border-left:1px solid color-mix(in oklch, var(--paper) 22%, transparent);
  padding-left:14px;
  line-height:1.4;
  max-width:120px;
}
.foot-brand .logo-plate .tag b{
  display:block;
  color:var(--paper);
  font-weight:600;
  font-size:10px;
  letter-spacing:0.16em;
}
.foot-col h4{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:color-mix(in oklch, var(--paper) 55%, transparent);
  font-weight:500;
  margin-bottom:18px;
}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-col a{
  font-family:var(--font-body);
  font-size:14px;
  color:color-mix(in oklch, var(--paper) 80%, transparent);
  transition:color .2s var(--ease-out-quart);
  line-height:1.5;
}
.foot-col a:hover{color:var(--vermelho-ink)}
.foot-col .pad{
  color:color-mix(in oklch, var(--paper) 60%, transparent);
  font-size:14px;
  line-height:1.5;
}

.bottom-strip{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding-top:24px;
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.1em;
  color:color-mix(in oklch, var(--paper) 50%, transparent);
  text-transform:uppercase;
  gap:24px;
  flex-wrap:wrap;
}

/* ============================================================
   FLOATING WHATSAPP
   ============================================================ */
.fab{
  position:fixed;
  bottom:24px;
  right:24px;
  z-index:60;
  width:60px;
  height:60px;
  border-radius:50%;
  background:#25D366;
  color:#fff;
  display:grid;
  place-items:center;
  box-shadow:0 14px 32px -10px color-mix(in oklch, #25D366 55%, transparent);
  transition:transform .25s var(--ease-out-quart), box-shadow .3s var(--ease-out-quart);
}
.fab:hover{transform:scale(1.06)}
.fab svg{width:28px;height:28px}
.fab::before{
  content:"";
  position:absolute;
  inset:-6px;
  border-radius:50%;
  border:2px solid #25D366;
  opacity:0;
}
@media (prefers-reduced-motion: no-preference){
  .fab.is-cued::before{animation:fabRing 2s var(--ease-out-quart) 1}
}
@keyframes fabRing{
  0%{opacity:.8;transform:scale(.9)}
  100%{opacity:0;transform:scale(1.4)}
}

/* ============================================================
   REVEAL
   ============================================================ */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .9s var(--ease-out-quart), transform .9s var(--ease-out-quart);
  will-change:opacity, transform;
}
.reveal.in{opacity:1;transform:translateY(0);will-change:auto}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  .reveal{opacity:1;transform:none}
  .hero-headline span > *{transform:none;animation:none}
}

/* ============================================================
   PRODUCT PAGES
   ============================================================ */
.pp-hero{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  background:var(--ink);
  color:var(--paper);
  padding:clamp(96px, 14vw, 180px) 0 clamp(56px, 8vw, 96px);
}
.pp-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  filter:grayscale(.55) brightness(.4) contrast(1.1);
  opacity:.55;
  z-index:-2;
}
.pp-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,
    color-mix(in oklch, var(--ink) 70%, transparent) 0%,
    color-mix(in oklch, var(--ink) 30%, transparent) 40%,
    color-mix(in oklch, var(--ink) 85%, transparent) 100%);
  z-index:-1;
}
.pp-hero[data-bg="mangueiras"]::before{background-image:url("mangueiras.jpg")}
.pp-hero[data-bg="tubos"]::before{background-image:url("tubos.jpg")}
.pp-hero[data-bg="juntas"]::before{background-image:url("juntas.jpg")}

.pp-breadcrumb{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:color-mix(in oklch, var(--paper) 60%, transparent);
  display:flex;
  gap:10px;
  align-items:center;
  margin-bottom:clamp(24px, 3vw, 36px);
}
.pp-breadcrumb a{color:color-mix(in oklch, var(--paper) 60%, transparent);transition:color .2s}
.pp-breadcrumb a:hover{color:var(--paper)}
.pp-breadcrumb .sep{opacity:.5}
.pp-breadcrumb .current{color:var(--paper)}

.pp-code{
  display:inline-block;
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  background:var(--vermelho);
  color:var(--paper);
  padding:6px 12px;
  margin-bottom:clamp(20px, 2.5vw, 28px);
  font-weight:500;
}
.pp-headline{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(40px, 7.6vw, 124px);
  line-height:0.92;
  letter-spacing:-0.045em;
  color:var(--paper);
  max-width:14ch;
  text-wrap:balance;
  margin-bottom:clamp(24px, 3vw, 36px);
}
.pp-headline em{
  font-style:italic;
  font-weight:600;
  color:var(--vermelho-ink);
}
.pp-lead{
  font-size:clamp(16px, 1.4vw, 21px);
  line-height:1.55;
  color:color-mix(in oklch, var(--paper) 85%, transparent);
  max-width:60ch;
  margin-bottom:clamp(32px, 4vw, 48px);
}
.pp-lead strong{color:var(--paper);font-weight:600}
.pp-cta-row{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-bottom:clamp(40px, 6vw, 72px);
}
.pp-cta-row .btn-ghost{
  background:transparent;
  color:var(--paper);
  border:1px solid color-mix(in oklch, var(--paper) 35%, transparent);
}
.pp-cta-row .btn-ghost:hover{
  background:var(--paper);
  color:var(--ink);
  border-color:var(--paper);
}

.pp-hero-stats{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:0;
  border-top:1px solid color-mix(in oklch, var(--paper) 22%, transparent);
  padding-top:clamp(28px, 3.5vw, 44px);
}
@media (max-width:780px){.pp-hero-stats{grid-template-columns:repeat(2, 1fr); gap:24px 16px}}
.pp-hero-stats > div{
  padding-right:clamp(16px, 2vw, 32px);
  border-right:1px solid color-mix(in oklch, var(--paper) 14%, transparent);
}
.pp-hero-stats > div:last-child{border-right:none}
@media (max-width:780px){
  .pp-hero-stats > div{border-right:none;padding-right:0}
}
.pp-hero-stats .k{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:color-mix(in oklch, var(--paper) 55%, transparent);
  display:block;
  margin-bottom:8px;
}
.pp-hero-stats .v{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(20px, 2.2vw, 30px);
  letter-spacing:-0.02em;
  color:var(--paper);
  line-height:1.1;
}
.pp-hero-stats .v small{
  font-size:0.55em;
  font-weight:500;
  color:color-mix(in oklch, var(--paper) 70%, transparent);
  margin-left:4px;
}

/* Pitch / proposta de valor */
.pp-pitch{
  background:var(--paper);
  padding:clamp(72px, 11vw, 140px) 0;
  border-bottom:1px solid var(--linha);
}
.pp-pitch .container{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:clamp(40px, 6vw, 96px);
  align-items:start;
}
@media (max-width:900px){.pp-pitch .container{grid-template-columns:1fr;gap:32px}}
.pp-pitch .seq{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--vermelho);
  margin-bottom:18px;
}
.pp-pitch h2{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(32px, 5vw, 72px);
  letter-spacing:-0.035em;
  line-height:0.96;
  color:var(--ink);
  text-wrap:balance;
}
.pp-pitch h2 em{font-style:italic;font-weight:600;color:var(--vermelho)}
.pp-pitch p{
  font-size:clamp(16px, 1.2vw, 19px);
  line-height:1.65;
  color:var(--ink-2);
  margin-bottom:18px;
}
.pp-pitch p:last-child{margin-bottom:0}
.pp-pitch strong{color:var(--ink);font-weight:600}

/* Aplicações */
.pp-apps{
  background:var(--paper-2);
  padding:clamp(72px, 11vw, 140px) 0;
}
.pp-apps .head{
  margin-bottom:clamp(40px, 5vw, 64px);
  max-width:54ch;
}
.pp-apps .head .seq{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--vermelho);
  margin-bottom:14px;
}
.pp-apps .head h2{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(32px, 4.6vw, 60px);
  letter-spacing:-0.03em;
  line-height:1;
  color:var(--ink);
  margin-bottom:14px;
  text-wrap:balance;
}
.pp-apps .head p{
  font-size:clamp(15px, 1.1vw, 18px);
  line-height:1.6;
  color:var(--ink-2);
  max-width:60ch;
}
.pp-apps-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1px;
  background:var(--linha);
  border:1px solid var(--linha);
}
@media (max-width:780px){.pp-apps-grid{grid-template-columns:repeat(2, 1fr)}}
@media (max-width:480px){.pp-apps-grid{grid-template-columns:1fr}}
.pp-app{
  background:var(--paper);
  padding:clamp(24px, 2.6vw, 36px);
  display:flex;
  flex-direction:column;
  gap:12px;
  transition:background .25s var(--ease-out-quart);
}
.pp-app:hover{background:var(--paper-3)}
.pp-app .code{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--vermelho);
  font-weight:500;
}
.pp-app h3{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(20px, 1.8vw, 26px);
  letter-spacing:-0.02em;
  color:var(--ink);
  line-height:1.1;
}
.pp-app p{
  font-size:14px;
  line-height:1.55;
  color:var(--ink-3);
}

/* Benefícios */
.pp-benefits{
  background:var(--ink);
  color:var(--paper);
  padding:clamp(72px, 11vw, 140px) 0;
}
.pp-benefits .head{
  margin-bottom:clamp(40px, 5vw, 64px);
  max-width:54ch;
}
.pp-benefits .head .seq{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--vermelho-ink);
  margin-bottom:14px;
}
.pp-benefits .head h2{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(32px, 4.6vw, 60px);
  letter-spacing:-0.03em;
  line-height:1;
  margin-bottom:14px;
  text-wrap:balance;
}
.pp-benefits .head h2 em{font-style:italic;font-weight:600;color:var(--vermelho-ink)}
.pp-benefits .head p{
  font-size:clamp(15px, 1.1vw, 18px);
  line-height:1.6;
  color:color-mix(in oklch, var(--paper) 75%, transparent);
}
.pp-benefits-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:1px;
  background:color-mix(in oklch, var(--paper) 14%, transparent);
}
@media (max-width:980px){.pp-benefits-grid{grid-template-columns:repeat(2, 1fr)}}
@media (max-width:520px){.pp-benefits-grid{grid-template-columns:1fr}}
.pp-benefit{
  background:var(--ink);
  padding:clamp(28px, 3vw, 40px);
  display:flex;
  flex-direction:column;
  gap:14px;
  transition:background .25s var(--ease-out-quart);
}
.pp-benefit:hover{background:var(--ink-2)}
.pp-benefit .num{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.16em;
  color:var(--vermelho-ink);
  font-weight:500;
}
.pp-benefit h3{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(19px, 1.6vw, 24px);
  letter-spacing:-0.015em;
  line-height:1.1;
}
.pp-benefit p{
  font-size:14px;
  line-height:1.55;
  color:color-mix(in oklch, var(--paper) 70%, transparent);
}

/* Specs table */
.pp-specs{
  background:var(--paper);
  padding:clamp(72px, 11vw, 140px) 0;
}
.pp-specs .head{
  margin-bottom:clamp(40px, 5vw, 64px);
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:clamp(40px, 5vw, 80px);
  align-items:end;
}
@media (max-width:780px){.pp-specs .head{grid-template-columns:1fr}}
.pp-specs .head .seq{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--vermelho);
  margin-bottom:14px;
}
.pp-specs .head h2{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(32px, 4.6vw, 60px);
  letter-spacing:-0.03em;
  line-height:1;
}
.pp-specs .head p{
  font-size:clamp(15px, 1.1vw, 17px);
  line-height:1.65;
  color:var(--ink-3);
}
.pp-specs-table{
  width:100%;
  border-top:2px solid var(--ink);
  border-bottom:1px solid var(--linha);
}
.pp-specs-row{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:24px;
  padding:clamp(16px, 1.8vw, 24px) 0;
  border-bottom:1px solid var(--linha);
  align-items:baseline;
}
@media (max-width:680px){.pp-specs-row{grid-template-columns:1fr;gap:6px}}
.pp-specs-row .idx{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.14em;
  color:var(--ink-mute);
  min-width:48px;
}
.pp-specs-row .lbl{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(16px, 1.3vw, 19px);
  color:var(--ink);
}
.pp-specs-row .val{
  font-family:var(--font-mono);
  font-size:clamp(13px, 1vw, 15px);
  color:var(--ink-2);
  text-align:right;
}
@media (max-width:680px){.pp-specs-row .val{text-align:left}}

/* CTA fim */
.pp-final-cta{
  background:var(--vermelho);
  color:var(--paper);
  padding:clamp(64px, 9vw, 120px) 0;
}
.pp-final-cta .container{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:clamp(32px, 5vw, 80px);
  align-items:center;
}
@media (max-width:780px){.pp-final-cta .container{grid-template-columns:1fr;gap:32px}}
.pp-final-cta h2{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(28px, 4.6vw, 60px);
  letter-spacing:-0.03em;
  line-height:0.98;
  text-wrap:balance;
  margin-bottom:14px;
}
.pp-final-cta h2 em{font-style:italic;font-weight:600;color:color-mix(in oklch, var(--paper) 80%, transparent)}
.pp-final-cta p{
  font-size:clamp(15px, 1.15vw, 18px);
  line-height:1.6;
  color:color-mix(in oklch, var(--paper) 85%, transparent);
  max-width:54ch;
}
.pp-final-cta .actions{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.pp-final-cta .btn{
  background:var(--ink);
  color:var(--paper);
  padding:18px 24px;
  font-size:14px;
}
.pp-final-cta .btn:hover{background:var(--azul-3)}
.pp-final-cta .btn-ghost{
  background:transparent;
  border:1px solid color-mix(in oklch, var(--paper) 55%, transparent);
  color:var(--paper);
}
.pp-final-cta .btn-ghost:hover{
  background:var(--paper);
  color:var(--vermelho);
  border-color:var(--paper);
}

/* ============================================================
   IMAGE BAND — full-bleed visual breaks
   ============================================================ */
.image-band{
  position:relative;
  width:100%;
  height:clamp(220px, 30vw, 420px);
  overflow:hidden;
  background:var(--ink);
  isolation:isolate;
}
.image-band img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  filter:grayscale(.4) brightness(.78) contrast(1.06) saturate(.8);
  transition:transform 1.4s var(--ease-out-quart), filter .6s var(--ease-out-quart);
  z-index:0;
}
.image-band:hover img{
  transform:scale(1.04);
  filter:grayscale(.2) brightness(.85) contrast(1.08) saturate(.95);
}
.image-band::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,
    color-mix(in oklch, var(--ink) 60%, transparent) 0%,
    color-mix(in oklch, var(--ink) 20%, transparent) 45%,
    color-mix(in oklch, var(--ink) 65%, transparent) 100%);
  z-index:1;
  pointer-events:none;
}
.image-band .container{
  position:relative;
  z-index:2;
  height:100%;
  display:flex;
  flex-direction:column;
  justify-content:center;
  color:var(--paper);
}
.image-band .seq{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--vermelho-ink);
  margin-bottom:14px;
}
.image-band h3{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(24px, 3.6vw, 48px);
  letter-spacing:-0.03em;
  line-height:1;
  text-wrap:balance;
  max-width:24ch;
}
.image-band h3 em{font-style:italic;font-weight:600;color:var(--vermelho-ink)}

/* About split — operário + texto */
.about-visual{
  margin-top:clamp(40px, 6vw, 80px);
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:clamp(20px, 3vw, 48px);
  align-items:stretch;
}
@media (max-width:780px){.about-visual{grid-template-columns:1fr}}
.about-visual figure{
  position:relative;
  overflow:hidden;
  min-height:300px;
  margin:0;
  isolation:isolate;
}
.about-visual figure img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  filter:grayscale(.3) contrast(1.05);
  transition:transform 1.4s var(--ease-out-quart);
}
.about-visual figure:hover img{transform:scale(1.04)}
.about-visual figure::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(160deg, transparent 50%, color-mix(in oklch, var(--ink) 65%, transparent) 100%);
  z-index:1;
}
.about-visual figcaption{
  position:absolute;
  z-index:2;
  bottom:clamp(16px, 2vw, 28px);
  left:clamp(16px, 2vw, 28px);
  right:clamp(16px, 2vw, 28px);
  color:var(--paper);
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.16em;
  text-transform:uppercase;
}
.about-visual figcaption b{
  display:block;
  font-family:var(--font-display);
  font-size:clamp(18px, 1.8vw, 24px);
  font-weight:600;
  letter-spacing:-0.015em;
  text-transform:none;
  margin-bottom:6px;
  color:var(--paper);
}

/* Split image card (texto + imagem) */
.split-card{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  border-top:2px solid var(--ink);
  border-bottom:2px solid var(--ink);
  margin:clamp(48px, 7vw, 96px) 0 0;
}
@media (max-width:780px){.split-card{grid-template-columns:1fr}}
.split-card .text{
  padding:clamp(32px, 4vw, 56px) clamp(28px, 3vw, 48px) clamp(32px, 4vw, 56px) 0;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:14px;
}
@media (max-width:780px){.split-card .text{padding:32px 0}}
.split-card .text .seq{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--vermelho);
  margin-bottom:6px;
}
.split-card .text h3{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(24px, 2.8vw, 38px);
  letter-spacing:-0.025em;
  line-height:1.05;
  text-wrap:balance;
}
.split-card .text p{
  font-size:15px;
  line-height:1.6;
  color:var(--ink-2);
}
.split-card figure{
  margin:0;
  position:relative;
  overflow:hidden;
  min-height:280px;
}
.split-card figure img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform 1.4s var(--ease-out-quart);
}
.split-card figure:hover img{transform:scale(1.04)}

