/* ══════════════════════════════════════════
   BASE CSS — Orb Digital Branding (site-v3)
   Variáveis, reset, tipografia, utilitários
══════════════════════════════════════════ */

/* ── Reset ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

/* ── Tokens Orb ── */
:root{
  /* Cores principais */
  --orb:     #003FFF;
  --orb2:    #2255FF;
  --blue:    #003FFF;
  --blue2:   #2255FF;

  /* Backgrounds */
  --bg-dark:   #000820;
  --bg-light:  #FDFCFF;
  --bg-soft:   #F7F5FC;

  /* Texto */
  --text-dark:   #1A1520;
  --text-muted:  #6B5F80;
  --text-light:  #f0ede8;
  --muted:       #3a4870;
  --line:        rgba(255,255,255,0.06);

  /* Pilares 2026 */
  --p1: #00C8FF; /* Branding */
  --p2: #0055FF; /* Estratégia */
  --p3: #CC00FF; /* Conteúdo */
  --p4: #FF00AA; /* Campanhas */
  --p5: #8800EE; /* Análise */

  /* Tipografia */
  --serif: 'Ubuntu', Helvetica, Arial, sans-serif;
  --sans:  'IBM Plex Sans', Helvetica, Arial, sans-serif;

  /* Easing */
  --ease: cubic-bezier(.77,0,.175,1);
}

html{scroll-behavior:smooth}

body{
  font-family:var(--sans);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}

/* ── Tipografia base ── */
h1,h2,h3,h4,h5,h6{font-family:var(--serif);font-weight:300;letter-spacing:-.02em}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto;display:block}

/* ══════════════════════════════════════════
   TIPOGRAFIA — piso de legibilidade (desktop + mobile)
   Corpo de texto: mín 15px · Descritivo: mín 14px
══════════════════════════════════════════ */

/* Corpo de texto — piso 15px */
p, .body-dark, .body-light, .flex-body,
.card-text, .phase-desc, .programa-desc,
.hero-sub, .page-hero-body,
.qs-hero-sub,
.forwho-card-yes, .forwho-card-no,
.symptom-card p, .deliver-content p,
.case-desc, .pratica-desc, .final-body,
blockquote{
  font-size:15px !important;
  line-height:1.75 !important;
}

/* Subtítulos de seção */
.cta-sub, .s-title + p,
.price-item span:last-child{
  font-size:15px !important;
}

/* Cards e items descritivos — piso 14px */
.service-desc, .pillar-desc,
.log-desc, .price-detail,
.qs-archetype p, .qs-value-card p,
.qs-pilar p, .approach-card p{
  font-size:14px !important;
  line-height:1.7 !important;
}

/* Inline styles em <p> — override global
   Qualquer <p> com font-size inline entre 11-14px sobe para 15px */
p[style*="font-size:11px"],
p[style*="font-size:12px"],
p[style*="font-size:13px"],
p[style*="font-size:14px"]{
  font-size:15px !important;
  line-height:1.75 !important;
}

/* Divs descritivos com inline styles (não labels) */
div[style*="font-size:11px"]:not([style*="letter-spacing"]),
div[style*="font-size:12px"]:not([style*="letter-spacing"]),
div[style*="font-size:13px"]:not([style*="letter-spacing"]){
  font-size:14px !important;
}

/* Spans descritivos (não labels) */
span[style*="font-size:11px"]:not([style*="letter-spacing"]):not([style*="text-transform"]),
span[style*="font-size:12px"]:not([style*="letter-spacing"]):not([style*="text-transform"]){
  font-size:13px !important;
}

/* ── Utilitários ── */
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);border:0;
}

/* ── Animações comuns ── */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}

@keyframes fadeIn{
  from{opacity:0}
  to{opacity:1}
}

/* ── WhatsApp Flutuante com ondas ── */
.wpp-wrap{
  position:fixed;
  bottom:100px;right:28px;
  z-index:9000;
  width:54px;height:54px;
  display:flex;align-items:center;justify-content:center;
}
.wpp-ring{
  position:absolute;inset:0;border-radius:50%;
  border:1.5px solid #25D366;
  opacity:0;
  animation:wppPulse 2.8s ease-out infinite;
}
.wpp-ring:nth-child(2){animation-delay:.9s}
.wpp-ring:nth-child(3){animation-delay:1.8s}
@keyframes wppPulse{
  0%  {transform:scale(1);opacity:.5}
  100%{transform:scale(2.4);opacity:0}
}
.wpp-float{
  position:relative;z-index:1;
  width:54px;height:54px;
  border-radius:50%;
  background:#25D366;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 14px rgba(37,211,102,.45);
  transition:transform .25s ease, box-shadow .25s ease;
  text-decoration:none;
}
.wpp-float:hover{
  transform:scale(1.1);
  box-shadow:0 6px 20px rgba(37,211,102,.6);
}
.wpp-float svg{
  width:28px;height:28px;
  fill:#fff;
}
/* ══════════════════════════════════════════
   NAV CSS — Orb Digital Branding (site-v3)
   Desktop: menu horizontal inline no header
   Mobile: hamburger circle + fullscreen menu
══════════════════════════════════════════ */

/* ── Cursor customizado (magenta) ── */
#cur{
  position:fixed;width:10px;height:10px;border-radius:50%;
  background:#FF00AA;pointer-events:none;z-index:99999;
  transform:translate(-50%,-50%);
  transition:width .22s var(--ease),height .22s var(--ease);
  mix-blend-mode:difference;
}
#cur.big{width:44px;height:44px}
@media(hover:none){#cur{display:none}}

/* Ocultar menu Portfólio */
.header-nav-link[href="portfolio.php"],
.mobile-menu-link[href="portfolio.php"]{display:none!important;}

/* ══════════════════════════════════════════
   HEADER BAR — logo + nav inline + CTA
══════════════════════════════════════════ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:600;
  display:flex;align-items:center;
  padding:16px 28px;
  transition:background .4s ease, backdrop-filter .4s ease;
}
.site-header.scrolled{
  background:rgba(0,8,32,.85);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
}

/* Logo */
.site-logo{
  display:flex;align-items:center;
  text-decoration:none;flex-shrink:0;
}
.site-logo img{height:28px;width:auto;opacity:0.9;transition:opacity .3s}
.site-logo:hover img{opacity:1}

/* ── Nav inline (desktop) ── */
.header-nav{
  display:flex;align-items:center;gap:6px;
  margin-left:auto;margin-right:24px;
}

.header-nav-link{
  font-family:var(--sans);
  font-size:14px;font-weight:500;
  letter-spacing:.03em;
  color:rgba(255,255,255,.45);
  text-decoration:none;
  padding:8px 14px;
  border-radius:3px;
  transition:color .2s, background .2s;
  cursor:none;
  border:none;background:none;
}
.header-nav-link:hover{
  color:rgba(255,255,255,.9);
  background:rgba(255,255,255,.04);
}
.header-nav-link.active{
  color:#fff;
}

/* ── Dropdown Cases (desktop) ── */
.header-nav-dropdown{
  position:relative;
}
.header-nav-chevron{
  display:inline-block;margin-left:3px;
  transition:transform .3s var(--ease);
  opacity:.5;vertical-align:middle;
}
.header-nav-dropdown.open .header-nav-chevron{
  transform:rotate(180deg);opacity:.8;
}

.header-dropdown-panel{
  position:absolute;
  top:calc(100% + 8px);left:50%;
  transform:translateX(-50%) translateY(4px);
  min-width:180px;
  background:rgba(0,8,32,.95);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.06);
  border-radius:6px;
  padding:10px 0;
  opacity:0;pointer-events:none;
  transition:opacity .25s ease, transform .25s ease;
  z-index:700;
}
.header-nav-dropdown.open .header-dropdown-panel{
  opacity:1;pointer-events:all;
  transform:translateX(-50%) translateY(0);
}
.header-dropdown-panel a{
  display:block;
  font-family:var(--sans);
  font-size:13px;font-weight:400;
  color:rgba(255,255,255,.45);
  text-decoration:none;
  padding:7px 20px;
  transition:color .2s, background .2s;
}
.header-dropdown-panel a:hover{
  color:#fff;
  background:rgba(255,255,255,.04);
}

/* CTA Group (desktop header) */
.site-cta-group{
  display:flex;align-items:center;gap:12px;flex-shrink:0;
}
.site-cta-secondary{
  font-family:var(--sans);
  font-size:10px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.5);
  text-decoration:none;
  padding:9px 14px;
  border-radius:100px;
  border:1px solid rgba(255,255,255,.12);
  transition:color .3s, border-color .3s, transform .2s;
  cursor:none;
}
.site-cta-secondary:hover{
  color:rgba(255,255,255,.9);
  border-color:rgba(255,255,255,.3);
  transform:translateY(-1px);
}
.site-cta-secondary.active{
  color:rgba(255,255,255,.7);
  border-color:rgba(255,255,255,.2);
}
.site-cta{
  display:inline-flex;align-items:center;gap:6px;
  padding:9px 20px;
  background:var(--blue);
  color:#fff;
  border:none;border-radius:100px;
  font-family:var(--sans);
  font-size:10px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  text-decoration:none;
  transition:background .3s, transform .2s;
  cursor:none;flex-shrink:0;
}
.site-cta:hover{background:var(--orb2, #2255FF);transform:translateY(-1px)}
.site-cta svg{width:14px;height:14px;fill:currentColor;opacity:.7}

/* ══════════════════════════════════════════
   CÍRCULO HAMBURGER — mobile only
══════════════════════════════════════════ */
.circle-wrap{
  position:fixed;
  top:20px;right:20px;
  z-index:10001;
  width:48px;height:48px;
  display:none; /* hidden on desktop */
  align-items:center;justify-content:center;
}

/* Anéis de energia */
.circle-ring{
  position:absolute;inset:0;border-radius:50%;
  border:1.5px solid var(--blue);
  opacity:0;
  animation:ringPulse 2.8s ease-out infinite;
}
.circle-ring:nth-child(2){animation-delay:.9s}
.circle-ring:nth-child(3){animation-delay:1.8s}

@keyframes ringPulse{
  0%  {transform:scale(1);opacity:.55}
  100%{transform:scale(2.6);opacity:0}
}

/* Glow interno */
.circle-glow{
  position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle,rgba(0,63,255,.35) 0%,transparent 70%);
  animation:glowBreath 3s ease-in-out infinite;
}
@keyframes glowBreath{
  0%,100%{transform:scale(.95);opacity:.6}
  50%{transform:scale(1.15);opacity:1}
}

/* Botão círculo */
.circle-btn{
  position:relative;z-index:1;
  width:48px;height:48px;border-radius:50%;border:none;
  background:var(--blue);
  cursor:pointer;
  transition:background .35s,transform .25s;
  display:flex;align-items:center;justify-content:center;
}
.circle-btn:hover{transform:scale(1.08)}
.circle-btn.open{background:var(--orb2)}

/* Ícone hamburger/X */
.circle-icon{
  width:18px;height:14px;position:relative;
  display:flex;flex-direction:column;
  align-items:center;justify-content:space-between;
  transition:transform .4s var(--ease);
}
.circle-icon span{
  display:block;width:16px;height:2px;
  background:#fff;border-radius:2px;
  transition:transform .4s var(--ease),opacity .3s;
  transform-origin:center center;
  position:absolute;
  left:50%;margin-left:-8px;
}
.circle-icon span:nth-child(1){top:0}
.circle-icon span:nth-child(2){top:6px}
.circle-icon span:nth-child(3){top:12px}

/* Estado X (aberto) */
.circle-btn.open .circle-icon span:nth-child(1){
  top:6px;transform:rotate(45deg);
}
.circle-btn.open .circle-icon span:nth-child(2){
  opacity:0;transform:scaleX(0);
}
.circle-btn.open .circle-icon span:nth-child(3){
  top:6px;transform:rotate(-45deg);
}

/* ══════════════════════════════════════════
   MOBILE MENU — fullscreen overlay
══════════════════════════════════════════ */
.mobile-menu{
  position:fixed;inset:0;z-index:10000;
  background:rgba(0,4,16,.97);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  display:none; /* hidden on desktop */
  opacity:0;pointer-events:none;
  transition:opacity .4s var(--ease);
}
.mobile-menu.open{
  opacity:1;pointer-events:all;
}

.mobile-menu-inner{
  display:flex;flex-direction:column;
  padding:100px 32px 60px;
  height:100vh;overflow-y:auto;
  gap:4px;
}

.mobile-menu-link{
  font-family:var(--serif);
  font-size:24px;font-weight:400;
  color:rgba(255,255,255,.5);
  text-decoration:none;
  padding:14px 0;
  border-bottom:1px solid rgba(255,255,255,.04);
  transition:color .2s;
  display:block;
  background:none;border-top:none;border-left:none;border-right:none;
  text-align:left;cursor:pointer;width:100%;
}
.mobile-menu-link:hover,
.mobile-menu-link.active{color:#fff}

/* Chevron do Cases mobile */
.mobile-menu-chevron{
  display:inline-block;margin-left:8px;
  transition:transform .3s var(--ease);
  opacity:.4;vertical-align:middle;
}
.mobile-menu-group.open .mobile-menu-chevron{
  transform:rotate(180deg);opacity:.7;
}

/* Sublinks Cases mobile */
.mobile-menu-sublinks{
  display:flex;flex-direction:row;flex-wrap:wrap;gap:6px 16px;
  padding:8px 0 12px;
  max-height:0;overflow:hidden;opacity:0;
  transition:max-height .4s var(--ease), opacity .3s ease, padding .3s ease;
}
.mobile-menu-group.open .mobile-menu-sublinks{
  max-height:300px;opacity:1;
  padding:12px 0 16px;
}
.mobile-menu-sublinks a{
  font-family:var(--sans);
  font-size:13px;font-weight:400;
  color:rgba(255,255,255,.4);
  text-decoration:none;
  padding:4px 0;
  transition:color .2s;
}
.mobile-menu-sublinks a:hover{color:rgba(255,255,255,.9)}

/* CTA no menu mobile */
.mobile-menu-cta{
  display:inline-block;
  margin-top:24px;
  padding:14px 28px;
  background:var(--blue);
  color:#fff;
  font-family:var(--sans);
  font-size:12px;font-weight:600;
  letter-spacing:.06em;
  text-decoration:none;
  border-radius:4px;
  text-align:center;
  transition:background .3s;
}
.mobile-menu-cta:hover{background:var(--orb2)}

/* CTA secundário no menu mobile */
.mobile-menu-cta-secondary{
  display:inline-block;
  margin-top:10px;
  padding:14px 28px;
  color:rgba(255,255,255,.5);
  font-family:var(--sans);
  font-size:12px;font-weight:600;
  letter-spacing:.06em;
  text-decoration:none;
  border:1px solid rgba(255,255,255,.12);
  border-radius:4px;
  text-align:center;
  transition:color .3s, border-color .3s;
}
.mobile-menu-cta-secondary:hover{
  color:rgba(255,255,255,.9);
  border-color:rgba(255,255,255,.3);
}

/* ══════════════════════════════════════════
   Transição de página
══════════════════════════════════════════ */
.page-fade{
  position:fixed;inset:0;z-index:9000;
  background:var(--bg-dark);opacity:0;pointer-events:none;
  transition:opacity .4s ease;
}
.page-fade.active{opacity:1;pointer-events:all}

/* ══════════════════════════════════════════
   TABLET — ≤1100px
══════════════════════════════════════════ */
@media(max-width:1100px){
  .header-nav{gap:2px}
  .header-nav-link{font-size:12px;padding:8px 10px}
  .header-dropdown-panel a{font-size:12px}
}

/* ══════════════════════════════════════════
   MOBILE — ≤768px
══════════════════════════════════════════ */
@media(max-width:768px){
  .site-header{padding:12px 20px}

  /* Esconder nav inline e CTA do header */
  .header-nav{display:none}
  .site-cta-group{display:none}
  .site-header > .site-cta{display:none}

  /* Mostrar hamburger circle */
  .circle-wrap{display:flex}

  /* Ativar mobile menu */
  .mobile-menu{display:block}
}
/* ══════════════════════════════════════════
   FOOTER CSS — Orb Digital Branding (site-v3)
══════════════════════════════════════════ */

footer{
  display:flex;align-items:center;justify-content:space-between;
  padding:24px 40px 80px;  /* padding-bottom extra para livrar o circle button */
  border-top:1px solid rgba(255,255,255,.08);
  flex-wrap:wrap;gap:16px;
  font-family:var(--sans);
  font-size:11px;
  color:rgba(240,237,232,.6);
  background:transparent;
}

.footer-logo{
  display:flex;align-items:center;gap:10px;
}
.footer-logo img{height:28px;opacity:.55;transition:opacity .3s}
.footer-logo:hover img{opacity:.8}
.footer-logo-name{
  font-family:var(--serif);
  font-size:13px;font-weight:400;
  color:rgba(240,237,232,.65);
}

.footer-assoc{
  display:flex;align-items:center;gap:12px;
}
.footer-assoc-label{
  font-size:9px;letter-spacing:.05em;
  color:rgba(240,237,232,.35);
}
.footer-assoc-logos{
  display:flex;align-items:center;gap:12px;
}
.footer-assoc-logo{
  height:22px;opacity:.35;
  filter:brightness(0) invert(1);
  transition:opacity .3s;
}
.footer-assoc-logo:hover{opacity:.55}

.footer-right{
  display:flex;align-items:center;gap:20px;
}
.footer-copy{
  font-size:10px;color:rgba(240,237,232,.65);
}
.footer-social{
  display:flex;gap:10px;
}
.footer-social-link{
  color:rgba(240,237,232,.65);
  transition:opacity .3s,color .3s;
  display:flex;align-items:center;
}
.footer-social-link:hover{color:rgba(240,237,232,.9)}

/* ── Mobile ── */
@media(max-width:768px){
  footer{
    flex-direction:column;
    align-items:center;text-align:center;
    padding:24px 20px 100px; /* extra bottom para circle */
    gap:12px;
  }
  .footer-assoc{flex-direction:column;gap:6px}
  .footer-right{flex-direction:column;gap:8px}
}
/* ── index — Orb Digital Branding (site-v3) ── */


:root {
  --orb:      #003FFF;
  --orb2:     #2255FF;
  --orb-glow: rgba(0,63,255,0.12);
  --blue:     #0055FF;
  --light:    #0a0e24;
  --lighter:  #000820;
  --border:   rgba(0,63,255,0.1);
  --text:     #f0ede8;
  --mid:      rgba(240,237,232,.75);
  --muted:    rgba(240,237,232,.65);
  --white:    #f0ede8;
  --serif:    'Ubuntu', Helvetica, Arial, sans-serif;
  --body:     'IBM Plex Sans', sans-serif;

  /* pilares */
  --p1: #00C8FF;
  --p2: #0055FF;
  --p3: #CC00FF;
  --p4: #FF00AA;
  --p5: #8800EE;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:#000820;
  color:var(--text);
  font-family:var(--body);
  font-weight:300;
  line-height:1.7;
  overflow-x:hidden;
  cursor:none;
}
@media(hover:none){body{cursor:auto}}

/* ── HERO */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:120px 56px 80px;
  text-align:center;
  position:relative;
  overflow:hidden;
  background:linear-gradient(145deg, #000D30 0%, #001060 40%, #000820 100%);
}

/* Scroll indicator arrow */
.hero-scroll-arrow{
  position:absolute;
  bottom:15vh;
  left:50%;
  transform:translateX(-50%);
  z-index:3;
  cursor:pointer;
  animation:scrollBounce 2s ease-in-out infinite;
  opacity:.75;
  transition:opacity .3s;
}
.hero-scroll-arrow:hover{opacity:.8}
@keyframes scrollBounce{
  0%,100%{transform:translateX(-50%) translateY(0)}
  50%{transform:translateX(-50%) translateY(8px)}
}
#heroPhysics{
  position:absolute;inset:0;
  width:100%;height:100%;
  z-index:0;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  font-size:9px;font-weight:600;
  letter-spacing:0.18em;text-transform:uppercase;
  color:#00EEFF;
  background:rgba(0,238,255,0.1);
  border:1px solid rgba(0,238,255,0.28);
  padding:6px 18px;border-radius:100px;
  margin-bottom:32px;
}
.hero-badge::before{
  content:'';width:6px;height:6px;
  border-radius:50%;background:#00EEFF;
}
h1.hero-h1{
  font-family:var(--serif);
  font-size:clamp(28px,4vw,50px);
  font-weight:300;line-height:1.1;
  color:#FFFFFF;
  margin-bottom:24px;
  letter-spacing:-0.02em;
}
h1.hero-h1 em{
  font-style:italic;
  background:linear-gradient(90deg, #00E6FF 0%, #A78BFA 40%, #fff 50%, #A78BFA 60%, #00E6FF 100%);
  background-size:300% 100%;
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  animation:heroShine 6s ease-in-out infinite;
}
@keyframes heroShine{
  0%{background-position:100% center;}
  50%{background-position:0% center;}
  100%{background-position:100% center;}
}
.hero-sub{
  font-size:17px;font-weight:300;
  color:rgba(255,255,255,0.82);line-height:1.75;
  max-width:640px;margin:0 auto 56px;
}
.hero-stats{
  display:flex;align-items:center;justify-content:center;
  gap:32px;flex-wrap:nowrap;
  padding:32px 0;
  border-top:1px solid rgba(255,255,255,0.12);
  border-bottom:1px solid rgba(255,255,255,0.12);
  max-width:760px;margin:0 auto;
}
.hero-stat-n{
  font-family:var(--serif);font-size:35px;font-weight:600;
  color:#FFFFFF;line-height:1;
}
.hero-stat-l{
  font-size:12px;font-weight:500;letter-spacing:0.1em;
  text-transform:uppercase;color:rgba(255,255,255,0.65);margin-top:4px;
}
.stat-div{width:1px;height:40px;background:rgba(255,255,255,0.15);}

/* ── INTRO */
.intro-s{
  padding:100px 56px;
  background:
    linear-gradient(135deg, rgba(0,13,48,.95) 0%, rgba(0,16,96,.6) 50%, rgba(85,51,170,.3) 100%),
    var(--bg-dark, #08060e);
  position:relative;
  overflow:hidden;
}
.intro-s::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 10% 90%, rgba(0,63,255,.12) 0%, transparent 50%),
    radial-gradient(ellipse at 90% 20%, rgba(136,0,238,.08) 0%, transparent 40%);
}
.intro-inner{
  position:relative;z-index:1;
  max-width:1160px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;
}
.intro-label{
  font-size:12px;font-weight:600;
  letter-spacing:0.18em;text-transform:uppercase;
  color:var(--orb);margin-bottom:20px;display:block;
}
.intro-title{
  font-family:var(--serif);
  font-size:clamp(28px,3.5vw,46px);
  font-weight:300;line-height:1.15;
  color:var(--text);margin-bottom:24px;
  letter-spacing:-0.02em;
}
.intro-title em{font-style:italic;color:var(--orb);}
.intro-body{
  font-size:14px;color:var(--mid);line-height:1.85;
  margin-bottom:16px;
}
.intro-quote{
  font-family:var(--serif);font-size:16px;font-style:italic;
  color:var(--mid);line-height:1.7;
  border-left:2px solid var(--orb);padding-left:20px;
  margin-top:28px;
}

/* ── PILLARS PREVIEW GRID */
.pillars-preview{
  display:grid;grid-template-columns:1fr 1fr;
  gap:12px;
}
.pp-item{
  padding:20px 22px;
  border:1px solid var(--border);
  border-radius:4px;
  background:rgba(255,255,255,.03);
  text-decoration:none;
  transition:border-color .2s,transform .2s;
  display:block;
}
.pp-item:hover{border-color:var(--orb);transform:translateY(-2px);}
.pp-num{
  font-size:9px;font-weight:600;
  letter-spacing:0.15em;text-transform:uppercase;
  color:var(--muted);margin-bottom:8px;display:block;
}
.pp-name{
  font-family:var(--serif);font-size:15px;font-weight:600;
  color:var(--text);line-height:1.3;
}
.pp-item:nth-child(5){grid-column:1/-1;}

/* ── ORBITAL SECTION */
.orbital-s{
  padding:100px 56px;
  background:rgba(255,255,255,.02);
  overflow:hidden;
}
.orbital-inner{max-width:1160px;margin:0 auto;}
.orbital-header{text-align:center;margin-bottom:64px;}
.section-label{
  font-size:12px;font-weight:600;
  letter-spacing:0.18em;text-transform:uppercase;
  color:var(--orb);margin-bottom:14px;display:block;
}
h2.s-title{
  font-family:var(--serif);
  font-size:clamp(28px,3.5vw,46px);
  font-weight:300;line-height:1.15;
  color:var(--text);margin-bottom:16px;
  letter-spacing:-0.02em;
}
h2.s-title em{font-style:italic;color:var(--orb);}
h2.s-title strong{font-weight:600;}
.s-intro{
  font-size:15px;color:var(--muted);
  max-width:560px;margin:0 auto;line-height:1.75;
}
.orbital-diagram{
  position:relative;
  width:580px;height:580px;
  margin:0 auto;
}
#orb-svg{display:block;width:100%;height:100%;}
.planet-node{transition:opacity .2s;}
.planet-node:hover circle:not([id^="pglow"]){filter:brightness(1.15);}
.detail-panel{
  margin-top:48px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-radius:6px;
  overflow:hidden;
  min-height:200px;
  transition:all .3s ease;
}
.detail-header{
  padding:28px 36px 20px;
  border-bottom:1px solid var(--border);
  display:flex;align-items:flex-start;gap:20px;
}
.detail-color-bar{
  width:4px;height:60px;border-radius:2px;flex-shrink:0;margin-top:4px;
}
.detail-eyebrow{
  font-size:9px;font-weight:600;
  letter-spacing:0.18em;text-transform:uppercase;
  color:var(--muted);margin-bottom:6px;display:block;
}
.detail-name{
  font-family:var(--serif);
  font-size:25px;font-weight:600;
  color:var(--text);line-height:1.2;
}
.detail-body{
  padding:24px 36px 28px;
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
}
.detail-desc{
  font-size:14px;color:var(--mid);line-height:1.75;
}
.detail-services-label{
  font-size:9px;font-weight:600;
  letter-spacing:0.15em;text-transform:uppercase;
  color:var(--muted);margin-bottom:14px;display:block;
}
.detail-service-list{
  display:flex;flex-direction:column;gap:8px;
}
.detail-service-item{
  display:flex;align-items:center;gap:10px;
  font-size:12px;color:var(--mid);
}
.dsv-dot{
  width:6px;height:6px;border-radius:50%;flex-shrink:0;
}
.detail-hint{
  padding:32px 36px;
  font-size:14px;font-style:italic;font-family:var(--serif);
  color:var(--muted);text-align:center;
  display:flex;align-items:center;justify-content:center;
  gap:10px;
}


/* ── INTRO IMAGE + NEON GLOW */
.intro-img-wrap{
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.intro-img-wrap::before{
  content:'';position:absolute;
  width:340px;height:340px;
  top:50%;left:50%;
  transform:translate(-50%,-55%);
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,0,170,0.35) 0%, rgba(255,0,170,0.15) 30%, rgba(255,0,170,0.05) 55%, transparent 70%);
  filter:blur(30px);
  z-index:0;
  animation:neonPulse 4s ease-in-out infinite;
}
.intro-img-wrap::after{
  content:'';position:absolute;
  width:260px;height:260px;
  top:50%;left:50%;
  transform:translate(-50%,-55%);
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,80,200,0.3) 0%, rgba(255,0,170,0.1) 40%, transparent 65%);
  filter:blur(15px);
  z-index:0;
  animation:neonPulse2 4s ease-in-out 1.5s infinite;
}
@keyframes neonPulse{
  0%{opacity:0.55;transform:translate(-50%,-55%) scale(0.97);}
  50%{opacity:1;transform:translate(-50%,-55%) scale(1.06);}
  100%{opacity:0.55;transform:translate(-50%,-55%) scale(0.97);}
}
@keyframes neonPulse2{
  0%{opacity:0.5;transform:translate(-50%,-55%) scale(1);}
  50%{opacity:0.9;transform:translate(-50%,-55%) scale(1.04);}
  100%{opacity:0.5;transform:translate(-50%,-55%) scale(1);}
}
@keyframes neonGlow{
  0%{filter:drop-shadow(0 0 18px rgba(255,0,170,0.2)) drop-shadow(0 0 50px rgba(255,0,170,0.08));}
  50%{filter:drop-shadow(0 0 25px rgba(255,0,170,0.32)) drop-shadow(0 0 70px rgba(255,0,170,0.14));}
  100%{filter:drop-shadow(0 0 18px rgba(255,0,170,0.2)) drop-shadow(0 0 50px rgba(255,0,170,0.08));}
}
.intro-img{
  position:relative;z-index:1;
  width:100%;max-width:520px;height:auto;object-fit:contain;
  border-radius:8px;
  filter:drop-shadow(0 0 20px rgba(255,0,170,0.25)) drop-shadow(0 0 60px rgba(255,0,170,0.1));
  animation:neonGlow 4s ease-in-out 0.8s infinite;
}
/* ── ACCORDION SECTION */
.orbital-s .orbital-inner{ max-width:800px; }
.orbital-s .orbital-header{ margin-bottom:0; }

/* ── PILAR ACCORDION */
.pilar-accordion{ display:flex; flex-direction:column; gap:0; margin-top:32px; }
.pa-item{
  border-bottom:1px solid var(--border);
  overflow:hidden;
}
.pa-item:first-child{ border-top:1px solid var(--border); }
.pa-summary{
  display:flex; align-items:center; gap:14px;
  padding:18px 4px; cursor:pointer;
  list-style:none; -webkit-appearance:none;
  outline:none;
}
.pa-summary::-webkit-details-marker{ display:none; }
.pa-dot{
  width:10px; height:10px; border-radius:50%; flex-shrink:0;
}
.pa-info{ flex:1; }
.pa-eyebrow{
  font-size:9px; font-weight:600; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--muted);
  display:block; margin-bottom:3px;
}
.pa-name{
  font-family:var(--serif); font-size:21px; font-weight:600;
  color:var(--text); line-height:1.2;
}
.pa-chevron{
  font-size:12px; color:var(--muted);
  transition:transform .25s;
  flex-shrink:0;
}
details[open] .pa-chevron{ transform:rotate(180deg); }
.pa-body{
  padding:0 4px 24px;
}
.pa-desc{
  font-size:14px; color:var(--mid); line-height:1.75;
  margin-bottom:16px;
}
.pa-connects{
  font-size:13px; color:var(--muted); font-style:italic;
  border-left-width:2px; border-left-style:solid;
  padding-left:12px; margin-bottom:20px; line-height:1.6;
}
.pa-services-label{
  font-size:9px; font-weight:600; letter-spacing:0.13em;
  text-transform:uppercase; color:var(--muted);
  display:block; margin-bottom:10px;
}
.pa-service-item{
  display:flex; align-items:center; gap:10px;
  font-size:12px; color:var(--mid); padding:5px 0;
  border-bottom:1px solid var(--border);
}
.pa-service-item:last-child{ border-bottom:none; }

/* ── INTEGRATION SECTION */
.integration-s{
  padding:100px 56px;
  background:rgba(255,255,255,.03);
}
.int-inner{max-width:1160px;margin:0 auto;}
.int-flow{
  margin-top:64px;
  position:relative;
}
.flow-track{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:0;
  position:relative;
}
.flow-track::before{
  content:'';
  position:absolute;
  top:40px;left:10%;right:10%;height:2px;
  background:linear-gradient(90deg, var(--p1),var(--p2),var(--p3),var(--p4),var(--p5));
  z-index:0;
}
.flow-item{
  display:flex;flex-direction:column;align-items:center;
  gap:16px;position:relative;z-index:1;
  padding:0 8px;
}
.flow-circle{
  width:80px;height:80px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  border:3px solid transparent;
  color:var(--white);
  font-family:var(--serif);font-size:12px;font-weight:600;
  text-align:center;line-height:1.2;
  box-shadow:0 4px 20px rgba(0,0,0,0.1);
  transition:transform .2s,box-shadow .2s;
  cursor:default;
}
.flow-circle:hover{transform:scale(1.08);box-shadow:0 8px 32px rgba(0,0,0,0.15);}
.flow-label{
  font-size:13px;font-weight:500;
  color:var(--muted);text-align:center;
  line-height:1.4;max-width:100px;
}
.int-connections{
  display:grid;grid-template-columns:1fr 1fr;
  gap:16px;margin-top:64px;
}
.conn-card{
  padding:24px 28px 24px 32px;
  background:rgba(255,255,255,.02);
  border:1px solid var(--border);
  border-radius:4px;
  position:relative;
  transition:border-color .2s;
}
.conn-card:hover{border-color:rgba(0,63,255,0.25);}
.conn-title{
  font-family:var(--serif);font-size:17px;font-weight:600;
  color:var(--text);margin-bottom:10px;
}
.conn-text{
  font-size:13px;color:var(--mid);line-height:1.75;
  margin-bottom:16px;
}
.conn-tags{display:flex;flex-wrap:wrap;gap:8px;}
.conn-tag{
  font-size:12px;font-weight:500;letter-spacing:0.06em;
  padding:4px 12px;border-radius:2px;border:1px solid;
}

/* ── CLIENTS */
.clients-s{
  padding:100px 56px;
  background:
    linear-gradient(135deg, rgba(0,13,48,.95) 0%, rgba(0,16,96,.6) 50%, rgba(85,51,170,.3) 100%),
    var(--bg-dark, #08060e);
  position:relative;
  overflow:hidden;
}
.clients-s::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 10% 90%, rgba(0,63,255,.12) 0%, transparent 50%),
    radial-gradient(ellipse at 90% 20%, rgba(136,0,238,.08) 0%, transparent 40%);
}
.clients-inner{position:relative;z-index:1;max-width:1160px;margin:0 auto;}
.clients-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:0;
  margin-top:40px;
  border-top:1px solid var(--border);
  border-left:1px solid var(--border);
}
.client-logo-item{
  display:flex;align-items:center;justify-content:center;
  padding:28px 24px;
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
  transition:background .2s;
}
.client-logo-item:hover{ background:rgba(0,63,255,.08); }
.client-logo-item img{
  max-height:36px;
  max-width:100%;
  width:auto;
  object-fit:contain;
  filter:brightness(0) invert(1) opacity(0.5);
  transition:filter .25s;
}
.client-logo-item:hover img{
  filter:brightness(0) invert(1) opacity(0.9);
}

/* ── CASE HIGHLIGHT */
.case-highlight-s{
  padding:100px 56px;
  background:rgba(255,255,255,.03);
}
.case-hl-inner{max-width:1160px;margin:0 auto;}
.case-hl-grid{
  display:grid;grid-template-columns:1.2fr 0.8fr;
  gap:64px;align-items:center;margin-top:40px;
}
.case-hl-client{
  font-size:12px;font-weight:600;
  letter-spacing:0.14em;text-transform:uppercase;
  color:var(--muted);display:block;margin-bottom:12px;
}
.case-hl-title{
  font-family:var(--serif);
  font-size:clamp(26px,3vw,40px);
  font-weight:300;line-height:1.2;
  color:var(--text);margin-bottom:20px;
  letter-spacing:-0.02em;
}
.case-hl-title em{font-style:italic;color:var(--orb);}
.case-hl-body{
  font-size:14px;color:var(--mid);line-height:1.85;
  margin-bottom:32px;
}
.case-hl-metrics{
  display:flex;gap:32px;flex-wrap:wrap;
  margin-bottom:32px;
  padding:24px 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.case-hl-metric{display:flex;flex-direction:column;gap:4px;}
.case-hl-number{
  font-family:var(--serif);font-size:31px;font-weight:600;
  color:var(--orb);line-height:1;
}
.case-hl-label{
  font-size:12px;color:var(--muted);line-height:1.4;max-width:160px;
}
.case-hl-cta{
  display:inline-block;
  font-size:13px;font-weight:600;
  letter-spacing:0.04em;
  color:var(--orb);text-decoration:none;
  border-bottom:1.5px solid var(--orb);
  padding-bottom:2px;
  transition:color .2s,border-color .2s;
}
.case-hl-cta:hover{color:var(--orb2);border-color:var(--orb2);}
.case-hl-visual{
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  background:rgba(255,255,255,.02);
  border:1px solid var(--border);
  border-radius:6px;
  padding:48px 32px;
  text-align:center;
  gap:24px;
}
.case-hl-badge-wrap{margin-bottom:0;}
.case-hl-badge{
  font-size:9px;font-weight:600;
  letter-spacing:0.14em;text-transform:uppercase;
  color:var(--muted);
  background:rgba(0,63,255,0.06);
  border:1px solid var(--border);
  padding:5px 14px;border-radius:100px;
}
.case-hl-pilares-used{
  display:flex;flex-wrap:wrap;gap:8px;
  justify-content:center;
}
.case-hl-pilar{
  font-size:12px;font-weight:500;
  letter-spacing:0.04em;
  padding:5px 14px;border-radius:2px;
  border:1px solid;
  background:transparent;
}
.case-hl-visual-quote{
  font-family:var(--serif);font-size:15px;font-style:italic;
  color:var(--muted);line-height:1.6;max-width:280px;
}

/* ── CASE CAROUSEL */
.cases-s{padding:100px 56px;background:rgba(255,255,255,.03);}
.cases-inner{max-width:1200px;margin:0 auto;}
.cases-carousel-wrapper{position:relative;overflow:hidden;margin-top:32px;width:100%;}
.cases-carousel-track{display:flex;width:100%;transition:transform 0.5s cubic-bezier(0.4,0,0.2,1);}
.cases-carousel-slide{width:100%;min-width:100%;flex:0 0 100%;padding:0;}

/* ── Case block (sua-marca style) inside carousel ── */
.case-block{position:relative;overflow:hidden;border-radius:6px;border:1px solid var(--border);}
.case-inner{display:grid;grid-template-columns:1fr 1fr;min-height:520px;}
.case-info{
  padding:56px 48px;display:flex;flex-direction:column;justify-content:center;
  background:rgba(255,255,255,.02);
}
.case-label{
  font-size:9px;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;
  color:rgba(255,255,255,0.35);margin-bottom:8px;display:block;
}
.case-name{
  font-family:var(--serif);font-size:clamp(24px,3vw,36px);font-weight:400;
  color:#fff;line-height:1.15;margin-bottom:8px;
}
.case-desc{font-size:13px;color:rgba(255,255,255,0.5);line-height:1.85;margin-bottom:24px;}
.case-desc strong{font-weight:500;color:rgba(255,255,255,0.8);}
.case-highlight{
  font-size:12px;font-weight:500;color:var(--orb);
  background:var(--orb-glow);border:1px solid rgba(0,63,255,0.15);
  display:inline-block;padding:5px 14px;border-radius:100px;margin-bottom:24px;
}
.case-metrics{display:flex;gap:28px;margin-bottom:28px;}
.case-metric-n{
  font-family:var(--serif);font-size:28px;font-weight:600;
  color:var(--text);line-height:1;margin-bottom:4px;
}
.case-metric-l{font-size:11px;color:rgba(255,255,255,0.35);line-height:1.4;}
.case-cta{
  display:inline-block;font-size:13px;font-weight:600;letter-spacing:0.04em;
  color:var(--orb);text-decoration:none;border-bottom:1.5px solid var(--orb);
  padding-bottom:2px;transition:color .2s,border-color .2s;
}
.case-cta:hover{color:var(--orb2);border-color:var(--orb2);}

.case-visual{position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.case-visual-gradient{position:absolute;inset:0;z-index:1;pointer-events:none;}
.case-visual img{width:100%;height:100%;object-fit:cover;opacity:0.7;transition:opacity .5s,transform .5s;}
.case-block:hover .case-visual img{opacity:0.85;transform:scale(1.03);}

.cases-dots{display:flex;justify-content:center;gap:10px;margin-top:24px;}
.cases-dot{width:10px;height:10px;border-radius:50%;background:var(--border);border:none;cursor:pointer;transition:background 0.3s;padding:0;}
.cases-dot.active{background:var(--orb);}

/* ── METHOD BRIDGE */
.method-bridge-s{
  padding:80px 56px;
  background:rgba(255,255,255,.02);
  text-align:center;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.method-bridge-inner{max-width:640px;margin:0 auto;}
.method-bridge-title{
  font-family:var(--serif);
  font-size:clamp(24px,3vw,36px);
  font-weight:300;line-height:1.2;
  color:var(--text);margin-bottom:16px;
  letter-spacing:-0.02em;
}
.method-bridge-title em{font-style:italic;color:var(--orb);}
.method-bridge-sub{
  font-size:14px;color:var(--muted);
  line-height:1.75;margin-bottom:32px;
}
.method-bridge-cta{
  display:inline-block;
  background:var(--orb);color:var(--white);
  font-family:var(--body);font-size:12px;font-weight:600;
  letter-spacing:0.06em;
  padding:14px 36px;border-radius:2px;text-decoration:none;
  transition:background .2s,transform .15s;
}
.method-bridge-cta:hover{background:var(--orb2);transform:translateY(-2px);}

/* ── CTA */
.cta-s{
  padding:120px 56px;
  background:rgba(255,255,255,.03);
  text-align:center;
  position:relative;overflow:hidden;
}
.cta-s::before{
  content:'';
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:600px;height:400px;
  background:radial-gradient(ellipse,rgba(0,63,255,0.06) 0%,transparent 65%);
  pointer-events:none;
}
.cta-title{
  font-family:var(--serif);
  font-size:clamp(32px,4.5vw,58px);
  font-weight:300;line-height:1.15;
  color:var(--text);margin-bottom:20px;
  letter-spacing:-0.02em;position:relative;
}
.cta-title em{font-style:italic;color:var(--orb);}
.cta-sub{
  font-size:16px;color:var(--muted);
  max-width:520px;margin:0 auto 52px;
  line-height:1.75;position:relative;
}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.btn-main{
  background:var(--orb);color:var(--white);
  font-family:var(--body);font-size:12px;font-weight:600;
  letter-spacing:0.06em;
  padding:16px 44px;border-radius:2px;text-decoration:none;
  transition:background .2s,transform .15s;
}
.btn-main:hover{background:var(--orb2);transform:translateY(-2px);}
.btn-ghost{
  border:1px solid var(--border);color:var(--muted);
  font-family:var(--body);font-size:12px;font-weight:500;
  padding:16px 36px;border-radius:2px;text-decoration:none;
  transition:border-color .2s,color .2s;
}
.btn-ghost:hover{border-color:var(--orb);color:var(--text);}

/* ── FOOTER */
footer{
  padding:36px 56px;
  display:flex;align-items:center;justify-content:space-between;
  border-top:1px solid var(--border);
  background:rgba(255,255,255,.02);
  flex-wrap:wrap;gap:16px;
}
.footer-logo{
  display:flex;align-items:center;
  gap:12px;
}
.footer-logo img{
  height:38px;width:auto;
  opacity:0.9;
}
.footer-logo-name{
  font-family:'Ubuntu',sans-serif;
  font-size:13px;font-weight:500;
  color:var(--mid);
  letter-spacing:0.02em;
  line-height:1.2;
}
.footer-copy{font-size:12px;color:var(--muted);}
.footer-social{display:flex;align-items:center;gap:16px;}
.footer-social-link{
  color:var(--muted);transition:color .2s;
  display:flex;align-items:center;
}
.footer-social-link:hover{color:var(--orb);}

/* ── ANIMATIONS */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(20px);}
  to{opacity:1;transform:translateY(0);}
}
.fu{opacity:0;animation:fadeUp .65s ease forwards;}
.fu:nth-child(1){animation-delay:.08s}
.fu:nth-child(2){animation-delay:.18s}
.fu:nth-child(3){animation-delay:.28s}
.fu:nth-child(4){animation-delay:.38s}

@keyframes orbitPulse{
  0%,100%{opacity:.4;r:6;}
  50%{opacity:.9;r:8;}
}
@keyframes ctablink{0%,100%{opacity:1;}50%{opacity:.3;}}

/* ── RESPONSIVE */
/* ── HAMBURGER & MOBILE NAV */

@keyframes nmIn{
  from{opacity:0;transform:translateY(-6px);}
  to{opacity:1;transform:translateY(0);}
}
  display:block;padding:14px 0;
  font-size:14px;font-weight:400;
  color:var(--mid);text-decoration:none;
  border-bottom:1px solid var(--border);
  letter-spacing:0.02em;transition:color .2s;
}
.nm-link:hover{color:var(--orb);}
.nm-section-label{
  font-size:12px;font-weight:600;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--muted);
  padding:16px 0 8px;
}
.nm-cases{
  display:flex;flex-direction:column;gap:0;
  padding-bottom:8px;border-bottom:1px solid var(--border);
}
.nm-cases a{
  display:block;padding:9px 12px;
  font-size:12px;color:var(--muted);
  text-decoration:none;border-radius:3px;
  transition:background .15s,color .15s;
}
.nm-cases a:hover{background:rgba(0,63,255,.1);color:var(--orb);}
@media(max-width:960px){
          .hero{padding:120px 24px 80px;}
  .intro-s{padding:72px 24px;}
  .intro-inner{grid-template-columns:1fr;gap:48px;}
  .orbital-s{padding:72px 24px;}
  .intro-img{max-width:100%;}
  .detail-body{grid-template-columns:1fr;}
  .integration-s{padding:72px 24px;}
  .flow-track{grid-template-columns:repeat(3,1fr);gap:16px;}
  .flow-track::before{display:none;}
  .int-connections{grid-template-columns:1fr;}
  .case-highlight-s{padding:72px 24px;}
  .case-hl-grid{grid-template-columns:1fr;gap:40px;}
  .method-bridge-s{padding:60px 24px;}
  .clients-s{padding:60px 24px;}
  .clients-grid{grid-template-columns:repeat(3,1fr);}
  .cta-s{padding:80px 24px;}
  footer{flex-direction:column;gap:10px;text-align:center;padding:28px 24px;}
  .pillars-preview{grid-template-columns:1fr;}
  .pp-item:nth-child(5){grid-column:auto;}
  .cases-s{padding:72px 24px;}
  .case-inner{grid-template-columns:1fr;min-height:auto;}
  .case-info{padding:40px 32px;}
  .case-visual{min-height:300px;}
}

/* ── MODAL */
#orb-modal {
  display: none;
  position: fixed; inset: 0; z-index: 99999;
  background: rgba(8,6,14,0.82);
  backdrop-filter: blur(10px);
  align-items: center; justify-content: center;
  padding: 24px;
  animation: modalIn .25s ease;
  cursor: auto;
}
#orb-modal *{cursor:auto}
#orb-modal input,
#orb-modal select,
#orb-modal textarea,
#orb-modal button{cursor:pointer}
@keyframes modalIn {
  from { opacity:0; }
  to   { opacity:1; }
}
#orb-modal-box {
  background: #100D18;
  border: 1px solid rgba(0,63,255,0.25);
  border-radius: 10px;
  width: 100%; max-width: 540px;
  max-height: 92vh;
  overflow-y: auto;
  position: relative;
  padding: 44px 40px 36px;
  animation: boxIn .3s ease;
}
@keyframes boxIn {
  from { opacity:0; transform: translateY(20px) scale(.98); }
  to   { opacity:1; transform: translateY(0) scale(1); }
}
#orb-modal-close {
  position: absolute; top: 14px; right: 18px;
  background: none; border: none;
  color: rgba(255,255,255,.25); font-size: 25px;
  cursor: pointer; line-height: 1;
  transition: color .2s;
  font-family: var(--body);
}
#orb-modal-close:hover { color: rgba(255,255,255,.6); }
.modal-header { margin-bottom: 28px; }
.modal-header h3 {
  font-family: var(--serif);
  font-size: 23px; font-weight: 600;
  color: #fff; margin-bottom: 6px;
  letter-spacing: -0.01em;
}
.modal-header p {
  font-size: 12px; color: rgba(255,255,255,.4);
  line-height: 1.5;
}
.modal-vagas {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12px; font-weight: 600;
  letter-spacing: .13em; text-transform: uppercase;
  color: #7B4FBE; margin-bottom: 22px;
}
.modal-vagas-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: #22C55E;
  box-shadow: 0 0 6px rgba(34,197,94,.55);
  animation: ctablink 1.8s ease-in-out infinite;
}
.modal-steps {
  display: flex; align-items: center;
  margin-bottom: 24px;
}
.ms-node {
  display: flex; align-items: center; gap: 8px;
}
.ms-num {
  width: 24px; height: 24px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700;
  transition: all .3s;
  flex-shrink: 0;
}
.ms-num.act  { background: #00C8FF; color: #fff; }
.ms-num.done { background: rgba(34,197,94,.85); color: #fff; }
.ms-num.pend { background: rgba(255,255,255,.08); color: rgba(255,255,255,.25); }
.ms-label {
  font-size: 12px; font-weight: 500;
  letter-spacing: .08em; text-transform: uppercase;
  transition: color .3s;
}
.ms-label.act  { color: rgba(255,255,255,.85); }
.ms-label.done { color: rgba(255,255,255,.4); }
.ms-label.pend { color: rgba(255,255,255,.2); }
.ms-line {
  flex: 1; height: 1px; min-width: 20px; max-width: 48px;
  background: rgba(255,255,255,.08); margin: 0 12px;
  transition: background .3s;
}
.ms-line.done { background: rgba(34,197,94,.5); }
.modal-slides { position: relative; overflow: hidden; }
.modal-slide {
  transition: opacity .3s ease, transform .3s ease;
  position: absolute; top: 0; left: 0; right: 0;
  opacity: 0; pointer-events: none;
  transform: translateX(24px);
}
.modal-slide.act {
  opacity: 1; pointer-events: auto;
  position: relative; transform: translateX(0);
}
.modal-slide.leaving {
  opacity: 0; transform: translateX(-24px);
  position: absolute;
}
.mf-hint {
  font-size: 12px; color: rgba(255,255,255,.42);
  line-height: 1.55; margin-bottom: 20px;
}
.mf-row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.mf-g { margin-bottom: 12px; }
.mf-g label {
  display: block; font-size: 9px; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase;
  color: rgba(255,255,255,.35); margin-bottom: 5px;
}
.mf-g input, .mf-g select, .mf-g textarea {
  width: 100%;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 4px;
  padding: 11px 13px;
  font-size: 13px; font-weight: 300;
  color: #fff; outline: none;
  transition: border-color .2s, background .2s;
  -webkit-appearance: none;
  font-family: var(--body);
}
.mf-g input::placeholder { color: rgba(255,255,255,.18); }
.mf-g input:focus, .mf-g select:focus, .mf-g textarea:focus {
  border-color: #7B4FBE;
  background: rgba(255,255,255,.07);
}
.mf-g select option { background: #1a1225; color: #fff; }
.mf-g textarea { resize: none; height: 78px; line-height: 1.55; }
.mf-err { border-color: rgba(239,68,68,.55) !important; }


.mf-btn-next, .mf-btn-submit {
  display: block; width: 100%;
  background: #00C8FF; color: #fff;
  font-family: var(--body);
  font-size: 12px; font-weight: 600;
  letter-spacing: .06em;
  padding: 14px 20px; border: none; border-radius: 4px;
  cursor: pointer; margin-top: 18px;
  transition: background .2s, transform .15s;
}
.mf-btn-next:hover, .mf-btn-submit:hover {
  background: #7B4FBE; transform: translateY(-1px);
}
.mf-btn-back {
  display: block; width: 100%;
  background: transparent;
  border: 1px solid rgba(255,255,255,.1);
  color: rgba(255,255,255,.35);
  font-size: 13px; font-weight: 400;
  padding: 9px; border-radius: 4px;
  cursor: pointer; margin-top: 8px;
  transition: border-color .2s, color .2s;
  font-family: var(--body);
}
.mf-btn-back:hover { border-color: rgba(255,255,255,.28); color: rgba(255,255,255,.65); }
.mf-priv {
  font-size: 12px; color: rgba(255,255,255,.2);
  text-align: center; margin-top: 10px; line-height: 1.5;
}
.mf-success {
  display: none; text-align: center; padding: 16px 8px 8px;
}
.mf-success-icon {
  width: 56px; height: 56px; border-radius: 50%;
  background: rgba(34,197,94,.1);
  border: 2px solid #22C55E;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 20px; font-size: 23px;
}
.mf-success h4 {
  font-family: var(--serif);
  font-size: 21px; font-weight: 600;
  color: #fff; margin-bottom: 10px;
  letter-spacing: -0.01em;
}
.mf-success p {
  font-size: 13px; color: rgba(255,255,255,.42);
  line-height: 1.7;
}
.mf-success strong { color: rgba(255,255,255,.8); }
@media(max-width:800px){
  /* Orbital no intro — preenche tela no mobile */
  .intro-s{padding:48px 20px;}
  .intro-img-wrap{margin-top:8px;}
  .intro-img{
    max-width:100%;width:100%;
  }
  .orbital-layout{ flex-direction:column; align-items:center; gap:32px; }
}

@media(max-width:600px){
  #orb-modal-box { padding: 32px 24px 28px; }
  .mf-row2 { grid-template-columns: 1fr; }

  /* Hero */
  .hero{ padding: 100px 20px 64px; text-align:center; }
  .hero-badge{ margin: 0 auto 20px; }
  .hero-sub{ font-size:16px; line-height:1.75; }
  .hero-stats{ gap:20px; justify-content:center; }
  .hero-stat-n{ font-size:31px; }

  /* Intro */
  .intro-s{ padding:56px 20px; }
  .intro-title{ font-size:clamp(24px,7vw,36px); }

  /* Orbital / pilares */
  .orbital-s{ padding:56px 20px; }

  /* Integração */
  .flow-track{ grid-template-columns:repeat(2,1fr); }

  /* Cases carousel */
  .cases-s{ padding:48px 20px; }
  .case-inner{ grid-template-columns:1fr;min-height:auto; }
  .case-inner[style*="direction:rtl"]{ direction:ltr !important; }
  .case-inner[style*="direction:rtl"] .case-visual{ direction:ltr !important; }
  .case-info{ padding:32px 24px; }
  .case-visual{ min-height:240px; }
  .case-metrics{ flex-direction:column;gap:16px; }
  .case-metric{ display:flex;align-items:baseline;gap:10px; }
  .case-metric-n{ font-size:22px; }

  /* Case highlight */
  .case-highlight-s{ padding:56px 20px; }
  .case-hl-grid{ grid-template-columns:1fr; gap:32px; }
  .case-hl-metrics{ gap:20px; }
  .method-bridge-s{ padding:48px 20px; }

  /* Clientes / CTA */
  .clients-s{ padding:48px 20px; }
  .clients-grid{ grid-template-columns:repeat(2,1fr); }
  .client-logo-item{ padding:20px 16px; }
  .cta-s{ padding:64px 20px; }
  .cta-title{ font-size:clamp(24px,7vw,40px); }

  /* Pilares preview grid */
  .pillars-preview{ grid-template-columns:1fr; }

  /* Section titles */
  h2.s-title{ font-size:clamp(22px,6.5vw,36px); }
}

/* Association logos */
.footer-assoc{display:flex;flex-direction:column;align-items:center;gap:7px;text-align:center;}
.footer-assoc-label{font-size:8px;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted);white-space:nowrap;}
.footer-assoc-logos{display:flex;align-items:center;gap:10px;}
.footer-assoc-logo{height:18px;width:auto;opacity:0.35;filter:brightness(0) invert(1);transition:opacity .3s;}
.footer-assoc-logo:hover{opacity:0.55;}
.footer-right{display:flex;align-items:center;gap:18px;}
.footer-right{display:flex;align-items:center;gap:18px;}


.grecaptcha-badge{visibility:hidden;}

