/* 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 */
/* ===== GALERIA ===== */
/* ====== Galeria ====== */
.gal-hero{background:#0e1724;color:#fff}
.gal-hero__inner{max-width:1100px;margin:0 auto;padding:56px 20px;text-align:center}
.gal-title{font-size:36px;font-weight:900;margin:0 0 6px}
.gal-sub{color:#c9d2dd;margin:0}

.gal-wrap{max-width:1180px;margin:0 auto;padding:22px 20px 70px}
.gal-grid{
  list-style:none;display:grid;gap:14px;padding:0;margin:0;
  grid-template-columns:repeat(auto-fill, minmax(100px, 1fr));
}
.gal-item{
  width:100%;aspect-ratio:1/1;border:1px solid #e7ebf2;border-radius:12px;
  background:#fff;display:flex;align-items:center;justify-content:center;
  overflow:hidden;cursor:pointer;box-shadow:0 10px 24px rgba(0,0,0,.06);
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.gal-item:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(0,0,0,.1);border-color:#e00000}
.gal-thumb{
  width:100px;height:100px;object-fit:contain;image-rendering:auto;pointer-events:none;
}

/* ====== Lightbox / Modal ====== */
.lb{
  position:fixed;inset:0;display:none;place-items:center;z-index:100;
  background:rgba(0,0,0,.78);backdrop-filter:saturate(120%) blur(2px);
}
.lb.is-open{display:grid}
.lb-img{
  max-width:min(92vw,1200px);max-height:80vh;width:auto;height:auto;
  border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.5);background:#fff;
}

/* Botões (44px+ para toque) */
.lb-close,.lb-prev,.lb-next{
  position:absolute;border:0;border-radius:999px;cursor:pointer;
  width:48px;height:48px;display:grid;place-items:center;
  background:rgba(255,255,255,.92);color:#111;font-size:28px;line-height:1;
  box-shadow:0 10px 24px rgba(0,0,0,.35);transition:transform .15s ease, background .15s ease;
}
.lb-close{top:18px;right:18px;font-size:30px}
.lb-prev{left:18px;top:50%;transform:translateY(-50%)}
.lb-next{right:18px;top:50%;transform:translateY(-50%)}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{background:#fff;transform:scale(1.04)}
@media (max-width:640px){
  .lb-img{max-height:72vh}
  .lb-prev,.lb-next{width:56px;height:56px;font-size:30px}
}


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