/* ===== THEME TOKENS ===== */
:root{
  --bg-1:#07221d;
  --bg-2:#0c3a2f;
  --grad-1:#0f7a53;
  --grad-2:#22b96b;
  --surface:rgba(255,255,255,.08);
  --border:rgba(255,255,255,.12);
  --text:#e7f6ee;
  --muted:#bfe7d0;
  --accent:#2dd36f;
  --accent-2:#1cc069;
  --shadow:0 10px 30px rgba(0,0,0,.35);
  --radius:18px;
  --nav-bg: rgba(5,26,22,.55);
  --card-grad: linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.04));
}
[data-theme="light"]{
  --bg-1:#4ba383;
  --bg-2:#a1e4cd;
  --grad-1:#8ed9bd;
  --grad-2:#39d98a;
  --surface:rgba(0,0,0,.04);
  --border:rgba(0,0,0,.12);
  --text:#0e1f19;
  --muted:#205c4a;
  --accent:#22b96b;
  --accent-2:#179e59;
  --nav-bg: rgba(255,255,255,.65);
  --card-grad: linear-gradient(180deg,rgba(0,0,0,.06),rgba(0,0,0,.02));
}

/* ===== RESET/BASICS ===== */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  line-height:1.6;
  background:
    radial-gradient(1200px 800px at 15% -10%, var(--grad-2) 0%, transparent 45%),
    radial-gradient(900px 600px at 110% 10%, var(--grad-1) 0%, transparent 40%),
    linear-gradient(180deg, var(--bg-2), var(--bg-1));
  color:var(--text);
}

/* ===== NAVBAR ===== */
.navbar{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 28px;background:var(--nav-bg);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--border);
}
.navbar .brand{display:flex;align-items:center;gap:12px;color:var(--text);text-decoration:none;font-weight:700}
.navbar .brand img{height:34px}
.navbar nav{display:flex;gap:22px;align-items:center}
.navbar nav a{color:var(--muted);text-decoration:none;font-weight:600}
.navbar .btn-cta{background:var(--accent);color:#0b281f;padding:10px 16px;border-radius:999px}
.navbar .btn-cta:hover{background:var(--accent-2)}
.hamburger{display:none;cursor:pointer}
.hamburger span{display:block;width:24px;height:2px;background:var(--text);margin:5px 0}
#nav-toggle{display:none}
.nav-drawer{display:none}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;
  height:44px;padding:0 18px;border-radius:12px;border:1px solid var(--border);
  text-decoration:none;font-weight:700;transition:.2s}
.btn-ghost{color:var(--text);background:transparent}
.btn-ghost:hover{background:var(--surface)}
.btn-cta { box-shadow: 0 6px 20px rgba(45,211,111,.25); }
.btn-cta:hover { transform: translateY(-1px); }
.btn-full{width:100%;height:50px;margin-top:14px}

/* ===== THEME TOGGLE (minimal) ===== */
.theme-toggle{background:none;border:none;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center}
.theme-toggle svg{width:22px;height:22px;fill:var(--text);transition:transform .25s ease, fill .25s ease}
.theme-toggle:hover svg{transform:rotate(18deg) scale(1.05);fill:var(--accent)}

/* ===== HERO ===== */
.hero{
  position: relative;
  z-index: 0;
  overflow: hidden;
  min-height: 82vh;
  display: grid;
  align-items: center;
  padding: clamp(60px, 8vw, 120px) 28px;
  color: var(--text);
  background:
    radial-gradient(900px 600px at 8% -12%, var(--grad-2) 0%, transparent 45%),
    radial-gradient(900px 600px at 110% 10%, var(--grad-1) 0%, transparent 40%),
    linear-gradient(180deg, var(--bg-2), var(--bg-1));
}
.hero-bg{
  position: absolute;
  inset: 0 auto 0 40%;
  width: 60%;
  height: 100%;
  object-fit: cover;
  clip-path: polygon(18% 0, 100% 0, 100% 100%, 0 100%);
  z-index: 0;
  opacity: .9;
  filter: contrast(1.05) saturate(1.05);
}
.hero-overlay{
  position: absolute; inset: 0; z-index: 1; pointer-events:none;
  background: linear-gradient(120deg, rgba(7,34,29,0) 38%, rgba(7,34,29,.35) 70%);
}
.hero .hero-inner{ position: relative; z-index: 2; max-width: 720px; }
.hero h1{font-size:clamp(36px,6vw,64px);line-height:1.1;font-weight:800;margin-bottom:16px}
.hero h1 span{font-weight:700;color:#bfe7d0}
.hero .lead{max-width:650px;margin-bottom:28px;color:#e7f6ee}
.actions{display:flex;gap:14px;flex-wrap:wrap}

.hero-logos{
  display:grid;
  grid-template-columns: repeat(5, minmax(80px,1fr));
  gap:22px; margin-top:26px; align-items:center;
}
.hero-logos img{
  height:44px; max-width:100%; object-fit:contain;
  filter: grayscale(1) brightness(1.15) contrast(1.15) drop-shadow(0 2px 6px rgba(0,0,0,.25));
  opacity:.95; transition: transform .2s ease, filter .2s ease;
}
.hero-logos img:hover{
  opacity:1; filter: grayscale(.2) brightness(1.25) contrast(1.2);
  transform: translateY(-2px);
}

/* ===== SECTIONS / CARDS ===== */
.section{padding:70px 28px;max-width:1100px;margin:0 auto}
.section.alt{background:linear-gradient(180deg,rgba(255,255,255,.03),transparent)}
.section-head{margin-bottom:22px}
.section h2{font-size:clamp(26px,4vw,40px);margin-bottom:6px;
  background: linear-gradient(90deg, #e7f6ee 0%, #bfe7d0 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.badge{background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:6px 12px;color:var(--muted)}
.grid-3{display:grid;gap:18px;grid-template-columns:repeat(3,1fr)}
.grid-2{display:grid;gap:18px;grid-template-columns:repeat(2,1fr)}
.card{ background: var(--card-grad); border:1px solid var(--border); border-radius:var(--radius); padding:22px; box-shadow:var(--shadow);
  transition: transform .18s ease, box-shadow .18s ease; }
.card:hover{ transform: translateY(-2px); box-shadow: 0 14px 34px rgba(0,0,0,.28); }

/* ===== TEAM ===== */
.team-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.member-card{ display:grid; justify-items:center; text-align:center; gap:10px; padding:24px; }
.member-card .avatar{
  width:96px;height:96px;border-radius:50%;overflow:hidden;display:grid;place-items:center;margin:4px auto 12px;
  background:var(--surface);border:1px solid var(--border);
  box-shadow: 0 8px 24px rgba(0,0,0,.25), inset 0 0 0 6px rgba(255,255,255,.04);
}
.member-card .avatar img{ width:100%; height:100%; object-fit:cover; }
.member-card h3{ font-size:18px; font-weight:800; }
.member-card .role{ color:var(--muted); font-weight:600; margin-top:-2px; }
.member-card .bio{ color:var(--muted); font-size:14px; margin-top:8px; }
.chips{ display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin:6px 0 2px; }
.chips li{
  list-style:none; font-size:12px; font-weight:700; padding:6px 10px; border-radius:999px;
  background:var(--surface); border:1px solid var(--border); color:var(--text);
}

/* ===== LISTS / DETAILS ===== */
.list{display:grid;gap:12px}
.list li{ list-style:none;background:rgba(255,255,255,.06);border:1px solid var(--border); padding:16px 18px;border-radius:12px }
.stack{display:grid;gap:12px}
details{ background:rgba(255,255,255,.06); border:1px solid var(--border); border-radius:12px; padding:12px 16px }
summary{ cursor:pointer; font-weight:700; margin:-4px 0 6px }

/* ===== TIMELINE ===== */
.timeline-wrap{ position: relative; border-top:1px solid var(--border); border-bottom:1px solid var(--border); background:linear-gradient(180deg, rgba(255,255,255,.03), transparent); border-radius:14px; padding-top:0 }
.tl-progress{ position: relative; height:8px; width:calc(100% - 48px); margin:0 24px 14px; background:rgba(255,255,255,.18); border-radius:999px; overflow:hidden }
.tl-progress__bar{ height:100%; width:0%; background:#fff; border-radius:inherit; transition:width .15s linear }
.tl-row{ display:grid; grid-auto-flow:column; grid-auto-columns:clamp(260px, 32vw, 360px); gap:22px; padding:16px 24px 24px; overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch }
.tl-row::-webkit-scrollbar{height:6px}
.tl-row::-webkit-scrollbar-thumb{background:rgba(255,255,255,.22);border-radius:999px}
.tl-item{ scroll-snap-align:center; background:var(--card-grad); border:1px solid var(--border); border-radius:var(--radius); padding:22px; box-shadow:var(--shadow); text-align:center; display:grid; justify-items:center; gap:10px }
.tl-item h3{ font-size:18px; margin-top:4px }
.tl-item p{ color:var(--muted); font-size:15px }
.tl-icon{ width:56px;height:56px;border-radius:50%; background:var(--accent); color:#0b281f; display:grid; place-items:center; border:1px solid rgba(0,0,0,.08); box-shadow:0 8px 24px rgba(45,211,111,.22) }

/* ===== MEDIA (Na mídia) ===== */
.video-grid{ display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr)); gap:22px }
.video-card{ background:var(--card-grad); border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow); overflow:hidden; transition: transform .2s ease, box-shadow .2s ease }
.video-card:hover{ transform: translateY(-4px); box-shadow: 0 14px 34px rgba(0,0,0,.28) }
.video-card .thumb{ position:relative }
.video-card img{ width:100%; display:block }
.play-btn{
  position:absolute; inset:0; margin:auto; width:64px; height:64px; border-radius:50%; border:none;
  background:var(--accent); color:#0b281f; font-size:28px; display:grid; place-items:center; cursor:pointer; transition: transform .2s ease, background .2s ease;
}
.play-btn:hover{ transform:scale(1.1); background:var(--accent-2) }
.video-card h3{margin:14px; font-size:18px}
.video-card p{margin:0 14px 18px; color:var(--muted); font-size:14px}

/* ===== FOOTER ===== */
.footer{margin-top:50px;border-top:1px solid var(--border);background:#061a16}
.footer-inner{max-width:1100px;margin:0 auto;padding:22px 28px;display:flex;justify-content:space-between;align-items:center}
.footer a{color:var(--muted);text-decoration:none}
.footer small{color:#a7d9c3}

/* ===== RESPONSIVE ===== */
@media (max-width:1100px){
  .grid-3{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .team-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width:900px){
  .hero{ padding:72px 24px }
  .hero-bg, .hero-overlay{ display:none }
  .hero .hero-inner{ max-width:640px; margin:0 auto }
  .hero-logos img{ height:34px }
}
@media (max-width:560px){
  .team-grid{ grid-template-columns: 1fr; }
  .member-card .avatar{ width:88px; height:88px; }
}
@media (max-width:840px){
  .navbar nav{display:none}
  .hamburger{display:block}
  #nav-toggle:checked ~ .nav-drawer{display:flex}
  .nav-drawer{
    position:fixed;inset:64px 14px auto 14px;
    background:rgba(7,34,29,.98);backdrop-filter:blur(6px);
    border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);
    padding:14px;flex-direction:column;gap:10px;z-index:40
  }
  .nav-drawer a{padding:12px;border-radius:10px;text-decoration:none;color:var(--text);background:rgba(255,255,255,.06)}
}
/* ==== Card (LinkedIn) ==== */
.link-card { padding: 0; overflow: hidden; }

.post-thumb-wrap {
  position: relative;
  display: block;
  line-height: 0;                 
  background: var(--surface);
}

.post-thumb {
  width: 100%;
  display: block;
  aspect-ratio: 16 / 9;           
  object-fit: cover;
  transition: transform .25s ease, filter .25s ease;
  filter: contrast(1.05) saturate(1.05);
}

.post-thumb-wrap:hover .post-thumb {
  transform: scale(1.02);
  filter: contrast(1.08) saturate(1.08);
}

/* Selo “LinkedIn”*/
.thumb-badge {
  position: absolute;
  left: 12px; bottom: 12px;
  display: inline-flex; gap: 8px; align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,.45);
  color: #fff;
  font-weight: 700;
  font-size: 12px;
  backdrop-filter: blur(4px);
  border: 1px solid rgba(255,255,255,.14);
}

.thumb-badge img {
  height: 16px; width: 16px; display: block; filter: brightness(1.1);
}

/* Conteúdo do card */
.post-body { padding: 14px 16px 16px; }
.post-title { font-size: 18px; margin-bottom: 6px; }
.post-snippet { color: var(--muted); font-size: 14px; margin-bottom: 10px; }
/* ===== CONTATO  ===== */
.contact{
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 24px;
}

.form-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px 16px;
}

.f{ display: grid; gap: 8px; }
.f span{
  font-weight: 700;
  font-size: 14px;
  color: var(--muted);
}

.f input,
.f textarea{
  width: 100%;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.06);
  color: var(--text);
  padding: 12px 14px;
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}

.f input::placeholder,
.f textarea::placeholder{ color: rgba(255,255,255,.55); }

.f input:focus,
.f textarea:focus{
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(45,211,111,.22);
  background: rgba(255,255,255,.08);
}

.f-full{ grid-column: 1 / -1; }

.form-actions{
  display: flex;
  gap: 14px;
  align-items: center;
  justify-content: space-between;
  margin-top: 12px;
}

.form-actions .btn{ padding: 0 22px; height: 48px; }

.alt-contact{
  color: var(--muted);
  opacity: .9;
}
.alt-contact a{ color: var(--text); text-decoration: underline; }

/* ===== responsivo ===== */
@media (max-width: 820px){
  .form-grid{ grid-template-columns: 1fr; }
  .form-actions{
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  .form-actions .btn{ width: 100%; }
  .alt-contact{ text-align: center; }
}

.hp-field { position:absolute !important; left:-9999px !important; opacity:0 !important; }
/* ===== Contato –  ===== */
.section.contact { max-width: 950px; }                

.form { margin-top: 8px; }

.form-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;                    
  gap: 16px 18px;
}

.form-field{
  display: grid;
  gap: 6px;
}

.form-field--full{ grid-column: 1 / -1; }             

.form-field label{
  font-weight: 700;
  color: var(--muted);
}

.form-field input,
.form-field textarea{
  width: 100%;
  background: #092922;
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px 12px;
  font: inherit;
  outline: none;
}

.form-field input:focus,
.form-field textarea:focus{
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(45,211,111,.18);
}

/* Botão alinhado */
.submit-btn{
  display: inline-flex;
  margin-top: 12px;
  padding-left: 28px;
  padding-right: 28px;
}

/* Esconde honeypot */
.hp-field{
  position: absolute !important;
  left: -10000px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Mobile: 1 coluna */
@media (max-width: 720px){
  .form-grid{ grid-template-columns: 1fr; }
  .submit-btn{ width: 100%; } /* no mobile fica full, mais confortável */
}
/* ===== CONTATO –  ===== */
.contact-wrap{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px 20px;
  background: rgba(255,255,255,.04);
  border:1px solid var(--border);
  border-radius: 16px;
  padding: 22px;
  box-shadow: var(--shadow);
}

.contact-wrap .field{ display:grid; gap:6px; }
.contact-wrap .field--full{ grid-column: 1 / -1; }

.contact-wrap label{
  font-weight: 600;
  color: var(--muted);
}

.contact-wrap input,
.contact-wrap textarea{
  width: 100%;
  background:#092922;
  color: var(--text);
  border:1px solid var(--border);
  border-radius:10px;
  padding:12px;
}

.contact-wrap textarea{ resize: vertical; }

.contact-wrap .actions{
  grid-column: 1 / -1;
  display:flex;
  align-items:center;
  gap:12px;
}

.form-status{
  font-size: 14px;
  color: var(--muted);
}

/* Mobile: 1 coluna */
@media (max-width: 800px){
  .contact-wrap{ grid-template-columns: 1fr; }
}

/* container das bandeiras dentro da navbar */
.navbar .lang-switch {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-left: auto; /* joga as flags pro lado direito */
  padding-right: 20px; /* afastamento da borda */
}

/* estilo dos botões */
.navbar .flag {
  width: 28px;
  height: 20px;
  border: none;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  border-radius: 3px;
  cursor: pointer;
  transition: transform 0.2s ease, filter 0.2s ease;
}

.navbar .flag:hover {
  transform: scale(1.1);
  filter: brightness(1.1);
}

/* bandeiras */
.flag--br { background-image: url('/img/flags/br.png?v=1'); }
.flag--us { background-image: url('/img/flags/us.png?v=1'); }
.flag--es { background-image: url('/img/flags/es.png?v=1'); }

/* pequenas melhorias visuais para novas seções */
#expertise .card p,
#nsg1 .card p { color: var(--muted); }

#parceiros .hero-logos img { height: 46px; }

