:root{
  /* Paleta inspirada no logotipo (azul/teal + navy) */
  --navy: #0b1f33;
  --navy-2:#102b45;
  --blue: #1f5e88;
  --teal: #27a7a4;
  --teal-2:#45c3bf;
  --ice: #f5f9ff;
  --muted: rgba(245,249,255,.78);
  --stroke: rgba(255,255,255,.12);
  --shadow: 0 18px 60px rgba(0,0,0,.35);
  --radius: 18px;
}

html,body{ height:100%; }

body{
  font-family: Inter, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  background:
    radial-gradient(2800px 600px at 10% 10%, rgba(39,167,164,.22), transparent 60%),
    radial-gradient(1900px 500px at 90% 20%, rgba(31,94,136,.25), transparent 55%),
    linear-gradient(180deg, var(--navy), #071626);
  color: var(--ice);
  overflow-x: hidden;
}

/* Fundo contínuo (evita “degrau” ao rolar) */
@media (min-width: 992px){
  body{ background-attachment: fixed; }
}

/* =========================
   Fundo animado (blobs)
   ========================= */
.bg-animated{
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  overflow: hidden;
}
.blob{
  position: absolute;
  width: 320px;
  height: 320px;
  filter: blur(50px);
  opacity: .55;
  border-radius: 50%;
  mix-blend-mode: screen;
  animation: drift 14s ease-in-out infinite alternate;
}
.blob.b1{
  left: -120px; top: 140px;
  background: radial-gradient(circle at 30% 30%, rgba(39,167,164,.95), rgba(39,167,164,.0) 62%);
  animation-duration: 16s;
}
.blob.b2{
  right: -160px; top: 40px;
  background: radial-gradient(circle at 40% 40%, rgba(31,94,136,.95), rgba(31,94,136,0) 60%);
  animation-duration: 18s;
}
.blob.b3{
  left: 25%; bottom: -240px;
  background: radial-gradient(circle at 40% 40%, rgba(69,195,191,.9), rgba(69,195,191,0) 60%);
  animation-duration: 20s;
}

@keyframes drift{
  0%   { transform: translate3d(0,0,0) scale(1); }
  50%  { transform: translate3d(40px,-30px,0) scale(1.08); }
  100% { transform: translate3d(-35px,25px,0) scale(1.02); }
}

/* Canvas particles */
#particles{
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: .35;
}

/* =========================
   Navbar
   ========================= */
.navbar{
  transition: background .25s ease, backdrop-filter .25s ease, border-color .25s ease;
  border-bottom: 1px solid transparent;
}
.navbar.scrolled{
  background: rgba(7,22,38,.7);
  backdrop-filter: blur(10px);
  border-bottom-color: rgba(255,255,255,.08);
}

.nav-link{
  color: rgba(245,249,255,.82) !important;
  font-weight: 600;
  letter-spacing: .2px;
}
.nav-link:hover{ color: #fff !important; }

.nav-link.active{
  color: #fff !important;
  position: relative;
}
.nav-link.active::after{
  content:"";
  position:absolute;
  left:.6rem; right:.6rem; bottom:.2rem;
  height:2px; border-radius:999px;
  background: linear-gradient(90deg, var(--teal), var(--blue));
  opacity: .9;
}

/* =========================
   Utilitários visuais
   ========================= */
.glass{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 12px 42px rgba(0,0,0,.25);
  border-radius: var(--radius);
}

.section{
  padding: 112px 0;
  scroll-margin-top: 110px;
  background: transparent; /* evita faixas */
}

.badge-soft{
  background: rgba(39,167,164,.16);
  border: 1px solid rgba(39,167,164,.28);
  color: rgba(245,249,255,.92);
  font-weight: 700;
  letter-spacing: .2px;
}

.text-muted-hero{ color: var(--muted) !important; }

.btn-primary{
  --bs-btn-bg: var(--teal);
  --bs-btn-border-color: rgba(0,0,0,0);
  --bs-btn-hover-bg: #1f9b98;
  --bs-btn-hover-border-color: rgba(0,0,0,0);
  --bs-btn-active-bg: #1b8a87;
  --bs-btn-active-border-color: rgba(0,0,0,0);
  box-shadow: 0 12px 30px rgba(39,167,164,.22);
  border-radius: 14px;
  font-weight: 800;
}

.btn-outline-light{
  border-radius: 14px;
  border-color: rgba(255,255,255,.25);
  font-weight: 800;
}
.btn-outline-light:hover{
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.35);
}

/* =========================
   Hero
   ========================= */
.hero{
  padding-top: 160px;
  padding-bottom: 70px;
  position: relative;
}
.hero-card{
  overflow: hidden;
  position: relative;
}
.hero-card::before{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(135deg, rgba(39,167,164,.12), rgba(31,94,136,.10), rgba(255,255,255,.02));
  pointer-events:none;
}
.hero h1{
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1.05;
  font-size: clamp(1.8rem, 2vw, 3.4rem);
}
.hero .lead{
  font-size: 1.08rem;
  line-height: 1.65;
}

.hero-image{
  border-radius: calc(var(--radius) + 6px);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: var(--shadow);
  overflow: hidden;
  transform: translateZ(0);
}
.hero-image img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.03);
  transition: transform .8s ease;
}
.hero-image:hover img{ transform: scale(1.10); }

/* =========================
   Cards / blocos
   ========================= */
.icon-pill{
  width: 46px; height: 46px;
  display: inline-grid; place-items:center;
  border-radius: 14px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
}

.service-card{
  height: 100%;
  transition: transform .25s ease, border-color .25s ease, background .25s ease;
}
.service-card:hover{
  transform: translateY(-6px);
  border-color: rgba(39,167,164,.35);
  background: rgba(255,255,255,.075);
}
.service-card .card-title{
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--teal);
}
.service-card .btn-link{
  color: rgba(245,249,255,.92);
  text-decoration: none;
  font-weight: 800;
}
.service-card .btn-link:hover{
  color: #fff;
  text-decoration: underline;
  text-underline-offset: 4px;
}

.check-list li{
  margin-bottom: .6rem;
  color: rgba(245,249,255,.86);
}
.check-list i{ color: var(--teal-2); }

/* =========================
   Separadores e rodapé (SEM DEGRAU)
   ========================= */
.divider{
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.14), transparent);
}

/* Footer sem faixa sólida: gradiente suave (não corta o fundo) */
footer{
  padding: 28px 0;
  color: rgba(245,249,255,.68);
  border-top: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg,
    rgba(7,22,38,0),
    rgba(7,22,38,.30)
  );
}

/* =========================
   Scroll reveal
   ========================= */
.reveal{
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .7s ease, transform .7s ease;
}
.reveal.show{
  opacity: 1;
  transform: translateY(0);
}

/* =========================
   Forms (tema escuro + glass)
   ========================= */
.form-control, .form-select{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  color: var(--ice);
  border-radius: 14px;
  padding: .85rem 1rem;
}
.form-control::placeholder{ color: rgba(245,249,255,.55); }
.form-control:focus, .form-select:focus{
  background: rgba(255,255,255,.08);
  border-color: rgba(39,167,164,.45);
  box-shadow: 0 0 0 .2rem rgba(39,167,164,.15);
  color: var(--ice);
}

/* Select com fonte escura (quando você usa fundo claro no select dentro do glass) */
.glass .form-select,
.glass select.form-select{
  color:#111 !important;
  background-color: rgba(255,255,255,.92);
  border: 1px solid rgba(255,255,255,.20);
}
.glass .form-select option{ color:#111; }
.glass .form-select option[disabled]{ color:#6c757d; }
.glass .form-select:focus{ color:#111 !important; }

/* Pequenos detalhes */
.brand-mark{
  width: auto;
  height: 84px;
  object-fit: contain;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.25));
}

.page-hero { margin-top: 160px; }

.card-body i { color: var(--teal); }

.text-accent{ color: var(--teal) !important; }

/* =========================
   CONTATO: overlay suave (remove “faixa/degrau”)
   ========================= */
section#contato{
  position: relative;
  background: transparent !important;
  overflow: hidden;
}
section#contato::before{
  content:"";
  position:absolute;
  inset:-120px 0 -120px 0;
  background: radial-gradient(1200px 520px at 50% 0%,
    rgba(7,22,38,.55),
    rgba(7,22,38,0) 70%);
  pointer-events:none;
  z-index: 0;
}
section#contato > .container{
  position: relative;
  z-index: 1;
}

/* =========================
   Stepper
   ========================= */
.form-steps{
  display:flex; align-items:center; gap:12px;
}
.step-dot{
  display:flex; flex-direction:column; align-items:center; gap:6px;
  opacity:.55;
}
.step-dot span{
  width:34px; height:34px; border-radius:999px;
  display:grid; place-items:center;
  border:1px solid rgba(255,255,255,.25);
  background: rgba(0,0,0,.15);
  color:#fff; font-weight:700;
}
.step-dot small{ font-size:.78rem; color: rgba(255,255,255,.75); }
.step-dot.active{ opacity:1; }
.step-dot.active span{
  background: rgba(0, 209, 204, .18);
  border-color: rgba(0, 209, 204, .55);
}
.step-line{
  flex:1;
  height:1px;
  background: rgba(255,255,255,.18);
}

/* =========================
   Escolha Empresa/Candidato
   ========================= */
.choice-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:14px;
}
@media (max-width: 576px){
  .choice-grid{ grid-template-columns: 1fr; }
}
.choice-btn{
  text-align:left;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  padding:16px 16px;
  color:#fff;
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
}
.choice-btn:hover{ transform: translateY(-1px); background: rgba(255,255,255,.10); }
.choice-btn.active{
  background: rgba(0, 209, 204, .16);
  border-color: rgba(0, 209, 204, .55);
  box-shadow: 0 0 0 3px rgba(0, 209, 204, .12);
}
.choice-title{ font-weight:800; font-size:1.05rem; }
.choice-sub{ font-size:.9rem; opacity:.85; margin-top:2px; }

/* =========================
   NAVBAR MOBILE: fundo sempre + menu como painel
   ========================= */
@media (max-width: 991.98px){
  .navbar{
    background: rgba(7,22,38,.78);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid rgba(255,255,255,.08);
  }

  .brand-mark{
    height: 46px !important;
    width: auto !important;
  }

  .navbar .navbar-collapse{
    margin-top: 12px;
    padding: 12px;
    border-radius: 16px;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: 0 12px 42px rgba(0,0,0,.25);
  }

  .navbar .navbar-nav{ gap: .25rem !important; }

  .navbar .nav-link{
    padding: .65rem .85rem !important;
    border-radius: 12px;
  }
  .navbar .nav-link:hover{
    background: rgba(255,255,255,.06);
  }

  .navbar .d-lg-flex{
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-top: 10px !important;
  }
  .navbar .d-lg-flex .btn{
    width: 100%;
    justify-content: center;
  }
}

/* =========================
   MODAL DARK GLASS (CLOG RH)
   (REMOVIDO o bloco antigo do modal claro)
   ========================= */
.modal-backdrop.show { opacity: .75; }

#ctaModal .modal-dialog { max-width: 920px; }

#ctaModal .modal-content{
  background: rgba(7,22,38,.82) !important;
  color: var(--ice) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  border-radius: calc(var(--radius) + 6px) !important;
  box-shadow: 0 18px 60px rgba(0,0,0,.55) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  overflow: hidden;
  position: relative;
}

#ctaModal .modal-content::before{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(135deg,
    rgba(39,167,164,.18),
    rgba(31,94,136,.10),
    rgba(255,255,255,.02)
  );
  opacity:.6;
  pointer-events:none;
}

#ctaModal .modal-header{
  background: rgba(255,255,255,.03) !important;
  border-bottom: 1px solid rgba(255,255,255,.10) !important;
  position: relative;
  z-index: 2;
}

#ctaModal .modal-title{
  color:#fff !important;
  font-weight: 900;
}

#ctaModal .btn-close{
  filter: invert(1) grayscale(100%);
  opacity: .9;
}

#ctaModal .modal-body{ position: relative; z-index: 2; }

#ctaModal .modal-side{
  background: rgba(255,255,255,.03);
  border-right: 1px solid rgba(255,255,255,.10);
}

#ctaModal .form-label{
  color: rgba(245,249,255,.92) !important;
  font-weight: 700;
}

#ctaModal .form-control{
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  color: var(--ice) !important;
  border-radius: 14px;
  padding: .9rem 1rem;
}
#ctaModal .form-control::placeholder{
  color: rgba(245,249,255,.55) !important;
}
#ctaModal .form-control:focus{
  background: rgba(255,255,255,.08) !important;
  border-color: rgba(39,167,164,.55) !important;
  box-shadow: 0 0 0 .2rem rgba(39,167,164,.18) !important;
}

#ctaModal .modal-input{ position: relative; }
#ctaModal .modal-input i{
  position:absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: rgba(245,249,255,.75);
  pointer-events:none;
}
#ctaModal .modal-input .form-control{ padding-left: 44px !important; }

#ctaModal .btn-primary, .btn-success {
  width:100%;
  padding: .95rem 1rem;
  border-radius: 14px;
  font-weight: 900;
  --bs-btn-bg: var(--teal);
  --bs-btn-border-color: rgba(0,0,0,0);
  --bs-btn-hover-bg: #1f9b98;
  --bs-btn-active-bg: #1b8a87;
  box-shadow: 0 14px 34px rgba(39,167,164,.22);
}

#ctaModal .btn-primary:disabled{
  opacity: .55;
  box-shadow: none;
}

#ctaModal .micro{ color: rgba(245,249,255,.70); }

#ctaModal .hero-image{
  border-radius: calc(var(--radius) + 6px);
  border: 1px solid rgba(255,255,255,.14);
  overflow: hidden;
}

#ctaModal .h-captcha{ max-width: 100%; }
.fw-bold { color: var(--teal) !important; }


.modal-content{background:linear-gradient(180deg, rgba(11,31,51,.98), rgba(7,22,38,.98));border:1px solid rgba(255,255,255,.08);color:var(--ice)}
.modal-header{border-bottom:1px solid rgba(255,255,255,.08)}
.modal-input{position:relative}.modal-input i{position:absolute;left:14px;top:50%;transform:translateY(-50%);opacity:.7}.modal-input .form-control{padding-left:42px}
.micro{color:rgba(245,249,255,.7)}
.raiox-offer-dialog{max-width:1120px}
.raiox-offer-content{overflow:hidden;border-radius:28px;background:linear-gradient(145deg, rgba(11,31,51,.98), rgba(9,25,42,.98));border:1px solid rgba(255,255,255,.09);box-shadow:0 30px 80px rgba(0,0,0,.4)}
.raiox-offer-close{position:absolute;right:18px;top:18px;z-index:4}
.raiox-offer-media{position:relative;min-height:320px;background:radial-gradient(circle at top left, rgba(39,167,164,.35), transparent 45%), linear-gradient(180deg, #0a2036, #081625)}
.raiox-offer-image{width:100%;height:100%;object-fit:cover;display:block}
.raiox-offer-badge{position:absolute;left:24px;top:24px;background:rgba(39,167,164,.92);color:#fff;padding:10px 16px;border-radius:999px;font-weight:800;letter-spacing:.3px;box-shadow:0 12px 30px rgba(39,167,164,.25)}
.raiox-offer-body{padding:42px 34px 36px}
.raiox-stepper{display:flex;align-items:center;gap:12px}
.raiox-step{display:flex;align-items:center;gap:10px;color:rgba(245,249,255,.6);font-weight:700}
.raiox-step span{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12)}
.raiox-step.active{color:#fff}.raiox-step.active span{background:var(--teal);border-color:transparent;box-shadow:0 10px 24px rgba(39,167,164,.28)}
.raiox-step small{font-size:.82rem;text-transform:uppercase;letter-spacing:.08em}
.raiox-step-line{height:1px;flex:1;background:linear-gradient(90deg, rgba(255,255,255,.18), rgba(255,255,255,.05))}
.raiox-code-card{padding:16px 18px;border:1px solid rgba(255,255,255,.1);border-radius:18px;background:rgba(255,255,255,.04)}
.raiox-code-input{text-align:center;letter-spacing:.5em;font-weight:800}
@media (max-width:991.98px){.raiox-offer-body{padding:28px 22px 24px}.brand-mark{height:62px}.hero{padding-top:138px}}


/* SEO + UX: destaque para candidatos e banco de currículos */
.navbar .nav-link.nav-curriculo{
  color: #fff !important;
  background: rgba(39,167,164,.18);
  border: 1px solid rgba(39,167,164,.45);
  border-radius: 999px;
  padding-left: 14px !important;
  padding-right: 14px !important;
}
.navbar .nav-link.nav-curriculo.active,
.navbar .nav-link.nav-curriculo:hover{
  background: rgba(39,167,164,.32);
  border-color: rgba(39,167,164,.75);
}
.hero-seo-links{
  display:flex;
  flex-wrap:wrap;
  gap:.45rem .65rem;
  color: rgba(245,249,255,.62);
  font-size:.95rem;
}
.hero-seo-links a{
  color: rgba(245,249,255,.82);
  text-decoration:none;
  font-weight:700;
}
.hero-seo-links a:hover{ color: var(--teal); }
.section-feature-candidates{
  padding-top: 40px;
}
.candidate-mini-card strong{ color: var(--ice); }
.choice-btn[data-perfil="Candidato"]{
  border-color: rgba(39,167,164,.65);
  background: rgba(39,167,164,.12);
}
@media (max-width: 991.98px){
  .navbar .nav-link.nav-curriculo{ display:inline-flex; margin:.25rem 0; }
}
