/* Importando apenas a fonte que realmente é usada aqui (Inter) */
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: Inter, Fallback;
}

body {
    font-family: Inter, Fallback;
    background: #f5f5f5;
    color: var(--black);
}

/* ======================= VARIÁVEIS ======================= */

:root {
    --red: #e00000;
    --red-dark: #c00000;
    --black: #111111;
    --gray-divider: #d0d0d0;
    --bg-white: #ffffff;
    --shadow-soft: 0 16px 30px rgba(0, 0, 0, 0.08);
    --radius-pill: 999px;
    --transition-fast: 0.2s ease;
    --transition-med: 0.3s ease;
}

/* ======================= NAVBAR ======================= */
/* Botão flutuante verde (chat) */
.ideal-para__fab {
  position: fixed;
  right: 32px;
  bottom: 32px;
  width: 56px;
  height: 56px;
  border-radius: 999px;
  border: none;
  background: #02c55b;
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 18px 35px rgba(0, 0, 0, 0.28);
  cursor: pointer;
  z-index: 40;
}

.ideal-para__fab-icon {
  font-size: 22px;
}
.ideal-para__fab > img{ width: 30px;}

.topbar {
    position: sticky;
    top: 0;
    z-index: 30;
    background: var(--bg-white);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.topbar-inner {
    padding: 0 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 82px;
    position: relative;
}

.logo-link {
    display: flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
}

.logo-link img {
    height: 80px;
    width: auto;
    display: block;
    transform-origin: center;
    transition: transform var(--transition-med);
}

.logo-link:hover img {
    transform: scale(1.06) rotate(-2deg);
}

/* MENU CONTAINER (desktop: linha; mobile: painel) */
.topbar-menu {
    display: flex;
    align-items: center;
    gap: 40px;
}
.topbar-menu[aria-hidden="true"]{ display:none !important; }
nav {
    flex: 1;
}

.nav-list {
    list-style: none;
    display: flex;
    align-items: center;
    gap: 32px;
}
/* quando fechado, impede clique e foco (JS já tira o foco) */
.topbar-menu.is-closed {
  pointer-events: none;
}

.nav-link,
.nav-dropdown-toggle {
    border: none;
    background: none;
    padding: 4px 0;
    font-weight: 500;
    font-size: 18px;
    cursor: pointer;
    position: relative;
    text-decoration: none;
    color: var(--black);
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: color var(--transition-fast), transform var(--transition-fast);
}

/* ===== ANIMAÇÕES DE ENTRADA ===== */
.logo-link img,
.nav-link,
.nav-dropdown-toggle,
.lang-switch,
.btn-cta {
    animation-name: animation-show;
    animation-duration: 0.7s;
    animation-timing-function: ease;
    animation-fill-mode: backwards;
}

.logo-link img { animation-delay: 0s; }

.nav-item:nth-child(1) .nav-link { animation-delay: 0.1s; }
.nav-item:nth-child(2) .nav-link { animation-delay: 0.2s; }
.nav-item:nth-child(3) .nav-dropdown-toggle { animation-delay: 0.3s; }
.nav-item:nth-child(4) .nav-link { animation-delay: 0.4s; }
.nav-item:nth-child(5) .nav-link { animation-delay: 0.5s; }
.nav-item:nth-child(6) .nav-link { animation-delay: 0.6s; }

.lang-switch { animation-delay: 0.7s; }
.btn-cta { animation-delay: 0.8s; }

.nav-link:hover,
.nav-dropdown-toggle:hover {
    color: var(--red);
    transform: translateY(-1px);
}

.nav-link::after,
.nav-dropdown-toggle::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -4px;
    width: 0;
    height: 2px;
    background: var(--red);
    border-radius: 10px;
    transition: width var(--transition-med);
}

.nav-link:hover::after,
.nav-dropdown-toggle:hover::after {
    width: 100%;
}

.nav-link--active {
    color: var(--red);
}

.nav-link--active::after {
    width: 100%;
}

.caret {
    font-size: 12px;
    transition: transform var(--transition-med);
}

.nav-dropdown-toggle.is-open .caret {
    transform: rotate(180deg);
}

/* DROPDOWN */

.nav-item--dropdown {
    position: relative;
}

.dropdown-menu {
    position: absolute;
    left: 0;
    top: calc(100% + 18px);
    min-width: 210px;
    background: var(--bg-white);
    border-radius: 18px;
    box-shadow: var(--shadow-soft);
    padding: 16px 0;
    opacity: 0;
    transform: translateY(-10px);
    transition: opacity var(--transition-med), transform var(--transition-med);
}

.dropdown-menu.is-open {
    opacity: 1;
    transform: translateY(0);
}

.dropdown-link {
    display: block;
    padding: 8px 24px;
    font-size: 15px;
    color: var(--black);
    text-decoration: none;
    transition: background var(--transition-fast), color var(--transition-fast),
        transform var(--transition-fast);
}

.dropdown-link:hover {
    background: rgba(224, 0, 0, 0.06);
    color: var(--red);
    transform: translateX(2px);
}

/* LANG SWITCH + CTA */

.nav-right {
    display: flex;
    align-items: center;
    gap: 24px;
}

.lang-switch {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
}

.lang-btn {
    border: none;
    background: none;
    cursor: pointer;
    padding: 2px 4px;
    font-size: 14px;
    color: var(--black);
    transition: color var(--transition-fast), transform var(--transition-fast);
}

.lang-btn--active {
    color: var(--red);
    font-weight: 600;
}

.lang-btn:hover {
    transform: translateY(-1px);
    color: var(--red);
}

.lang-divider {
    color: var(--gray-divider);
    user-select: none;
}

.btn-cta {
    text-decoration: none;
    padding: 12px 26px;
    border-radius: 10px;
    background: var(--red);
    color: #ffffff;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.01em;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 14px 25px rgba(224, 0, 0, 0.35);
    transition: background var(--transition-fast), transform var(--transition-fast),
        box-shadow var(--transition-fast);
    white-space: nowrap;
}

.btn-cta:hover {
    background: var(--red-dark);
    transform: translateY(-1px);
    box-shadow:var(--shadow-soft);
}

.btn-cta:active {
    transform: translateY(1px);
    box-shadow: 0 8px 18px rgba(224, 0, 0, 0.3);
}

/* BOTÃO MENU MOBILE */

.menu-toggle {
    display: none;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    border: none;
    background: #ffffff;
    box-shadow: var(--shadow-soft);
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
    margin-left: auto;
    position: relative;
    overflow: hidden;
}

.menu-toggle-bars {
    width: 20px;
    height: 16px;
    position: relative;
}

.menu-toggle-bars span {
    position: absolute;
    left: 0;
    right: 0;
    height: 2px;
    border-radius: 10px;
    background: var(--red);
    transition: transform var(--transition-med), opacity var(--transition-med),
        top var(--transition-med), bottom var(--transition-med);
}

.menu-toggle-bars span:nth-child(1) {
    top: 0;
}

.menu-toggle-bars span:nth-child(2) {
    top: 7px;
}

.menu-toggle-bars span:nth-child(3) {
    bottom: 0;
}

.menu-toggle.is-open .menu-toggle-bars span:nth-child(1) {
    top: 7px;
    transform: rotate(45deg);
}

.menu-toggle.is-open .menu-toggle-bars span:nth-child(2) {
    opacity: 0;
}

.menu-toggle.is-open .menu-toggle-bars span:nth-child(3) {
    bottom: 7px;
    transform: rotate(-45deg);
}

/* ======================= MOBILE ======================= */

@media (max-width: 1090px) {
    .topbar-inner {
        height: 72px;
        gap: 16px;
    }

    .topbar-menu {
        position: absolute;
        left: 0;
        right: 0;
        top: 100%;
        background: #ffffff;
        box-shadow: var(--shadow-soft);
        padding: 12px 24px 18px;
        border-radius: 0 0 20px 20px;
        display: flex;
        flex-direction: column;
        gap: 18px;
        transform: translateY(-12px);
        opacity: 0;
        pointer-events: none;
        transition: opacity var(--transition-med),
            transform var(--transition-med);
    }

    .topbar.menu-open .topbar-menu {
        opacity: 1;
        pointer-events: auto;
        transform: translateY(0);
    }

    nav {
        width: 100%;
    }

    .nav-list {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }

    .nav-item--dropdown {
        width: 100%;
    }

    .dropdown-menu {
        display: block !important;
        opacity: 1;
        position: static;
        box-shadow: none;
        margin-top: 6px;
        border-radius: 14px;
        background: rgba(0, 0, 0, 0.02);
        transform: translateY(0);
    }

    .dropdown-menu.is-open {
        opacity: 1;
        pointer-events: auto;
    }

    .dropdown-link {
        padding-left: 18px;
    }

    .nav-right {
        width: 100%;
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .btn-cta {
        width: 100%;
        justify-content: center;
    }

    .lang-switch {
        gap: 4px;
    }

    .menu-toggle {
        display: inline-flex;
    }
}


/* HERO */
.cert-hero{
  color:#fff;
  background:
    repeating-linear-gradient(135deg,rgba(255,255,255,.04) 0 14px,rgba(255,255,255,0) 14px 40px),
    radial-gradient(1100px 380px at 80% 110%, rgba(224,0,0,.43), transparent 70%),
    linear-gradient(180deg,#0b0b0c 0%, #1a0a0a 55%, #0b0b0c 100%);
}
.cert-hero__inner{max-width:1100px;margin:0 auto;padding:80px 20px 88px;text-align:center}
.cert-hero__title{font-size:42px;line-height:1.15;font-weight:900;margin:0 0 8px}
.cert-hero__subtitle{font-size:16px;color:#c7cfda;margin:0}

/* GRID PRINCIPAL */
.cert-wrap{max-width:1180px;margin:0 auto;padding:0 20px}
.cert-split{background:#fff;padding:56px 0}
.cert-grid{display:grid; grid-template-columns: 1fr 1fr; gap:24px;align-items:center}

/* TEXTO */
.cert-title{font-size:36px;line-height:1.2;color:#111;margin:0 0 10px}
.cert-title span{color:var(--red)}
.cert-lead{font-size:16px;line-height:1.75;color:#26313a;margin:0 0 10px}
.cert-text{font-size:16px;line-height:1.75;color:#45505c;margin:0 0 6px}

.cert-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:14px}
.cert-btn{
  display:inline-flex;align-items:center;justify-content:center;cursor:pointer;
  height:44px;padding:0 22px;border-radius:10px;border:2px solid transparent;
  font-weight:700;font-size:14px;letter-spacing:.2px;text-decoration:none;transition:.2s ease;
}
.cert-btn--primary{background:var(--red);color:#fff;border-color:var(--red)}
.cert-btn--primary:hover{background:var(--red-dark);border-color:var(--red-dark);transform:translateY(-1px)}
.cert-btn--ghost{background:transparent;color:var(--red);border-color:var(--red)}
.cert-btn--ghost:hover{background:#ffe8e8;transform:translateY(-1px)}

/* CARROSSEL */
.cert-media{width:80%}
.cert-carousel{
  position:relative;overflow:hidden;background:#fff;border:1px solid var(--line);
  border-radius:16px;box-shadow:0 16px 36px rgba(0,0,0,.06);
}
.cert-track{display:flex;transition:transform .45s ease}
.cert-slide{min-width:100%;user-select:none}
.cert-slide img{display:block;width:100%;height:auto}

.cert-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border:none;border-radius:999px;cursor:pointer;
  background:var(--red);color:#fff;font-size:24px;line-height:1;display:grid;place-items:center;
  box-shadow:0 8px 18px rgba(224,0,0,.35);transition:transform .15s ease, background .15s ease;
}
.cert-nav:hover{background:var(--red-dark);transform:translateY(-50%) scale(1.03)}
.cert-prev{left:10px}
.cert-next{right:10px}

.cert-dots{
  position:absolute;left:50%;bottom:12px;transform:translateX(-50%);
  display:flex;gap:8px
}
.cert-dots button{
  width:9px;height:9px;border-radius:50%;border:2px solid rgba(255,255,255,.9);
  background:rgba(255,255,255,.25);cursor:pointer;transition:.2s ease
}
.cert-dots button.is-active{background:#fff}

/* RESPONSIVO */
@media (max-width:1090px){
  .cert-grid{grid-template-columns:1fr;gap:18px}
  .cert-title{font-size:30px}
  .cert-media{width: 100%;}
}
@media (max-width:640px){
  .cert-hero__title{font-size:32px}
}

/*==========FOOTER==================*/

.site-footer{
  background:#0e1724;
  color:#c9d2dd;
  border-top:1px solid #182233;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
}
.footer-inner{
  max-width:1100px;
  margin:0 auto;
  padding:32px 20px 18px;
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr 1fr;
  gap:28px;
}

/* Coluna 1 (logo + copy + sociais) */
.f-brand{ display:flex; flex-direction:column; gap:14px; }
.f-logo{
  width:56px; height:56px; border-radius:50%;
  display:flex; justify-content: center; align-items: center; ;
}
.f-logo img{ width:44px; height:44px; display:flex; justify-content: center; align-items: center; }

.f-copy{ font-size:14px; line-height:1.55; max-width:260px; color:#c9d2dd; }
.f-social{ display:flex; gap:12px; margin-top:6px; }
.f-social a{
  width:20px; height:20px; display:grid; place-items:center;
  color:#c9d2dd; text-decoration:none; transition:transform .18s ease,color .18s ease;
}
.f-social a:hover{ color:var(--red); transform:translateY(-2px); }

/* Títulos e listas */
.f-title{ color:#ffffff; font-weight:800; font-size:16px; margin:0 0 10px; }
.f-sub{ color:#c9d2dd; font-weight:700; font-size:14px; margin:6px 0 6px; }
.f-list{ list-style:none; padding:0; margin:0; display:grid; gap:8px; }
.f-link{ color:#c9d2dd; font-size:14px; text-decoration:none; }
.f-link:hover{ color:#ffffff; }

.f-line{ height:1px; background:#182233; margin:14px 0; }

.f-bottom{
  text-align:center;
  color:#9aa6b2;
  font-size:13px;
  padding:0 20px 22px;
  display:grid; gap:6px;
}

/* Ícones */
.ico{ width:16px; height:16px; display:inline-block; vertical-align:-3px; margin-right:8px; fill:#9aa6b2; }
.f-link:hover .ico{ fill:#ffffff; }

/* Mobile: 1 coluna e centralizado */
@media (max-width: 820px){
  .f-logo{margin-left: auto;margin-right: auto;}
  .footer-inner{
    grid-template-columns: 1fr;
    text-align:center;
  }
  .f-copy{ margin:0 auto; max-width:420px; }
  .f-social{ justify-content:center; }
  .cert-copy{display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center;}
}
