/* =====================================================================
   ABTS - Camada de UX/UI para as páginas de inscrição de curso
   (inscricao-select / inscricao-pf / inscricao-pj)
   Override carregado por último — restila o template legado (Ansonika)
   com a identidade visual da landing page (verde/amarelo ABTS).
   ===================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root{
  --abts-verde:#0c3b2c;
  --abts-verde-2:#0e4233;
  --abts-verde-3:#13503d;
  --abts-amarelo:#f6b400;
  --abts-amarelo-2:#e0a300;
  --abts-texto:#1d2b25;
  --abts-texto-2:#5a6b63;
  --abts-cinza:#f4f6f5;
  --abts-borda:#e3e8e6;
  --abts-radius:12px;
  --abts-shadow:0 18px 45px -22px rgba(0,0,0,.30);
}

body{
  font-family:'Inter',Arial,sans-serif !important;
  color:var(--abts-texto);
  background:var(--abts-cinza) !important;
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
}
a{color:var(--abts-verde-3);}
a:hover{color:var(--abts-verde);}

/* ---------- Header (top-area) ---------- */
#top-area{
  height:auto !important;min-height:0 !important;
  background-image:linear-gradient(120deg,var(--abts-verde) 0%,var(--abts-verde-3) 55%,#0a5238 100%) !important;
  border-bottom:4px solid var(--abts-amarelo);
  padding-bottom:8px;position:relative;
}
#top-area header{padding:0;background:transparent;}
.topbar-flex{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  min-height:74px;padding:8px 0;
}
.top-logo{display:inline-flex;align-items:center;}
.top-logo img{height:46px;width:auto;display:block;}
#top-nav{float:none;}
#top-nav ul{display:flex;gap:26px;margin:0;padding:0;list-style:none;align-items:center;}
#top-nav ul li{margin:0;padding:0;float:none;list-style:none;}
#top-nav ul li a{
  color:#dfeee8 !important;font-weight:600;font-size:14.5px;padding:6px 0;position:relative;
}
#top-nav ul li a:hover{color:#fff !important;}
#top-nav ul li a:hover::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--abts-amarelo);
}
.btn-responsive-menu{
  display:none;background:transparent;border:0;cursor:pointer;
  width:42px;height:42px;border-radius:8px;flex-direction:column;gap:5px;
  align-items:center;justify-content:center;
}
.btn-responsive-menu .bar{display:block;width:24px;height:2.5px;background:#fff;border-radius:2px;}

#top-area .main-title{padding:22px 0 30px;text-align:center;}
#top-area .main-title h2{
  font-weight:800;font-size:32px;line-height:1.15;color:#fff;margin:0 0 14px;
}
.main-meta{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 22px;}
.main-meta span{
  display:inline-flex;align-items:center;gap:8px;color:#eafff6;font-size:15px;font-weight:500;
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);
  padding:7px 16px;border-radius:50px;
}
.main-meta span svg{width:17px;height:17px;color:var(--abts-amarelo);flex:0 0 17px;}

@media (max-width:768px){
  .btn-responsive-menu{display:inline-flex !important;float:none !important;margin:0 !important;}
  .btn-responsive-menu .bar{margin:0 !important;width:26px;height:3px;background:#fff;}
  #top-nav{
    display:block !important;width:100%;flex-basis:100%;
    max-height:0;overflow:hidden;transition:max-height .25s ease;
  }
  #top-nav.open{max-height:260px;}
  #top-nav ul{flex-direction:column;gap:2px;align-items:stretch;padding:6px 0;}
  #top-nav ul li{border-bottom:1px solid rgba(255,255,255,.15);}
  #top-nav ul li:last-child{border-bottom:0;}
  .topbar-flex{flex-wrap:wrap;}
  #top-area .main-title h2{font-size:23px;}
}

/* ---------- Container principal ---------- */
#main{padding-top:34px;padding-bottom:50px;}
#survey_container,
#main > .row,
#middle-wizard,
#bottom-wizard{
  background:#fff;
  border:1px solid var(--abts-borda);
  border-radius:var(--abts-radius);
  box-shadow:var(--abts-shadow);
}
#middle-wizard{padding:30px 30px 8px;margin-bottom:18px;}
#bottom-wizard{padding:24px 30px;text-align:center;}
/* z-index:auto remove o stacking context do tema (z-index:9) que prendia
   o modal de inscritos abaixo do .modal-backdrop */
#survey_container{padding:26px;margin-top:0 !important;margin-bottom:26px;z-index:auto !important;}

/* títulos das seções do formulário */
#middle-wizard h3,
.step h3{
  font-size:18px !important;font-weight:800;color:var(--abts-verde);
  border-left:4px solid var(--abts-amarelo);
  padding:2px 0 2px 12px;margin:22px 0 14px;width:100%;float:none;
}
.step .row:first-child h3{margin-top:4px;}

/* ---------- Campos de formulário ---------- */
.data-list{list-style:none;margin:0;padding:0;}
.data-list li{margin-bottom:14px;list-style:none;}
.data-list.floated li{display:inline-block;margin-right:18px;}

input.form-control,
select.form-control,
.step input[type=text],
.step input[type=email],
.step textarea,
.styled-select select{
  width:100%;
  height:auto !important;
  padding:12px 14px !important;
  font-size:15px !important;
  color:var(--abts-texto) !important;
  background:#fff !important;
  border:1.5px solid var(--abts-borda) !important;
  border-radius:10px !important;
  box-shadow:none !important;
  margin-bottom:14px;
  transition:border-color .15s, box-shadow .15s;
}
input.form-control::placeholder{color:#9fb0a8;}
input.form-control:focus,
select.form-control:focus,
.styled-select select:focus,
.step textarea:focus{
  border-color:var(--abts-verde-3) !important;
  box-shadow:0 0 0 3px rgba(19,80,61,.12) !important;
  outline:none !important;
}
.styled-select{position:relative;}
.styled-select select{appearance:none;-webkit-appearance:none;background-image:none !important;}
.styled-select::after{
  content:"";position:absolute;right:16px;top:18px;pointer-events:none;
  border:6px solid transparent;border-top-color:var(--abts-verde-3);
}

/* ---------- Radios / checkboxes ---------- */
label.radio{
  display:inline-flex;align-items:center;gap:8px;cursor:pointer;
  font-size:15px;color:var(--abts-texto);font-weight:500;margin:0;
}
label.radio input[type=radio]{accent-color:var(--abts-verde-3);width:18px;height:18px;}
.data-list.floated p{font-weight:600;color:var(--abts-texto-2);width:100%;margin-bottom:6px;}
#alertaErro{
  background:#fff7e6;border:1px solid #ffe3a3;color:#8a5a00 !important;
  padding:10px 14px;border-radius:10px;font-size:13px;font-weight:500 !important;
  width:100% !important;float:none !important;text-align:left !important;margin-top:10px;
}

/* ---------- Botão efetivar inscrição ---------- */
#bottom-wizard #btnInscrever,
.btn-abts{
  background:var(--abts-amarelo) !important;color:#3a2c00 !important;
  border:0 !important;border-radius:10px !important;
  width:auto !important;min-width:240px;height:auto !important;
  padding:15px 34px !important;font-size:16px !important;font-weight:800 !important;
  cursor:pointer;transition:.18s;box-shadow:0 10px 22px -10px rgba(246,180,0,.7);
}
#bottom-wizard #btnInscrever:hover,
.btn-abts:hover{background:var(--abts-amarelo-2) !important;transform:translateY(-1px);}
#bottom-wizard p{color:var(--abts-texto-2);font-size:14px;margin-bottom:16px;}
#bottom-wizard input[type=checkbox]{width:18px;height:18px;vertical-align:middle;accent-color:var(--abts-verde-3);}

/* ---------- Tabela de valores ---------- */
.tabela-valores{
  width:100%;max-width:480px;margin:10px auto 6px;
  border-collapse:separate;border-spacing:0;border:1px solid var(--abts-borda);
  border-radius:14px;overflow:hidden;box-shadow:var(--abts-shadow);font-size:14px;background:#fff;
}
.tabela-valores th,.tabela-valores td{padding:12px 14px;text-align:center;border-bottom:1px solid var(--abts-borda);}
.tabela-valores thead th{
  background:linear-gradient(120deg,var(--abts-verde) 0%,var(--abts-verde-3) 100%);
  color:#fff;font-weight:700;font-size:12.5px;line-height:1.3;border-bottom:0;vertical-align:middle;
}
.tabela-valores thead th small{display:block;font-weight:400;opacity:.85;font-size:11.5px;margin-top:2px;}
.tabela-valores thead th:first-child{width:34%;}
.tabela-valores tbody th{background:var(--abts-cinza);color:var(--abts-verde);font-weight:700;text-align:left;}
.tabela-valores tbody td{color:var(--abts-texto);font-weight:600;}
.tabela-valores tbody td.destaque{color:var(--abts-verde-3);font-weight:800;font-size:15px;}
.tabela-valores tbody tr:last-child th,
.tabela-valores tbody tr:last-child td{border-bottom:0;}

/* ---------- Modal de quantidade de inscritos (PJ) ---------- */
.abts-modal .modal-dialog{margin-top:40px;}
.abts-modal .modal-content{
  border:0;border-radius:16px;overflow:hidden;box-shadow:0 30px 70px -20px rgba(0,0,0,.5);
}
.abts-modal .modal-header{
  background:linear-gradient(120deg,var(--abts-verde) 0%,var(--abts-verde-3) 100%);
  border:0;padding:18px 24px;
}
.abts-modal .modal-title{color:#fff;font-weight:800;font-size:19px;}
.abts-modal .modal-header .close{
  color:#fff;opacity:.9;text-shadow:none;font-size:26px;font-weight:400;margin-top:2px;
}
.abts-modal .modal-header .close:hover{opacity:1;}
.abts-modal .modal-body{padding:24px;max-height:70vh;overflow-y:auto;background:var(--abts-cinza);}
.abts-modal .modal-body h4{
  color:var(--abts-verde);font-size:15px;font-weight:800;margin:0 0 12px;
  padding:8px 12px;background:#fff;border-left:4px solid var(--abts-amarelo);border-radius:8px;
}
.abts-modal .modal-body .row{
  background:#fff;border:1px solid var(--abts-borda);border-radius:12px;
  padding:18px;margin:0 0 16px;box-shadow:0 6px 18px -12px rgba(0,0,0,.25);
}
.abts-modal .modal-empty{color:var(--abts-texto-2);text-align:center;padding:24px 10px;margin:0;}
.abts-modal .modal-footer{border-top:1px solid var(--abts-borda);padding:16px 24px;text-align:right;}
.abts-modal .modal-footer .btn-abts{min-width:0;}

/* ---------- Página de seleção (PF/PJ) ---------- */
#top-wizard{text-align:center;}
#top-wizard img.img-responsive{border-radius:10px;margin:0 auto 18px;}

/* cards de escolha PF / PJ (CSS + SVG, substituem as imagens antigas) */
.insc-cards{
  display:flex;flex-wrap:wrap;justify-content:center;gap:22px;
  margin:8px auto 6px;max-width:720px;
}
.insc-card{
  flex:1 1 280px;max-width:330px;
  display:flex;flex-direction:column;align-items:center;text-align:center;
  background:#fff;border:1.5px solid var(--abts-borda);border-radius:16px;
  padding:30px 26px 28px;color:var(--abts-texto) !important;text-decoration:none;
  transition:.18s;box-shadow:0 10px 30px -18px rgba(0,0,0,.25);
}
.insc-card:hover{
  transform:translateY(-4px);border-color:var(--abts-verde-3);
  box-shadow:0 24px 50px -22px rgba(12,59,44,.45);
}
.insc-icon{
  width:84px;height:84px;border-radius:50%;
  background:linear-gradient(135deg,var(--abts-verde-3),var(--abts-verde));
  color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:18px;
}
.insc-icon svg{width:42px;height:42px;}
.insc-card h4{font-size:20px;font-weight:800;color:var(--abts-verde);margin:0 0 8px;line-height:1.2;}
.insc-card p{font-size:13.5px;color:var(--abts-texto-2);margin:0 0 20px;min-height:38px;}
.insc-btn{
  display:inline-block;background:var(--abts-amarelo);color:#3a2c00;
  font-weight:800;font-size:15px;letter-spacing:.4px;
  padding:12px 30px;border-radius:50px;transition:.18s;
  box-shadow:0 10px 22px -10px rgba(246,180,0,.7);
}
.insc-card:hover .insc-btn{background:var(--abts-amarelo-2);}
.alert-success{
  background:#e7f7ee !important;border:1px solid #b7dfca !important;color:#0a7d4f !important;
  border-radius:10px;padding:12px 16px;font-weight:600;
}

/* boxes de informação (cancelamento / pagamento / quórum) */
.box{
  background:#fff;border:1px solid var(--abts-borda);border-radius:var(--abts-radius);
  padding:24px;text-align:center;box-shadow:var(--abts-shadow);height:100%;
}
.box img{height:48px;width:auto;margin:0 auto 12px;display:block;}
.box h3{color:var(--abts-verde);font-size:17px;font-weight:700;margin-bottom:8px;}
.box p{color:var(--abts-texto-2);font-size:14px;}

#main h3 strong{color:var(--abts-verde);}
.divider{border-top:1px solid var(--abts-borda);margin:40px 0;}
.project-item-image-container img{border-radius:10px;}

/* =====================================================================
   Bloco compartilhado (inc-info-adicionais.php): Informações / Descontos / Cursos
   ===================================================================== */
.sec-block{margin:0 0 34px;}
.sec-h{
  text-align:center;font-size:26px !important;font-weight:800;color:var(--abts-verde) !important;
  margin:0 0 24px;border:0 !important;padding:0 !important;float:none !important;width:auto !important;
}
.sec-h::after{
  content:"";display:block;width:60px;height:4px;border-radius:3px;
  background:var(--abts-amarelo);margin:12px auto 0;
}
.sec-h span{display:block;font-size:15px;font-weight:600;color:var(--abts-texto-2);margin-top:8px;}

/* cards de informações adicionais (SVG) */
.info-cards{display:flex;flex-wrap:wrap;gap:22px;}
.info-card{
  flex:1 1 260px;background:#fff;border:1px solid var(--abts-borda);
  border-radius:14px;padding:28px 24px;box-shadow:var(--abts-shadow);text-align:center;
}
.info-ic{
  width:60px;height:60px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;
  background:rgba(12,59,44,.07);color:var(--abts-verde);margin-bottom:14px;
}
.info-ic svg{width:30px;height:30px;}
.info-card h4{font-size:17px;font-weight:700;color:var(--abts-verde);margin:0 0 8px;}
.info-card p{font-size:14px;color:var(--abts-texto-2);margin:0;line-height:1.55;}

/* descontos */
.descontos-box{
  background:#fff;border:1px solid var(--abts-borda);border-left:4px solid var(--abts-amarelo);
  border-radius:12px;padding:22px 26px;box-shadow:var(--abts-shadow);
  font-size:15px;color:var(--abts-texto-2);max-width:760px;margin:0 auto;text-align:left;
}
.descontos-box h5{color:var(--abts-verde);font-weight:700;margin:10px 0 4px;font-size:15px;}
.descontos-box p{margin:0 0 8px;}

/* cursos ABTS */
.cursos-abts{text-align:center;}
.cursos-intro{max-width:820px;margin:0 auto 26px;color:var(--abts-texto-2);font-size:15px;line-height:1.6;}
.curso-item{
  background:#fff;border:1px solid var(--abts-borda);border-radius:14px;
  padding:24px;margin:0 auto 20px;max-width:760px;box-shadow:var(--abts-shadow);
}
.curso-item h4{color:var(--abts-verde);font-weight:700;font-size:18px;margin:0 0 14px;}
.curso-banner{margin-bottom:14px;}
.curso-banner img{border-radius:10px;max-width:100%;height:auto;margin:0 auto;display:block;}
.curso-item p{color:var(--abts-texto-2);font-size:14.5px;margin:0;line-height:1.6;}

@media (max-width:768px){
  .sec-h{font-size:22px !important;}
  .info-cards{flex-direction:column;}
}

/* ---------- Rodapé ---------- */
footer{background:#08231b !important;color:#bcd0c7 !important;margin-top:30px;}
footer a{color:#bcd0c7 !important;}
footer a:hover{color:var(--abts-amarelo) !important;}

.abts-footer{padding:54px 0 0;font-size:14.5px;line-height:1.6;}
.abts-footer .foot-grid{
  display:grid;grid-template-columns:1.6fr 1fr 1.3fr;gap:40px;padding-bottom:34px;
}
.foot-logo{height:46px;width:auto;margin-bottom:16px;}
.foot-about p{color:#a9c2b6;margin:0 0 16px;}
.abts-footer h3{color:#fff !important;font-size:16px;font-weight:700;margin:0 0 16px;text-transform:none;}
.foot-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;}
.foot-col a{color:#a9c2b6 !important;}
.foot-contact ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px;}
.foot-contact li{display:flex;gap:11px;align-items:flex-start;color:#a9c2b6;}
.foot-contact li svg{width:18px;height:18px;flex:0 0 18px;color:var(--abts-amarelo);margin-top:3px;}
.foot-social{display:flex;gap:12px;}
.foot-social a{
  width:38px;height:38px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.08);color:#dfeee8 !important;transition:.18s;
}
.foot-social a svg{width:18px;height:18px;}
.foot-social a:hover{background:var(--abts-amarelo);color:#3a2c00 !important;transform:translateY(-2px);}
.foot-bottom{
  border-top:1px solid rgba(255,255,255,.1);background:#06201a;
}
.foot-bottom .container{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;
  padding-top:18px;padding-bottom:18px;color:#7f9b8e;font-size:13px;
}

@media (max-width:768px){
  .abts-footer .foot-grid{grid-template-columns:1fr;gap:28px;text-align:center;}
  .foot-social{justify-content:center;}
  .foot-contact li{justify-content:center;text-align:left;}
  .foot-bottom .container{justify-content:center;text-align:center;}
}

/* mensagens de processamento (AJAX) */
.msg-processamento-ok{
  background:#e7f7ee;border:1px solid #b7dfca;color:#0a7d4f;
  border-radius:10px;padding:18px;font-size:15px;
}
.msg-processamento-erro{
  background:#fbe9e7;border:1px solid #f5c6c0;color:#b23b2e;
  border-radius:10px;padding:16px;font-weight:600;
}

/* ---------- Responsivo ---------- */
@media (max-width:768px){
  #top-area .main-title h2{font-size:24px;}
  #middle-wizard{padding:22px 18px 4px;}
  #bottom-wizard{padding:20px 18px;}
  #survey_container{padding:18px;}
  #bottom-wizard #btnInscrever,.btn-abts{width:100% !important;min-width:0;}
  .data-list.floated li{display:block;margin-bottom:10px;}
}

