/* 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;
    }
}

/* Paleta */
:root{
  --red:#e00000;
  --red-dark:#b80000;
  --ink:#0c0d0f;
  --bg:#f6f7fb;
  --card:#ffffff;
  --muted:#5a6674;
  --line:#eceff3;
}

/* Hero */
.ct-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%);
}
.ct-hero__inner{max-width:1100px;margin:0 auto;padding:88px 20px 96px;text-align:center}
.ct-hero__title{font-size:42px;line-height:1.15;font-weight:900;margin:0 0 8px}
.ct-hero__title span{color:var(--red)}
.ct-hero__subtitle{font-size:16px;color:#c7cfda;margin:0}

/* Grid principal */
.ct-wrap{background:var(--bg);padding:40px 0 70px}
.ct-grid{max-width:1180px;margin:0 auto;padding:0 20px;display:grid;grid-template-columns:1fr 1.2fr;gap:22px;align-items:start}

/* Cards */
.ct-card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:16px;
  box-shadow:0 16px 36px rgba(0,0,0,.06);
  padding:22px;
}
.ct-h2{font-size:26px;line-height:1.25;color:#101318;margin:0 0 12px}
.ct-h3{font-size:16px;margin:16px 0 8px;color:#111}

/* Lista/infos */
.ct-list{margin:0;padding-left:18px;display:grid;gap:6px}
.ct-email a{color:var(--red);text-decoration:none}
.ct-email a:hover{text-decoration:underline}
.ct-note{font-size:14px;color:var(--muted)}
.ct-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.ct-badge{font-size:12px;padding:6px 10px;border-radius:999px;background:#ffe8e8;color:#900;border:1px solid rgba(224,0,0,.25)}

/* Formulário */
.ct-fields{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ct-field{display:flex;flex-direction:column;gap:6px}
.ct-field--full{grid-column:1 / -1}
.ct-field label{font-size:13px;color:#2b3340}
.ct-field input,.ct-field textarea{
  font-size:14px;color:#0f1720;background:#fff;border:1px solid var(--line);
  border-radius:12px;padding:12px 14px;outline:none;transition:border .15s ease, box-shadow .15s ease;
}
.ct-field input::placeholder,.ct-field textarea::placeholder{color:#9aa6b2}
.ct-field input:focus,.ct-field textarea:focus{
  border-color:var(--red);
  box-shadow:0 0 0 3px rgba(224,0,0,.12);
}

/* Botões */
.ct-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px}
.ct-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;
}
.ct-btn--primary{background:var(--red);color:#fff;border-color:var(--red)}
.ct-btn--primary:hover{background:var(--red-dark);border-color:var(--red-dark);transform:translateY(-1px)}
.ct-btn--ghost{background:transparent;color:var(--red);border-color:var(--red)}
.ct-btn--ghost:hover{background:#ffe8e8;transform:translateY(-1px)}
.ct-terms{font-size:12px;color:var(--muted);margin-top:10px}

/* Colunas */
.ct-info .ct-card{position:sticky;top:20px}

/* Responsivo */
@media (max-width:1090px){
  .ct-grid{grid-template-columns:1fr;gap:18px}
  .ct-info .ct-card{position:static}
}
@media (max-width:640px){
  .ct-hero__title{font-size:32px}
  .ct-fields{grid-template-columns:1fr}
}

/*==========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; }
}
