/* ============================================================
   NEXUS · DESIGN SYSTEM v3 — Premium Edition
   Paleta: Deep Space Navy + Precision Teal
   ============================================================ */

:root{
  /* Base */
  --bg:          #060f1e;
  --bg-2:        #091829;
  --bg-3:        #0d2240;
  --bg-deep:     #030a14;
  --bg-alt:      #041127;
  --bg-mid:      #070e1c;
  --line:        rgba(45,212,191,.1);
  --line-strong: rgba(45,212,191,.2);

  /* Accent */
  --teal:        #2dd4bf;
  --teal-2:      #5eead4;
  --teal-dim:    #0f766e;
  --teal-glow:   rgba(45,212,191,.18);

  /* Text */
  --white:       #ffffff;
  --text:        #d9ece9;
  --muted:       #6b8fa0;
  --dim:         #3d5a6e;

  /* Radius */
  --r-sm: 6px;
  --r-md: 12px;
  --r-lg: 18px;
  --r-xl: 26px;

  /* Shadow */
  --shadow-sm: 0 8px 32px rgba(0,0,0,.45);
  --shadow:    0 20px 60px rgba(0,0,0,.55);
  --shadow-lg: 0 40px 100px rgba(0,0,0,.65);
  --glow:      0 0 40px var(--teal-glow);
}

/* ============ RESET ============ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background-color:var(--bg);
  background-image:
    radial-gradient(rgba(45,212,191,.055) 1px, transparent 1px);
  background-size:36px 36px;
  background-attachment:fixed;
  color:var(--text);
  font-family:'Inter',-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;
  font-weight:400;
  line-height:1.65;
  overflow-x:hidden;
  min-height:100vh;
}
h1,h2,h3,h4{
  font-family:'Fraunces','Playfair Display',Georgia,serif;
  font-weight:600;
  letter-spacing:-.03em;
  line-height:1.1;
  color:var(--white)
}
a{color:inherit;text-decoration:none;transition:color .2s}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none}
.container{max-width:1240px;margin:0 auto;padding:0 28px}


/* ============ SECTION BACKGROUNDS ============ */
.s-bg-dark  { background-color: var(--bg-alt); }
.s-bg-mid   { background-color: var(--bg-mid); }


/* ============ SECTION SEPARATORS ============ */
.s-sep{
  position:relative;
  z-index:2;
  line-height:0;
  overflow:hidden;
  height:80px;
  margin-bottom:-2px;
  pointer-events:none;
}
.s-sep svg{display:block;width:100%;height:100%}


/* ============ TOP BAR ============ */
.topbar{
  background:var(--bg-deep);
  border-bottom:1px solid var(--line);
  font-size:12.5px;
  color:var(--muted);
}
.topbar .row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;flex-wrap:wrap;gap:8px}
.topbar i{color:var(--teal);margin-right:6px}
.topbar .info span{margin-right:20px}


/* ============ NAV ============ */
.nav{
  position:sticky;top:0;z-index:100;
  background:rgba(6,15,30,.85);
  backdrop-filter:blur(24px) saturate(1.6);
  -webkit-backdrop-filter:blur(24px) saturate(1.6);
  border-bottom:1px solid var(--line);
  transition:background .3s, box-shadow .3s;
}
.nav.scrolled{
  background:rgba(3,10,20,.95);
  box-shadow:0 4px 32px rgba(0,0,0,.5);
  border-bottom-color:var(--line);
}
.nav .row{display:flex;align-items:center;justify-content:space-between;padding:16px 0}
.nav.scrolled .row{padding:11px 0}

/* ---- LOGO / BRAND ---- */
.brand{display:flex;align-items:center;gap:14px;font-family:'Fraunces',serif}
.brand-logo{
  width:52px;height:52px;
  object-fit:contain;
  /* Logo branca — contrasta com o fundo escuro */
  filter: brightness(0) invert(1) drop-shadow(0 2px 10px rgba(45,212,191,.25));
  transition:transform .4s ease, filter .3s ease;
}
.brand:hover .brand-logo{
  transform:scale(1.07);
  filter: brightness(0) invert(1) drop-shadow(0 4px 18px rgba(45,212,191,.45));
}
.brand-name{font-size:21px;font-weight:700;color:var(--white);letter-spacing:.3px;line-height:1.1}
.brand-name span{color:var(--teal-2)}
.brand-name small{
  display:block;font-size:9.5px;font-weight:500;color:var(--muted);
  letter-spacing:2.8px;text-transform:uppercase;margin-top:3px;
  font-family:'Inter',sans-serif
}

/* ---- NAV LINKS ---- */
.nav-links{display:flex;gap:34px;align-items:center}
.nav-links a{
  font-size:13.5px;color:var(--muted);font-weight:500;
  position:relative;padding:6px 0;letter-spacing:.1px;
}
.nav-links a.active,.nav-links a:hover{color:var(--white)}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-2px;
  width:0;height:1.5px;
  background:linear-gradient(90deg, var(--teal), var(--teal-2));
  transition:width .3s cubic-bezier(.4,0,.2,1);
  border-radius:1px;
}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}


/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 26px;border-radius:999px;
  font-weight:600;font-size:13.5px;letter-spacing:.2px;
  transition:all .3s cubic-bezier(.4,0,.2,1);
  cursor:pointer;border:none;white-space:nowrap;
  position:relative;overflow:hidden;
}
.btn-primary{
  background:linear-gradient(135deg, var(--teal) 0%, var(--teal-2) 100%);
  color:var(--bg-deep);
  box-shadow:0 8px 28px rgba(45,212,191,.3), inset 0 1px 0 rgba(255,255,255,.25);
  font-weight:700;
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 40px rgba(45,212,191,.45), inset 0 1px 0 rgba(255,255,255,.3)
}
.btn-ghost{
  background:transparent;
  color:var(--text);
  border:1px solid rgba(45,212,191,.25);
}
.btn-ghost:hover{
  border-color:var(--teal);
  color:var(--teal-2);
  background:rgba(45,212,191,.06)
}
.btn-wpp{background:#25D366;color:#fff;box-shadow:0 8px 28px rgba(37,211,102,.25)}
.btn-wpp:hover{background:#1fbe59;transform:translateY(-2px);box-shadow:0 14px 36px rgba(37,211,102,.4)}
.btn-lg{padding:17px 36px;font-size:14.5px}
.menu-toggle{display:none;background:none;color:var(--text);font-size:22px}
.nav .btn{padding:10px 22px;font-size:13px}


/* ============ RIPPLE ============ */
.ripple{position:absolute;border-radius:50%;transform:scale(0);animation:ripple .65s linear;background:rgba(255,255,255,.3);pointer-events:none}
@keyframes ripple{to{transform:scale(4);opacity:0}}


/* ============ HERO VIDEO BACKGROUND ============ */
.hero-video-bg{
  position:absolute;
  inset:0;
  overflow:hidden;
  z-index:0;
}
.hero-video-bg video{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  min-width:100%;min-height:100%;
  width:auto;height:auto;
  object-fit:cover;
  will-change:transform;
}
/* Máscara escura — overlay suave, mostra mais vídeo no centro */
.hero-video-overlay{
  position:absolute;
  inset:0;
  background:
    /* Gradiente vertical: topo e base bem escuros, centro mais aberto */
    linear-gradient(
      to bottom,
      rgba(6,15,30,.90) 0%,
      rgba(6,15,30,.55) 28%,
      rgba(6,15,30,.50) 55%,
      rgba(6,15,30,.90) 100%
    ),
    /* Lateral esquerda mais escura para destacar o texto */
    linear-gradient(
      to right,
      rgba(6,15,30,.55) 0%,
      rgba(6,15,30,.10) 60%,
      rgba(6,15,30,.0) 100%
    );
  z-index:1;
}
/* Padrão de pontilhado levíssimo sobre o vídeo */
.hero-video-overlay::after{
  content:"";
  position:absolute;inset:0;
  background-image:radial-gradient(rgba(45,212,191,.04) 1px, transparent 1px);
  background-size:36px 36px;
  pointer-events:none;
}


/* ============ HERO ============ */
.hero{
  position:relative;
  min-height:88vh;
  display:flex;align-items:center;
  padding:70px 0 40px;
  overflow:hidden;
}

/* Com vídeo: grade de linhas fica no z-index:2 para ficar visível sobre a overlay */
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(45,212,191,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(45,212,191,.04) 1px, transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(ellipse 80% 80% at 60% 50%, black 20%, transparent 80%);
  pointer-events:none;
  z-index:2;
}

/* Glow canto direito — acima do vídeo */
.hero::after{
  content:"";position:absolute;top:-180px;right:-160px;width:600px;height:600px;
  background:radial-gradient(circle, rgba(45,212,191,.1), transparent 65%);
  filter:blur(48px);pointer-events:none;
  z-index:2;
}

/* Número decorativo no fundo — acima do vídeo */
.hero-bg-deco{
  position:absolute;
  right:-40px;top:50%;transform:translateY(-50%);
  font-family:'Fraunces',serif;font-size:clamp(280px,35vw,480px);
  font-weight:700;line-height:1;letter-spacing:-.05em;
  color:transparent;
  -webkit-text-stroke:1px rgba(45,212,191,.07);
  pointer-events:none;
  z-index:3;
  user-select:none;
}

.hero > .container{position:relative;z-index:3}
.hero .row{display:grid;grid-template-columns:1.15fr .85fr;gap:72px;align-items:center}

/* Kicker */
.kicker{
  display:inline-flex;align-items:center;gap:10px;
  padding:6px 0;
  color:var(--teal-2);font-size:11px;font-weight:700;
  margin-bottom:22px;letter-spacing:2.8px;text-transform:uppercase;
  position:relative;
}
.kicker::before{
  content:"";width:24px;height:1.5px;
  background:linear-gradient(90deg, var(--teal), var(--teal-2));
  display:inline-block;border-radius:1px;
}
.kicker .dot{display:none}

.hero h1{
  font-size:clamp(44px,5.8vw,74px);
  margin-bottom:28px;font-weight:500;
  letter-spacing:-.035em;
  line-height:1.07;
}
.hero h1 em{
  font-style:italic;
  color:transparent;
  background:linear-gradient(135deg, var(--teal), var(--teal-2));
  -webkit-background-clip:text;background-clip:text;
  font-weight:500;
}
.hero p.lead{
  font-size:18px;color:var(--muted);
  margin-bottom:42px;max-width:560px;line-height:1.75;
}
.hero .ctas{display:flex;gap:14px;flex-wrap:wrap}

/* Card lateral do hero */
.hero-card{
  background:rgba(9,24,41,.7);
  backdrop-filter:blur(16px);
  border:1px solid rgba(45,212,191,.12);
  border-top:1px solid rgba(45,212,191,.28);
  border-radius:var(--r-xl);padding:36px;
  box-shadow:var(--shadow-sm), inset 0 1px 0 rgba(255,255,255,.04);
  position:relative;
}
.hero-card::before{
  content:"";position:absolute;inset:0;
  border-radius:var(--r-xl);
  background:linear-gradient(135deg, rgba(45,212,191,.06), transparent 50%);
  pointer-events:none;
}
.hero-card h3{
  color:var(--white);font-size:18px;margin-bottom:24px;
  font-family:'Fraunces',serif;letter-spacing:-.02em;
}
.hero-card h3 i{color:var(--teal);margin-right:10px}
.hero-card ul{list-style:none;display:flex;flex-direction:column;gap:13px}
.hero-card li{
  display:flex;align-items:flex-start;gap:14px;
  color:var(--text);font-size:14.5px;line-height:1.5;
}
.hero-card li i{color:var(--teal);margin-top:4px;font-size:13px;flex-shrink:0}

.hero-stats{display:grid;grid-template-columns:repeat(3,auto);gap:44px;margin-top:60px}
.hero-stat{border-left:2px solid var(--teal);padding-left:18px}
.hero-stat strong{
  display:block;font-family:'Fraunces',serif;
  font-size:36px;color:var(--white);line-height:1;
}
.hero-stat span{font-size:12.5px;color:var(--muted);margin-top:5px;display:block;letter-spacing:.5px}


/* ============ SECTIONS ============ */
section{padding:110px 0;position:relative}
.section-head{
  text-align:center;margin-bottom:72px;
  max-width:820px;margin-left:auto;margin-right:auto;
}
.section-head h2{
  font-size:clamp(32px,4.2vw,52px);
  margin-bottom:18px;line-height:1.08;
  letter-spacing:-.035em;
}
.section-head h2 em{
  font-style:italic;color:transparent;
  background:linear-gradient(135deg, var(--teal), var(--teal-2));
  -webkit-background-clip:text;background-clip:text;
  font-weight:500;
}
.section-head p{color:var(--muted);font-size:17px;line-height:1.72}


/* ============ CARDS GENÉRICOS ============ */
.card{
  background:rgba(9,24,41,.65);
  border:1px solid rgba(45,212,191,.1);
  border-top:1px solid rgba(45,212,191,.22);
  border-radius:var(--r-lg);
  padding:36px;
  transition:all .35s cubic-bezier(.4,0,.2,1);
  position:relative;overflow:hidden;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.card:hover{
  border-color:rgba(45,212,191,.3);
  border-top-color:rgba(45,212,191,.5);
  transform:translateY(-4px);
  box-shadow:var(--shadow-sm), inset 0 1px 0 rgba(255,255,255,.06);
}


/* ============ PILLAR ICONS ============ */
.ico-badge{
  width:64px;height:64px;border-radius:16px;
  background:linear-gradient(135deg,rgba(45,212,191,.14),rgba(45,212,191,.04));
  border:1px solid rgba(45,212,191,.28);
  display:flex;align-items:center;justify-content:center;
  color:var(--teal-2);font-size:24px;margin-bottom:22px;
  transition:transform .4s cubic-bezier(.4,0,.2,1), box-shadow .3s;
  box-shadow:0 4px 16px rgba(45,212,191,.1);
}
.card:hover .ico-badge{
  transform:scale(1.08) rotate(-4deg);
  box-shadow:0 6px 24px rgba(45,212,191,.2);
}


/* ============ CTA CARDS (Home) ============ */
.cta-wall{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
.cta-card{
  background:rgba(9,24,41,.6);
  border:1px solid rgba(45,212,191,.1);
  border-top:1px solid rgba(45,212,191,.24);
  border-radius:var(--r-xl);
  padding:44px 36px;
  position:relative;overflow:hidden;
  transition:all .4s cubic-bezier(.4,0,.2,1);
  min-height:400px;
  display:flex;flex-direction:column;justify-content:space-between;
  cursor:pointer;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.cta-card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 0% 100%, rgba(45,212,191,.06), transparent 55%);
  pointer-events:none;transition:opacity .4s;
}
.cta-card::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 100% 0%, rgba(45,212,191,.12), transparent 45%);
  opacity:0;transition:opacity .4s;pointer-events:none;
}
.cta-card:hover::after{opacity:1}
.cta-card:hover{
  transform:translateY(-8px);
  border-color:rgba(45,212,191,.35);
  border-top-color:rgba(45,212,191,.55);
  box-shadow:var(--shadow), inset 0 1px 0 rgba(255,255,255,.07);
}
.cta-num{
  font-family:'Fraunces',serif;
  font-size:clamp(80px,9vw,120px);
  line-height:.9;
  color:transparent;
  -webkit-text-stroke:1.5px rgba(45,212,191,.2);
  transition:all .4s;
  display:block;
  margin-bottom:8px;
}
.cta-card:hover .cta-num{
  -webkit-text-stroke-color:rgba(45,212,191,.5);
}
.cta-card h3{font-size:28px;margin:16px 0 10px;letter-spacing:-.025em}
.cta-card p{color:var(--muted);font-size:15px;margin-bottom:28px;line-height:1.65}
.cta-card .arrow{
  display:inline-flex;align-items:center;gap:10px;
  color:var(--teal-2);font-weight:600;font-size:13px;
  transition:gap .3s;letter-spacing:.8px;text-transform:uppercase;
}
.cta-card:hover .arrow{gap:18px}


/* ============ MVV ============ */
.mvv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.mvv-card{text-align:center;padding:48px 32px}
.mvv-card .ico-badge{margin-left:auto;margin-right:auto;width:72px;height:72px;font-size:28px}
.mvv-card h3{font-size:26px;color:var(--white);margin-bottom:14px;letter-spacing:-.025em}
.mvv-card p{color:var(--muted);font-size:15px;line-height:1.7}


/* ============ CONSULTOR ============ */
.consultor-wrap{
  display:grid;grid-template-columns:.85fr 1.15fr;gap:72px;align-items:center;
  background:rgba(9,24,41,.55);
  border:1px solid rgba(45,212,191,.1);
  border-top:1px solid rgba(45,212,191,.22);
  border-radius:var(--r-xl);padding:60px;
  position:relative;overflow:hidden;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.consultor-wrap::before{
  content:"";position:absolute;top:-80px;right:-80px;width:350px;height:350px;
  background:radial-gradient(circle,rgba(45,212,191,.08),transparent 65%);
  pointer-events:none;
}
.consultor-photo{
  aspect-ratio:4/5;border-radius:var(--r-lg);
  background-image:
    linear-gradient(180deg, rgba(4,17,39,.05) 0%, rgba(4,17,39,.3) 55%, rgba(4,17,39,.9) 100%),
    url("assets/angelo.jpg");
  background-size:cover;background-position:center 15%;
  display:flex;align-items:flex-end;padding:28px;position:relative;overflow:hidden;
  border:1px solid rgba(45,212,191,.15);
}
.consultor-photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, transparent 60%, rgba(45,212,191,.06) 100%);
  pointer-events:none;
}
.consultor-photo .label{position:relative;z-index:2;color:var(--white)}
.consultor-photo .label b{
  display:block;color:var(--teal-2);font-size:10px;
  letter-spacing:3px;margin-bottom:4px;font-weight:700;text-transform:uppercase;
}
.consultor-photo .label strong{font-family:'Fraunces',serif;font-weight:600;font-size:20px}
.consultor-photo.has-image{}

.consultor-text h3{font-size:38px;margin-bottom:8px;letter-spacing:-.03em}
.consultor-text .role{
  color:var(--teal-2);font-size:11px;letter-spacing:3px;
  text-transform:uppercase;margin-bottom:24px;display:block;font-weight:600;
}
.consultor-text p{color:var(--muted);margin-bottom:16px;font-size:16px;line-height:1.78}
.consultor-text p strong{color:var(--white);font-weight:600}
.consultor-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}
.tag{
  background:rgba(45,212,191,.07);
  border:1px solid rgba(45,212,191,.28);
  padding:6px 14px;border-radius:999px;
  font-size:11.5px;color:var(--teal-2);font-weight:600;
  letter-spacing:.3px;
}


/* ============ ACADEMY MÓDULOS ============ */
.module-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.module{
  background:rgba(9,24,41,.55);
  border:1px solid rgba(45,212,191,.1);
  border-top:1px solid rgba(45,212,191,.2);
  border-radius:var(--r-lg);
  padding:34px;transition:all .3s;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
}
.module:hover{border-color:rgba(45,212,191,.28)}
.module-head{
  display:flex;align-items:center;gap:14px;margin-bottom:24px;
  padding-bottom:20px;border-bottom:1px solid var(--line);position:relative;
}
.module-icon{
  width:50px;height:50px;border-radius:12px;
  background:linear-gradient(135deg,var(--teal),var(--teal-dim));
  color:var(--bg-deep);display:flex;align-items:center;justify-content:center;
  font-size:20px;font-weight:700;
  box-shadow:0 6px 20px rgba(45,212,191,.3);
  flex-shrink:0;
}
.module h3{font-size:19px;letter-spacing:-.02em}
.module h3 span{
  display:block;color:var(--teal-2);font-size:10px;
  letter-spacing:2.5px;text-transform:uppercase;
  font-family:'Inter',sans-serif;font-weight:700;margin-bottom:4px;
}
.mod-count{
  margin-left:auto;background:rgba(45,212,191,.15);color:var(--teal-2);
  border:1px solid rgba(45,212,191,.4);padding:4px 12px;border-radius:999px;
  font-size:11.5px;font-weight:700;opacity:0;transition:all .3s;transform:scale(.5);
}
.mod-count.visible{opacity:1;transform:scale(1)}

.course-list{display:flex;flex-direction:column;gap:8px}
.course{
  display:flex;align-items:center;gap:14px;
  padding:12px 16px;background:rgba(6,15,30,.5);
  border:1px solid var(--line);
  border-radius:var(--r-sm);cursor:pointer;transition:all .22s;
  font-size:14px;color:var(--text);position:relative;overflow:hidden;
}
.course:hover{border-color:rgba(45,212,191,.3);background:rgba(45,212,191,.04)}
.course input{
  appearance:none;-webkit-appearance:none;
  width:18px;height:18px;border:1.5px solid var(--line-strong);
  border-radius:5px;background:transparent;cursor:pointer;
  position:relative;flex-shrink:0;transition:all .2s;
}
.course input:checked{background:linear-gradient(135deg,var(--teal),var(--teal-2));border-color:var(--teal)}
.course input:checked::after{
  content:"\f00c";font-family:"Font Awesome 6 Free";font-weight:900;
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  color:var(--bg-deep);font-size:10px;
}
.course.selected{border-color:rgba(45,212,191,.3);background:rgba(45,212,191,.07)}


/* ============ PROGRAMAS ============ */
.prog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.prog-card{
  background:rgba(9,24,41,.6);
  border:1px solid rgba(45,212,191,.1);
  border-top:1px solid rgba(45,212,191,.22);
  border-radius:var(--r-lg);
  padding:36px;transition:all .35s;position:relative;overflow:hidden;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.prog-card:hover{border-color:rgba(45,212,191,.28)}
.prog-card h3{font-size:23px;margin-bottom:22px;display:flex;align-items:center;gap:12px;letter-spacing:-.02em}
.prog-card h3 i{color:var(--teal);font-size:20px}
.prog-card ul{list-style:none;margin-bottom:24px}
.prog-card li{
  display:flex;align-items:center;gap:12px;
  padding:10px 0;color:var(--text);font-size:14.5px;
  border-bottom:1px solid var(--line);
}
.prog-card li:last-child{border-bottom:none}
.prog-card li i{color:var(--teal);font-size:10px}
.prog-select{
  width:100%;padding:13px;border-radius:var(--r-sm);
  background:rgba(45,212,191,.07);border:1px solid rgba(45,212,191,.28);
  color:var(--teal-2);font-weight:600;cursor:pointer;transition:all .25s;
  font-family:'Inter',sans-serif;font-size:13.5px;letter-spacing:.3px;
}
.prog-select:hover,.prog-select.selected{
  background:linear-gradient(135deg,var(--teal),var(--teal-2));
  color:var(--bg-deep);border-color:var(--teal);
}


/* ============ CONSULTORIA PLANS ============ */
.plans-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.plan-card{
  background:rgba(9,24,41,.6);
  border:1px solid rgba(45,212,191,.1);
  border-top:1px solid rgba(45,212,191,.22);
  border-radius:var(--r-xl);
  padding:52px 40px;position:relative;transition:all .35s;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.plan-card.featured{
  border-color:rgba(45,212,191,.3);
  border-top-color:rgba(45,212,191,.6);
  box-shadow:0 24px 72px rgba(45,212,191,.1), inset 0 1px 0 rgba(255,255,255,.06);
}
.plan-card.featured::after{
  content:"MAIS COMPLETO";
  position:absolute;top:-14px;right:28px;
  background:linear-gradient(135deg,var(--teal),var(--teal-2));color:var(--bg-deep);
  padding:6px 16px;border-radius:999px;font-size:10.5px;font-weight:700;letter-spacing:2.2px;
}
.plan-head{display:flex;align-items:center;gap:16px;margin-bottom:28px}
.plan-badge{
  width:64px;height:64px;border-radius:16px;
  background:rgba(45,212,191,.1);border:1px solid rgba(45,212,191,.35);
  display:flex;align-items:center;justify-content:center;
  color:var(--teal-2);font-family:'Fraunces',serif;font-size:24px;font-weight:700;
}
.plan-card h3{font-size:25px;margin-bottom:4px;letter-spacing:-.025em}
.plan-sub{color:var(--teal-2);font-size:11px;letter-spacing:2.5px;text-transform:uppercase;font-weight:700}
.plan-focus{
  color:var(--muted);font-size:14.5px;margin-bottom:28px;
  padding:14px 18px;
  background:rgba(6,15,30,.4);
  border-left:2.5px solid var(--teal);
  border-radius:0 var(--r-sm) var(--r-sm) 0;
  line-height:1.6;
}
.plan-focus strong{color:var(--teal-2)}

.plan-tabs{
  display:flex;gap:4px;margin-bottom:22px;
  background:rgba(6,15,30,.5);padding:5px;
  border-radius:var(--r-sm);border:1px solid var(--line);
}
.plan-tab{
  flex:1;padding:10px;background:transparent;color:var(--muted);
  font-size:12.5px;font-weight:600;border-radius:6px;transition:all .22s;letter-spacing:.3px;
}
.plan-tab.active{
  background:linear-gradient(135deg,var(--teal),var(--teal-dim));
  color:var(--bg-deep);
}
.plan-tab:hover:not(.active){color:var(--teal-2)}
.tab-pane{display:none;animation:fadeIn .4s ease}
.tab-pane.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

.phases{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.phase{display:flex;gap:16px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--line)}
.phase:last-child{border-bottom:none}
.phase-num{
  flex-shrink:0;width:34px;height:34px;border-radius:50%;
  background:rgba(45,212,191,.1);border:1px solid var(--teal-dim);
  color:var(--teal-2);display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:12.5px;
}
.phase-text strong{display:block;color:var(--white);font-size:13.5px;margin-bottom:2px}
.phase-text span{color:var(--muted);font-size:12.5px}

.plan-format{
  background:rgba(6,15,30,.5);border:1px dashed rgba(45,212,191,.2);
  border-radius:var(--r-sm);padding:18px;margin-bottom:22px;
}
.plan-format h4{color:var(--teal-2);font-size:11px;letter-spacing:2.5px;margin-bottom:12px;font-family:'Inter',sans-serif;text-transform:uppercase}
.plan-format ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.plan-format li{color:var(--text);font-size:13.5px;display:flex;gap:10px;align-items:center}
.plan-format li i{color:var(--teal);font-size:9px}


/* ============ CASES ============ */
.cli-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:56px}
.cli-stat{text-align:center;padding:32px 20px}
.cli-stat .num{
  font-family:'Fraunces',serif;font-size:52px;color:var(--teal-2);
  font-weight:700;display:block;line-height:1;
}
.cli-stat .lbl{
  color:var(--muted);font-size:12px;margin-top:10px;
  text-transform:uppercase;letter-spacing:1.8px;
}

.clients-showcase{
  background:rgba(255,255,255,.96);
  border-radius:var(--r-xl);padding:52px 40px;
  box-shadow:var(--shadow-lg);
  position:relative;overflow:hidden;
}
.clients-showcase img{width:100%;height:auto;display:block}

.client-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:40px}
.client-card{
  background:rgba(255,255,255,.95);border-radius:var(--r-md);padding:22px;
  display:flex;align-items:center;justify-content:center;
  min-height:110px;transition:all .3s;filter:grayscale(40%);
  border:1px solid transparent;
}
.client-card:hover{
  filter:grayscale(0);transform:translateY(-4px);
  box-shadow:0 12px 36px rgba(0,0,0,.3);
  border-color:var(--teal);
}
.client-card img{max-height:56px;width:auto;max-width:90%;object-fit:contain}

/* Marquee — fundo escuro premium */
.marquee{
  overflow:hidden;position:relative;padding:28px 0;
  background:rgba(9,24,41,.7);
  border:1px solid rgba(45,212,191,.12);
  border-top:1px solid rgba(45,212,191,.22);
  border-radius:var(--r-lg);margin-top:40px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.marquee-track{display:flex;gap:60px;animation:slide 40s linear infinite;width:max-content;align-items:center}
.marquee-track:hover{animation-play-state:paused}
.marquee-item{
  height:64px;display:flex;align-items:center;padding:0 24px;
  opacity:.65;
  transition:opacity .3s, transform .3s;
}
.marquee-item:hover{opacity:1;transform:scale(1.06)}
.marquee-item img{max-height:52px;width:auto;max-width:160px;object-fit:contain}
@keyframes slide{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.marquee::before,.marquee::after{
  content:"";position:absolute;top:0;bottom:0;width:100px;z-index:2;pointer-events:none;
}
.marquee::before{left:0;background:linear-gradient(90deg,rgba(9,24,41,.9),transparent)}
.marquee::after{right:0;background:linear-gradient(-90deg,rgba(9,24,41,.9),transparent)}


/* ============ GALERIA DE TREINAMENTOS ============ */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px}
.gallery-item{
  aspect-ratio:4/3;border-radius:var(--r-md);overflow:hidden;
  position:relative;cursor:pointer;
  background:linear-gradient(135deg,var(--bg-3),var(--bg-2));
  border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  color:var(--dim);font-size:12px;letter-spacing:1px;text-transform:uppercase;
  transition:all .4s;
}
.gallery-item::before{
  content:"\f030";font-family:"Font Awesome 6 Free";font-weight:900;
  font-size:48px;color:rgba(45,212,191,.15);position:absolute;
  top:50%;left:50%;transform:translate(-50%,-50%);
  transition:all .4s;
}
.gallery-item:hover::before{color:var(--teal);transform:translate(-50%,-50%) scale(1.15)}
.gallery-item:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:rgba(45,212,191,.28)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.4,0,.2,1)}
.gallery-item:hover img{transform:scale(1.07)}
.gallery-item.large{grid-column:span 2;grid-row:span 2}
.gallery-item .overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%, rgba(3,10,20,.92) 100%);
  display:flex;align-items:flex-end;padding:22px;
  opacity:0;transition:opacity .4s;z-index:2;
}
.gallery-item:hover .overlay{opacity:1}
.gallery-item .overlay span{color:var(--white);font-size:13px;letter-spacing:.8px}


/* ============ FORMULÁRIO ============ */
.form-wrap{
  background:rgba(9,24,41,.65);
  border:1px solid rgba(45,212,191,.12);
  border-top:1px solid rgba(45,212,191,.28);
  border-radius:var(--r-xl);padding:56px;
  box-shadow:var(--shadow-lg), inset 0 1px 0 rgba(255,255,255,.04);
  position:relative;max-width:920px;margin:0 auto;
}
.form-wrap::before{
  content:"";position:absolute;inset:-1px;border-radius:var(--r-xl);
  background:linear-gradient(135deg,rgba(45,212,191,.2) 0%,transparent 30%,transparent 70%,rgba(45,212,191,.08) 100%);
  z-index:-1;
}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:26px}
.field{display:flex;flex-direction:column;gap:7px}
.field.full{grid-column:1/-1}
.field label{font-size:11px;color:var(--teal-2);letter-spacing:2px;text-transform:uppercase;font-weight:700}
.field input,.field select,.field textarea{
  background:rgba(6,15,30,.6);border:1px solid rgba(45,212,191,.18);
  border-radius:var(--r-sm);
  padding:13px 16px;color:var(--text);font-family:inherit;font-size:14.5px;
  transition:all .22s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;
  border-color:var(--teal);
  background:rgba(6,15,30,.8);
  box-shadow:0 0 0 3px rgba(45,212,191,.12);
}
.field textarea{resize:vertical;min-height:130px}
.field select{
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%232dd4bf'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;background-size:18px;padding-right:40px;
}

.selected-summary{
  background:rgba(6,15,30,.45);border:1px dashed rgba(45,212,191,.2);
  border-radius:var(--r-md);padding:20px;margin-bottom:26px;
}
.selected-summary h4{color:var(--teal-2);font-size:11px;letter-spacing:2px;text-transform:uppercase;margin-bottom:13px;font-family:'Inter',sans-serif}
.summary-chips{display:flex;flex-wrap:wrap;gap:8px;min-height:34px}
.chip{background:rgba(45,212,191,.1);border:1px solid rgba(45,212,191,.35);color:var(--teal-2);padding:6px 14px;border-radius:999px;font-size:12px;display:inline-flex;align-items:center;gap:8px}
.chip i{cursor:pointer;font-size:10px;opacity:.7}
.chip i:hover{opacity:1;color:#ff6b6b}
.empty-state{color:var(--muted);font-size:13px;font-style:italic}

.form-cta{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:28px}
.form-note{text-align:center;color:var(--muted);font-size:12.5px;margin-top:16px}
.form-note i{color:var(--teal)}


/* ============ FOOTER ============ */
footer{
  background:var(--bg-deep);
  border-top:1px solid var(--line);
  padding:72px 0 36px;
  position:relative;
}
footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(45,212,191,.35),transparent);
}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;margin-bottom:52px}
.foot-brand p{color:var(--muted);font-size:14px;margin-top:16px;line-height:1.7}
.foot h4{color:var(--white);font-family:'Inter',sans-serif;font-size:12px;margin-bottom:20px;letter-spacing:2.5px;text-transform:uppercase;font-weight:700}
.foot ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.foot ul li{color:var(--muted);font-size:14px;display:flex;gap:10px;align-items:center}
.foot ul li i{color:var(--teal);width:18px}
.foot ul a:hover{color:var(--teal-2)}
.foot-bottom{
  border-top:1px solid var(--line);padding-top:28px;
  text-align:center;color:var(--dim);font-size:12.5px;
}
.foot-bottom span{color:var(--teal-2)}

/* Logo no footer também branca */
footer .brand-logo{
  filter: brightness(0) invert(1) drop-shadow(0 2px 8px rgba(45,212,191,.2));
}


/* ============ FLOATING UI ============ */
.float-wpp{
  position:fixed;bottom:28px;right:28px;z-index:90;
  width:60px;height:60px;border-radius:50%;
  background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:26px;box-shadow:0 10px 32px rgba(37,211,102,.4);
  transition:transform .2s;animation:wppPulse 2.5s ease-in-out infinite;
}
.float-wpp:hover{transform:scale(1.1)}
@keyframes wppPulse{0%,100%{box-shadow:0 10px 32px rgba(37,211,102,.4)}50%{box-shadow:0 10px 48px rgba(37,211,102,.7)}}

.plan-fab{
  position:fixed;bottom:108px;right:28px;z-index:90;
  background:linear-gradient(135deg,var(--teal),var(--teal-2));color:var(--bg-deep);
  padding:12px 20px;border-radius:999px;font-weight:700;
  display:flex;align-items:center;gap:10px;
  box-shadow:0 10px 28px rgba(45,212,191,.35);
  transition:transform .2s,opacity .3s;font-size:13px;letter-spacing:.5px;
  opacity:0;pointer-events:none;
}
.plan-fab.visible{opacity:1;pointer-events:auto}
.plan-fab:hover{transform:scale(1.05)}
.plan-fab .badge{background:var(--bg-deep);color:var(--teal-2);border-radius:999px;padding:2px 10px;font-size:11.5px;min-width:22px;text-align:center}

.plan-panel{
  position:fixed;top:0;right:-440px;width:420px;max-width:90vw;height:100vh;
  background:linear-gradient(180deg,var(--bg-2),var(--bg-deep));
  border-left:1px solid rgba(45,212,191,.18);
  z-index:200;padding:32px 26px;overflow-y:auto;
  transition:right .4s cubic-bezier(.4,0,.2,1);
  box-shadow:-30px 0 80px rgba(0,0,0,.7);
}
.plan-panel.open{right:0}
.plan-panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:26px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.plan-panel-head h3{color:var(--teal-2);font-size:21px}
.plan-panel-head button{background:none;color:var(--text);font-size:22px;transition:transform .3s}
.plan-panel-head button:hover{transform:rotate(90deg);color:var(--teal)}
.plan-group{margin-bottom:24px}
.plan-group h4{color:var(--teal);font-size:10.5px;letter-spacing:2.5px;text-transform:uppercase;margin-bottom:12px;font-family:'Inter',sans-serif}
.plan-group .items{display:flex;flex-direction:column;gap:8px}
.plan-group .item{background:rgba(6,15,30,.6);border:1px solid var(--line);padding:11px 14px;border-radius:var(--r-sm);font-size:13px;color:var(--text);display:flex;justify-content:space-between;align-items:center;gap:10px}
.plan-group .item i{color:#ff6b6b;cursor:pointer;opacity:.6}
.plan-group .item i:hover{opacity:1}
.plan-empty{color:var(--muted);font-size:13px;font-style:italic;text-align:center;padding:28px}
.plan-actions{display:flex;flex-direction:column;gap:10px;margin-top:22px;padding-top:22px;border-top:1px solid var(--line)}

.backdrop{position:fixed;inset:0;background:rgba(3,10,20,.75);z-index:150;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(8px)}
.backdrop.show{opacity:1;pointer-events:auto}


/* ============ TOAST ============ */
.toast{
  position:fixed;bottom:36px;left:50%;
  transform:translate(-50%,120px);
  background:linear-gradient(135deg,var(--teal),var(--teal-2));color:var(--bg-deep);
  padding:13px 26px;border-radius:999px;font-weight:700;z-index:250;
  box-shadow:0 20px 48px rgba(45,212,191,.35);
  opacity:0;transition:all .45s cubic-bezier(.4,0,.2,1);
  display:flex;align-items:center;gap:10px;
  font-size:14px;
}
.toast.show{opacity:1;transform:translate(-50%,0)}


/* ============ PROGRESS BAR ============ */
.progress-bar{
  position:fixed;top:0;left:0;height:2px;
  background:linear-gradient(90deg,var(--teal),var(--teal-2));
  width:0;z-index:1000;transition:width .08s ease-out;
  box-shadow:0 0 12px rgba(45,212,191,.5);
}


/* ============ REVEAL ============ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s cubic-bezier(.4,0,.2,1),transform .75s cubic-bezier(.4,0,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal.delay-1{transition-delay:.1s}
.reveal.delay-2{transition-delay:.2s}
.reveal.delay-3{transition-delay:.3s}


/* ============ GRADIENT TEXT ============ */
.gradient-text{
  background:linear-gradient(90deg,var(--teal),var(--teal-2),var(--teal));
  background-size:200% auto;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  animation:shine 3s linear infinite
}
@keyframes shine{to{background-position:200% center}}


/* ============ PAGE HERO (inner pages) ============ */
.page-hero{padding:140px 0 80px;position:relative;overflow:hidden}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(45,212,191,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(45,212,191,.05) 1px, transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(ellipse at center, black 30%, transparent 80%);
  pointer-events:none;
}
.page-hero::after{
  content:"";position:absolute;top:-180px;right:-140px;width:480px;height:480px;
  background:radial-gradient(circle, rgba(45,212,191,.1), transparent 65%);
  filter:blur(36px);pointer-events:none;
}
.page-hero > .container{position:relative;z-index:1;text-align:center;max-width:900px}
.page-hero h1{font-size:clamp(36px,4.8vw,62px);margin-bottom:20px;line-height:1.08;letter-spacing:-.035em}
.page-hero h1 em{
  font-style:italic;color:transparent;
  background:linear-gradient(135deg,var(--teal),var(--teal-2));
  -webkit-background-clip:text;background-clip:text;
  font-weight:500;
}
.page-hero p{color:var(--muted);font-size:17.5px;line-height:1.72;max-width:680px;margin:0 auto}
.page-hero .breadcrumb{display:flex;justify-content:center;align-items:center;gap:10px;margin-bottom:20px;color:var(--muted);font-size:12.5px}
.page-hero .breadcrumb a{color:var(--teal-2)}
.page-hero .breadcrumb i{font-size:9px;opacity:.5}


/* ============ QUOTE ============ */
.quote{
  border-left:2.5px solid var(--teal);
  background:rgba(6,15,30,.5);
  padding:28px 32px;border-radius:0 var(--r-md) var(--r-md) 0;
  font-family:'Fraunces',serif;font-style:italic;font-size:18.5px;
  color:var(--text);line-height:1.65;margin:32px 0;
}
.quote cite{
  display:block;margin-top:14px;font-style:normal;
  font-family:'Inter',sans-serif;font-size:12px;
  color:var(--teal-2);letter-spacing:2px;text-transform:uppercase;
}


/* ============ DELIVERIES ============ */
.deliveries{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:40px 0}
.delivery{
  background:rgba(9,24,41,.55);
  border:1px solid rgba(45,212,191,.1);
  border-top:1px solid rgba(45,212,191,.2);
  border-radius:var(--r-md);padding:28px;
  transition:all .3s;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
}
.delivery:hover{border-color:rgba(45,212,191,.28);transform:translateY(-4px)}
.delivery .num{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:50%;
  background:rgba(45,212,191,.1);border:1px solid var(--teal-dim);
  color:var(--teal-2);font-family:'Fraunces',serif;font-weight:700;font-size:15px;
  margin-bottom:16px;
}
.delivery h4{color:var(--white);font-family:'Inter',sans-serif;font-size:15.5px;font-weight:600;margin-bottom:10px;letter-spacing:.1px}
.delivery p{color:var(--muted);font-size:14px;line-height:1.65}
@media(max-width:960px){.deliveries{grid-template-columns:1fr}}


/* ============ FILTER PILLS ============ */
.filter-pills{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:40px}
.filter-pill{
  background:rgba(6,15,30,.55);border:1px solid rgba(45,212,191,.18);
  padding:10px 20px;border-radius:999px;color:var(--muted);
  font-size:12.5px;font-weight:600;cursor:pointer;transition:all .22s;
}
.filter-pill:hover{border-color:rgba(45,212,191,.4);color:var(--teal-2)}
.filter-pill.active{
  background:linear-gradient(135deg,var(--teal),var(--teal-2));
  color:var(--bg-deep);border-color:var(--teal);
}


/* ============ CASE CARDS ============ */
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.case-card{
  background:rgba(9,24,41,.6);
  border:1px solid rgba(45,212,191,.1);
  border-top:1px solid rgba(45,212,191,.2);
  border-radius:var(--r-lg);
  padding:34px;transition:all .35s;position:relative;overflow:hidden;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
}
.case-card:hover{border-color:rgba(45,212,191,.28);transform:translateY(-6px);box-shadow:var(--shadow-sm)}
.case-card .logo-holder{
  background:rgba(255,255,255,.96);padding:20px;border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;height:96px;
  margin-bottom:22px;
}
.case-card .logo-holder img{max-height:56px;max-width:85%;object-fit:contain}
.case-card h3{font-size:19px;margin-bottom:8px;letter-spacing:-.02em}
.case-card .sector{color:var(--teal-2);font-size:10.5px;letter-spacing:2px;text-transform:uppercase;font-weight:700;margin-bottom:14px;display:block}
.case-card p{color:var(--muted);font-size:14px;line-height:1.65;margin-bottom:18px}
.case-card .outcomes{display:flex;flex-direction:column;gap:8px;padding-top:16px;border-top:1px dashed var(--line)}
.case-card .outcomes .out{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text)}
.case-card .outcomes .out i{color:var(--teal);font-size:10px}
@media(max-width:960px){.case-grid{grid-template-columns:1fr}}


/* ============ TIMELINE ============ */
.timeline{
  position:relative;padding:20px 0;
  display:grid;grid-template-columns:repeat(5,1fr);gap:16px;
}
.timeline.six{grid-template-columns:repeat(6,1fr)}
.timeline::before{
  content:"";position:absolute;top:40px;left:5%;right:5%;height:1.5px;
  background:linear-gradient(90deg,transparent,var(--teal-dim),transparent);
}
.t-step{text-align:center;position:relative;z-index:2}
.t-step .dot{
  width:76px;height:76px;margin:0 auto 16px;border-radius:50%;
  background:rgba(9,24,41,.8);
  border:1.5px solid var(--teal-dim);
  display:flex;align-items:center;justify-content:center;
  color:var(--teal-2);font-family:'Fraunces',serif;font-size:24px;font-weight:700;
  transition:all .3s;position:relative;
}
.t-step:hover .dot{
  border-color:var(--teal);color:var(--teal);
  box-shadow:0 0 24px rgba(45,212,191,.25);transform:translateY(-3px);
}
.t-step h4{font-family:'Inter',sans-serif;color:var(--white);font-size:13px;font-weight:700;margin-bottom:6px;letter-spacing:.2px}
.t-step p{color:var(--muted);font-size:12px;line-height:1.5}
@media(max-width:960px){
  .timeline,.timeline.six{grid-template-columns:1fr;gap:12px}
  .timeline::before{display:none}
  .t-step{display:flex;gap:16px;text-align:left;align-items:flex-start}
  .t-step .dot{flex-shrink:0;width:58px;height:58px;font-size:20px;margin:0}
}


/* ============ FORMAT GRID ============ */
.format-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:28px}
.format-item{
  background:rgba(6,15,30,.5);border:1px dashed rgba(45,212,191,.2);
  border-radius:var(--r-md);padding:22px;text-align:center;transition:all .3s;
}
.format-item:hover{border-style:solid;border-color:rgba(45,212,191,.32);background:rgba(6,15,30,.7)}
.format-item i{color:var(--teal);font-size:24px;margin-bottom:12px;display:block}
.format-item strong{color:var(--white);font-family:'Inter',sans-serif;font-size:13.5px;font-weight:600;display:block}
@media(max-width:960px){.format-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.format-grid{grid-template-columns:1fr}}


/* ============ GALLERY BENTO ============ */
.gallery-bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:180px;gap:14px}
.gallery-bento .b{
  border-radius:var(--r-md);overflow:hidden;position:relative;
  background:linear-gradient(135deg,var(--bg-3),var(--bg-2));
  border:1px solid var(--line);transition:all .4s;
  display:flex;align-items:center;justify-content:center;color:var(--dim);
}
.gallery-bento .b:hover{transform:translateY(-4px);border-color:rgba(45,212,191,.28);box-shadow:var(--shadow-sm)}
.gallery-bento .b img{width:100%;height:100%;object-fit:cover;display:block}
.gallery-bento .b.wide{grid-column:span 2}
.gallery-bento .b.tall{grid-row:span 2}
.gallery-bento .b.big{grid-column:span 2;grid-row:span 2}
.gallery-bento .cap{
  position:absolute;inset:auto 0 0 0;padding:14px 18px;
  background:linear-gradient(180deg,transparent,rgba(3,10,20,.9));
  color:var(--white);font-size:12px;font-weight:600;letter-spacing:1px;z-index:2;
  opacity:0;transition:opacity .3s;
}
.gallery-bento .b:hover .cap{opacity:1}
@media(max-width:960px){
  .gallery-bento{grid-template-columns:repeat(2,1fr)}
  .gallery-bento .b.big,.gallery-bento .b.wide{grid-column:span 2}
}


/* ============ TRAINING GALLERY ============ */
.training-gallery{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:220px;
  grid-auto-flow:dense;
  gap:14px;
}
.tg-item{
  position:relative;overflow:hidden;
  border-radius:var(--r-md);
  border:1px solid rgba(45,212,191,.12);
  cursor:pointer;margin:0;
  background:var(--bg-3);
  transition:border-color .3s,box-shadow .3s;
}
.tg-item:hover{border-color:rgba(45,212,191,.32);box-shadow:0 12px 40px rgba(0,0,0,.45)}
.tg-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s cubic-bezier(.25,.46,.45,.94)}
.tg-item:hover img{transform:scale(1.06)}
.tg-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(4,17,39,.0) 40%,rgba(4,17,39,.65));
  display:flex;align-items:flex-end;justify-content:flex-end;
  padding:16px;opacity:0;transition:opacity .35s;
}
.tg-overlay i{
  width:40px;height:40px;border-radius:50%;
  background:rgba(45,212,191,.18);border:1px solid rgba(45,212,191,.4);
  color:var(--teal);font-size:15px;
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(4px);
}
.tg-item:hover .tg-overlay{opacity:1}
.tg-big{grid-column:span 2;grid-row:span 2}
.tg-tall{grid-row:span 2}
.tg-wide{grid-column:span 2}

/* LIGHTBOX */
.lightbox{
  position:fixed;inset:0;z-index:9999;
  background:rgba(2,5,15,.92);
  backdrop-filter:blur(12px);
  display:none;align-items:center;justify-content:center;
  padding:32px;
}
.lightbox.open{display:flex;animation:lbIn .25s ease}
@keyframes lbIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
.lightbox img{
  max-width:90vw;max-height:85vh;
  object-fit:contain;
  border-radius:var(--r-md);
  border:1px solid rgba(45,212,191,.18);
  box-shadow:0 48px 140px rgba(0,0,0,.8);
}
.lb-close{
  position:absolute;top:22px;right:26px;
  background:rgba(45,212,191,.1);border:1px solid rgba(45,212,191,.28);
  color:var(--white);border-radius:50%;
  width:46px;height:46px;font-size:18px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .2s;z-index:1;
}
.lb-close:hover{background:rgba(45,212,191,.24);transform:scale(1.08)}
@media(max-width:960px){
  .training-gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:190px}
  .tg-big,.tg-wide{grid-column:span 2}
  .tg-tall{grid-row:span 2}
}
@media(max-width:560px){
  .training-gallery{grid-template-columns:1fr;grid-auto-rows:210px}
  .tg-big,.tg-tall,.tg-wide{grid-column:span 1;grid-row:span 1}
}


/* ============ SESSION FEATURE ============ */
.session-feature{display:grid;grid-template-columns:.9fr 1.1fr;gap:52px;align-items:center}
.session-photo{position:relative;margin:0;border-radius:var(--r-lg);overflow:hidden;border:1px solid rgba(45,212,191,.15);box-shadow:var(--shadow-sm)}
.session-photo img{width:100%;display:block;object-fit:cover;aspect-ratio:3/4}
.session-photo figcaption{
  position:absolute;inset:auto 0 0 0;padding:16px 20px;
  background:linear-gradient(180deg,transparent,rgba(3,10,20,.92));
  color:var(--white);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
}
.session-text h3{font-size:32px;margin-bottom:16px;font-family:'Fraunces',serif;font-weight:500;line-height:1.12;letter-spacing:-.03em}
.session-text p{color:var(--muted);font-size:15.5px;line-height:1.75;margin-bottom:14px}
.session-text p strong{color:var(--white);font-weight:600}
.session-list{list-style:none;margin-top:20px;display:flex;flex-direction:column;gap:10px}
.session-list li{position:relative;padding-left:22px;color:var(--text);font-size:14px;line-height:1.55}
.session-list li::before{content:"";position:absolute;left:0;top:9px;width:10px;height:1.5px;background:var(--teal-2);border-radius:1px}
@media(max-width:960px){.session-feature{grid-template-columns:1fr;gap:32px}}


/* ============ FORMULÁRIO CONTATO ============ */
.msg-preview{
  background:rgba(3,10,20,.6);border:1px dashed rgba(45,212,191,.2);
  border-radius:var(--r-md);padding:22px;margin-top:18px;
  font-family:'Courier New',monospace;font-size:12.5px;line-height:1.7;
  color:var(--teal-2);white-space:pre-wrap;max-height:260px;overflow-y:auto;
}
.msg-preview::-webkit-scrollbar{width:5px}
.msg-preview::-webkit-scrollbar-thumb{background:var(--teal-dim);border-radius:3px}


/* ============ CONTACT GRID ============ */
.contact-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:flex-start}
.contact-side{
  background:rgba(9,24,41,.6);
  border:1px solid rgba(45,212,191,.1);
  border-top:1px solid rgba(45,212,191,.22);
  border-radius:var(--r-xl);padding:40px;
  position:sticky;top:100px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.contact-side h3{font-size:21px;margin-bottom:10px;letter-spacing:-.025em}
.contact-side p{color:var(--muted);font-size:13.5px;margin-bottom:20px;line-height:1.7}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:18px}
.contact-list li{display:flex;gap:14px;align-items:flex-start;color:var(--text);font-size:14px}
.contact-list li i{
  color:var(--teal);width:34px;height:34px;
  background:rgba(45,212,191,.08);border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
}
.contact-list li b{display:block;color:var(--white);font-weight:600;margin-bottom:2px}
@media(max-width:960px){.contact-grid{grid-template-columns:1fr}.contact-side{position:static}}


/* ============ ACADEMY NAV ============ */
.academy-nav{
  display:flex;gap:6px;flex-wrap:wrap;justify-content:center;margin-bottom:48px;
  padding:7px;background:rgba(6,15,30,.55);
  border:1px solid var(--line);border-radius:999px;
  max-width:fit-content;margin-left:auto;margin-right:auto;
}
.academy-nav a{padding:10px 18px;border-radius:999px;color:var(--muted);font-size:13px;font-weight:600;transition:all .22s;letter-spacing:.2px}
.academy-nav a:hover{color:var(--teal-2)}
.academy-nav a.active,.academy-nav a:hover{background:rgba(45,212,191,.08)}
.academy-nav a.active{color:var(--teal-2)}


/* ============ FEATURE BANNER ============ */
.feature-banner{
  background:linear-gradient(135deg,rgba(45,212,191,.1),rgba(6,15,30,.6));
  border:1px solid rgba(45,212,191,.28);
  border-top:1px solid rgba(45,212,191,.45);
  border-radius:var(--r-xl);padding:52px;text-align:center;
  position:relative;overflow:hidden;
  box-shadow:0 24px 64px rgba(45,212,191,.08), inset 0 1px 0 rgba(255,255,255,.04);
}
.feature-banner::before{
  content:"";position:absolute;top:-40px;left:50%;transform:translateX(-50%);
  width:400px;height:200px;
  background:radial-gradient(circle, rgba(45,212,191,.12), transparent 65%);
  filter:blur(24px);pointer-events:none;
}
.feature-banner h3{font-size:30px;margin-bottom:14px;letter-spacing:-.03em}
.feature-banner p{color:var(--muted);max-width:600px;margin:0 auto 28px;font-size:16px;line-height:1.7}


/* ============ ACADEMY BANNER ============ */
.academy-banner{
  display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:center;
  background:rgba(9,24,41,.6);
  border:1px solid rgba(45,212,191,.2);
  border-top:1px solid rgba(45,212,191,.4);
  border-radius:var(--r-xl);padding:40px;
  margin-bottom:56px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.academy-banner .mega-ico{
  width:88px;height:88px;border-radius:22px;
  background:linear-gradient(135deg,var(--teal),var(--teal-dim));
  display:flex;align-items:center;justify-content:center;
  color:var(--bg-deep);font-size:36px;
  box-shadow:0 10px 32px rgba(45,212,191,.35);
  flex-shrink:0;
}
.academy-banner h3{font-size:24px;margin-bottom:8px;color:var(--white);letter-spacing:-.025em}
.academy-banner p{color:var(--muted);font-size:15px;max-width:680px;line-height:1.7}
@media(max-width:960px){.academy-banner{grid-template-columns:1fr;text-align:center}.academy-banner .mega-ico{margin:0 auto}}


/* ============ FEATURE BANNER ============ */
.feature-banner{
  background:linear-gradient(135deg,rgba(45,212,191,.1),rgba(6,15,30,.6));
  border:1px solid rgba(45,212,191,.28);
  border-top:1px solid rgba(45,212,191,.45);
  border-radius:var(--r-xl);padding:52px;text-align:center;
  position:relative;overflow:hidden;
  box-shadow:0 24px 64px rgba(45,212,191,.08), inset 0 1px 0 rgba(255,255,255,.04);
}
.feature-banner::before{
  content:"";position:absolute;top:-40px;left:50%;transform:translateX(-50%);
  width:400px;height:200px;
  background:radial-gradient(circle, rgba(45,212,191,.12), transparent 65%);
  filter:blur(24px);pointer-events:none;
}
.feature-banner h3{font-size:30px;margin-bottom:14px;letter-spacing:-.03em}
.feature-banner h3 em{
  font-style:italic;color:transparent;
  background:linear-gradient(135deg,var(--teal),var(--teal-2));
  -webkit-background-clip:text;background-clip:text;
}
.feature-banner p{color:var(--muted);max-width:600px;margin:0 auto 28px;font-size:16px;line-height:1.7}


/* ============ LINK UTILITIES ============ */
.link-aqua{color:var(--teal-2);border-bottom:1px dashed rgba(45,212,191,.4)}
.link-aqua:hover{color:var(--white);border-bottom-color:var(--teal)}

/* Gradient divider line */
.divider{height:1px;background:linear-gradient(90deg,transparent,rgba(45,212,191,.3),transparent);margin:80px 0;border:none}


/* ============ NAV STATES ============ */
.nav.scrolled .row{padding:10px 0}


/* ============ RESPONSIVE ============ */
@media(max-width:960px){
  .nav-links{display:none}
  .menu-toggle{display:block}
  .hero .row,.consultor-wrap,.cta-wall,.mvv-grid,.module-grid,.prog-grid,.plans-grid,.form-grid,.foot-grid,.client-grid,.cli-stats,.gallery-grid{grid-template-columns:1fr !important;gap:20px}
  .cli-stats,.client-grid{grid-template-columns:repeat(2,1fr) !important}
  .gallery-item.large{grid-column:auto;grid-row:auto}
  .consultor-wrap,.form-wrap{padding:32px}
  .plan-card{padding:36px 28px}
  .clients-showcase{padding:28px 20px}
  .plan-fab{bottom:96px;right:16px;padding:10px 14px;font-size:12px}
  .plan-panel{width:100%}
  .hero-stats{grid-template-columns:repeat(3,1fr);gap:20px}
  .hero-stat strong{font-size:26px}
  section{padding:72px 0}
  .hero-bg-deco{display:none}
}
@media(max-width:560px){
  .cli-stats,.client-grid{grid-template-columns:1fr !important}
  .hero-stats{grid-template-columns:1fr}
}

/* Mobile nav */
@media(max-width:960px){
  .nav-links{
    display:none;
    position:absolute;top:100%;left:0;right:0;
    background:rgba(3,10,20,.97);backdrop-filter:blur(20px);
    border-bottom:1px solid var(--line);
    flex-direction:column;gap:0;padding:12px 0;
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:14px 28px;width:100%}
  .nav-links .btn{margin:12px 28px;width:calc(100% - 56px);justify-content:center}
}
