/* eAula — Matrícula restyle
   Requires: home-restyle.css (variáveis :root, .eax-container, .eax-btn-*, .eax-bg-*)
             contact-restyle.css (.eax-form-group/label/input/select/textarea/row/select-wrap)
   Não substitui style-r.css — convive em paralelo (JS depende de regras lá: .loading,
   .collapsible, #course-subjects{display:none}, #credit-card-pg-form{display:none}, etc).
*/

:root{
  --eax-reg-header-h:52px;
}

/* ===================================================================
   LOADING — override do .loading legado: blur de fundo + spinner moderno
   (não toca em style-r.css; cascade vence pelo arquivo carregado depois)
=================================================================== */
.loading{
  /* tinta roxa bem leve + blur do conteúdo atrás */
  background:rgba(44,22,84,.18) !important;
  backdrop-filter:blur(8px) saturate(140%);
  -webkit-backdrop-filter:blur(8px) saturate(140%);
  /* container do conteúdo central */
  flex-direction:column;gap:1.1rem;
}
.loading-icon{
  /* ring com gradiente roxo→coral usando conic + mask */
  position:relative;
  width:62px;height:62px;border:0 !important;
  background:conic-gradient(from 90deg,
    var(--eax-secondary-2) 0%,
    var(--eax-primary-2) 35%,
    rgba(45,0,93,0) 70%,
    var(--eax-secondary-2) 100%);
  border-radius:50%;
  -webkit-mask:radial-gradient(circle,transparent 60%,#000 62%);
  mask:radial-gradient(circle,transparent 60%,#000 62%);
  filter:drop-shadow(0 8px 16px rgba(45,0,93,.25));
  animation:eax-spin 1s linear infinite !important;
}
@keyframes eax-spin{to{transform:rotate(360deg)}}
.loading::after{
  content:'Processando...';
  color:var(--eax-primary-2);font-weight:700;font-size:.95rem;
  letter-spacing:.02em;
  text-shadow:0 1px 2px rgba(255,255,255,.6);
}
@media(prefers-reduced-motion:reduce){
  .loading-icon{animation:none !important}
}

/* Estado "carregando" / disabled em botões eax-btn (durante submit) */
.eax-btn:disabled,
.eax-btn[aria-busy="true"]{
  opacity:.7;cursor:not-allowed;pointer-events:none;
  transform:none;
}
.eax-btn .fa-spinner{margin-right:.15rem}

/* ===================================================================
   MODAL BOOTSTRAP — overrides para visual moderno + backdrop com blur
   (Mantém #stdContractModal funcionando via Bootstrap JS; só estilo)
=================================================================== */
.modal-backdrop,
.modal-backdrop.show{
  background:rgba(44,22,84,.18)!important;
  opacity:1!important;
  backdrop-filter:blur(8px) saturate(140%);
  -webkit-backdrop-filter:blur(8px) saturate(140%);
}
.modal-dialog-centered{
  display:flex;align-items:center;min-height:calc(100% - 1rem);
}
.modal-content{
  background:#fff!important;
  border:0!important;
  border-radius:1.25rem!important;
  box-shadow:0 25px 50px -12px rgba(44,22,84,.4),0 12px 24px -6px rgba(44,22,84,.18)!important;
  overflow:hidden;
}
.modal-header{
  padding:1.5rem 1.5rem 1rem!important;
  border-bottom:1px solid var(--eax-border,#e5e7eb)!important;
  display:flex;align-items:flex-start;gap:1rem;
}
.modal-title{
  font-size:1.15rem!important;font-weight:800!important;line-height:1.3!important;
  color:var(--eax-fg,#2c1654)!important;
  letter-spacing:-.005em!important;margin:0!important;flex:1;
}
.modal-header .close{
  width:2rem;height:2rem;padding:0!important;margin:0!important;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:50%;border:0!important;background:transparent!important;
  font-size:1.5rem!important;line-height:1!important;font-weight:300!important;
  color:var(--eax-muted-fg,#6b7280)!important;opacity:1!important;
  text-shadow:none!important;cursor:pointer;
  transition:all .2s ease;
}
.modal-header .close:hover{
  background:#f3f4f6!important;color:var(--eax-fg,#2c1654)!important;
  opacity:1!important;
}
.modal-header .close span{line-height:1}

.modal-body{
  padding:1.25rem 1.5rem!important;
  font-size:.95rem!important;color:var(--eax-muted-fg,#6b7280)!important;
  line-height:1.6!important;
}
.modal-body strong{color:var(--eax-fg,#2c1654);font-weight:700}

.modal-footer{
  padding:1rem 1.5rem 1.5rem!important;
  border-top:0!important;
  display:flex;align-items:center;justify-content:flex-end;gap:.6rem;flex-wrap:wrap;
}
/* Botões Bootstrap dentro do modal (mantém classes .btn .btn-primary etc) */
.modal-footer .btn{
  display:inline-flex!important;align-items:center;justify-content:center;gap:.4rem;
  padding:.65rem 1.25rem!important;
  border-radius:9999px!important;
  font-weight:600!important;font-size:.9rem!important;
  border:2px solid transparent!important;
  transition:all .25s ease!important;
  text-shadow:none!important;cursor:pointer;
  min-width:5.5rem;
}
.modal-footer .btn-primary{
  background:var(--eax-primary-2,#2d005d)!important;color:#fff!important;
  border-color:var(--eax-primary-2,#2d005d)!important;
}
.modal-footer .btn-primary:hover{
  background:#fff!important;color:var(--eax-primary-2,#2d005d)!important;
  border-color:var(--eax-primary-2,#2d005d)!important;
  box-shadow:0 8px 20px -8px rgba(45,0,93,.5)!important;
  transform:scale(1.03);
}
.modal-footer .btn-secondary{
  background:#fff!important;color:var(--eax-muted-fg,#6b7280)!important;
  border-color:var(--eax-border,#e5e7eb)!important;
}
.modal-footer .btn-secondary:hover{
  background:#f9fafb!important;color:var(--eax-fg,#2c1654)!important;
  border-color:#cbd5e1!important;
}

/* Animação de entrada (mais suave que a padrão do Bootstrap) */
.modal.fade .modal-dialog{
  transition:transform .35s cubic-bezier(.16,1,.3,1),opacity .25s ease!important;
  transform:translateY(1.5rem) scale(.96)!important;opacity:0;
}
.modal.show .modal-dialog{
  transform:translateY(0) scale(1)!important;opacity:1;
}
@media(prefers-reduced-motion:reduce){
  .modal.fade .modal-dialog{transition:none!important;transform:none!important;opacity:1}
}

/* ===================================================================
   0. HEADER FIXO do checkout (logo centralizada)
=================================================================== */
.eax-reg-header{
  position:fixed;top:0;left:0;right:0;z-index:60;
  height:var(--eax-reg-header-h);
  background:#fff;
  border-bottom:1px solid var(--eax-border);
  box-shadow:0 1px 3px rgba(44,22,84,.06);
  display:flex;align-items:center;justify-content:center;
  padding:0 1rem;
}
.eax-reg-header a{
  display:inline-flex;align-items:center;
  transition:transform .2s ease;
}
.eax-reg-header a:hover{transform:scale(1.04)}
.eax-reg-header img{
  height:26px;width:auto;display:block;
}
@media(min-width:768px){.eax-reg-header img{height:30px}}

/* ===================================================================
   1. STEPPER (eax-stepper) — 4 etapas, design v0-inspired
   Done   → primary purple (#2c1654) com check
   Current→ coral (#ff304c) com scale 1.1 + shadow + pulse
   Todo   → cinza neutro
=================================================================== */
.eax-stepper-wrap{
  position:sticky;top:var(--eax-reg-header-h);z-index:40;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(12px);
  -webkit-backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--eax-border);
  box-shadow:0 1px 0 rgba(229,231,235,.7),0 4px 20px -10px rgba(44,22,84,.08);
  padding:1rem 0 1.25rem;
}
.eax-stepper{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  max-width:64rem;margin:0 auto;padding:0 1rem;
  position:relative;list-style:none;
}
.eax-stepper-item{
  display:flex;flex-direction:column;align-items:center;
  gap:.5rem;position:relative;text-align:center;padding:.5rem .25rem;
}
.eax-stepper-bubble{
  width:2.5rem;height:2.5rem;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.95rem;
  background:#fff;color:var(--eax-muted-fg);
  border:2px solid rgba(107,114,128,.3);
  transition:all .3s ease;z-index:1;position:relative;
}
.eax-stepper-bubble i{font-size:1rem}
.eax-stepper-label{
  font-size:.72rem;font-weight:600;color:var(--eax-muted-fg);
  line-height:1.25;letter-spacing:.01em;
}
@media(min-width:480px){.eax-stepper-bubble{width:2.75rem;height:2.75rem}.eax-stepper-label{font-size:.78rem}}
@media(min-width:640px){.eax-stepper-bubble{width:3rem;height:3rem}.eax-stepper-label{font-size:.85rem}}
@media(min-width:768px){.eax-stepper-label{font-size:.9rem}.eax-stepper-bubble{width:2.5rem;height:2.5rem}}

/* Conector entre bolinhas */
.eax-stepper-item:not(:last-child)::after{
  content:'';position:absolute;
  top:1.25rem;left:calc(50% + 1.5rem);right:calc(-50% + 1.5rem);
  height:2px;background:var(--eax-muted);
  z-index:0;transition:background .35s ease;
}
@media(min-width:480px){.eax-stepper-item:not(:last-child)::after{top:1.375rem;left:calc(50% + 1.65rem);right:calc(-50% + 1.65rem)}}
@media(min-width:640px){.eax-stepper-item:not(:last-child)::after{top:1.5rem;left:calc(50% + 1.75rem);right:calc(-50% + 1.75rem)}}
@media(min-width:768px){.eax-stepper-item:not(:last-child)::after{top:1.25rem;left:calc(50% + 1.5rem);right:calc(-50% + 1.5rem)}}

/* Estados — v0 inspired */
.eax-stepper-item.is-done .eax-stepper-bubble{
  background:var(--eax-primary-2);border-color:var(--eax-primary-2);color:#fff;
}
.eax-stepper-item.is-done::after{background:var(--eax-primary-2)}
.eax-stepper-item.is-done .eax-stepper-label{color:var(--eax-fg)}

.eax-stepper-item.is-current .eax-stepper-bubble{
  background:var(--eax-secondary-2);border-color:var(--eax-secondary-2);color:#fff;
  transform:scale(1.1);
  box-shadow:0 8px 20px -4px rgba(255,48,76,.45),0 0 0 4px rgba(255,48,76,.12);
  animation:eax-stepper-pulse 2.2s ease-in-out infinite;
}
.eax-stepper-item.is-current .eax-stepper-label{
  color:var(--eax-fg);font-weight:700;
}

@keyframes eax-stepper-pulse{
  0%,100%{box-shadow:0 8px 20px -4px rgba(255,48,76,.45),0 0 0 4px rgba(255,48,76,.12)}
  50%{box-shadow:0 8px 20px -4px rgba(255,48,76,.55),0 0 0 8px rgba(255,48,76,.05)}
}
@media(prefers-reduced-motion:reduce){
  .eax-stepper-item.is-current .eax-stepper-bubble{animation:none}
}

/* Mobile (<768px): barra de progresso ao invés de bolinhas (estilo v0) */
.eax-stepper-mobile{
  display:none;padding:.25rem 1rem .5rem;
}
.eax-stepper-mobile-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:.6rem;font-size:.78rem;font-weight:600;
  color:var(--eax-muted-fg);
}
.eax-stepper-mobile-current{color:var(--eax-fg)}
.eax-stepper-mobile-bar{
  width:100%;height:.5rem;background:var(--eax-muted);
  border-radius:9999px;overflow:hidden;
}
.eax-stepper-mobile-fill{
  height:100%;background:linear-gradient(90deg,var(--eax-primary-2),var(--eax-secondary-2));
  border-radius:9999px;transition:width .5s ease;
}
@media(max-width:767px){
  .eax-stepper{display:none}
  .eax-stepper-mobile{display:block}
}

/* ===================================================================
   2. SHELL DE PÁGINA — hero gradient roxo→coral + main
=================================================================== */
.eax-reg-shell{
  background:linear-gradient(180deg,rgba(243,244,246,.5) 0%,#fff 40%);
  min-height:100vh;padding-top:var(--eax-reg-header-h);
  display:flex;flex-direction:column;
}
/* Hero banner com gradiente (v0 style) */
.eax-reg-hero{
  background:linear-gradient(135deg,var(--eax-primary-2) 0%,var(--eax-secondary-2) 100%);
  color:#fff;padding:2.5rem 1rem 3rem;text-align:center;
  position:relative;overflow:hidden;
}
/* Variante compacta usada como cabeçalho do CPF (sem stepper logo abaixo) */
.eax-reg-hero--compact{padding:2rem 1rem 6.5rem}
@media(min-width:768px){.eax-reg-hero--compact{padding:2.25rem 1rem 7.5rem}}
.eax-reg-hero--compact h1{font-size:1.4rem}
@media(min-width:768px){.eax-reg-hero--compact h1{font-size:2rem}}
.eax-reg-hero--compact p{font-size:.9rem;opacity:.88}
.eax-reg-hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(circle at 15% 25%,rgba(255,255,255,.1),transparent 50%),
    radial-gradient(circle at 85% 75%,rgba(255,255,255,.08),transparent 45%);
}
.eax-reg-hero > *{position:relative;z-index:1}
.eax-reg-hero h1{
  font-size:1.65rem;font-weight:800;color:#fff;
  margin:0 0 .65rem;letter-spacing:-.01em;text-wrap:balance;
}
@media(min-width:768px){.eax-reg-hero h1{font-size:2.5rem}}
@media(min-width:1024px){.eax-reg-hero h1{font-size:3rem}}
.eax-reg-hero p{
  font-size:.95rem;color:rgba(255,255,255,.92);
  margin:0 auto;max-width:42rem;line-height:1.6;text-wrap:balance;
}
@media(min-width:768px){.eax-reg-hero p{font-size:1.1rem}}

/* Heads neutros (fallback para views sem hero gradient) */
.eax-reg-head{
  text-align:center;padding:2rem 1rem 1.5rem;
}
.eax-reg-head h1{
  font-size:1.5rem;font-weight:800;color:var(--eax-fg);
  margin:0 0 .5rem;letter-spacing:-.01em;
}
@media(min-width:768px){.eax-reg-head h1{font-size:2rem}}
.eax-reg-head p{
  font-size:.95rem;color:var(--eax-muted-fg);
  margin:0 auto;max-width:38rem;line-height:1.55;
}
.eax-reg-main{
  padding:1.5rem 1rem 0;max-width:60rem;margin:0 auto;
}
.eax-reg-main--wide{max-width:72rem}

/* ===================================================================
   3. SECTION CARDS — substitui .card / .card-header / .card-body
=================================================================== */
.eax-reg-card{
  background:#fff;border:1px solid var(--eax-border);border-radius:1.25rem;
  padding:1.5rem;margin-bottom:1.25rem;
  box-shadow:0 1px 2px rgba(44,22,84,.04),0 4px 16px -8px rgba(44,22,84,.08);
}
@media(min-width:768px){.eax-reg-card{padding:2rem}}
.eax-reg-card-head{
  display:flex;align-items:center;gap:.85rem;
  margin:0 0 1.5rem;padding-bottom:1rem;
  border-bottom:1px solid var(--eax-border);
}
.eax-reg-card-head-icon{
  width:2.5rem;height:2.5rem;border-radius:.75rem;
  display:inline-flex;align-items:center;justify-content:center;
  color:#fff;
  background:linear-gradient(135deg,var(--eax-primary-2),var(--eax-secondary-2));
  flex-shrink:0;
}
.eax-reg-card-head-icon i{font-size:1rem}
.eax-reg-card-head h2{
  font-size:1.05rem;font-weight:700;margin:0;
  color:var(--eax-fg);letter-spacing:-.005em;
}
@media(min-width:768px){.eax-reg-card-head h2{font-size:1.2rem}}

/* ===================================================================
   4. CPF ENTRY (register_cpf.php) — v0 inspired: card flutuante sobre o hero
=================================================================== */
.eax-cpf-shell{
  min-height:100vh;display:flex;flex-direction:column;
  padding-top:var(--eax-reg-header-h);
  background:linear-gradient(180deg,rgba(243,244,246,.5) 0%,#fff 50%);
}
.eax-cpf-entry{
  flex:1;display:flex;justify-content:center;align-items:flex-start;
  padding:0 1rem;
  margin-top:-5rem;position:relative;z-index:2;
}
@media(min-width:768px){.eax-cpf-entry{margin-top:-6rem}}
.eax-cpf-card{
  background:#fff;border:1px solid var(--eax-border);border-radius:1.5rem;
  padding:2.25rem 1.75rem;max-width:28rem;width:100%;
  text-align:center;
  box-shadow:0 25px 50px -12px rgba(44,22,84,.25),0 8px 16px -8px rgba(44,22,84,.12);
}
@media(min-width:640px){.eax-cpf-card{padding:2.5rem 2.25rem}}
.eax-cpf-card-icon{
  width:3.5rem;height:3.5rem;border-radius:.85rem;
  background:linear-gradient(135deg,var(--eax-primary-2),var(--eax-secondary-2));
  color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  margin-bottom:1rem;font-size:1.4rem;
  box-shadow:0 12px 24px -8px rgba(255,48,76,.35);
}
.eax-cpf-card h1{
  font-size:1.4rem;margin:0 0 .5rem;font-weight:800;color:var(--eax-fg);
  letter-spacing:-.01em;
}
@media(min-width:640px){.eax-cpf-card h1{font-size:1.65rem}}
.eax-cpf-card > p{
  color:var(--eax-muted-fg);font-size:.92rem;line-height:1.55;
  margin:0 0 1.5rem;
}
.eax-cpf-help{
  margin-top:1.5rem;text-align:center;
  font-size:.85rem;color:var(--eax-muted-fg);
}
.eax-cpf-help a{
  color:var(--eax-primary-2);font-weight:600;text-decoration:none;
  display:inline-flex;align-items:center;gap:.4rem;margin-left:.25rem;
}
.eax-cpf-help a:hover{text-decoration:underline}
.eax-cpf-card .eax-form-group{text-align:left;margin-bottom:1.25rem}
.eax-cpf-card .eax-form-input{
  text-align:center;
  font-size:1.05rem;
  letter-spacing:.04em;
}
.eax-cpf-card .eax-form-input::placeholder{
  letter-spacing:.02em;color:#9ca3af;
}
.eax-cpf-card .eax-btn{width:100%}
.eax-cpf-error{
  background:#fff5f4;border:1px solid #ff9797;color:#d12818;
  padding:.75rem 1rem;border-radius:.65rem;
  font-size:.9rem;margin-top:1rem;text-align:left;
  display:flex;align-items:flex-start;gap:.65rem;
}
.eax-cpf-error i{flex-shrink:0;margin-top:.15rem}

/* ===================================================================
   5. CPF badge (mostra CPF do aluno dentro de cards)
=================================================================== */
.eax-cpf-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(45,0,93,.06);color:var(--eax-primary-2);
  border-radius:9999px;padding:.4rem .9rem;
  font-size:.85rem;font-weight:600;margin-bottom:1.25rem;
}
.eax-cpf-badge i{font-size:.85rem}
.eax-cpf-badge strong{font-weight:700}

/* ===================================================================
   6. ASTERISCO obrigatório
=================================================================== */
.eax-required{color:#ef4444;font-weight:700;margin-left:.15rem}

/* ===================================================================
   7. RADIO PILLS (formação)
=================================================================== */
.eax-radio-group{display:flex;flex-wrap:wrap;gap:.75rem}
.eax-radio-pill{position:relative}
.eax-radio-pill input[type="radio"]{
  position:absolute;opacity:0;pointer-events:none;
}
.eax-radio-pill label{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.85rem 1.5rem;
  border:2px solid var(--eax-border);border-radius:9999px;
  cursor:pointer;font-weight:600;font-size:.95rem;
  color:var(--eax-fg);background:#fff;
  transition:all .2s ease;
}
.eax-radio-pill label:hover{
  border-color:var(--eax-primary-2);background:rgba(45,0,93,.04);
}
.eax-radio-pill input:checked + label{
  border-color:var(--eax-primary-2);background:var(--eax-primary-2);
  color:#fff;box-shadow:0 4px 12px -2px rgba(45,0,93,.3);
}
.eax-radio-pill input:focus-visible + label{
  outline:2px solid var(--eax-primary-2);outline-offset:2px;
}

/* ===================================================================
   8. PAYMENT METHOD TOGGLE (boleto / cartão)
=================================================================== */
.eax-pay-methods{
  display:grid;grid-template-columns:1fr;gap:.75rem;margin-bottom:1.5rem;
}
@media(min-width:640px){.eax-pay-methods{grid-template-columns:1fr 1fr;gap:1rem}}
.eax-pay-method{position:relative}
.eax-pay-method input[type="radio"]{
  position:absolute;opacity:0;pointer-events:none;
}
.eax-pay-method label{
  display:flex;align-items:center;gap:1rem;
  padding:1.25rem 1.5rem;
  border:2px solid var(--eax-border);border-radius:1rem;
  cursor:pointer;background:#fff;transition:all .25s ease;
}
.eax-pay-icon{
  width:2.75rem;height:2.75rem;border-radius:.75rem;
  background:var(--eax-muted);color:var(--eax-muted-fg);
  display:inline-flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:all .25s ease;
}
.eax-pay-icon i{font-size:1.2rem}
.eax-pay-text{display:flex;flex-direction:column;gap:.15rem;text-align:left}
.eax-pay-title{font-weight:700;color:var(--eax-fg);font-size:.95rem}
.eax-pay-sub{font-size:.8rem;color:var(--eax-muted-fg)}
.eax-pay-method label:hover{border-color:var(--eax-primary-2)}
.eax-pay-method input:checked + label{
  border-color:var(--eax-primary-2);background:rgba(45,0,93,.04);
}
.eax-pay-method input:checked + label .eax-pay-icon{
  background:var(--eax-primary-2);color:#fff;
}
.eax-pay-method input:disabled + label{opacity:.55;cursor:not-allowed}
.eax-pay-method input:focus-visible + label{
  outline:2px solid var(--eax-primary-2);outline-offset:2px;
}

/* ===================================================================
   9. RESUME TABLE (override do estilo Bootstrap nas tabelas de cálculo)
   IDs internos preservados — só visual.
=================================================================== */
.eax-resume{
  background:#fafafd;border-radius:.85rem;padding:1rem;margin-top:1rem;
}
.eax-resume-title{
  font-size:1.05rem;font-weight:700;color:var(--eax-fg);
  margin:0 0 .85rem;display:flex;align-items:center;gap:.5rem;
}
.eax-resume-title i{color:var(--eax-primary-2)}
.eax-resume .table{font-size:.88rem;margin-bottom:0;width:100%}
.eax-resume .table thead th{
  border-top:0;border-bottom:2px solid var(--eax-border);
  color:var(--eax-muted-fg);font-size:.72rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.04em;
  padding:.65rem .5rem;text-align:left;
}
.eax-resume .table tbody td{
  border-top:1px solid var(--eax-border);
  padding:.8rem .5rem;vertical-align:middle;color:var(--eax-fg);
}
.eax-resume #payment-resume-table_total td,
.eax-resume #payment-cc-resume-table_total td{
  background:rgba(45,0,93,.08);font-weight:700;font-size:.95rem;
  color:var(--eax-primary-2);
}

/* ===================================================================
   10. CREDIT CARD FLAGS
=================================================================== */
.eax-cc-flags{
  display:flex;gap:.65rem;flex-wrap:wrap;align-items:center;
  color:#4a4a4a;font-size:1.75rem;margin-top:.35rem;
}
.eax-cc-flags i{transition:transform .2s ease}
.eax-cc-flags i:hover{transform:scale(1.15)}
.eax-cc-info{
  background:#f9fafb;border:1px solid var(--eax-border);
  border-radius:.75rem;padding:1rem 1.25rem;margin-bottom:1rem;
}
.eax-cc-info-head{font-weight:700;color:var(--eax-fg);font-size:.95rem;margin-bottom:.25rem}
.eax-cc-info-sub{font-size:.85rem;color:var(--eax-muted-fg);margin-bottom:.65rem}

/* ===================================================================
   11. NOTICES (info / success / warning / error)
=================================================================== */
.eax-notice{
  display:flex;align-items:flex-start;gap:.9rem;
  border-radius:.85rem;padding:1rem 1.25rem;margin:1rem 0;
  border:2px solid;
}
.eax-notice i{font-size:1.25rem;flex-shrink:0;margin-top:.15rem}
.eax-notice h3{font-size:1rem;font-weight:700;margin:0 0 .25rem}
.eax-notice p{margin:0;font-size:.9rem;line-height:1.55}
.eax-notice a{font-weight:600;text-decoration:underline}
.eax-notice-info{background:#eff6ff;border-color:#3b82f6;color:#1e40af}
.eax-notice-info i,.eax-notice-info a{color:#1e40af}
.eax-notice-success{background:#f0fdf4;border-color:#10b981;color:#065f46}
.eax-notice-success i,.eax-notice-success a{color:#065f46}
.eax-notice-warning{background:#fffbeb;border-color:#f59e0b;color:#92400e}
.eax-notice-warning i,.eax-notice-warning a{color:#92400e}
.eax-notice-error{background:#fef2f2;border-color:#ef4444;color:#991b1b}
.eax-notice-error i,.eax-notice-error a{color:#991b1b}

/* ===================================================================
   12. CONTRACT (register_contract.php) — escopo isolado em .eax-contract-body
=================================================================== */
.eax-contract-shell{
  background:#fff;border:2px solid var(--eax-border);
  border-radius:1rem;overflow:hidden;margin-bottom:1.5rem;
}
.eax-contract-toolbar{
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;padding:1rem 1.25rem;background:#fafafd;
  border-bottom:1px solid var(--eax-border);
  font-size:.85rem;color:var(--eax-muted-fg);font-weight:600;
}
.eax-contract-toolbar i{color:var(--eax-primary-2);margin-right:.4rem}
.eax-contract-body{
  max-height:32rem;overflow-y:auto;
  padding:1.5rem 1.75rem;
  font-size:.92rem;line-height:1.7;color:#333;
  scrollbar-width:thin;scrollbar-color:var(--eax-border) transparent;
}
.eax-contract-body::-webkit-scrollbar{width:8px}
.eax-contract-body::-webkit-scrollbar-thumb{background:var(--eax-border);border-radius:4px}
.eax-contract-body::-webkit-scrollbar-track{background:transparent}
.eax-contract-body h1,
.eax-contract-body h2,
.eax-contract-body h3{
  color:var(--eax-fg);font-weight:700;margin:1.25rem 0 .65rem;line-height:1.3;
}
.eax-contract-body h1{font-size:1.15rem}
.eax-contract-body h2{font-size:1.05rem}
.eax-contract-body h3{font-size:.95rem}
.eax-contract-body p{margin:0 0 .85rem}
.eax-contract-body ul,
.eax-contract-body ol{margin:0 0 .85rem 1.25rem;padding:0}
.eax-contract-body li{margin-bottom:.35rem}
.eax-contract-body table{
  width:100%;border-collapse:collapse;margin:.85rem 0;font-size:.85rem;
}
.eax-contract-body table td,
.eax-contract-body table th{
  border:1px solid var(--eax-border);
  padding:.5rem .65rem;vertical-align:top;
}
.eax-contract-body strong,
.eax-contract-body b{color:var(--eax-fg)}

/* Card de assinatura abaixo do contrato */
.eax-contract-sign{
  background:#fafafd;border:2px solid var(--eax-border);
  border-radius:1rem;padding:1.5rem;
}
@media(min-width:768px){.eax-contract-sign{padding:2rem}}

/* Checkbox custom */
.eax-checkbox{
  display:inline-flex;align-items:center;gap:.65rem;
  cursor:pointer;font-size:.95rem;color:var(--eax-fg);
}
.eax-checkbox input[type="checkbox"]{
  width:1.15rem;height:1.15rem;
  accent-color:var(--eax-primary-2);cursor:pointer;
}

/* ===================================================================
   13. SUCCESS (register_success.php)
=================================================================== */
.eax-success-hero{
  text-align:center;padding:2.5rem 1rem 1rem;
}
.eax-success-circle{
  width:5.5rem;height:5.5rem;border-radius:50%;
  background:var(--eax-green);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  margin-bottom:1rem;font-size:2.25rem;
  box-shadow:0 12px 32px -8px rgba(16,185,129,.5);
}
.eax-success-hero h1{
  font-size:1.65rem;font-weight:800;color:var(--eax-fg);
  margin:0 0 .5rem;line-height:1.2;
}
@media(min-width:768px){.eax-success-hero h1{font-size:2.1rem}}
.eax-success-hero p{
  color:var(--eax-muted-fg);font-size:1rem;
  margin:0 auto;max-width:38rem;line-height:1.55;
}
.eax-success-course{
  display:inline-block;margin-top:.85rem;padding:.4rem 1rem;
  border-radius:9999px;background:rgba(45,0,93,.08);
  color:var(--eax-primary-2);font-weight:600;font-size:.9rem;
}

/* Payment card grande */
.eax-payment-card{
  background:#fff;border:2px solid var(--eax-border);
  border-radius:1rem;padding:1.75rem;margin-top:1.5rem;
  box-shadow:var(--eax-shadow);
}
@media(min-width:768px){.eax-payment-card{padding:2rem}}
.eax-payment-card-head{
  display:flex;align-items:center;gap:.75rem;
  margin-bottom:1.25rem;padding-bottom:1rem;
  border-bottom:1px solid var(--eax-border);
}
.eax-payment-card-head-icon{
  width:2.5rem;height:2.5rem;border-radius:.65rem;
  display:inline-flex;align-items:center;justify-content:center;
  color:#fff;background:var(--eax-primary-2);flex-shrink:0;
}
.eax-payment-card-head h2{font-size:1.1rem;margin:0;font-weight:700;color:var(--eax-fg)}
.eax-payment-card-grid{
  display:grid;grid-template-columns:1fr;gap:1rem;
}
@media(min-width:640px){.eax-payment-card-grid{grid-template-columns:1fr 1fr}}
.eax-payment-stat-label{
  font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;
  color:var(--eax-muted-fg);font-weight:600;margin-bottom:.2rem;
}
.eax-payment-stat-value{
  font-size:1.2rem;font-weight:800;color:var(--eax-fg);
}
.eax-payment-stat-value.is-money{color:var(--eax-primary-2)}
.eax-payment-card-actions{
  margin-top:1.5rem;display:flex;flex-direction:column;
  gap:.75rem;align-items:stretch;
}
@media(min-width:640px){.eax-payment-card-actions{flex-direction:row;justify-content:center;align-items:center}}
.eax-payment-card-foot-note{
  font-size:.82rem;color:var(--eax-muted-fg);
  text-align:center;margin-top:1rem;line-height:1.5;
}

/* ===================================================================
   14. FOOTER simples (substitui inline-style do footer legado)
=================================================================== */
.eax-reg-footer{
  border-top:1px solid var(--eax-border);
  padding:1.5rem 1rem;text-align:center;
  color:var(--eax-muted-fg);font-size:.85rem;
  margin-top:auto;
}
.eax-reg-footer p{margin:0;line-height:1.55}

/* ===================================================================
   15. AJUSTES — form-row em 3 colunas e helpers
=================================================================== */
.eax-form-row-3{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:640px){.eax-form-row-3{grid-template-columns:1fr 1fr}}
@media(min-width:768px){.eax-form-row-3{grid-template-columns:1fr 1fr 1fr}}

.eax-form-row-4{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:640px){.eax-form-row-4{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.eax-form-row-4{grid-template-columns:repeat(4,1fr)}}

.eax-help-tip{
  display:inline-flex;align-items:center;justify-content:center;
  width:1.1rem;height:1.1rem;border-radius:50%;
  background:var(--eax-muted);color:var(--eax-muted-fg);
  font-size:.7rem;margin-left:.4rem;cursor:help;
  transition:all .2s ease;
}
.eax-help-tip:hover{background:var(--eax-primary-2);color:#fff}

/* CPF inline na ficha de pagamento (substitui .cpf-line-in-register) */
.eax-student-line{
  display:flex;flex-direction:column;gap:.4rem;
  background:#f9fafb;border-radius:.75rem;padding:1rem 1.25rem;
}
@media(min-width:640px){.eax-student-line{flex-direction:row;align-items:center;justify-content:space-between;gap:1rem}}
.eax-student-line-name{font-weight:700;color:var(--eax-fg);font-size:1rem}
.eax-student-line-cpf{font-size:.85rem;color:var(--eax-muted-fg);font-weight:600;letter-spacing:.02em}

/* Collapsible "Disciplinas do Curso" — só visual; classe .collapsible mantida */
.eax-reg-card .collapsible{
  background:#fafafd;border:1px solid var(--eax-border);
  border-radius:.75rem;padding:1rem 1.25rem;margin-top:1rem;
  cursor:pointer;display:flex;align-items:center;justify-content:space-between;
  transition:all .2s ease;
}
.eax-reg-card .collapsible:hover{background:#f3f4f6}
.eax-reg-card .collapsible h4{
  margin:0;font-size:.95rem;font-weight:700;color:var(--eax-fg);
  display:flex;align-items:center;gap:.6rem;
}
.eax-reg-card .collapsible h4 i{color:var(--eax-primary-2)}
.eax-reg-card .collapsible-content{
  background:#fff;border:1px solid var(--eax-border);border-top:0;
  border-radius:0 0 .75rem .75rem;padding:0 1.25rem;
  max-height:0;overflow:hidden;transition:all .3s ease;
}
.eax-reg-card .collapsible.collapsible-active + .collapsible-content,
.eax-reg-card .collapsible-content.collapsible-active{
  max-height:32rem;padding:1rem 1.25rem;overflow-y:auto;
}

/* ===================================================================
   16. AJUSTES finais — espaçamento entre stepper e conteúdo
=================================================================== */
.eax-stepper-wrap + .eax-reg-head{padding-top:1.5rem}
