/* ===== Tema Fábrica dos Sites - Hospedagem e Criação de Sites ===== */
/* PHP, Bootstrap 5, Poppins - Totalmente responsivo */

:root {
  --accent: #2E93EE;
  --accent-secondary: #1a7bd4;
  --accent-hover: #1a7bd4;
  --accent-dark: #215A8B;
  --text: #1f2044;
  --text-muted: #6c757d;
  --bg-light: #f8f9fa;
  --fds-hero-bg: #f5f3f2;
  /* Topo fixo: faixa promo + header (atualizado via JS em main.js) */
  --fds-promo-h: 0px;
  --fds-header-h: 88px;
}

* {
  box-sizing: border-box;
}

html {
  background: #ffffff;
  scroll-padding-top: calc(var(--fds-promo-h, 0px) + var(--fds-header-h, 88px));
}
body {
  font-family: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--text);
  background: #ffffff;
  line-height: 1.6;
  overflow-x: hidden;
  overflow-y: scroll;
}
body.fds-theme {
  padding-top: calc(var(--fds-promo-h, 0px) + var(--fds-header-h, 88px));
}

h1, h2, h3, h4, h5, h6, .lead, p, a, span, li, button, input {
  font-family: 'Poppins', sans-serif;
}

a {
  color: var(--accent);
  text-decoration: none;
  transition: color 0.2s;
}
a:hover {
  color: var(--accent-hover);
}

/* ===== Faixa promocional (topo, acima do header) ===== */
.fds-promo-bar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1001;
  width: 100%;
  font-size: 0.875rem;
  line-height: 1.3;
  text-align: center;
}
.fds-promo-bar .container-fluid {
  max-width: 100%;
  text-align: center;
}
.fds-promo-inner {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: center;
  gap: 0.65rem 1rem;
  width: 100%;
  box-sizing: border-box;
  padding: 0.35rem 0.75rem;
}
.fds-promo-text {
  flex: 0 1 auto;
  min-width: 0;
  max-width: calc(100% - 10.5rem);
  margin: 0;
  text-align: center !important;
  box-sizing: border-box;
}
.fds-promo-link {
  font-weight: 600;
}
.fds-promo-link:hover {
  opacity: 0.9;
}
.fds-promo-timer-box {
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  flex: 0 0 auto;
  gap: 0.35rem;
  padding: 0.22rem 0.6rem;
  border-radius: 4px;
  font-size: 0.8rem;
  font-weight: 400;
  white-space: nowrap;
}
.fds-promo-timer-box .fds-promo-n {
  font-size: 0.95rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.02em;
}
.fds-promo-timer-box .fds-promo-u {
  font-size: 0.68rem;
  font-weight: 600;
  line-height: 1;
  margin-left: 0.06rem;
  vertical-align: 0.12em;
  opacity: 1;
}
@media (max-width: 575.98px) {
  .fds-promo-inner {
    gap: 0.45rem 0.6rem;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }
  .fds-promo-text {
    max-width: calc(100% - 8.75rem);
    font-size: 0.8rem;
  }
  .fds-promo-timer-box {
    gap: 0.28rem;
    padding: 0.18rem 0.45rem;
    font-size: 0.72rem;
  }
  .fds-promo-timer-box .fds-promo-n {
    font-size: 0.85rem;
  }
  .fds-promo-timer-box .fds-promo-u {
    font-size: 0.62rem;
  }
}

/* ===== Header - visual clean estilo SaaS ===== */
.fds-header-bar {
  background: transparent;
  position: fixed;
  top: var(--fds-promo-h, 0px);
  left: 0;
  right: 0;
  width: 100%;
  z-index: 3000; /* garante sobreposição ao slider */
  padding: 0.55rem 0;
  overflow: visible;
}
@media (max-width: 767px) {
  /* Remove faixa clara no topo e mantém leve respiro */
  .fds-header-bar {
    padding-top: 0.2rem;
    padding-bottom: 0;
  }
  /* Mais padding interno no card do header */
  .fds-navbar {
    padding-top: 0.8rem;
    padding-bottom: 0.7rem;
    padding-left: 0.85rem;
    padding-right: 0.85rem;
  }
}
.fds-navbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.65rem 1rem;
  flex-wrap: wrap;
  background: #ffffff;
  border-radius: 12px;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.08);
  border: 1px solid #eef0f6;
  overflow: visible;
  /* Evita salto quando a fonte web carrega e o texto refaz o wrap */
  min-height: 3.25rem;
}
.fds-logo-link {
  display: flex;
  align-items: center;
  text-decoration: none;
  color: #1f2937;
  font-weight: 700;
  font-size: 1.2rem;
}
.fds-logo-link:hover { color: #111827; }
.fds-header-bar .fds-logo-img { filter: none; }
.fds-logo-img {
  max-height: 30px;
  width: auto;
  object-fit: contain;
}
.fds-header-bar .fds-logo-text { color: #1f2937; }
.fds-nav-center {
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
}
.fds-nav-menu {
  display: flex;
  align-items: center;
  gap: 0.5rem 1.5rem;
  list-style: none;
  margin: 0;
  padding: 0;
}
.fds-nav-menu li { position: relative; }
.fds-header-bar .fds-nav-menu a {
  color: #374151;
  text-decoration: none;
  font-size: 0.82rem;
  font-weight: 500;
  padding: 0.55rem 0.9rem;
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
  position: relative;
  border-radius: 8px;
  transition: color 0.2s, background-color 0.2s;
}
.fds-nav-menu .dropdown-toggle::after {
  display: none;
}
.fds-header-bar .fds-nav-menu a:hover {
  color: #111827;
  background: #f3f4f6;
}
.fds-nav-menu .dropdown.show > .dropdown-toggle {
  color: #111827;
  background: #f3f4f6;
}
.fds-nav-menu .dropdown-toggle .bi-chevron-down { font-size: 0.65rem; transition: transform 0.2s; }
.fds-nav-menu .dropdown.show .dropdown-toggle .bi-chevron-down { transform: rotate(180deg); }
.fds-nav-menu .dropdown-menu {
  border: none;
  box-shadow: 0 8px 24px rgba(0,0,0,0.12);
  border-radius: 8px;
  padding: 0.5rem 0;
}
.fds-header-bar .dropdown-menu {
  background: #ffffff;
  min-width: 220px;
  padding: 0.75rem 0;
  border-radius: 22px;
}
.fds-header-bar .dropdown-menu .dropdown-item {
  font-size: 0.92rem;
  font-weight: 500;
  color: #111827;
  padding-top: 0.55rem;
  padding-bottom: 0.55rem;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  transition: color 0.2s ease;
}
.fds-header-bar .dropdown-menu .dropdown-item:hover,
.fds-header-bar .dropdown-menu .dropdown-item:focus {
  background-color: #ffffff;
  color: var(--accent);
}

.fds-nav-badge {
  display: inline-block;
  padding: 0.05rem 0.4rem;
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 999px;
  background: #eef2ff;
  color: #4f46e5;
  position: absolute;
  right: 0.1rem;
  top: -0.55rem;
}
.fds-header-bar.header-scrolled .fds-nav-badge {
  background: rgba(0,48,185,0.08);
  color: #0030b9;
}
.fds-nav-store-link .fds-nav-store-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  font-size: 0.85rem;
  margin-right: 0.05rem;
}
.fds-nav-store-link .fds-nav-badge {
  position: static;
  right: auto;
  top: auto;
  margin-left: 0.35rem;
  padding: 0.12rem 0.42rem;
  font-size: 0.58rem;
  line-height: 1;
  background: var(--accent);
  color: #ffffff;
  letter-spacing: 0.06em;
}
.fds-header-bar.header-scrolled .fds-nav-store-link .fds-nav-badge {
  background: var(--accent);
  color: #ffffff;
}
.fds-nav-menu .dropdown-item { padding: 0.5rem 1rem; }
.fds-nav-menu .dropdown-item:hover,
.fds-nav-menu .dropdown-item:focus {
  background-color: #ffffff;
  color: var(--accent);
}
.fds-nav-icons {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}
.fds-nav-login-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  padding: 0 1rem;
  border-radius: 12px;
  border: 1px solid var(--accent, #2E93EE);
  background: var(--accent, #2E93EE);
  color: #ffffff;
  font-size: 0.82rem;
  font-weight: 600;
  text-decoration: none;
  transition: background-color 0.2s, border-color 0.2s, color 0.2s;
  white-space: nowrap;
}
.fds-nav-login-btn:hover {
  background: var(--accent-hover, #1a7bd4);
  border-color: var(--accent-hover, #1a7bd4);
  color: #ffffff;
}
.fds-nav-login-btn.dropdown-toggle::after {
  display: none;
}

/* Cliente logado no header (foto + nome + Sair) — compacto */
.fds-header-user {
  max-width: min(200px, 32vw);
  gap: 0.35rem !important;
}
.fds-header-user-profile {
  color: #111827;
  min-width: 0;
  max-width: 100%;
  border-radius: 8px;
  padding: 0.1rem 0.3rem 0.1rem 0.1rem;
  gap: 0.4rem !important;
}
.fds-header-user-profile:hover {
  background: transparent;
  color: inherit;
}
.fds-header-user-avatar {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  border: 1px solid rgba(15, 23, 42, 0.08);
}
.fds-header-user-avatar--placeholder {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #e5e7eb;
  color: #6b7280;
  font-size: 0.85rem;
}
.fds-header-user-name {
  font-size: 0.72rem;
  font-weight: 500;
  max-width: 92px;
  line-height: 1.2;
  color: #374151;
}
.fds-header-logout-btn {
  border-radius: 8px;
  font-size: 0.72rem;
  font-weight: 600;
  padding: 0.22rem 0.5rem;
  border: 1px solid #d1d5db;
  background: #fff;
  color: #4b5563;
  line-height: 1.2;
  white-space: nowrap;
}
.fds-header-logout-btn:hover {
  background: #f9fafb;
  border-color: #9ca3af;
  color: #111827;
}

.fds-mobile-user-banner {
  border-color: #eef0f6 !important;
  padding-bottom: 0.85rem !important;
  margin-bottom: 0.85rem !important;
}
.fds-mobile-user-banner .fw-semibold {
  font-size: 0.9rem;
}
.fds-mobile-user-banner .small {
  font-size: 0.78rem;
}
.fds-mobile-user-banner .btn {
  margin-top: 0.65rem !important;
  font-size: 0.8rem;
  padding: 0.3rem 0.65rem;
}
.fds-mobile-user-avatar {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid rgba(15, 23, 42, 0.08);
}
.fds-mobile-user-avatar--placeholder {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #e5e7eb;
  color: #6b7280;
  font-size: 1rem;
}

/* Dropdown do botão Entrar (desktop) */
.fds-login-dropdown {
  position: absolute !important; /* garante overlay, não entra no fluxo */
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.10);
  padding: 0.35rem 0;
  min-width: 420px;
  top: calc(100% + 18px);
  right: 0;
  left: auto;
  margin-top: 0;
  z-index: 4000;
}
.fds-login-dropdown::before {
  content: "";
  position: absolute;
  top: -10px;
  right: 34px;
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-bottom: 10px solid #ffffff;
  filter: drop-shadow(0 -1px 0 #e5e7eb);
}
.fds-login-item {
  display: flex !important;
  align-items: center;
  gap: 0.9rem;
  padding: 0.9rem 1.05rem !important;
}
.fds-login-item:hover,
.fds-login-item:focus {
  background: transparent !important;
}
.fds-login-ico {
  width: 30px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #111827;
  flex: 0 0 auto;
  opacity: 0.85;
  font-size: 1.1rem;
}
.fds-login-txt {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  min-width: 0;
  flex: 1 1 auto;
}
.fds-login-title {
  font-weight: 600;
  font-size: 0.9rem;
  line-height: 1.1;
  color: var(--accent, #2E93EE);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.fds-login-sub {
  font-size: 0.88rem;
  color: #6b7280;
  line-height: 1.15;
}
.fds-login-arrow {
  color: #6b7280;
  flex: 0 0 auto;
}

/* Modal login cliente */
.client-login-modal {
  border-radius: 16px;
  border: 1px solid #e5e7eb;
  overflow: hidden;
  background: #ffffff;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  box-shadow: 0 16px 44px rgba(15, 23, 42, 0.12);
}
.client-login-modal .modal-header {
  padding: 1.1rem 1.25rem 0.5rem;
}
.client-login-modal .modal-body {
  padding: 0.75rem 1.25rem 1.25rem;
}
.client-login-dialog.has-hero {
  max-width: 860px;
}
.client-login-layout {
  display: block;
}
.client-login-hero {
  display: none;
}
.client-login-hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.client-login-modal .modal-title {
  font-weight: 700;
  color: #111827;
}
.client-login-form .form-control {
  border-radius: 10px;
  padding: 0.75rem 0.9rem;
  border-color: #e5e7eb;
  background: #ffffff;
}
.client-input-wrap {
  position: relative;
}
.client-input-icon {
  position: absolute;
  left: 0.8rem;
  top: 50%;
  transform: translateY(-50%);
  color: #6b7280;
  font-size: 0.95rem;
  pointer-events: none;
}
.client-login-form .form-control.has-icon {
  padding-left: 2.35rem;
}
.client-login-form .form-control.has-toggle {
  padding-right: 2.5rem;
}
.client-input-toggle {
  position: absolute;
  right: 0.65rem;
  top: 50%;
  transform: translateY(-50%);
  border: 0;
  background: transparent;
  color: #6b7280;
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.client-input-toggle:hover {
  background: #f3f4f6;
  color: #374151;
}
.client-login-form .form-control:focus {
  border-color: var(--accent, #2E93EE);
  box-shadow: 0 0 0 4px rgba(46, 147, 238, 0.18);
}
.client-login-btn {
  border-radius: 12px;
  background: var(--accent, #2E93EE);
  border-color: var(--accent, #2E93EE);
  color: #fff;
  padding: 0.8rem 1rem;
  font-weight: 600;
}
.client-login-btn:hover {
  background: var(--accent-hover, #1a7bd4);
  border-color: var(--accent-hover, #1a7bd4);
  color: #fff;
}
.client-login-forgot {
  color: var(--accent, #2E93EE);
  text-decoration: none;
  font-size: 0.9rem;
}
.client-login-forgot:hover {
  text-decoration: underline;
}
@media (min-width: 992px) {
  .client-login-dialog.has-hero .client-login-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 407px;
    gap: 1rem;
    align-items: stretch;
  }
  .client-login-dialog.has-hero .client-login-form {
    padding-right: 0.35rem;
  }
  .client-login-dialog.has-hero .client-login-hero {
    display: block;
    border-radius: 14px;
    overflow: hidden;
    border: 1px solid #e5e7eb;
    background: #f8fafc;
    width: 407px;
    height: 251px;
    min-height: 251px;
  }
}

/* Backdrop acrílico do modal */
.modal-backdrop.show {
  opacity: 1;
  background: rgba(15, 23, 42, 0.20);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 6000;
}

/* Garantir modal acima do header (header tem z-index alto) */
.modal {
  z-index: 6010;
}
body.modal-open {
  overflow-y: scroll !important;
  padding-right: 0 !important;
}
.fds-header-bar .fds-nav-icon {
  color: #334155;
  font-size: 1.1rem;
  padding: 0.35rem;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: color 0.2s, background-color 0.2s;
  border-radius: 8px;
}
.fds-header-bar .fds-nav-icon:hover { color: #111827; background: #f8fafc; }
.fds-nav-icon {
  color: var(--text);
  font-size: 1.15rem;
  padding: 0.35rem;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: color 0.2s;
}
.fds-nav-icon:hover { color: var(--accent); }
.fds-header-bar .fds-nav-toggler {
  color: #334155;
}

/* Header ao rolar: mantém o mesmo visual */
.fds-header-bar.header-scrolled {
  background: transparent;
}
.fds-header-bar.header-scrolled .fds-logo-link,
.fds-header-bar.header-scrolled .fds-logo-link:hover {
  color: var(--accent);
}
.fds-header-bar.header-scrolled .fds-logo-img {
  filter: none;
}
.fds-header-bar.header-scrolled .fds-logo-text {
  color: var(--accent);
}
/* Só links do 1.º nível; não afeta .dropdown-item (hover usa --accent) */
.fds-header-bar.header-scrolled .fds-nav-menu > li > a,
.fds-header-bar.header-scrolled .fds-nav-menu > li > a:hover {
  color: #202145;
}
.fds-header-bar.header-scrolled .fds-nav-icon,
.fds-header-bar.header-scrolled .fds-nav-icon:hover {
  color: #202145;
}
.fds-header-bar.header-scrolled .fds-nav-toggler {
  color: #202145;
}

.fds-nav-toggler {
  display: none;
  background: none;
  border: none;
  font-size: 1.5rem;
  color: var(--text);
  padding: 0.35rem;
}

@media (min-width: 992px) {
  .fds-nav-center.collapse {
    display: flex !important;
    visibility: visible;
  }
}
@media (max-width: 991px) {
  .fds-nav-toggler {
    display: flex;
    margin-left: auto;
  }
  .fds-navbar {
    align-items: flex-start;
    border-radius: 10px;
    padding: 0.55rem 0.75rem;
  }
  .fds-nav-center {
    display: none !important;
    order: 3;
    width: 100%;
    flex-basis: 100%;
    justify-content: flex-start;
    overflow: hidden;
  }
  .fds-nav-center.collapsing {
    transition: height 0.2s ease-out;
  }
  .fds-nav-menu {
    flex-direction: column;
    align-items: stretch;
    padding: 1rem 0 0.5rem;
    gap: 0.25rem;
  }
  .fds-header-bar .fds-nav-menu a {
    justify-content: flex-start;
    padding: 0.55rem 0;
    font-size: 1rem;
  }
  .fds-nav-icons {
    display: inline-flex;
    gap: 0.12rem;
    align-self: center;
    margin-left: 0;
  }
  /* Mobile: mantém apenas o carrinho visível ao lado do hambúrguer */
  .fds-nav-icons > :not(.fds-cart-trigger) {
    display: none !important;
  }
}
/* Drawer mobile do menu principal */
.fds-mobile-menu {
  width: min(80vw, 320px) !important;
  border-right: 1px solid #e5e7eb;
  border-top-right-radius: 22px;
  border-bottom-right-radius: 22px;
  z-index: 4100;
}
.offcanvas-backdrop.show {
  z-index: 4090;
}
.fds-mobile-menu .offcanvas-header {
  border-bottom: 1px solid #eef0f6;
  padding: 0.95rem 1rem;
}
.fds-mobile-menu-head {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.fds-mobile-menu-logo {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}
.fds-mobile-menu-logo .fds-logo-img {
  max-height: 28px;
}
.fds-mobile-menu .offcanvas-title {
  font-size: 0.9rem;
  font-weight: 600;
  color: #6b7280;
  margin: 0;
}
.fds-mobile-menu .offcanvas-body {
  padding: 0.85rem 1rem 1.1rem;
  display: flex;
  flex-direction: column;
}
.fds-mobile-menu-nav {
  display: flex;
  flex-direction: column;
  gap: 0.95rem;
}
.fds-mobile-menu-section {
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
}
.fds-mobile-menu-section-toggle {
  width: 100%;
  border: 0;
  background: #f8fafc;
  color: #111827;
  font-weight: 600;
  font-size: 0.95rem;
  padding: 0.72rem 0.85rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.fds-mobile-menu-section-toggle .bi {
  transition: transform 0.2s ease;
}
.fds-mobile-menu-section-toggle[aria-expanded="true"] .bi {
  transform: rotate(180deg);
}
.fds-mobile-submenu,
.fds-mobile-main-links {
  list-style: none;
  margin: 0;
  padding: 0;
}
.fds-mobile-submenu li + li,
.fds-mobile-main-links li + li {
  border-top: 1px solid #f1f5f9;
}
.fds-mobile-submenu a,
.fds-mobile-main-links a {
  color: #1f2937;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.72rem 0.85rem;
  font-size: 0.95rem;
  font-weight: 500;
}
.fds-mobile-main-links {
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
}
.fds-mobile-main-links a .bi {
  color: #0032ba;
}
.fds-mobile-main-links .fds-mobile-main-cta {
  border-top: 0 !important;
  margin-top: 0.6rem;
}
.fds-mobile-main-links .fds-mobile-main-cta + .fds-mobile-main-cta {
  margin-top: 0.45rem;
}
.fds-mobile-main-links .fds-mobile-main-cta a {
  background: var(--accent, #2E93EE);
  color: #fff;
  border-radius: 10px;
  justify-content: center;
  font-weight: 600;
  box-shadow: 0 8px 18px rgba(46, 147, 238, 0.22);
}
.fds-mobile-main-links .fds-mobile-main-cta a .bi {
  color: #fff;
}
.fds-mobile-main-links .fds-mobile-main-cta a:hover {
  background: var(--accent-hover, #1a7bd4);
}
.fds-mobile-menu-social {
  margin-top: auto;
  padding-top: 1rem;
}
.fds-mobile-menu-social-title {
  display: block;
  font-size: 0.8rem;
  font-weight: 600;
  color: #64748b;
  margin-bottom: 0.55rem;
}
.fds-mobile-menu-social-links {
  display: flex;
  align-items: center;
  gap: 0.55rem;
}
.fds-mobile-menu-social-links a {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  color: #334155;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-size: 1rem;
}
.fds-mobile-menu-social-links a:hover {
  background: #eef2ff;
  color: #1d4ed8;
}
@media (min-width: 992px) {
  .fds-mobile-menu {
    display: none !important;
  }
}
/* Sobrescreve flex-start do breakpoint 991px: logo e hamburger centralizados na vertical */
@media (max-width: 767px) {
  .fds-navbar {
    align-items: center;
  }
}

/* ===== Main ===== */
/* Barra superior simples (Início | Grandes marcas) – fundo branco, aba azul */
.fds-top-strip {
  background: #ffffff;
  font-size: 0.85rem;
  color: #0032ba;
}
.fds-top-strip-nav {
  display: inline-flex;
  align-items: center;
  gap: 1.5rem;
  padding: 0.4rem 0 0;
  position: relative;
}
.fds-top-strip-nav a {
  position: relative;
  color: #0032ba;
  text-decoration: none;
  padding: 0.35rem 0.9rem;
  border-radius: 12px 12px 0 0;
}
.fds-top-strip-nav a.active {
  background-color: #0032ba;
  color: #ffffff;
  font-weight: 600;
}
.fds-top-strip-nav::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 0;
  background: transparent;
}

.fds-main {
  min-height: 60vh;
  background: transparent;
}

/* ===== Faixa: Inclusos em todos os planos ===== */
.fds-included-plans {
  background-color: var(--included-bg, #162736);
  padding: 0;
}
.fds-included-wrap {
  position: relative;
  background: transparent;
  border-radius: 0;
  overflow: hidden;
  display: grid;
  grid-template-columns: 220px 1fr;
  align-items: stretch;
  padding-block: 0.8rem;
}
.fds-included-title {
  position: relative;
  padding: 1.05rem 0.95rem;
  background: transparent;
  display: flex;
  align-items: center;
  overflow: visible;
  z-index: 1;
}
.fds-included-title::after {
  content: none;
}
.fds-included-title h3 {
  position: relative;
  z-index: 3;
  margin: 0;
  color: var(--included-title, #ffffff);
  font-size: 1.55rem;
  line-height: 0.95;
  font-weight: 600;
  letter-spacing: -0.01em;
}
.fds-included-items {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.fds-included-item {
  position: relative;
  padding: 0.95rem 0.95rem;
  color: #d9e6ef;
  min-height: 140px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.fds-included-item + .fds-included-item {
  border-left: 0;
  padding-left: 1.05rem;
}
.fds-included-item + .fds-included-item::before {
  content: "";
  position: absolute;
  left: -0.18rem;
  top: 50%;
  width: 2px;
  height: 30px;
  background: var(--included-divider, #8b5cf6);
  border-radius: 2px;
  transform: translateY(-50%) rotate(16deg);
  opacity: 0.95;
}
.fds-included-icon {
  width: 48px;
  height: 48px;
  border-radius: 8px;
  color: var(--included-icon, #28c7e8);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.85rem;
  margin: 0 auto 0.24rem;
}
.fds-included-icon--img {
  color: transparent;
}
.fds-included-icon--img img {
  max-width: 48px;
  max-height: 48px;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
}
.fds-included-item h4 {
  margin: 0 0 0.12rem;
  color: var(--included-item-title, #ffffff);
  font-size: 0.8rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.2;
}
.fds-included-item p {
  margin: 0;
  color: var(--included-item-text, #d5e3ef);
  font-size: 0.66rem;
  line-height: 1.2;
  text-align: center;
  max-width: 205px;
  margin-left: auto;
  margin-right: auto;
}

/* ===== Seção "Porque escolher" ===== */
.fds-why-section {
  background: #fafafa;
  padding: 6.6rem 0 5.8rem;
}
.fds-why-head {
  max-width: 860px;
  margin: 0 auto;
}
.fds-why-title {
  margin: 0 0 0.7rem;
  font-size: clamp(1.9rem, 3.9vw, 2.7rem);
  line-height: 1.04;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #0f172a;
}
.fds-why-title-secondary {
  margin-bottom: 1rem;
  font-family: Georgia, "Times New Roman", serif;
  font-style: italic;
  font-weight: 500;
  letter-spacing: -0.01em;
}
.fds-why-text {
  margin: 0 auto;
  max-width: 860px;
}
.fds-why-text p {
  margin: 0 0 1rem;
  font-size: 1.1rem;
  line-height: 1.65;
  color: #4b5563;
}
.fds-why-text p:last-child {
  margin-bottom: 0;
}
.fds-why-cta-wrap {
  margin-top: 1.8rem;
}
.fds-why-cta {
  height: 52px;
  padding: 0 1.25rem;
  border-radius: 10px;
  font-size: 1rem;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.fds-why-cta:hover {
  transform: translateY(-3px);
  box-shadow: none;
}
@media (max-width: 767px) {
  .fds-why-section {
    padding: 3.4rem 0 2.2rem;
  }
  .fds-why-head {
    max-width: 100%;
    background: #ffffff;
    border: 1px solid #eceff5;
    border-radius: 20px;
    box-shadow: 0 10px 26px rgba(15, 23, 42, 0.07);
    padding: 1.35rem 1rem 1.1rem;
  }
  .fds-why-title {
    font-size: clamp(1.9rem, 8.2vw, 2.2rem);
    line-height: 1.06;
    margin-bottom: 0.45rem;
    letter-spacing: -0.02em;
  }
  .fds-why-title-secondary {
    font-size: clamp(1.15rem, 7vw, 1.55rem);
    line-height: 1.12;
    margin-bottom: 1rem;
  }
  .fds-why-text {
    max-width: 100%;
  }
  .fds-why-text p {
    font-size: 1.02rem;
    line-height: 1.52;
    color: #334155;
    margin-bottom: 0.85rem;
  }
  .fds-why-text p + p {
    margin-top: 0.1rem;
  }
  .fds-why-cta-wrap {
    margin-top: 1.15rem;
  }
  .fds-why-cta {
    width: 100%;
    max-width: 320px;
    height: 50px;
    border-radius: 12px;
    font-size: 1.03rem;
    font-weight: 600;
    box-shadow: 0 10px 24px rgba(225, 7, 67, 0.25);
  }
}

/* ===== Loja de Templates ===== */
.templates-store-section {
  background: #ffffff;
}
.templates-store-title {
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--text);
}
.templates-store-subtitle {
  font-size: 0.95rem;
  color: var(--text-muted);
}
.templates-store-total {
  font-size: 0.92rem;
  color: #475569;
}
.templates-store-total strong {
  color: var(--accent);
  font-weight: 700;
}

.fds-modal-loja-templates-aviso {
  border-radius: 16px;
  overflow: hidden;
}
.fds-modal-loja-templates-aviso .modal-body {
  font-size: 0.98rem;
  line-height: 1.55;
  color: #334155;
}
.fds-modal-loja-templates-aviso .modal-title {
  color: #0f172a;
}
.fds-loja-templates-aviso-check .form-check-input {
  width: 1.1em;
  height: 1.1em;
  margin-top: 0.15rem;
}
.page-loja-templates .fds-loja-templates-aviso-bell {
  position: fixed;
  left: max(10px, env(safe-area-inset-left, 0px));
  bottom: max(14px, calc(env(safe-area-inset-bottom, 0px) + 10px));
  z-index: 1035;
  width: 52px;
  height: 52px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: linear-gradient(145deg, var(--accent, #e10743) 0%, #c10538 100%);
  color: #fff;
  font-size: 1.2rem;
  display: none;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow:
    0 4px 16px rgba(15, 23, 42, 0.22),
    0 0 0 1px rgba(255, 255, 255, 0.12) inset;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  animation: fds-loja-bell-float 3s ease-in-out infinite;
}
.page-loja-templates .fds-loja-templates-aviso-bell__ico {
  display: block;
  position: relative;
  z-index: 1;
  animation: fds-loja-bell-shake 2.8s ease-in-out infinite;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.15));
}
.page-loja-templates .fds-loja-templates-aviso-bell__ping {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  animation: fds-loja-bell-ping 2s cubic-bezier(0, 0, 0.2, 1) infinite;
}
.page-loja-templates .fds-loja-templates-aviso-bell__badge {
  position: absolute;
  top: 2px;
  right: 2px;
  z-index: 2;
  min-width: 1.125rem;
  height: 1.125rem;
  padding: 0 4px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.65rem;
  font-weight: 800;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  color: #fff;
  background: #dc2626;
  border: 2px solid #fff;
  border-radius: 999px;
  box-shadow: 0 2px 6px rgba(15, 23, 42, 0.25);
  animation: fds-loja-bell-badge-pulse 1.8s ease-in-out infinite;
}
.page-loja-templates .fds-loja-templates-aviso-bell:hover {
  transform: scale(1.04) translateY(-2px);
  box-shadow:
    0 8px 24px rgba(15, 23, 42, 0.28),
    0 0 0 1px rgba(255, 255, 255, 0.18) inset;
  color: #fff;
  animation: none;
}
.page-loja-templates .fds-loja-templates-aviso-bell:hover .fds-loja-templates-aviso-bell__ico {
  animation: none;
}
.page-loja-templates .fds-loja-templates-aviso-bell.is-visible {
  display: inline-flex;
}
@keyframes fds-loja-bell-float {
  0%, 100% {
    box-shadow:
      0 4px 16px rgba(15, 23, 42, 0.22),
      0 0 0 1px rgba(255, 255, 255, 0.12) inset,
      0 0 0 0 rgba(225, 7, 67, 0.35);
  }
  50% {
    box-shadow:
      0 6px 22px rgba(15, 23, 42, 0.26),
      0 0 0 1px rgba(255, 255, 255, 0.15) inset,
      0 0 22px 4px rgba(225, 7, 67, 0.2);
  }
}
@keyframes fds-loja-bell-shake {
  0%, 100% { transform: rotate(0deg); }
  12% { transform: rotate(14deg); }
  24% { transform: rotate(-12deg); }
  36% { transform: rotate(8deg); }
  48% { transform: rotate(-4deg); }
  60% { transform: rotate(0deg); }
}
@keyframes fds-loja-bell-ping {
  0% {
    box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.45);
    opacity: 1;
  }
  70% {
    box-shadow: 0 0 0 14px rgba(255, 255, 255, 0);
    opacity: 0.6;
  }
  100% {
    box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
    opacity: 0;
  }
}
@keyframes fds-loja-bell-badge-pulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.12); opacity: 0.95; }
}
@media (max-width: 575px) {
  .page-loja-templates .fds-loja-templates-aviso-bell {
    bottom: max(12px, calc(env(safe-area-inset-bottom, 0px) + 8px));
    left: max(8px, env(safe-area-inset-left, 0px));
    width: 48px;
    height: 48px;
    font-size: 1.05rem;
  }
  .page-loja-templates .fds-loja-templates-aviso-bell__badge {
    font-size: 0.6rem;
    min-width: 1rem;
    height: 1rem;
    padding: 0 3px;
  }
}

/* Banner tipo loja-templates (também em Fale Conosco) */
.templates-hero {
  background: var(--fds-hero-bg);
  color: #0f172a;
  padding: 50px 0 50px;
}

/* Hero com fundo por trás da barra de navegação */
.page-loja-templates .templates-hero,
.page-fale-conosco .templates-hero,
.page-wp-care .templates-hero,
.page-sistemas-web .templates-hero,
.page-mapa-do-site .templates-hero,
.page-portfolio .templates-hero,
.page-legal-institucional .templates-hero,
.page-hospedagem-sites .templates-hero,
.page-central-de-ajuda .templates-hero,
.page-registro-dominio .rd-hero {
  margin-top: calc(-1 * (var(--fds-promo-h, 0px) + var(--fds-header-h, 88px)));
  padding-top: calc(var(--fds-promo-h, 0px) + var(--fds-header-h, 88px) + 40px);
  padding-bottom: 48px;
  position: relative;
  z-index: 0;
  background: #ffffff;
  color: #1e293b;
  overflow: hidden;
}

/* Criação de sites — hero: cor principal do tema, texto e CTAs à esquerda */
.page-criacao-de-sites .templates-hero {
  margin-top: calc(-1 * (var(--fds-promo-h, 0px) + var(--fds-header-h, 88px)));
  padding-top: calc(var(--fds-promo-h, 0px) + var(--fds-header-h, 88px) + 40px);
  padding-bottom: 48px;
  position: relative;
  z-index: 2;
  background: var(--accent, #2e93ee);
  color: #ffffff;
  overflow: hidden;
}
.page-criacao-de-sites .templates-hero .templates-hero-badge {
  color: rgba(255, 255, 255, 0.95);
  border-color: rgba(255, 255, 255, 0.4);
  background: rgba(255, 255, 255, 0.12);
}
.page-criacao-de-sites .templates-hero .templates-hero-title {
  text-align: left;
  color: #ffffff;
}
.page-criacao-de-sites .templates-hero .templates-hero-subtitle {
  text-align: left;
  color: rgba(255, 255, 255, 0.92);
  margin-left: 0;
  margin-right: 0;
  max-width: 38rem;
}
.page-criacao-de-sites .templates-hero .templates-hero-subtitle strong {
  color: #ffffff;
  font-weight: 700;
}
.page-criacao-de-sites .templates-hero .wp-care-hero-btn--primary {
  background: #ffffff;
  border-color: #ffffff;
  color: var(--accent, #2e93ee);
}
.page-criacao-de-sites .templates-hero .wp-care-hero-btn--primary:hover {
  background: rgba(255, 255, 255, 0.92);
  border-color: #ffffff;
  color: var(--accent-hover, #1a7bd4);
}
.page-criacao-de-sites .templates-hero .wp-care-hero-btn--outline {
  background: transparent;
  border-color: rgba(255, 255, 255, 0.85);
  color: #ffffff;
}
.page-criacao-de-sites .templates-hero .wp-care-hero-btn--outline:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: #ffffff;
  color: #ffffff;
}

/* Criação de sites — hero: WordPress + PHP sobrepostos (tom claro, efeito mesclado) */
.page-criacao-de-sites .cds-hero-stack {
  width: 100%;
  max-width: 420px;
}
/* Faixa de tecnologias — grelha estática, logos cinza, tamanho único */
.page-criacao-de-sites .cds-tech-strip-full {
  position: relative;
  z-index: 1;
  margin-top: 0;
  padding: 1.35rem 0 1.5rem;
  /* Igual ao bloco .fds-portfolio-safari (portfólio) */
  background: #fafafa;
  border-bottom: none;
  overflow: hidden;
}
.page-criacao-de-sites .cds-tech-logos-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 1rem 1.25rem;
  align-items: center;
  justify-items: center;
  max-width: 920px;
  margin-left: auto;
  margin-right: auto;
}
.page-criacao-de-sites .cds-tech-logo-cell {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 56px;
}
.page-criacao-de-sites .cds-tech-logo-img {
  width: 48px;
  height: 48px;
  max-width: 48px;
  max-height: 48px;
  object-fit: contain;
  object-position: center;
  filter: grayscale(100%) brightness(0.3) contrast(0.9);
  opacity: 0.62;
}
.page-criacao-de-sites .cds-tech-logo-img[alt="WooCommerce"] {
  width: 98px;
  height: 98px;
  max-width: 98px;
  max-height: 98px;
}
.page-criacao-de-sites .cds-tech-logo-img[alt="JavaScript"] {
  width: 38px;
  height: 38px;
  max-width: 38px;
  max-height: 38px;
}
.page-criacao-de-sites .cds-tech-logo-img[alt="WordPress"] {
  width: 40px;
  height: 40px;
  max-width: 40px;
  max-height: 40px;
}
@media (max-width: 767px) {
  .page-criacao-de-sites .cds-tech-logos-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
  }
}
@media (max-width: 399px) {
  .page-criacao-de-sites .cds-tech-logos-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
.page-criacao-de-sites .cds-hero-stack-inner {
  position: relative;
  width: 100%;
  isolation: isolate;
}
.page-criacao-de-sites .cds-hero-stack-inner::before {
  content: "";
  position: absolute;
  left: 5%;
  right: -5%;
  top: 10%;
  bottom: 10%;
  background: radial-gradient(ellipse 90% 80% at 55% 50%, rgba(255, 255, 255, 0.18) 0%, transparent 68%);
  z-index: 0;
  pointer-events: none;
}
.page-criacao-de-sites .cds-hero-orbit-wrap {
  position: relative;
  width: 100%;
  min-height: 320px;
}
.page-criacao-de-sites .cds-hero-browser-center {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 5;
  pointer-events: none;
}
.page-criacao-de-sites .cds-hero-browser {
  position: relative;
  width: clamp(132px, 36vw, 168px);
  border-radius: 10px;
  overflow: hidden;
  background: rgba(15, 23, 42, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.35);
  box-shadow:
    0 12px 28px rgba(0, 0, 0, 0.28),
    0 0 0 1px rgba(255, 255, 255, 0.08) inset;
}
.page-criacao-de-sites .cds-hero-browser-chrome {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  background: rgba(255, 255, 255, 0.14);
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}
.page-criacao-de-sites .cds-hero-browser-dots {
  display: inline-flex;
  gap: 4px;
  flex-shrink: 0;
}
.page-criacao-de-sites .cds-hero-browser-dots i {
  display: block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.45);
}
.page-criacao-de-sites .cds-hero-browser-dots i:nth-child(1) {
  background: #fb7185;
}
.page-criacao-de-sites .cds-hero-browser-dots i:nth-child(2) {
  background: #fbbf24;
}
.page-criacao-de-sites .cds-hero-browser-dots i:nth-child(3) {
  background: #34d399;
}
.page-criacao-de-sites .cds-hero-browser-url {
  flex: 1;
  height: 14px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.2);
  border: 1px solid rgba(255, 255, 255, 0.12);
}
.page-criacao-de-sites .cds-hero-browser-viewport {
  position: relative;
  min-height: 72px;
  padding: 10px 10px 14px;
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.12) 0%, rgba(255, 255, 255, 0.04) 100%);
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.page-criacao-de-sites .cds-hero-browser-line {
  display: block;
  height: 5px;
  border-radius: 3px;
  background: rgba(255, 255, 255, 0.28);
  width: 100%;
}
.page-criacao-de-sites .cds-hero-browser-line--mid {
  width: 78%;
  opacity: 0.85;
}
.page-criacao-de-sites .cds-hero-browser-line--short {
  width: 52%;
  opacity: 0.7;
}
.page-criacao-de-sites .cds-hero-browser-cursor {
  position: absolute;
  right: 12%;
  bottom: 14%;
  font-size: 1.35rem;
  line-height: 1;
  color: #ffffff;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.4));
  animation: cds-hero-cursor-tap 1.85s ease-in-out infinite;
}
.page-criacao-de-sites .cds-hero-orbit {
  position: absolute;
  inset: 50% auto auto 50%;
  width: min(300px, 80%);
  aspect-ratio: 1 / 1;
  transform: translate(-50%, -50%);
  z-index: 2;
  animation: cds-hero-orbit-spin 16s linear infinite;
}
.page-criacao-de-sites .cds-hero-orbit-ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 2px dashed rgba(255, 255, 255, 0.5);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.16) inset;
}
.page-criacao-de-sites .cds-hero-orbit-item {
  position: absolute;
  width: 52px;
  height: 52px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.18);
  border: 1px solid rgba(255, 255, 255, 0.35);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}
.page-criacao-de-sites .cds-hero-orbit-item img {
  width: 30px;
  height: 30px;
  object-fit: contain;
  filter: brightness(0) invert(1);
  opacity: 0.98;
  animation: cds-hero-orbit-counter 16s linear infinite;
}
.page-criacao-de-sites .cds-hero-orbit-item--top {
  left: 50%;
  top: -10px;
  transform: translateX(-50%);
}
.page-criacao-de-sites .cds-hero-orbit-item--right {
  right: -10px;
  top: 50%;
  transform: translateY(-50%);
}
.page-criacao-de-sites .cds-hero-orbit-item--bottom {
  left: 50%;
  bottom: -10px;
  transform: translateX(-50%);
}
.page-criacao-de-sites .cds-hero-orbit-item--left {
  left: -10px;
  top: 50%;
  transform: translateY(-50%);
}
@keyframes cds-hero-orbit-spin {
  from { transform: translate(-50%, -50%) rotate(0deg); }
  to { transform: translate(-50%, -50%) rotate(360deg); }
}
@keyframes cds-hero-orbit-counter {
  from { transform: rotate(0deg); }
  to { transform: rotate(-360deg); }
}
@keyframes cds-hero-cursor-tap {
  0%,
  100% {
    transform: translate(0, 0) scale(1);
  }
  42% {
    transform: translate(-3px, 2px) scale(0.94);
  }
  52% {
    transform: translate(-1px, 0) scale(1);
  }
}
@media (prefers-reduced-motion: reduce) {
  .page-criacao-de-sites .cds-hero-orbit,
  .page-criacao-de-sites .cds-hero-orbit-item img {
    animation: none !important;
  }
  .page-criacao-de-sites .cds-hero-browser-cursor {
    animation: none !important;
  }
}
@media (min-width: 992px) {
  .page-criacao-de-sites .cds-hero-stack {
    max-width: 420px;
  }
  .page-criacao-de-sites .cds-hero-orbit-wrap {
    min-height: 320px;
  }
}

.page-registro-dominio .rd-hero-globe-bg {
  position: absolute;
  z-index: 0;
  right: max(-4rem, -8vw);
  top: 42%;
  transform: translateY(-50%);
  pointer-events: none;
  line-height: 1;
  color: #94a3b8;
  opacity: 0.22;
  font-size: clamp(11rem, 32vw, 22rem);
}
.page-registro-dominio .rd-hero-globe-bg i {
  display: block;
}
.page-registro-dominio .rd-hero-main {
  position: relative;
  z-index: 1;
}
@media (max-width: 767px) {
  .page-registro-dominio .rd-hero-globe-bg {
    right: -18vw;
    top: 28%;
    opacity: 0.14;
    font-size: clamp(7rem, 58vw, 13rem);
  }
}
.rd-hero-kicker {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #475569;
  margin-bottom: 0.75rem;
}
.rd-hero-title {
  font-size: clamp(1.65rem, 4vw, 2.35rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.2;
  max-width: 42rem;
  margin-bottom: 0.65rem;
  text-align: left;
}
.rd-hero-title-muted {
  color: #0f172a;
}
.rd-hero-title-accent {
  color: #e11d74;
  display: inline;
}
.rd-hero-lead {
  font-size: 1rem;
  color: #475569;
  margin-bottom: 1.35rem;
  max-width: 36rem;
}
.rd-hero-card {
  max-width: 920px;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  padding: 1rem 1.15rem 1.15rem;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
}
.rd-hero-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1rem;
}
.rd-hero-tab {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  border: none;
  border-radius: 999px;
  padding: 0.5rem 1rem;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
  background: #f1f5f9;
  color: #334155;
}
.rd-hero-tab:hover {
  background: #e2e8f0;
  color: #0f172a;
}
.rd-hero-tab.is-active {
  background: #334155;
  color: #fff;
}
.rd-hero-tab.is-active i {
  color: inherit;
}
.rd-hero-form {
  margin: 0;
}
.rd-hero-search {
  display: flex;
  align-items: stretch;
  width: 100%;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
}
.rd-hero-search-field {
  display: flex;
  align-items: center;
  flex: 1;
  min-width: 0;
}
.rd-hero-search-ico {
  display: flex;
  align-items: center;
  padding-left: 0.9rem;
  color: #94a3b8;
  font-size: 1.1rem;
  flex-shrink: 0;
}
.rd-hero-search-input {
  flex: 1;
  min-width: 0;
  border: none;
  outline: none;
  padding: 0.75rem 0.75rem 0.75rem 0.35rem;
  font-size: 1rem;
  color: #0f172a;
}
.rd-hero-search-input::placeholder {
  color: #94a3b8;
}
.rd-hero-search-submit {
  flex-shrink: 0;
  border: none;
  padding: 0 1.35rem;
  font-weight: 600;
  font-size: 0.95rem;
  color: #fff;
  background: #e11d74;
  cursor: pointer;
  transition: background 0.2s, filter 0.2s;
}
.rd-hero-search-submit:hover {
  background: #c91663;
  color: #fff;
}
.rd-hero-prices {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: flex-start;
  gap: 0;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid #f1f5f9;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.rd-hero-price-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 5.5rem;
  padding: 0.35rem 0.65rem;
  text-align: center;
  font-size: 0.8rem;
  color: #64748b;
  border-right: 1px solid #e2e8f0;
}
.rd-hero-price-item:last-child {
  border-right: none;
}
.rd-hero-price-item strong {
  display: block;
  font-size: 0.88rem;
  font-weight: 700;
  color: #0f172a;
  margin-bottom: 0.15rem;
}
.rd-hero-panel--ia {
  padding-top: 0.25rem;
}
.rd-hero-ia-text {
  font-size: 0.95rem;
  color: #64748b;
  margin: 0;
  max-width: 36rem;
}
.rd-hero-ia-btn {
  border-radius: 10px;
  font-weight: 600;
  padding: 0.5rem 1.1rem;
  font-size: 0.9rem;
  background: #e11d74;
  border: 1px solid #e11d74;
  color: #fff;
}
.rd-hero-ia-btn:hover {
  background: #c91663;
  border-color: #c91663;
  color: #fff;
}
.rd-hero-ia-btn--outline {
  background: #fff;
  border-color: #e2e8f0;
  color: #334155;
}
.rd-hero-ia-btn--outline:hover {
  border-color: #e11d74;
  color: #e11d74;
  background: #fff;
}
.rd-hero-links a {
  color: #64748b;
}
.rd-hero-links a:hover {
  color: #e11d74;
}
.rd-hero-links-sep {
  margin: 0 0.35rem;
  color: #cbd5e1;
}

/* Resultados da busca — registro de domínio (destaques + outras opções) */
.page-registro-dominio-resultados {
  scroll-margin-top: calc(var(--fds-header-h, 88px) + 12px);
}
.rd-result-spinner {
  color: #0f766e;
  border-color: rgba(13, 148, 136, 0.25);
  border-right-color: #0d9488;
}
.rd-result-layout {
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
}
.rd-result-card {
  height: 100%;
  border-radius: 14px;
  border: 1px solid #e2e8f0;
  background: #fff;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.rd-result-card-head {
  font-size: 0.82rem;
  font-weight: 600;
  padding: 0.55rem 1rem;
  display: flex;
  align-items: center;
  gap: 0.35rem;
}
.rd-result-card--exact .rd-result-card-head {
  background: linear-gradient(180deg, #e0f2fe 0%, #dbeafe 100%);
  color: #0369a1;
}
.rd-result-card--bundle .rd-result-card-head {
  background: linear-gradient(180deg, #fef3c7 0%, #fde68a 100%);
  color: #92400e;
}
.rd-result-card-body {
  padding: 1.1rem 1.15rem 1.15rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.rd-result-domain {
  font-size: 1.15rem;
  font-weight: 700;
  color: #0d9488;
  word-break: break-word;
  margin-bottom: 0.5rem;
}
.rd-result-preco {
  font-size: 1.1rem;
  color: #0f172a;
  margin-bottom: 0.25rem;
}
.rd-result-preco-suf {
  font-size: 0.85rem;
  font-weight: 500;
  color: #64748b;
}
.rd-result-disclaimer {
  font-size: 0.72rem;
  color: #94a3b8;
  margin-bottom: 0.65rem;
}
.rd-result-status--ok {
  color: #0f766e;
}
.rd-result-status--no {
  color: #b91c1c;
}
.rd-result-actions {
  margin-top: auto;
  padding-top: 0.5rem;
}
.rd-result-btn-reg {
  border-radius: 10px;
  font-weight: 600;
  padding: 0.55rem 1.25rem;
  border: 2px solid #0d9488;
  background: #fff;
  color: #0d9488;
}
.rd-result-btn-reg:hover:not(:disabled) {
  background: #f0fdfa;
  color: #0f766e;
  border-color: #0f766e;
}
.rd-result-btn-reg:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.rd-result-btn-pacote {
  border-radius: 10px;
  font-weight: 600;
  padding: 0.6rem 1.2rem;
  background: #0d9488;
  border: 1px solid #0d9488;
  color: #fff;
  width: 100%;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  transition: background 0.2s, border-color 0.2s;
}
.rd-result-btn-pacote:hover {
  background: #0f766e;
  border-color: #0f766e;
  color: #fff;
}
.rd-result-bundle-lead {
  font-size: 0.92rem;
  color: #334155;
  line-height: 1.45;
}
.rd-result-foot {
  color: #94a3b8;
  line-height: 1.4;
}
.rd-result-outras-wrap {
  border-top: 1px solid #f1f5f9;
  padding-top: 1.25rem;
  margin-top: 0.25rem;
}
.rd-result-outras-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: #0f172a;
  margin-bottom: 0.75rem;
}
.rd-result-outras-list {
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
}
.rd-result-outras-item {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.85rem 1rem;
  border-bottom: 1px solid #f1f5f9;
}
.rd-result-outras-item:last-child {
  border-bottom: none;
}
.rd-result-outras-name {
  font-weight: 600;
  color: #0d9488;
  word-break: break-word;
  min-width: 0;
  flex: 1 1 200px;
}
.rd-result-outras-meta {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-shrink: 0;
}
.rd-result-outras-preco {
  font-size: 0.95rem;
  font-weight: 600;
  color: #0f172a;
  white-space: nowrap;
}
.rd-result-btn-reg-outline {
  border-radius: 10px;
  font-weight: 600;
  padding: 0.4rem 0.9rem;
  border: 2px solid #0d9488;
  background: #fff;
  color: #0d9488;
  font-size: 0.85rem;
}
.rd-result-btn-reg-outline:hover:not(:disabled) {
  background: #f0fdfa;
  color: #0f766e;
}
.rd-result-btn-reg-outline:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

@media (max-width: 575px) {
  .rd-hero-prices {
    flex-wrap: nowrap;
    justify-content: flex-start;
  }
  .rd-hero-price-item {
    flex: 0 0 auto;
  }
  .rd-hero-search {
    flex-direction: column;
    align-items: stretch;
  }
  .rd-hero-search-field {
    border-bottom: 1px solid #e2e8f0;
  }
  .rd-hero-search-submit {
    width: 100%;
    border-radius: 0;
    padding: 0.75rem 1rem;
  }
}
.templates-hero-badge {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #334155;
  padding: 0.2rem 0.9rem;
  border-radius: 999px;
  border: 1px solid #cbd5e1;
  margin-bottom: 0.9rem;
}
.templates-hero-title {
  font-size: 2.4rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  text-align: center;
}
.templates-hero-subtitle {
  font-size: 1rem;
  color: #334155;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}
.templates-hero-cta {
  margin-top: 1.2rem;
  display: flex;
  justify-content: center;
}
.templates-hero-whatsapp {
  border-radius: 999px;
  background: #ffffff;
  border: none;
  color: #0030b9;
  font-size: 0.9rem;
  font-weight: 600;
  padding: 0.9rem 1.6rem;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  box-shadow: 0 6px 18px rgba(15,23,42,0.3);
}
.templates-hero-whatsapp i {
  font-size: 1.1rem;
}
.templates-hero-whatsapp:hover {
  background: #e5edff;
  color: #001a72;
}

.templates-hero-search-wrap {
  margin-top: 1.35rem;
  display: flex;
  justify-content: center;
}
.templates-hero-search {
  width: min(760px, 100%);
  position: relative;
  background: #ffffff;
  border: 1px solid #dbe2ec;
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
  display: flex;
  align-items: center;
  padding: 0.3rem 0.3rem 0.3rem 2.7rem;
}
.templates-hero-search-ico {
  position: absolute;
  left: 1rem;
  color: #64748b;
  font-size: 1rem;
}
.templates-hero-search-input {
  flex: 1 1 auto;
  min-width: 0;
  border: 0;
  outline: 0;
  background: transparent;
  color: #0f172a;
  font-size: 1rem;
  padding: 0.58rem 0.45rem;
}
.templates-hero-search-input::placeholder {
  color: #94a3b8;
}
.templates-hero-search-btn {
  border: 0;
  background: var(--accent);
  color: #ffffff;
  border-radius: 12px;
  font-weight: 600;
  font-size: 0.95rem;
  padding: 0.62rem 1.15rem;
  min-width: 114px;
  transition: background-color 0.2s ease, transform 0.2s ease;
}
.templates-hero-search-btn:hover {
  background: var(--accent-hover);
  transform: translateY(-1px);
}
@media (max-width: 575px) {
  .templates-hero-title {
    font-size: 2rem;
  }
  .templates-hero-search {
    padding: 0.25rem 0.25rem 0.25rem 2.35rem;
    border-radius: 12px;
    display: flex;
    align-items: center;
    gap: 0.35rem;
  }
  .templates-hero-search-ico {
    position: absolute;
    left: 0.78rem;
    top: 50%;
    transform: translateY(-50%);
    margin: 0;
  }
  .templates-hero-search-input {
    flex: 1 1 auto;
    padding: 0.45rem 0.35rem;
    font-size: 0.95rem;
  }
  .templates-hero-search-btn {
    margin: 0;
    min-width: 98px;
    padding: 0.54rem 0.85rem;
    font-size: 0.92rem;
  }
}

.templates-sidebar {
  border-radius: 18px;
  padding: 1.1rem 1rem 0.95rem;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border: 1px solid rgba(var(--bs-primary-rgb, 46, 147, 238), 0.2);
  box-shadow: 0 10px 24px rgba(var(--bs-primary-rgb, 46, 147, 238), 0.1);
}
.templates-sidebar-title {
  font-size: 0.95rem;
  font-weight: 700;
  color: #0f172a;
  margin-bottom: 0.65rem;
}
.templates-sidebar-subtitle {
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent);
  margin-bottom: 0.6rem;
}
.templates-filter-pill {
  display: flex;
  align-items: center;
  gap: 0.52rem;
  width: 100%;
  text-align: left;
  font-size: 0.92rem;
  font-weight: 500;
  padding: 0.52rem 0.8rem;
  border-radius: 12px;
  border: 1px solid transparent;
  background: rgba(var(--bs-primary-rgb, 46, 147, 238), 0.06);
  color: #334155;
  margin-bottom: 0.45rem;
  cursor: pointer;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.templates-filter-pill .bi {
  font-size: 0.95rem;
  line-height: 1;
  color: #64748b;
}
.templates-filter-pill:hover {
  background: rgba(var(--bs-primary-rgb, 46, 147, 238), 0.13);
  border-color: rgba(var(--bs-primary-rgb, 46, 147, 238), 0.22);
  color: var(--accent-hover);
}
.templates-filter-pill.active {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.templates-filter-pill.active .bi {
  color: #fff;
}
.templates-sidebar-highlight {
  margin-top: 1rem;
  padding: 0.78rem 0.9rem;
  border-radius: 14px;
  background: rgba(var(--bs-primary-rgb, 46, 147, 238), 0.1);
  border: 1px dashed rgba(var(--bs-primary-rgb, 46, 147, 238), 0.45);
  font-size: 0.85rem;
  color: #1e293b;
  position: relative;
  overflow: hidden;
}
.templates-download-widget {
  margin-bottom: 0.7rem;
}
.templates-download-widget-top {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  color: #0f172a;
  margin-bottom: 0.4rem;
}
.templates-download-widget-top .bi {
  font-size: 1rem;
  color: #15803d;
  animation: templates-download-icon-bob 1.6s ease-in-out infinite;
}
.templates-download-bar-track {
  position: relative;
  height: 9px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(22, 163, 74, 0.35);
  overflow: hidden;
  box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.06);
}
.templates-download-bar-fill {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 38%;
  border-radius: inherit;
  background: linear-gradient(90deg, #15803d 0%, #22c55e 40%, #4ade80 75%, #16a34a 100%);
  background-size: 200% 100%;
  animation:
    templates-download-fill-loop 2.1s ease-in-out infinite,
    templates-download-bar-hue 3.5s linear infinite;
  box-shadow: 0 0 14px rgba(34, 197, 94, 0.45);
}
.templates-download-bar-shimmer {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    105deg,
    transparent 0%,
    rgba(255, 255, 255, 0.1) 40%,
    rgba(255, 255, 255, 0.65) 50%,
    rgba(255, 255, 255, 0.1) 60%,
    transparent 100%
  );
  background-size: 200% 100%;
  animation: templates-download-shimmer-slide 1.6s linear infinite;
  pointer-events: none;
}
.templates-sidebar-highlight strong {
  display: block;
  font-weight: 600;
  margin-bottom: 0.15rem;
}
.templates-sidebar-highlight > span {
  display: block;
  line-height: 1.4;
}
@keyframes templates-download-fill-loop {
  0%,
  100% {
    width: 32%;
  }
  50% {
    width: 100%;
  }
}
@keyframes templates-download-bar-hue {
  0% {
    background-position: 0% 50%;
  }
  100% {
    background-position: 200% 50%;
  }
}
@keyframes templates-download-shimmer-slide {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}
@keyframes templates-download-icon-bob {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(2px);
  }
}

.templates-sidebar-cta {
  margin-top: 1rem;
  padding: 0.95rem 1rem;
  border-radius: 14px;
  background: #ffffff;
  border: 1px solid rgba(var(--bs-primary-rgb, 46, 147, 238), 0.22);
  color: #0f172a;
  box-shadow: 0 8px 22px rgba(var(--bs-primary-rgb, 46, 147, 238), 0.08);
}
.templates-sidebar-cta h3 {
  font-size: 0.98rem;
  font-weight: 600;
  margin-bottom: 0.35rem;
  color: #111827;
}
.templates-sidebar-cta p {
  font-size: 0.85rem;
  margin-bottom: 0.6rem;
}
.templates-sidebar-cta-link {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
}
.templates-sidebar-cta-link i {
  font-size: 1rem;
}
.templates-sidebar-cta-link:hover {
  color: var(--accent-hover);
  text-decoration: underline;
}
.templates-pagination .page-link {
  border-radius: 999px !important;
  border: 1px solid #dbe5f1;
  background: #ffffff;
  color: #475569;
  padding: 0.4rem 0.9rem;
  font-size: 0.9rem;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
.templates-pagination .page-link:hover {
  background: rgba(var(--bs-primary-rgb, 46, 147, 238), 0.08);
  border-color: rgba(var(--bs-primary-rgb, 46, 147, 238), 0.3);
  color: var(--accent);
}
.templates-pagination .page-item.active .page-link {
  background-color: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.templates-pagination .page-item.disabled .page-link {
  opacity: 0.5;
}
.template-card {
  background: #fff;
  border: 1px solid #e8edf4;
  border-radius: 20px;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.06);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.template-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 18px 36px rgba(15, 23, 42, 0.13);
}
.template-card-thumb {
  position: relative;
  background: #f8fafc;
  padding-top: 68%;
  overflow: hidden;
}
.template-card-promo-badge {
  position: absolute;
  top: 0.6rem;
  left: 0.6rem;
  z-index: 2;
  display: inline-block;
  background: var(--accent, #2E93EE);
  color: #ffffff;
  padding: 0.2rem 0.72rem;
  border-radius: 100px;
  font-size: 0.78rem;
  font-weight: 600;
  font-size: 0.75rem;
  letter-spacing: 0.02em;
}
.template-card-promo-badge::after {
  content: " 🔥";
  display: inline-block;
  animation: promoFirePulse 1s ease-in-out infinite;
  transform-origin: center;
}
@keyframes promoFirePulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.18); }
}
.template-card-thumb img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.35s ease;
}
.template-card:hover .template-card-thumb img {
  transform: scale(1.02);
}
.template-card-thumb-placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #e5e7eb;
  color: #9ca3af;
  font-size: 2rem;
}
.template-card-body {
  padding: 1.05rem 1.05rem 1.1rem;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}
.template-card-title {
  font-size: 1.02rem;
  line-height: 1.3;
  font-weight: 700;
  margin: 0;
  color: #172554;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.template-card-meta {
  font-size: 0.84rem;
  color: #64748b !important;
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem 0.4rem;
}
.template-card-cat {
  display: inline-flex;
  align-items: center;
  gap: 0.32rem;
  padding: 0;
  border: 0;
  background: transparent;
  color: #64748b;
}
.template-card-cat .bi {
  font-size: 0.84rem;
  color: var(--accent);
}
.template-card-delivery {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  width: fit-content;
  margin-top: -0.1rem;
  margin-bottom: 0.2rem;
  padding: 0.2rem 0.55rem;
  border-radius: 999px;
  background: rgba(var(--bs-primary-rgb, 46, 147, 238), 0.1);
  border: 1px solid rgba(var(--bs-primary-rgb, 46, 147, 238), 0.2);
  color: #1e293b;
  font-size: 0.76rem;
  font-weight: 600;
}
.template-card-delivery .bi {
  font-size: 0.78rem;
  color: var(--accent);
}

/* ===== Fale Conosco ===== */
.contact-hero {
  background: #0030b9;
  color: #fff;
}
.contact-hero-wrap {
  padding: 2.6rem 0 2.1rem;
}
.contact-hero-title {
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: -0.02em;
}
.contact-hero-subtitle {
  font-size: 1rem;
  color: rgba(255,255,255,0.9);
  max-width: 620px;
}
.contact-section {
  background: #ffffff;
}
.contact-card {
  background: #fff;
  border-radius: 20px;
  padding: 2.25rem 2.25rem 2rem;
  box-shadow: 0 12px 40px rgba(15, 23, 42, 0.08);
  border: 1px solid #eef0f6;
}
.contact-card .form-label {
  font-size: 0.95rem;
  font-weight: 500;
  color: #374151;
  margin-bottom: 0.4rem;
}
.contact-input {
  border-radius: 12px;
  background: #f9fafb;
  border: 1px solid #e5e7eb;
  font-size: 1rem;
  min-height: 52px;
  padding: 0.75rem 1.25rem;
}
.contact-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-light, rgba(46, 147, 238, 0.2));
  background: #ffffff;
  outline: none;
}
.contact-input[rows] {
  border-radius: 12px;
  min-height: 140px;
  padding: 1rem 1.25rem;
}
.contact-submit-btn {
  border-radius: 12px;
  background: var(--accent);
  border: 1px solid var(--accent);
  font-weight: 600;
  color: #ffffff;
  padding: 0.8rem 1.6rem;
  box-shadow: 0 8px 20px var(--accent-light-2, rgba(46, 147, 238, 0.2));
  transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease;
}
.contact-submit-btn:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
  box-shadow: 0 12px 28px var(--accent-light-2, rgba(46, 147, 238, 0.28));
  transform: translateY(-1px);
  color: #ffffff;
}
.contact-info-card {
  background: #ffffff;
  border-radius: 18px;
  padding: 1.5rem 1.75rem;
  border: 1px solid #e5e7eb;
}
.contact-info-title {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}
.contact-info-text {
  font-size: 0.9rem;
  color: #6b7280;
}
.contact-info-list li {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.9rem;
  color: #374151;
  margin-bottom: 0.4rem;
}
.contact-info-list i {
  color: var(--accent);
}
.contact-info-note {
  margin-top: 1.25rem;
  padding: 1.1rem 1.1rem;
  border-radius: 12px;
  background: var(--fds-hero-bg);
  font-size: 0.85rem;
  color: #374151;
  border: 1px solid #e8e4e0;
}
.contact-info-note h3 {
  font-size: 1rem;
  font-weight: 600;
  color: #111827;
}
.contact-note-links {
  margin: 0;
  padding: 0;
  list-style: none;
}
.contact-note-links li + li {
  margin-top: 0.2rem;
}
.contact-note-links a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.35rem;
  font-size: 0.84rem;
  color: #1f2937;
  padding: 0.35rem 0.6rem;
  border-radius: 12px;
  text-decoration: none;
  transition: background-color 0.18s ease, color 0.18s ease, transform 0.15s ease;
}
.contact-note-links a i {
  font-size: 0.9rem;
  color: var(--accent);
}
.contact-note-links a:hover {
  background-color: var(--accent-light, rgba(46, 147, 238, 0.12));
  color: var(--accent);
  transform: translateY(-0.5px);
}
.contact-client-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  margin-top: 0.75rem;
  border-radius: 12px;
  background: var(--accent);
  border: 1px solid var(--accent);
  color: #ffffff;
  font-size: 0.9rem;
  font-weight: 600;
  padding: 0.65rem 1.35rem;
  text-decoration: none;
  box-shadow: 0 6px 18px var(--accent-light-2, rgba(46, 147, 238, 0.25));
  transition: background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease, color 0.2s ease;
}
.contact-client-btn:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
  color: #ffffff;
  box-shadow: 0 8px 24px var(--accent-light-2, rgba(46, 147, 238, 0.35));
  transform: translateY(-1px);
}

/* ===== WP Care (landing) ===== */
.wp-care-hero-btn {
  border-radius: 12px;
  font-weight: 600;
  padding: 0.65rem 1.35rem;
  font-size: 0.95rem;
  transition: background 0.2s, color 0.2s, border-color 0.2s, transform 0.15s;
}
.wp-care-hero-btn--primary {
  background: var(--accent);
  border: 1px solid var(--accent);
  color: #fff;
}
.wp-care-hero-btn--primary:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
  color: #fff;
  transform: translateY(-1px);
}
.wp-care-hero-btn--outline {
  background: #fff;
  border: 1px solid #e5e7eb;
  color: #334155;
}
.wp-care-hero-btn--outline:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: #fff;
}
.wp-care-hero-btn--light {
  background: #fff;
  border: 1px solid #fff;
  color: var(--accent);
}
.wp-care-hero-btn--light:hover {
  background: rgba(255, 255, 255, 0.92);
  color: var(--accent-hover);
  border-color: #fff;
}
.wp-care-section--muted {
  background: #f8fafc;
}
.wp-care-section--hero-bg {
  background: var(--fds-hero-bg);
}
/* Faixa de tecnologias (WP Care) — visual premium */
.wp-care-tech-strip {
  position: relative;
  padding: 3.25rem 0 3.75rem;
  background: #ffffff;
  border-bottom: 1px solid #eef0f6;
  overflow: hidden;
}
@media (min-width: 992px) {
  .wp-care-tech-strip {
    padding: 4rem 0 4.5rem;
  }
}
.wp-care-tech-head {
  position: relative;
  max-width: 38rem;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 2.25rem;
}
@media (min-width: 768px) {
  .wp-care-tech-head {
    margin-bottom: 2.75rem;
  }
}
.wp-care-tech-kicker {
  position: relative;
  display: inline-block;
  padding-bottom: 0.85rem;
  margin-bottom: 0.35rem;
}
.wp-care-tech-kicker::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: min(120px, 40vw);
  height: 2px;
  border-radius: 2px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  opacity: 0.9;
}
.wp-care-tech-title {
  font-size: clamp(1.5rem, 4vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: #0a0f1a;
  line-height: 1.2;
  margin: 0 0 1rem;
}
.wp-care-tech-lead {
  font-size: 0.98rem;
  line-height: 1.65;
  color: #64748b;
  max-width: 32rem;
  margin-bottom: 0;
  font-weight: 400;
}
.wp-care-tech-panel {
  position: relative;
  max-width: 1040px;
  margin-left: auto;
  margin-right: auto;
  padding: 1.5rem 1rem 1.75rem;
  border-radius: 24px;
  background: #ffffff;
  border: 1px solid #eef0f6;
  box-shadow: 0 24px 48px -28px rgba(15, 23, 42, 0.08);
}
@media (min-width: 768px) {
  .wp-care-tech-panel {
    padding: 2rem 1.75rem 2.25rem;
  }
}
.wp-care-tech-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}
@media (min-width: 576px) {
  .wp-care-tech-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
  }
}
@media (min-width: 992px) {
  .wp-care-tech-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 1.1rem;
  }
}
/* Sistemas Web: 6 tecnologias na grelha (desktop) */
.page-sistemas-web .wp-care-tech-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
@media (min-width: 576px) {
  .page-sistemas-web .wp-care-tech-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (min-width: 992px) {
  .page-sistemas-web .wp-care-tech-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 1rem;
  }
}

/* Sistemas Web — timeline vertical (metodologia) */
.page-sistemas-web .sw-methodology .sw-timeline {
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}
.page-sistemas-web .sw-timeline-item {
  display: flex;
  align-items: stretch;
  gap: 1rem;
  list-style: none;
}
@media (min-width: 576px) {
  .page-sistemas-web .sw-timeline-item {
    gap: 1.35rem;
  }
}
.page-sistemas-web .sw-timeline-item + .sw-timeline-item {
  margin-top: 0.25rem;
}
.page-sistemas-web .sw-timeline-track {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 52px;
  flex-shrink: 0;
}
@keyframes sw-timeline-dot-breathe {
  0%,
  100% {
    box-shadow:
      0 1px 0 rgba(255, 255, 255, 0.18) inset,
      0 6px 18px rgba(49, 65, 79, 0.35),
      0 0 0 0 rgba(49, 65, 79, 0.4);
    transform: scale(1);
  }
  50% {
    box-shadow:
      0 1px 0 rgba(255, 255, 255, 0.22) inset,
      0 8px 22px rgba(49, 65, 79, 0.45),
      0 0 0 10px rgba(49, 65, 79, 0);
    transform: scale(1.02);
  }
}
@keyframes sw-timeline-connector-flow {
  0% {
    background-position: 0% 0%;
  }
  100% {
    background-position: 0% 200%;
  }
}
.page-sistemas-web .sw-timeline-dot {
  position: relative;
  z-index: 1;
  overflow: visible;
  width: 52px;
  height: 52px;
  border-radius: 14px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.28rem;
  color: #fff;
  background: #31414f;
  border: 1px solid rgba(255, 255, 255, 0.18);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.18) inset,
    0 6px 18px rgba(49, 65, 79, 0.35);
  transition: transform 0.35s cubic-bezier(0.34, 1.3, 0.64, 1);
  animation: sw-timeline-dot-breathe 2.6s ease-in-out infinite;
}
.page-sistemas-web .sw-timeline-item:nth-child(1) .sw-timeline-dot {
  animation-delay: 0s;
}
.page-sistemas-web .sw-timeline-item:nth-child(2) .sw-timeline-dot {
  animation-delay: 0.35s;
}
.page-sistemas-web .sw-timeline-item:nth-child(3) .sw-timeline-dot {
  animation-delay: 0.7s;
}
.page-sistemas-web .sw-timeline-item:nth-child(4) .sw-timeline-dot {
  animation-delay: 1.05s;
}
.page-sistemas-web .sw-timeline-dot i {
  position: relative;
  z-index: 2;
  transition: transform 0.35s cubic-bezier(0.34, 1.3, 0.64, 1);
  filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.12));
}
.page-sistemas-web .sw-timeline-item:hover .sw-timeline-dot {
  animation-play-state: paused;
  transform: scale(1.08) rotate(-2deg);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.28) inset,
    0 10px 28px rgba(49, 65, 79, 0.5),
    0 0 0 4px rgba(49, 65, 79, 0.22);
}
.page-sistemas-web .sw-timeline-item:hover .sw-timeline-dot i {
  transform: scale(1.12);
}
.page-sistemas-web .sw-timeline-connector {
  flex: 1 1 auto;
  width: 3px;
  min-height: 1.25rem;
  margin-top: 0.4rem;
  border-radius: 3px;
  background: linear-gradient(
    180deg,
    #31414f 0%,
    rgba(49, 65, 79, 0.5) 28%,
    rgba(49, 65, 79, 0.12) 62%,
    #e2e8f0 100%
  );
  background-size: 100% 220%;
  animation: sw-timeline-connector-flow 4s linear infinite;
}
@media (prefers-reduced-motion: reduce) {
  .page-sistemas-web .sw-timeline-dot,
  .page-sistemas-web .sw-timeline-connector {
    animation: none !important;
  }
  .page-sistemas-web .sw-timeline-dot {
    box-shadow:
      0 1px 0 rgba(255, 255, 255, 0.18) inset,
      0 6px 18px rgba(49, 65, 79, 0.32);
  }
  .page-sistemas-web .sw-timeline-item:hover .sw-timeline-dot {
    transform: none;
  }
  .page-sistemas-web .sw-timeline-item:hover .sw-timeline-dot i {
    transform: none;
  }
}
.page-sistemas-web .sw-timeline-item:last-child .sw-timeline-connector {
  display: none;
}
.page-sistemas-web .sw-timeline-card {
  flex: 1;
  min-width: 0;
  background: #fff;
  border: 1px solid #eef0f6;
  border-radius: 16px;
  padding: 1.15rem 1.2rem 1.25rem;
  margin-bottom: 1.35rem;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
  transition:
    border-color 0.25s ease,
    box-shadow 0.25s ease,
    transform 0.25s ease;
}
.page-sistemas-web .sw-timeline-item:last-child .sw-timeline-card {
  margin-bottom: 0;
}
.page-sistemas-web .sw-timeline-item:hover .sw-timeline-card {
  border-color: rgba(49, 65, 79, 0.22);
  box-shadow: 0 12px 32px rgba(15, 23, 42, 0.08);
  transform: translateY(-2px);
}
.page-sistemas-web .sw-timeline-step {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #31414f;
  margin-bottom: 0.35rem;
}
.page-sistemas-web .sw-timeline-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: #0f172a;
  margin-bottom: 0.45rem;
  line-height: 1.25;
}
.page-sistemas-web .sw-timeline-text {
  font-size: 0.9rem;
  color: #64748b;
  line-height: 1.55;
}

/* Registro de domínio — busca rápida (inline) */
.page-registro-dominio .rd-busca-inline {
  max-width: 520px;
}
.page-registro-dominio .rd-busca-inline-group {
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid #e2e8f0;
}
.page-registro-dominio .rd-busca-inline-group .form-control:focus {
  box-shadow: none;
  border-color: #e2e8f0;
}
.page-registro-dominio .rd-busca-www {
  font-weight: 600;
  color: #64748b;
  border-color: #e2e8f0 !important;
}
.wp-care-tech-item {
  list-style: none;
  min-height: 100%;
}
.wp-care-tech-card {
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 1.35rem 0.85rem 1.2rem;
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  border: 1px solid rgba(226, 232, 240, 0.9);
  box-shadow: 0 2px 4px rgba(15, 23, 42, 0.03);
  transition:
    transform 0.4s cubic-bezier(0.34, 1.3, 0.64, 1),
    box-shadow 0.35s ease,
    border-color 0.3s ease,
    background 0.3s ease;
}
.wp-care-tech-card:hover {
  transform: translateY(-6px);
  border-color: rgba(46, 147, 238, 0.28);
  background: linear-gradient(180deg, #ffffff 0%, #f0f7ff 100%);
  box-shadow:
    0 20px 40px -16px rgba(15, 23, 42, 0.14),
    0 0 0 1px rgba(46, 147, 238, 0.1);
}
.wp-care-tech-ico-wrap {
  width: 80px;
  height: 80px;
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.95rem;
  background: linear-gradient(145deg, #ffffff 0%, #f1f5f9 100%);
  border: 1px solid rgba(226, 232, 240, 0.95);
  box-shadow: 0 8px 20px -10px rgba(15, 23, 42, 0.15);
  transition: box-shadow 0.35s ease, transform 0.35s cubic-bezier(0.34, 1.3, 0.64, 1);
}
.wp-care-tech-card:hover .wp-care-tech-ico-wrap {
  transform: scale(1.04);
  box-shadow: 0 12px 28px -8px rgba(46, 147, 238, 0.25);
}
.wp-care-tech-ico-img {
  width: 44px;
  height: 44px;
  object-fit: contain;
}
/* JetEngine: Bootstrap Icons (mesma stack do admin — bi bi-*) */
.wp-care-tech-ico-wrap--bi {
  display: flex;
  align-items: center;
  justify-content: center;
}
.wp-care-tech-bi {
  font-size: 2.35rem;
  line-height: 1;
  color: #616cc1;
  display: block;
}
.wp-care-tech-card:hover .wp-care-tech-bi {
  color: var(--accent);
}
.wp-care-tech-name {
  display: block;
  font-size: 0.94rem;
  font-weight: 700;
  color: #0f172a;
  letter-spacing: -0.02em;
  line-height: 1.25;
  margin-bottom: 0.35rem;
}
.wp-care-tech-tag {
  display: block;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #94a3b8;
  line-height: 1.3;
}
.wp-care-tech-card:hover .wp-care-tech-tag {
  color: var(--accent);
}

/* Hospedagem — faixa de tecnologias sem borda inferior */
.page-hospedagem-sites .wp-care-tech-strip {
  border-bottom: none;
}

/* Hospedagem — faixa de logos em scroll infinito */
.page-hospedagem-sites .hs-logo-marquee-box {
  margin-top: 0;
  border: none;
  border-radius: 12px;
  background: transparent;
  padding: 1.15rem 0;
  overflow: hidden;
}
.page-hospedagem-sites .hs-logo-marquee {
  overflow: hidden;
}
.page-hospedagem-sites .hs-logo-marquee-track {
  display: flex;
  width: max-content;
  align-items: center;
  gap: clamp(1.75rem, 4vw, 2.85rem);
  padding: 0 0.5rem;
  animation: hs-logo-marquee-x 48s linear infinite;
  will-change: transform;
}
@keyframes hs-logo-marquee-x {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
@media (prefers-reduced-motion: reduce) {
  .page-hospedagem-sites .hs-logo-marquee-track {
    animation: none;
  }
}
.page-hospedagem-sites .hs-logo-marquee-item {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
}
.page-hospedagem-sites .hs-logo-marquee-img {
  height: 38px;
  width: auto;
  max-width: 118px;
  object-fit: contain;
  opacity: 0.92;
}
.page-hospedagem-sites .hs-logo-marquee-text {
  font-size: 1.12rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  color: #64748b;
  white-space: nowrap;
  line-height: 1;
}

/* Hospedagem — bloco de estatísticas de performance */
.page-hospedagem-sites .hs-perf-section {
  border-top: none;
}
.page-hospedagem-sites .hs-perf-title {
  font-size: clamp(1.35rem, 3.5vw, 1.85rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #1d2144;
  line-height: 1.25;
  max-width: 52rem;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 0.65rem;
}
.page-hospedagem-sites .hs-perf-subtitle {
  font-size: 1rem;
  color: #64748b;
  font-weight: 500;
  max-width: 36rem;
  margin-left: auto;
  margin-right: auto;
}
.page-hospedagem-sites .hs-perf-card {
  background: #fff;
  border: 1px solid #e8ecf4;
  border-radius: 16px;
  padding: 1.5rem 1.15rem 1.6rem;
  box-shadow: 0 4px 20px rgba(15, 23, 42, 0.04);
  transition:
    box-shadow 0.25s ease,
    border-color 0.25s ease;
}
.page-hospedagem-sites .hs-perf-card:hover {
  border-color: rgba(var(--bs-primary-rgb, 46, 147, 238), 0.25);
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.07);
}
.page-hospedagem-sites .hs-perf-card-ico-wrap {
  display: flex;
  justify-content: center;
  margin-bottom: 1rem;
}
.page-hospedagem-sites .hs-perf-card-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 12px;
  font-size: 1.45rem;
  color: #ffffff;
  background: #31414f;
  box-shadow: none;
}
.page-hospedagem-sites .hs-perf-card-stat {
  font-size: clamp(2rem, 4vw, 2.35rem);
  font-weight: 800;
  line-height: 1.1;
  color: var(--accent, #2e93ee);
  margin-bottom: 0.65rem;
  letter-spacing: -0.03em;
}
.page-hospedagem-sites .hs-perf-card-text {
  font-size: 0.9rem;
  line-height: 1.55;
  color: #5c6378;
}
.page-hospedagem-sites .hs-perf-footnote {
  font-size: 0.72rem;
  line-height: 1.55;
  color: #94a3b8;
  max-width: 56rem;
  margin-left: auto;
  margin-right: auto;
}

/* Fundo em diagonal (hero → branco), estilo “tilt” entre secções */
.wp-care-section--split-diagonal {
  position: relative;
  background: #ffffff;
  overflow: hidden;
}
.wp-care-section--split-diagonal::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  background: var(--fds-hero-bg);
  clip-path: polygon(0 0, 100% 0, 100% 42%, 0 100%);
  z-index: 0;
  pointer-events: none;
}
.wp-care-section--split-diagonal > .container {
  position: relative;
  z-index: 1;
}
@media (min-width: 992px) {
  .wp-care-section--split-diagonal::before {
    clip-path: polygon(0 0, 100% 0, 100% 36%, 0 92%);
  }
}

/* Hospedagem — evita friso horizontal no topo da secção Segmentos (junção hero-bg → split-diagonal) */
.page-hospedagem-sites .wp-care-section--hero-bg {
  border-bottom: none;
  box-shadow: none;
}
.page-hospedagem-sites .wp-care-section--split-diagonal {
  margin-top: -1px;
  border-top: none;
  box-shadow: none;
}
.page-hospedagem-sites .wp-care-section--split-diagonal::before {
  top: -1px;
  bottom: auto;
  height: calc(100% + 2px);
}

.wp-care-kicker {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
}
.wp-care-h2 {
  font-size: 1.65rem;
  font-weight: 700;
  color: #0f172a;
  letter-spacing: -0.02em;
}
@media (min-width: 768px) {
  .wp-care-h2 {
    font-size: 1.85rem;
  }
}
.wp-care-lead {
  font-size: 1rem;
  color: #475569;
  line-height: 1.65;
}
.wp-care-narrow {
  max-width: 640px;
}
.wp-care-media {
  margin: 0 auto;
  max-width: min(520px, 96%);
}
.wp-care-media-img {
  display: block;
  width: 100%;
  height: auto;
}
.wp-care-visual {
  min-height: 220px;
  background: linear-gradient(145deg, var(--accent-light, rgba(46, 147, 238, 0.12)), #fff);
  border: 1px solid #e5e7eb;
}
.wp-care-visual--alt {
  background: linear-gradient(145deg, #fff, var(--accent-light, rgba(46, 147, 238, 0.1)));
}
.wp-care-visual-ico {
  font-size: 4.5rem;
  color: var(--accent);
  opacity: 0.85;
}

/* Assistência em todo o ciclo — monitor WordPress (visual refinado) */
.wp-care-cycle-row {
  --bs-gutter-x: 0.5rem;
  --bs-gutter-y: 1rem;
}
@media (min-width: 992px) {
  .wp-care-cycle-row {
    --bs-gutter-x: 0.65rem;
  }
}
.wp-care-monitor-wrap {
  width: 100%;
  max-width: min(400px, 100%);
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 992px) {
  .wp-care-monitor-wrap {
    margin-left: auto;
    margin-right: 0;
  }
}
.wp-care-monitor {
  position: relative;
  min-height: 240px;
  padding: 0.75rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.wp-care-monitor__card {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 360px;
  border-radius: 14px;
  background: #ffffff;
  border: 1px solid #eef1f4;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04), 0 16px 40px -20px rgba(15, 23, 42, 0.1);
  overflow: hidden;
}
.wp-care-monitor__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.65rem;
  padding: 0.65rem 0.9rem;
  border-bottom: 1px solid #f4f6f8;
  background: #fafbfc;
}
.wp-care-monitor__status {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #7c8794;
}
.wp-care-monitor__dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #8eb8a8;
  box-shadow: 0 0 0 0 rgba(142, 184, 168, 0.35);
  animation: wp-care-dot-pulse 2.8s ease-out infinite;
}
.wp-care-monitor__chip {
  font-size: 0.62rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: #6b7785;
  padding: 0.2rem 0.5rem;
  border-radius: 999px;
  background: #f1f3f5;
  border: 1px solid #e8ecf0;
}
.wp-care-monitor__main {
  display: flex;
  align-items: center;
  gap: 0.95rem;
  padding: 1rem 0.9rem 0.95rem;
}
.wp-care-monitor__wp-ico {
  flex-shrink: 0;
  width: 58px;
  height: 58px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f6f7f9;
  border: 1px solid #eceff2;
  box-shadow: none;
  animation: wp-care-wp-float 5s ease-in-out infinite;
}
.wp-care-monitor__wp-ico i {
  font-size: 1.85rem;
  color: #6d7a88;
  line-height: 1;
}
.wp-care-monitor__side {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}
.wp-care-monitor__metric-label {
  display: block;
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #a8b2bd;
  margin-bottom: 0.1rem;
}
.wp-care-monitor__metric-value {
  display: flex;
  align-items: baseline;
  gap: 0.08rem;
  font-variant-numeric: tabular-nums;
}
.wp-care-monitor__metric-num {
  font-size: 1.2rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: #4a5562;
}
.wp-care-monitor__metric-suffix {
  font-size: 0.82rem;
  font-weight: 500;
  color: #8e9aa8;
}
.wp-care-monitor__chart {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 5px;
  height: 34px;
  padding-top: 0.15rem;
}
.wp-care-monitor__chart span {
  flex: 0 0 5px;
  width: 5px;
  min-width: 5px;
  height: 100%;
  border-radius: 3px;
  transform-origin: bottom center;
  transform: scaleY(0.42);
  opacity: 0.88;
  animation: wp-care-bar 2.4s ease-in-out infinite;
}
/* Tons desaturados: sage e cinza-azulado */
.wp-care-monitor__chart span:nth-child(odd) {
  background: linear-gradient(180deg, #c5d4ce 0%, #9eafa8 100%);
}
.wp-care-monitor__chart span:nth-child(even) {
  background: linear-gradient(180deg, #c5ccd4 0%, #9aa3ae 100%);
}
.wp-care-monitor__chart span:nth-child(1) {
  animation-delay: 0s;
}
.wp-care-monitor__chart span:nth-child(2) {
  animation-delay: 0.15s;
}
.wp-care-monitor__chart span:nth-child(3) {
  animation-delay: 0.3s;
}
.wp-care-monitor__chart span:nth-child(4) {
  animation-delay: 0.45s;
}
.wp-care-monitor__chart span:nth-child(5) {
  animation-delay: 0.6s;
}
.wp-care-monitor__chart span:nth-child(6) {
  animation-delay: 0.75s;
}
.wp-care-monitor__chart span:nth-child(7) {
  animation-delay: 0.9s;
}
.wp-care-monitor__chart span:nth-child(8) {
  animation-delay: 1.05s;
}
.wp-care-monitor__footer {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.55rem 0.9rem 0.65rem;
  font-size: 0.68rem;
  font-weight: 500;
  color: #8e9aa8;
  border-top: 1px solid #f4f6f8;
  background: #fcfcfd;
}
.wp-care-monitor__footer i {
  color: #8eb8a8;
  font-size: 0.88rem;
  flex-shrink: 0;
  opacity: 0.95;
}

@keyframes wp-care-dot-pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(142, 184, 168, 0.25);
  }
  70% {
    box-shadow: 0 0 0 7px rgba(142, 184, 168, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(142, 184, 168, 0);
  }
}
@keyframes wp-care-wp-float {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-2px);
  }
}
@keyframes wp-care-bar {
  0%,
  100% {
    transform: scaleY(0.35);
    opacity: 0.55;
  }
  50% {
    transform: scaleY(1);
    opacity: 0.92;
  }
}

@media (prefers-reduced-motion: reduce) {
  .wp-care-monitor__dot,
  .wp-care-monitor__wp-ico,
  .wp-care-monitor__chart span {
    animation: none !important;
  }
  .wp-care-monitor__dot {
    box-shadow: none;
  }
  .wp-care-monitor__chart span {
    opacity: 0.85;
    transform: scaleY(0.65);
  }
}

.wp-care-cta-btn {
  border-radius: 12px;
  background: var(--accent);
  border: 1px solid var(--accent);
  color: #fff;
  font-weight: 600;
  padding: 0.65rem 1.25rem;
}
.wp-care-cta-btn:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
  color: #fff;
}
.wp-care-feature {
  background: #fff;
  border: 1px solid #eef0f6;
  border-radius: 16px;
  padding: 1.35rem 1.25rem;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
}
.wp-care-feature-ico {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background: rgba(49, 65, 79, 0.08);
  color: #31414f;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.35rem;
  margin-bottom: 0.85rem;
}
.wp-care-feature-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: #0f172a;
  margin-bottom: 0.45rem;
}
.wp-care-feature-text {
  font-size: 0.9rem;
  color: #64748b;
  line-height: 1.5;
}
.wp-care-stat {
  padding: 1rem 0.5rem;
}
.wp-care-stat-value {
  display: block;
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--accent);
  letter-spacing: -0.02em;
}
.wp-care-stat-label {
  display: block;
  font-size: 0.78rem;
  color: #64748b;
  margin-top: 0.25rem;
  line-height: 1.35;
}
.template-card-price {
  display: flex;
  flex-direction: column;
  gap: 0.18rem;
  min-height: 92px; /* garante alinhamento entre cards com/sem promoção */
}
.template-card-promo-badge {
  display: inline-block;
  background: rgba(31, 32, 68, 0.9);
  color: #fff;
  padding: 0.2rem 0.5rem;
  border-radius: 6px;
  font-weight: 600;
  font-size: 0.75rem;
  letter-spacing: 0.02em;
  width: fit-content;
}
.template-card-price-de {
  font-size: 0.86rem;
  color: #94a3b8;
  text-decoration: line-through;
}
.template-card-price-por {
  font-size: 0.92rem;
  font-weight: 500;
  line-height: 1.2;
  color: #334155;
}
.template-card-price-por b,
.template-card-price-por strong {
  font-size: 1.48rem;
  font-weight: 700;
  color: var(--accent, #2E93EE);
}
.template-card-price-por.is-label-only {
  font-size: 0.92rem;
  font-weight: 500;
  line-height: 1.1;
  color: #334155;
}
.template-card-price-valor {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.1;
  color: var(--accent, #2E93EE);
}
.template-card-desconto {
  display: inline-flex;
  width: fit-content;
  margin-top: 0.1rem;
  padding: 0.14rem 0.55rem;
  border-radius: 999px;
  background: rgba(22, 163, 74, 0.12);
  color: #15803d;
  font-weight: 600;
  font-size: 0.78rem;
  letter-spacing: 0.01em;
}
.template-card-price-de.is-placeholder,
.template-card-desconto.is-placeholder {
  visibility: hidden;
}
.template-card-actions {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  margin-top: 0.35rem;
}
.template-btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  min-height: 42px;
  padding: 0.42rem 0.95rem;
  font-size: 0.88rem;
  border: 1px solid #cbd5e1;
  background: #ffffff;
  color: #334155;
  font-weight: 500;
}
.template-btn-outline:hover {
  background: #f8fafc;
  color: #1e293b;
  border-color: #94a3b8;
}
.template-btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  min-height: 42px;
  padding: 0.45rem 1.05rem;
  font-size: 0.9rem;
  font-weight: 600;
  background: #31414f;
  border-color: #31414f;
  color: #fff;
}
.template-btn-primary:hover {
  background: #263540;
  border-color: #263540;
  color: #fff;
}
.template-btn-label-mobile {
  display: none;
}
.template-btn-add-cart {
  width: 36px;
  height: 36px;
  padding: 0 !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: none;
  background: transparent;
  color: #64748b;
  font-size: 1.1rem;
}
.template-btn-add-cart:hover {
  background: transparent;
  color: #0030b9 !important;
}

/* Página do produto */
.product-page-section {
  background: #ffffff;
}
/* Mobile: título → bloco mídia (demo + imagem) → card → descrição → compartilhar */
.product-page-layout {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.product-page-block--side {
  display: contents;
}
.product-page-block--media {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.product-page-block--title {
  order: 1;
}
.product-page-block--media {
  order: 2;
}
.product-page-block--card {
  order: 3;
}
.product-page-block--desc {
  order: 4;
}
.product-page-block--share {
  order: 5;
}
.product-page-block--title .product-page-cats {
  margin-top: 0.35rem;
}
@media (min-width: 992px) {
  .product-page-layout {
    display: grid;
    grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
    gap: 1.5rem;
    align-items: start;
    grid-template-areas:
      "media side"
      "desc side"
      "share side";
  }
  .product-page-block--side {
    grid-area: side;
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }
  .product-page-block--media {
    grid-area: media;
    order: 0;
  }
  .product-page-block--desc {
    grid-area: desc;
    order: 0;
  }
  .product-page-block--share {
    grid-area: share;
    order: 0;
  }
  .product-page-block--title,
  .product-page-block--card {
    order: 0;
  }
}
.product-page-thumb {
  position: relative;
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 14px 40px rgba(15,23,42,0.09);
  overflow: hidden;
}
.product-page-promo-badge {
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 2;
  background: rgba(31, 32, 68, 0.92);
  color: #fff;
  padding: 0.35rem 0.75rem;
  border-radius: 6px;
  font-weight: 600;
  font-size: 0.85rem;
  letter-spacing: 0.02em;
}
.product-page-thumb img {
  width: 100%;
  display: block;
}
.product-demo-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  padding: 0.52rem 1.15rem;
  border-radius: 12px;
  border: 1px solid #cbd5e1;
  background: #ffffff;
  font-size: 0.92rem;
  font-weight: 600;
  color: #334155;
  text-decoration: none;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}
.product-demo-pill i {
  font-size: 1rem;
  color: var(--accent);
}
.product-demo-pill:hover {
  background: rgba(var(--bs-primary-rgb, 46, 147, 238), 0.08);
  border-color: rgba(var(--bs-primary-rgb, 46, 147, 238), 0.35);
  color: var(--accent-hover);
  text-decoration: none;
  box-shadow: 0 6px 16px rgba(var(--bs-primary-rgb, 46, 147, 238), 0.12);
}
.product-demo-pill:hover i {
  color: var(--accent-hover);
}
.product-page-thumb-placeholder {
  min-height: 260px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #e5e7eb;
  color: #9ca3af;
  font-size: 3rem;
}
.product-page-info {
  background: transparent;
}
.product-page-title {
  font-size: 1.9rem;
  font-weight: 700;
  color: var(--text);
}
.product-page-desc {
  font-size: 16px;
  color: #374151;
  text-align: justify;
}
.product-page-share {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.product-page-share-label {
  font-size: 0.9rem;
  font-weight: 600;
  color: #374151;
  margin-right: 0.25rem;
}
.product-page-share-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  color: #fff;
  font-size: 1.1rem;
  transition: transform 0.2s, opacity 0.2s;
  text-decoration: none;
}
.product-page-share-btn:hover {
  color: #fff;
  transform: translateY(-2px);
  opacity: 0.9;
}
.product-page-share-btn:nth-child(2) { background: #1877f2; }
.product-page-share-btn:nth-child(3) { background: #000; }
.product-page-share-btn:nth-child(4) { background: #25d366; }
.product-license-card {
  margin-top: 0;
  border-radius: 18px;
  border: 1px solid #e5e7eb;
  background: #fff;
  padding: 1.3rem 1.4rem 1.2rem;
  box-shadow: 0 10px 30px rgba(15,23,42,0.05);
  font-size: 0.9rem;
}
@media (min-width: 992px) {
  .product-license-card {
    position: sticky;
    top: 1.5rem;
    align-self: flex-start;
  }
}
.product-license-title {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}
.product-license-list {
  list-style: none;
  padding: 0;
  margin: 0 0 1rem;
}
.product-license-list li {
  position: relative;
  padding-left: 1.4rem;
  margin-bottom: 0.25rem;
}
.product-license-list li::before {
  content: '✔';
  position: absolute;
  left: 0;
  top: 0;
  font-size: 0.8rem;
  color: #16a34a;
}
.product-license-payments {
  background: #f3f4f6;
  border-radius: 12px;
  padding: 0.6rem 0.9rem;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  margin-bottom: 0.9rem;
}
.product-license-payments-label {
  font-size: 0.78rem;
  color: #6b7280;
}
.product-license-payments-logos {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1.1rem;
  color: #111827;
}
.product-license-appmax {
  font-size: 0.85rem;
  font-weight: 600;
}
.product-license-price-wrap {
  display: flex;
  flex-direction: column;
  gap: 0.12rem;
  margin-bottom: 0.7rem;
}
.product-license-price-label {
  font-size: 0.92rem;
  font-weight: 500;
  color: #334155;
}
.product-license-price {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--accent, #2E93EE);
  margin-bottom: 0;
}
.product-license-price-wrap .product-license-price {
  margin-bottom: 0;
}
.product-license-promo-badge {
  display: inline-block;
  background: rgba(31, 32, 68, 0.9);
  color: #fff;
  padding: 0.25rem 0.6rem;
  border-radius: 6px;
  font-weight: 600;
  font-size: 0.85rem;
  letter-spacing: 0.02em;
  margin-bottom: 0.5rem;
}
.product-license-price-block {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  margin-bottom: 0.7rem;
}
.product-license-price-de {
  font-size: 0.95rem;
  color: #6b7280;
  text-decoration: line-through;
}
.product-license-price-block .product-license-price-label {
  margin-top: 0.1rem;
}
.product-license-price-valor {
  font-size: 1.5rem;
  line-height: 1.15;
}
.product-license-price-valor strong {
  font-weight: 700;
  color: var(--accent, #2E93EE);
}
.product-license-price-por {
  font-size: 1.1rem;
  font-weight: 600;
  color: #111827;
}
.product-license-desconto {
  color: #16a34a;
  font-weight: 500;
}
.product-license-btn {
  width: 100%;
  border-radius: 999px;
  background: #22c55e;
  border-color: #22c55e;
  color: #fff;
  font-weight: 600;
  margin-bottom: 0.4rem;
  padding: 0.9rem 1.25rem;
  font-size: 1.05rem;
}
.product-license-btn:hover {
  background: #16a34a;
  border-color: #16a34a;
  color: #fff;
}
.product-license-note {
  font-size: 0.75rem;
  color: #6b7280;
  margin-top: 0.75rem;
  margin-bottom: 0.8rem;
  text-align: center;
}
.product-license-info-title {
  font-size: 0.85rem;
  font-weight: 600;
  margin-bottom: 0.35rem;
}
.product-license-info-line {
  display: flex;
  justify-content: space-between;
  font-size: 0.8rem;
  color: #4b5563;
}
.product-license-info-line + .product-license-info-line {
  margin-top: 0.1rem;
}
.product-checkout-form {
  background: #fff;
  border-radius: 14px;
  padding: 1rem 1.1rem;
  box-shadow: 0 10px 30px rgba(15,23,42,0.06);
  max-width: 460px;
}
.product-checkout-form .form-control,
.product-checkout-form .form-select {
  font-size: 0.85rem;
}
.product-checkout-form label {
  font-size: 0.78rem;
}
.product-checkout-feedback {
  min-height: 1.2em;
}

/* Checkout — alinhado ao tema do site (--accent, cards sólidos) */
.checkout-section {
  --checkout-primary: #30404e;
  --checkout-primary-hover: #25323d;
  --checkout-accent: #de003b;
  --checkout-accent-hover: #b80031;
  background: #ffffff;
  min-height: 100vh;
}
/* Mesmas variáveis onde o resumo/checkout aparece fora de .checkout-section (ex.: produto-ps, carrinho) */
.carrinho-dominios-section,
.produto-ps-section {
  --checkout-primary: #30404e;
  --checkout-primary-hover: #25323d;
  --checkout-accent: #de003b;
  --checkout-accent-hover: #b80031;
}
/* produto-ps: títulos em preto (evita azul fixo do resumo e ícones de secção) */
.produto-ps-section .carrinho-dominios-resumo-nome {
  color: #0f172a;
}
.produto-ps-section .carrinho-dominios-resumo > h2 {
  color: #0f172a;
}
.produto-ps-section h1.h3,
.produto-ps-section h2.h4,
.produto-ps-section h2.h5,
.produto-ps-section h2.h6 {
  color: #0f172a;
}
.produto-ps-section .checkout-section-title {
  color: #0f172a;
}
.produto-ps-section .checkout-section-title i {
  color: #334155;
}
/* Selo de confiança — topo da coluna de dados (checkout) */
.checkout-trust-strip {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 0.95rem;
  margin-bottom: 1.25rem;
  border-radius: 12px;
  border: 1px solid #ccebdc;
  background: #f4fbf7;
  box-shadow: none;
}
.checkout-trust-strip-icon {
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #e5f7ee;
  color: #16a34a;
  font-size: 0.95rem;
  line-height: 1;
}
.checkout-trust-strip-body {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0;
  min-width: 0;
  text-align: left;
}
.checkout-trust-strip-title {
  display: block;
  font-size: 0.9rem;
  font-weight: 600;
  color: #15803d;
  letter-spacing: 0;
}
.checkout-trust-strip-text {
  display: block;
  font-size: 0.75rem;
  line-height: 1.5;
  color: #4b5563;
}
@media (max-width: 575px) {
  .checkout-trust-strip {
    padding: 0.7rem 0.9rem;
    gap: 0.65rem;
  }
  .checkout-trust-strip-icon {
    width: 28px;
    height: 28px;
    font-size: 0.9rem;
  }
}
.checkout-summary-card {
  background: #ffffff;
  border-radius: 18px;
  padding: 0;
  box-shadow: 0 10px 30px rgba(15,23,42,0.06);
  border: 1px solid #e5e7eb;
}
.checkout-summary-header {
  background: var(--checkout-primary);
  color: #ffffff;
  border-radius: 17px 17px 0 0;
  padding: 1rem 1.4rem;
  font-size: 1.02rem;
  font-weight: 600;
}
.checkout-summary-body {
  padding: 1.1rem 1.3rem 1.2rem;
}
.checkout-summary-product {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.9rem;
  position: relative;
}
.checkout-summary-remove {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  color: #6b7280;
  flex-shrink: 0;
  transition: color 0.2s, background 0.2s;
}
.checkout-summary-remove:hover {
  color: #dc3545;
  background: rgba(220,53,69,0.08);
}
.checkout-summary-thumb {
  width: 64px;
  height: 64px;
  border-radius: 12px;
  overflow: hidden;
  background: #f3f4f6;
  display: flex;
  align-items: center;
  justify-content: center;
}
.checkout-summary-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.checkout-summary-info {
  flex: 1;
}
.checkout-summary-name {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text);
}
.checkout-summary-total {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  padding-top: 0.8rem;
  margin-top: 0.8rem;
  border-top: 1px solid #e5e7eb;
  font-size: 0.95rem;
}
.checkout-summary-total strong {
  font-size: 1.3rem;
  color: var(--checkout-accent);
}
.checkout-total-promo {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.15rem;
}
.checkout-total-de {
  font-size: 0.85rem;
  color: #6b7280;
  text-decoration: line-through;
}
.checkout-total-desconto {
  color: #16a34a;
  font-weight: 500;
}
.checkout-summary-safe {
  margin-top: 1rem;
  border-top: 1px dashed #e5e7eb;
  padding-top: 0.9rem;
  text-align: center;
  font-size: 0.75rem;
  color: #6b7280;
}
.checkout-safe-block {
  font-size: 0.9rem;
  color: var(--text-muted);
  text-align: center;
  margin-top: 2rem;
  padding-top: 2rem;
  border-top: 1px solid #e5e7eb;
}
.checkout-safe-block .checkout-safe-badge {
  justify-content: center;
  gap: 0.5rem;
}
.checkout-safe-block .checkout-safe-badge i.bi-shield-check {
  font-size: 1.25rem;
  color: #16a34a;
}
.checkout-asaas-logo {
  height: 16px;
  width: auto;
  vertical-align: middle;
  margin: 0 0.2em;
}
.checkout-safe-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  color: #10b981;
  font-size: 0.8rem;
  font-weight: 500;
}
.checkout-safe-icon {
  width: 14px;
  height: 14px;
  border-radius: 999px;
  border: 2px solid #10b981;
  position: relative;
}
.checkout-safe-icon::after {
  content: '';
  position: absolute;
  top: 1px;
  left: 3px;
  width: 4px;
  height: 7px;
  border-right: 2px solid #10b981;
  border-bottom: 2px solid #10b981;
  transform: rotate(45deg);
}

.checkout-benefits-card {
  margin-top: 0.75rem;
  border-radius: 18px;
  border: 1px solid #e5e7eb;
  background: #ffffff;
  padding: 0.9rem 1rem 1.1rem;
  box-shadow: 0 10px 30px rgba(15,23,42,0.06);
}
.checkout-benefits-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.checkout-benefits-list li {
  display: flex;
  align-items: flex-start;
  gap: 0.45rem;
  font-size: 0.85rem;
  color: var(--text);
}
.checkout-benefits-list li + li {
  margin-top: 0.3rem;
}
.checkout-benefit-icon {
  width: 14px;
  height: 14px;
  border-radius: 999px;
  border: 2px solid var(--checkout-primary);
  position: relative;
  margin-top: 2px;
}
.checkout-benefit-icon::after {
  content: '';
  position: absolute;
  top: 1px;
  left: 3px;
  width: 4px;
  height: 7px;
  border-right: 2px solid var(--checkout-primary);
  border-bottom: 2px solid var(--checkout-primary);
  transform: rotate(45deg);
}
.payment-alert-boleto {
  margin-top: 0.6rem;
  font-size: 0.85rem;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.payment-alert-boleto i {
  color: var(--checkout-primary);
}
.checkout-order-pay-btn {
  border-radius: 12px;
  background: var(--checkout-accent, #de003b);
  border-color: var(--checkout-accent, #de003b);
  color: #fff;
  font-weight: 600;
  padding: 0.85rem 1.75rem;
  font-size: 1.1rem;
}
.checkout-order-pay-btn:hover {
  background: var(--checkout-accent-hover, #b80031);
  border-color: var(--checkout-accent-hover, #b80031);
  color: #fff;
}
.checkout-main-card {
  background: #ffffff;
  border-radius: 18px;
  padding: 1.6rem 1.7rem 1.4rem;
  box-shadow: 0 10px 30px rgba(15,23,42,0.06);
  border: 1px solid #e5e7eb;
}
.checkout-main-product {
  display: flex;
  align-items: center;
  gap: 0.85rem;
}
.checkout-main-thumb {
  width: 64px;
  height: 64px;
  border-radius: 12px;
  overflow: hidden;
  background: #f3f4f6;
  display: flex;
  align-items: center;
  justify-content: center;
}
.checkout-main-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.checkout-main-product-info {
  flex: 1;
}
.checkout-main-name {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text);
}
.checkout-main-price {
  font-size: 0.9rem;
  color: var(--checkout-primary);
  font-weight: 600;
}
.checkout-section-title {
  font-size: 1.05rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  color: var(--text);
}
.checkout-section-title i {
  font-size: 1.2rem;
  color: var(--checkout-primary);
}
.checkout-auth-switch {
  display: inline-flex;
  border-radius: 999px;
  background: #f3f4f6;
  padding: 0.15rem;
}
.checkout-auth-tab {
  border: none;
  background: transparent;
  padding: 0.25rem 0.9rem;
  border-radius: 999px;
  font-size: 0.85rem;
}
.checkout-auth-tab.active {
  background: #fff;
  box-shadow: 0 2px 6px rgba(15,23,42,0.08);
  color: var(--checkout-primary);
  font-weight: 600;
}
.checkout-auth-form {
  max-width: 360px;
}
.checkout-full-form {
  margin-top: 0.5rem;
}
.checkout-divider {
  margin: 1.25rem 0;
  border: none;
  border-top: 1px dashed rgba(0, 0, 0, 0.12);
}
.checkout-cupom-label {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text);
}
.checkout-cupom-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: nowrap;
}
.checkout-cupom-row .checkout-input {
  flex: 1;
  min-width: 0;
}
.checkout-cupom-feedback {
  flex-shrink: 0;
  font-size: 0.875rem;
  white-space: nowrap;
}
.checkout-cupom .checkout-input {
  text-transform: uppercase;
}
.checkout-cupom-btn {
  border-radius: 12px;
  background: var(--checkout-primary);
  color: #fff;
  border: none;
  padding: 0.6rem 1.5rem;
  font-size: 1rem;
  font-weight: 600;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.checkout-cupom-btn:hover {
  background: var(--checkout-primary-hover);
  color: #fff;
}
.checkout-cupom-btn.applied {
  background: #16a34a;
}
.checkout-cupom-btn.applied:hover {
  background: #15803d;
  color: #fff;
}
.checkout-input {
  border-radius: 12px;
  border-color: #e5e7eb;
  background-color: #f9fafb;
  font-size: 0.95rem;
  padding: 0.55rem 1rem;
  height: 46px;
}
.checkout-input:focus {
  border-color: var(--checkout-primary);
  box-shadow: 0 0 0 1px rgba(48,64,78,0.22);
  background-color: #ffffff;
}
.checkout-create-btn {
  display: inline-block;
  border-radius: 12px;
  padding: 0.55rem 1.8rem;
  font-size: 0.9rem;
  font-weight: 600;
  background: var(--checkout-primary);
  border-color: var(--checkout-primary);
  color: #fff;
}
.checkout-create-btn:hover {
  background: var(--checkout-primary-hover);
  border-color: var(--checkout-primary-hover);
  color: #fff;
}
.checkout-payment-methods {
  display: flex;
  gap: 0.5rem;
}
.checkout-payment-option {
  flex: 1;
  cursor: pointer;
  border-radius: 12px;
  border: 1px solid #e5e7eb;
  background: #ffffff;
  box-shadow: 0 1px 2px rgba(15,23,42,0.04);
  padding: 1rem 0.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  text-align: center;
  color: var(--checkout-primary, #30404e);
}
.checkout-payment-option input {
  display: none;
}
.checkout-payment-option.active,
.checkout-payment-option:hover {
  border-color: var(--checkout-primary, #30404e);
  background: var(--checkout-primary, #30404e);
  color: #ffffff;
  box-shadow: 0 3px 12px rgba(48, 64, 78, 0.28);
}
.checkout-payment-option.active .checkout-payment-icon,
.checkout-payment-option.active .checkout-payment-label,
.checkout-payment-option:hover .checkout-payment-icon,
.checkout-payment-option:hover .checkout-payment-label {
  color: inherit;
}
.checkout-payment-icon {
  font-size: 1.75rem;
  line-height: 1;
}
.checkout-payment-label {
  font-size: 0.85rem;
  font-weight: 600;
}
.checkout-submit-btn {
  border-radius: 12px;
  background: var(--checkout-primary);
  border-color: var(--checkout-primary);
  color: #fff;
  padding-inline: 1.6rem;
}
.checkout-submit-btn:hover {
  background: var(--checkout-primary-hover);
  border-color: var(--checkout-primary-hover);
  color: #fff;
}
.checkout-feedback {
  min-height: 1.2em;
}

/* Modal “conta criada” (checkout.php) */
.checkout-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 1060;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  background: rgba(15, 23, 42, 0.45);
}
.checkout-modal {
  width: 100%;
  max-width: 420px;
  background: #ffffff;
  border-radius: 18px;
  padding: 2rem 1.75rem;
  box-shadow: 0 20px 60px rgba(15, 23, 42, 0.15);
  border: 1px solid #e5e7eb;
}
.checkout-modal-icon.success {
  width: 64px;
  height: 64px;
  margin: 0 auto 1rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.75rem;
  background: rgba(48, 64, 78, 0.12);
  color: var(--checkout-primary);
}
.checkout-modal-title {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--text);
  text-align: center;
  margin-bottom: 0.75rem;
}
.checkout-modal-text {
  color: var(--text-muted);
  text-align: center;
  margin-bottom: 0;
  font-size: 0.95rem;
  line-height: 1.5;
}

.checkout-card-fields {
  margin-top: 0.3rem;
}
.checkout-card-note {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.checkout-card-preview {
  display: none;
  margin-top: 0.9rem;
  margin-bottom: 0.2rem;
  perspective: 1000px;
  opacity: 0;
  transform: translateY(8px) scale(0.97);
  transition: all 0.25s ease-out;
}
.checkout-card-preview.visible {
  display: block;
  opacity: 1;
  transform: translateY(0) scale(1);
}
.checkout-card-preview-inner {
  position: relative;
  width: 100%;
  max-width: 340px;
  height: 200px;
  margin: 0 auto;
  transform-style: preserve-3d;
  transition: transform 0.6s ease;
}
.checkout-card-preview.flipped .checkout-card-preview-inner {
  transform: rotateY(180deg);
}
.checkout-card-face {
  position: absolute;
  inset: 0;
  border-radius: 18px;
  backface-visibility: hidden;
}
.checkout-card-front {
  background: linear-gradient(135deg, var(--accent-secondary), var(--accent-hover));
  color: #f9fafb;
  padding: 1.1rem 1.2rem;
  box-shadow: 0 16px 40px rgba(15,23,42,0.35);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.checkout-card-back {
  background: #111827;
  transform: rotateY(180deg);
  padding: 1rem;
  box-shadow: 0 16px 40px rgba(15,23,42,0.35);
}
.checkout-card-chip {
  width: 40px;
  height: 28px;
  border-radius: 8px;
  background: rgba(249,250,251,0.85);
  margin-bottom: 0.5rem;
}
.checkout-card-brand {
  font-size: 0.8rem;
  text-align: right;
  opacity: 0.85;
}
.checkout-card-number {
  font-family: 'Poppins', monospace;
  letter-spacing: 0.12em;
  font-size: 1.05rem;
  margin-top: 0.6rem;
}
.checkout-card-label span.small {
  font-size: 0.7rem;
  opacity: 0.85;
}
.checkout-card-name,
.checkout-card-expiry {
  font-size: 0.9rem;
  font-weight: 600;
}
.checkout-card-strip {
  height: 40px;
  background: #030712;
  margin-bottom: 1.2rem;
}
.checkout-card-cvv-box {
  margin-left: auto;
  max-width: 120px;
  text-align: right;
  color: #e5e7eb;
}
.checkout-card-cvv {
  margin-top: 0.2rem;
  background: #e5e7eb;
  color: #111827;
  padding: 0.25rem 0.5rem;
  border-radius: 6px;
  display: inline-block;
  min-width: 48px;
  text-align: center;
}

/* ===== Slider - Primeira dobra (imagens) ===== */
/* Desktop: 1920×550px | Mobile: 1080×800px - cantos retos como no exemplo */
.fds-slider {
  position: relative;
  border-radius: 0;
  overflow: hidden;
}
.fds-slider .carousel {
  overflow: hidden;
  border-radius: 0;
}
/* Desktop: proporção 1920/550 ≈ 3.49 */
.fds-slider .carousel-inner,
.fds-slider .carousel-item {
  aspect-ratio: 1920 / 550;
  min-height: 460px;
  max-height: 85vh;
  border-radius: 0;
}
.fds-slide {
  height: 100%;
  position: relative;
  display: flex;
  align-items: center;
  overflow: hidden;
  border-radius: 0;
}

/* Em telas menores, não limitar altura nem cortar o conteúdo do slide */
@media (max-width: 991px) {
  .fds-slider,
  .fds-slider .carousel,
  .fds-slide {
    overflow: visible;
  }
  .fds-slider .carousel-inner,
  .fds-slider .carousel-item {
    aspect-ratio: auto;
    min-height: 520px;
    max-height: none;
    height: auto;
  }
}

/* Novo modelo: slide com conteúdo + imagem à direita */
.fds-slide-hero {
  background: var(--fds-slide-bg, #ffffff);
}
.fds-slide-hero .container {
  position: relative;
  z-index: 2;
  height: 100%;
  padding-top: 0;
  padding-bottom: 0;
}
.fds-slide-hero .row {
  height: 100%;
}
.fds-slide-hero .col-lg-6 {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.fds-slide-hero .col-lg-6:first-child {
  align-items: flex-start; /* evita o botão esticar no desktop */
}
.fds-slide-hero .col-lg-6:last-child {
  justify-content: center;
}
.fds-slide-kicker {
  font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fds-slide-kicker, rgba(31, 32, 68, 0.78));
  font-size: 0.82rem;
  margin-bottom: 1rem;
  display: inline-flex;
  align-items: center;
  padding: 0.45rem 0.9rem;
  border-radius: 100px;
  border: 1px solid rgba(148, 163, 184, 0.35);
  background: rgba(255, 255, 255, 0.22);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.fds-slide-sub2 {
  font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 2.6rem;
  color: var(--fds-slide-sub, rgba(31, 32, 68, 0.75));
  margin-bottom: 0.35rem;
  font-weight: 650;
  letter-spacing: -0.03em;
  line-height: 1.15;
}
.fds-slide-title2 {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 2.6rem;
  font-weight: 500;
  font-style: italic;
  color: var(--fds-slide-title, #1f2044);
  letter-spacing: -0.03em;
  margin: 0 0 1.1rem;
}
.fds-slide-desc {
  font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 1rem;
  line-height: 1.5;
  color: var(--fds-slide-desc, rgba(31, 32, 68, 0.84));
  margin: 0 0 1.25rem;
  max-width: 36rem;
}
.fds-slide-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 52px;
  padding: 0 1.25rem;
  border-radius: 10px;
  background: var(--fds-slide-btn, #001074);
  color: var(--fds-slide-btn-text, #fff);
  text-decoration: none;
  font-size: 1rem;
  font-weight: 600;
  box-shadow: none;
  transition: transform 0.25s ease, opacity 0.2s ease;
}
.fds-slide-btn:hover {
  color: var(--fds-slide-btn-text, #fff);
  opacity: 0.95;
  transform: translateY(-3px);
  box-shadow: none;
}
.fds-slide-btn.is-disabled {
  opacity: 0.55;
  cursor: not-allowed;
  box-shadow: none;
}
.fds-slide-media-link { display: block; }
.fds-slide-media {
  display: block;
  width: 100%;
  height: 100%;
}
.fds-slide-media-img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border-radius: 0;
}

@media (max-width: 991px) {
  .fds-included-plans {
    padding: 0.85rem 0 1.15rem;
  }
  .fds-included-wrap {
    grid-template-columns: 1fr;
    padding-block: 0;
    gap: 0.35rem;
  }
  .fds-included-title {
    padding: 1.2rem 1rem 0.85rem;
    justify-content: center;
    text-align: center;
  }
  .fds-included-title::after {
    display: none;
  }
  .fds-included-title h3 {
    font-size: clamp(1.85rem, 7.2vw, 2.25rem);
    line-height: 0.98;
    letter-spacing: -0.02em;
  }
  .fds-included-items {
    grid-template-columns: 1fr;
    gap: 0.7rem;
    padding: 0 0.4rem 0.5rem;
  }
  .fds-included-item {
    min-height: auto;
    padding: 1.15rem 1rem;
    border-radius: 16px;
    border: 1px solid rgba(129, 140, 248, 0.22);
    background: linear-gradient(180deg, rgba(18, 37, 56, 0.72), rgba(13, 30, 47, 0.72));
    box-shadow: 0 12px 28px rgba(3, 10, 22, 0.24);
  }
  .fds-included-item + .fds-included-item {
    border-left: 0;
    border-top: 0;
    padding-left: 1rem;
  }
  .fds-included-item + .fds-included-item::before {
    display: none;
  }
  .fds-included-icon {
    width: 54px;
    height: 54px;
    border-radius: 14px;
    margin: 0 auto 0.45rem;
    font-size: 1.7rem;
    background: rgba(8, 201, 255, 0.12);
    border: 1px solid rgba(8, 201, 255, 0.5);
  }
  .fds-included-item h4 {
    font-size: 1.08rem;
    margin-bottom: 0.28rem;
  }
  .fds-included-item p {
    font-size: 0.9rem;
    line-height: 1.35;
    max-width: 29ch;
  }
  /* No mobile, imagem do banner ocupa toda a largura e ajusta a altura sem distorcer */
  .fds-slide-media {
    height: auto;
  }
  .fds-slide-media-img {
    width: 100%;
    height: auto;
    max-height: none;
    object-fit: contain;
    background: transparent;
  }
  .fds-slide-title2 { font-size: 1.85rem; }
  .fds-slide-sub2 { font-size: 1.85rem; }
  .fds-slide-media-img { border-radius: 0; }
  .fds-slide-btn { padding: 0.8rem 1.1rem; }
}

/* Ajuste fino do banner em telas até tablet */
@media (max-width: 991px) {
  .fds-slide-hero .container {
    padding-top: 2.5rem;
    padding-bottom: 3rem;
  }
  .fds-slide-sub2 {
    font-size: 1.5rem;
    line-height: 1.2;
  }
  .fds-slide-title2 {
    font-size: 1.8rem;
    line-height: 1.2;
  }
  .fds-slide-desc {
    font-size: 0.95rem;
    margin-bottom: 1rem;
  }
  .fds-slide-hero .col-lg-6:first-child {
    align-items: flex-start;
  }
  .fds-slide-btn {
    width: 100%;
    max-width: 320px;
    text-align: center;
  }
}
.fds-slide-link {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: block;
  text-decoration: none;
  color: inherit;
}
.fds-slide-link:focus-visible {
  outline: 3px solid rgba(59, 130, 246, 0.7);
  outline-offset: -3px;
}
.fds-slide-img picture,
.fds-slide-img .fds-slide-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0;
}
.fds-slide-overlay {
  position: relative;
  z-index: 2;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
}
.fds-slide-content {
  max-width: 560px;
}
.fds-slide-title {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 0.5rem;
  text-shadow: 0 1px 3px rgba(255,255,255,0.8);
}
.fds-slide-subtitle {
  font-size: 1.35rem;
  font-weight: 500;
  color: var(--accent-dark);
  text-shadow: 0 1px 2px rgba(255,255,255,0.8);
}
.fds-slider .carousel-control-prev,
.fds-slider .carousel-control-next {
  z-index: 5;
  width: 118px;
  height: 118px;
  top: 50%;
  transform: translateY(-50%);
  background: transparent;
  color: #ffffff;
  opacity: 0;
  box-shadow: none;
  transition: opacity 0.25s ease, color 0.2s ease, transform 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
}
/* Arredondado só do lado do conteúdo - prev: direita | next: esquerda */
.fds-slider .carousel-control-prev {
  border-radius: 0;
}
.fds-slider .carousel-control-next {
  border-radius: 0;
}
.fds-slider:hover .carousel-control-prev,
.fds-slider:hover .carousel-control-next {
  opacity: 1;
}
/* Em dispositivos touch, controles sempre visíveis */
@media (hover: none) {
  .fds-slider .carousel-control-prev,
  .fds-slider .carousel-control-next { opacity: 1; }
}
.fds-slider .carousel-control-prev { left: 0; }
.fds-slider .carousel-control-next { right: 0; }
.fds-slider .carousel-control-prev:hover,
.fds-slider .carousel-control-next:hover {
  color: var(--accent);
  transform: translateY(-50%) scale(1.08);
}
.fds-slider .carousel-control-prev i,
.fds-slider .carousel-control-next i {
  font-size: 3.6rem;
  font-weight: 400;
  text-shadow: none;
}

/* Dots do banner (canto esquerdo) */
.fds-hero-dots-wrap {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 34px; /* mais pra cima */
  z-index: 5;
  pointer-events: none; /* só os botões clicam */
}
.fds-hero-dots {
  justify-content: flex-start;
  position: static;
  margin: 0;
  gap: 10px;
  pointer-events: auto;
}
.fds-hero-dots [data-bs-target] {
  position: relative;
  overflow: hidden;
  width: 56px;
  height: 8px;
  border-radius: 999px;
  border: none;
  background: rgba(255, 255, 255, 0.92);
  opacity: 1;
  box-shadow: none;
  transition: transform 0.2s ease, background-color 0.2s ease;
}
.fds-hero-dots [data-bs-target]::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 0%;
  background: var(--accent);
  border-radius: inherit;
}
.fds-hero-dots [data-bs-target]:hover {
  background: #ffffff;
}
.fds-hero-dots .active {
  background: #ffffff;
  box-shadow: none;
}
.fds-hero-dots [data-bs-target].is-progress::before {
  animation: fds-hero-dot-progress var(--hero-progress-duration, 5000ms) linear forwards;
}
@keyframes fds-hero-dot-progress {
  from { width: 0%; }
  to { width: 100%; }
}
@media (max-width: 767px) {
  .fds-hero-dots-wrap { bottom: 22px; }
  .fds-hero-dots { gap: 8px; }
  .fds-hero-dots [data-bs-target] { width: 44px; height: 7px; }
}
@media (prefers-reduced-motion: reduce) {
  .fds-hero-dots .active.is-progress::before {
    animation: none;
    width: 100%;
  }
}

/* Wrapper slider + buscador sobreposto */
.fds-hero-wrap {
  position: relative;
}
.fds-hero-wrap.has-hero-bg {
  background-image: var(--hero-bg);
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
  margin-top: calc(-1 * (var(--fds-promo-h, 0px) + var(--fds-header-h, 88px)));
  padding-top: calc(var(--fds-promo-h, 0px) + var(--fds-header-h, 88px));
}
.fds-hero-wrap.has-slider .fds-domain-bar {
  margin-top: -42px;
  position: relative;
  z-index: 10;
  padding-bottom: 1.5rem;
}
.fds-hero-wrap:not(.has-slider) .fds-domain-bar {
  padding-top: 1.5rem;
}

/* Círculo com favicon sobreposto ao banner (home) */
.fds-hero-wrap.has-slider .fds-hero-favicon-bar {
  margin-top: -36px; /* desce um pouco no desktop */
  position: relative;
  z-index: 10;
  padding-bottom: 1.25rem;
}
.fds-hero-wrap:not(.has-slider) .fds-hero-favicon-bar {
  padding-top: 1.25rem;
}
.fds-hero-favicon-badge {
  width: 76px;
  height: 76px;
  border-radius: 50%;
  background: #fff;
  box-shadow: none;
  display: flex;
  align-items: center;
  justify-content: center;
  transform: translateZ(0);
  will-change: transform;
}
.fds-hero-favicon-img {
  width: 52px;
  height: 52px;
  object-fit: contain;
  border-radius: 12px;
}
.fds-hero-favicon-badge.is-rotating {
  animation: fds-spin 1.4s linear infinite;
}
.fds-hero-favicon-badge.is-ccw {
  animation-direction: reverse;
}
@keyframes fds-spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

@media (max-width: 767px) {
  .fds-hero-favicon-badge {
    width: 64px;
    height: 64px;
  }
  .fds-hero-favicon-img {
    width: 44px;
    height: 44px;
    border-radius: 10px;
  }
}

/* No mobile, esconder o círculo sobreposto para não tampar o banner */
@media (max-width: 767px) {
  .fds-hero-wrap.has-hero-bg {
    background-position: center center;
  }
  .fds-hero-favicon-bar {
    display: none;
  }
}

/* Barra de busca - metade sobre o banner, formato pill */
.fds-domain-bar {
  background: transparent;
}
.domain-search-registro {
  margin: 0;
}
.domain-search-inner {
  display: flex;
  align-items: center;
  background: #fff;
  border-radius: 100px;
  padding: 0.75rem 1.25rem 0.75rem 1.75rem;
  min-height: 64px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.15), 0 0 0 1px rgba(0,0,0,0.04);
  gap: 0.75rem;
  flex-wrap: wrap;
}
.domain-search-label {
  color: #6c757d;
  font-size: 0.95rem;
  white-space: nowrap;
}
.domain-search-label strong { color: #495057; }
.domain-search-www {
  color: #adb5bd;
  font-size: 0.9rem;
  font-weight: 500;
}
.domain-search-input {
  flex: 1;
  min-width: 180px;
  border: none;
  outline: none;
  font-size: 1rem;
  padding: 0.75rem 0.85rem;
  background: #f5f6f8;
  border-radius: 100px;
}
.domain-search-input::placeholder {
  color: #adb5bd;
}
.domain-search-btn {
  width: auto;
  min-width: 36px;
  height: 36px;
  align-self: center;
  padding: 0 0.5rem;
  border: none;
  border-radius: 0;
  background: transparent;
  color: #0030b9;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.35rem;
  cursor: pointer;
  transition: color 0.2s;
  flex-shrink: 0;
}
.domain-search-btn:hover {
  color: #3366e0;
  background: transparent;
}
.domain-search-result {
  margin-top: 0.75rem;
  margin-left: 1rem;
  font-size: 0.95rem;
  min-height: 1.5em;
  color: #1f2044;
}
.domain-search-result .disponivel { color: #198754; font-weight: 600; }
.domain-search-result .indisponivel { color: #dc3545; font-weight: 500; }
.domain-search-result .text-muted { color: #6c757d !important; }
.domain-search-result .text-warning { color: #856404 !important; }
.domain-search-result .text-danger { color: #dc3545 !important; }

.domain-search-tlds {
  margin-top: 0.5rem;
  margin-left: 1rem;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.35rem;
  font-size: 0.8rem;
  color: #6c757d;
}
.domain-search-tlds-label {
  font-weight: 500;
}
.domain-search-tld-pill {
  padding: 0.1rem 0.6rem;
  border-radius: 999px;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  color: #334155;
}

/* Busca de domínio – mobile estilo app */
@media (max-width: 767px) {
  .fds-domain-bar .container {
    padding-left: 12px;
    padding-right: 12px;
  }
  .domain-search-registro {
    width: 100%;
  }
  .domain-search-inner {
    flex-wrap: nowrap;
    min-height: 52px;
    padding: 0.5rem 0.6rem 0.5rem 1rem;
    border-radius: 999px;
    gap: 0.5rem;
    box-shadow: 0 4px 20px rgba(0,0,0,0.1), 0 0 0 1px rgba(0,0,0,0.06);
  }
  .domain-search-input {
    min-width: 0;
    font-size: 0.95rem;
    padding: 0.6rem 0.75rem;
    border-radius: 999px;
  }
  .domain-search-btn {
    min-width: 44px;
    height: 44px;
    font-size: 1.2rem;
    flex-shrink: 0;
    border-radius: 50%;
    color: #0030b9;
  }
  .domain-search-btn:active {
    opacity: 0.85;
  }
  .domain-search-result {
    margin-top: 0.6rem;
    margin-left: 0.25rem;
    font-size: 0.9rem;
  }
}

/* Busca de domínio (legado/outras seções) */
.fds-domain-search {
  background: #fff;
  border: 1px solid #e0e0e0;
}
.fds-domain-title {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--text);
}
.fds-domain-search .input-group-text {
  background: #f5f5f5;
  border-color: #dee2e6;
}
.fds-domain-search .btn-primary {
  background: var(--btn-bg, var(--accent-secondary));
  border-color: var(--btn-bg, var(--accent-secondary));
  color: #1f2044;
}
.fds-domain-search .btn-primary:hover {
  background: var(--btn-hover, var(--accent-hover));
  border-color: var(--btn-hover, var(--accent-hover));
}

/* ===== Busca de domínio - Página de resultados ===== */
.busca-dominio-header {
  background: #0030b9;
  padding: 1.5rem 0 2rem;
}
.busca-dominio-dica {
  color: #fff;
  font-size: 0.95rem;
  margin-bottom: 1rem;
  text-align: center;
}
.busca-dominio-form {
  width: 100%;
  max-width: 100%;
}
.busca-dominio-search-inner {
  display: flex;
  align-items: center;
  background: #fff;
  border-radius: 100px;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
  width: 100%;
}
.busca-dominio-www {
  padding: 0 1rem 0 1.25rem;
  color: #6c757d;
  font-size: 0.9rem;
}
.busca-dominio-input {
  flex: 1;
  min-width: 0;
  border: none;
  outline: none;
  padding: 0.85rem 0.5rem;
  font-size: 1rem;
}
.busca-dominio-input::placeholder { color: #adb5bd; }
.busca-dominio-btn {
  background: transparent;
  border: none;
  padding: 0 1.25rem 0 0.75rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
}
.busca-dominio-btn i {
  font-size: 1.1rem;
  color: #0032ba;
}
.busca-dominio-btn:hover i {
  color: var(--accent-hover);
}

/* Colunas dos resultados: permitem o card encolher e quebrar domínios longos */
#domainResultsCards > [class*="col-"],
#produtoDominioBuscaCards > [class*="col-"] {
  min-width: 0;
}

.busca-dominio-card {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  padding: 1.25rem;
  height: 100%;
  min-width: 0;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  transition: box-shadow 0.2s, border-color 0.2s;
  overflow-wrap: anywhere;
  word-wrap: break-word;
}
.busca-dominio-card:hover {
  border-color: var(--accent);
  box-shadow: 0 4px 16px rgba(30, 147, 238, 0.12);
}
.busca-dominio-card-badge {
  display: inline-block;
  background: #f1f5f9;
  color: #64748b;
  font-size: 0.75rem;
  padding: 0.2rem 0.5rem;
  border-radius: 6px;
  margin-bottom: 0.75rem;
}
.busca-dominio-card-domain {
  font-size: 1.25rem;
  font-weight: 700;
  color: #0f172a;
  margin: 0 0 0.5rem 0;
  line-height: 1.25;
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.busca-dominio-card-desc {
  font-size: 0.875rem;
  color: #6c757d;
  margin-bottom: 1rem;
  flex: 1;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.busca-dominio-card-preco {
  margin-bottom: 1rem;
}
.busca-dominio-card-preco .preco-valor {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--text);
}
.busca-dominio-card-preco .preco-periodo { color: #6c757d; font-size: 0.9rem; }
.busca-dominio-card-footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
  padding-top: 0.75rem;
  border-top: 1px solid #eee;
}
.busca-dominio-card-footer span {
  font-size: 0.85rem;
  flex: 1;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.busca-dominio-opcoes { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.busca-dominio-btn-add {
  background: var(--accent) !important;
  background-color: var(--accent) !important;
  color: #fff !important;
  border: none !important;
  padding: 0.5rem 1rem;
  font-size: 0.9rem;
  font-weight: 600;
  border-radius: 12px;
  white-space: nowrap;
  cursor: pointer;
  box-shadow: none;
}
/* Lista compacta — um resultado (correspondência exata) */
.produto-ps-busca-dominio-lista {
  margin-top: 0.5rem;
}
.produto-ps-busca-linha {
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  padding: 0.75rem 1rem;
  background: #fff;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem 1rem;
}
.produto-ps-busca-linha__main { flex: 1 1 200px; min-width: 0; }
.produto-ps-busca-linha__dominio { font-weight: 600; color: #0f172a; word-break: break-word; margin: 0 0 0.25rem 0; font-size: 1rem; }
.produto-ps-busca-linha__status { font-size: 0.85rem; margin: 0; line-height: 1.35; }
.produto-ps-busca-linha__preco { font-weight: 700; white-space: nowrap; }
.produto-ps-busca-linha .busca-dominio-btn-add { flex: 0 0 auto; min-width: 140px; }

.busca-dominio-btn-add:hover,
.busca-dominio-btn-add:focus,
.busca-dominio-btn-add:active,
.busca-dominio-btn-add:focus-visible {
  background: var(--accent-hover) !important;
  background-color: var(--accent-hover) !important;
  color: #fff !important;
  border-color: transparent !important;
  box-shadow: none !important;
}
.busca-dominio-btn-add:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  background: var(--accent) !important;
  background-color: var(--accent) !important;
}

/* ===== Carrinho de domínios ===== */
.carrinho-dominios-progress {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}
.carrinho-dominios-progress-steps {
  display: flex;
  align-items: center;
  gap: 0;
}
.carrinho-dominios-step {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: #adb5bd;
  font-size: 0.9rem;
}
.carrinho-dominios-step.active {
  color: var(--accent);
  font-weight: 600;
}
.carrinho-dominios-step .step-num {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: #e9ecef;
  color: #6c757d;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
}
.carrinho-dominios-step.active .step-num {
  background: var(--accent);
  color: #fff;
}
.carrinho-dominios-step-line {
  width: 40px;
  height: 2px;
  background: #e9ecef;
  margin: 0 0.25rem;
}
.carrinho-dominios-seguro {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.9rem;
  color: #198754;
}
.carrinho-dominios-card {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  padding: 1.25rem;
}
.carrinho-dominios-card .dominio-nome {
  font-size: 1.1rem;
  font-weight: 600;
  color: #0030b9;
}
.carrinho-dominios-doc-row {
  align-items: stretch;
}
.carrinho-dominios-doc-input {
  min-height: 44px;
  border-radius: 100px !important;
  padding-left: 1.25rem;
  padding-right: 1.25rem;
  flex: 1;
}
.carrinho-dominios-doc-btn {
  min-height: 44px;
  border-radius: 100px !important;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  font-weight: 600;
  white-space: nowrap;
  color: #fff !important;
}
.carrinho-dominios-doc-btn:hover {
  color: #fff !important;
}
.carrinho-dominios-resumo {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  padding: 1.5rem;
  position: sticky;
  top: 1rem;
}
.carrinho-dominios-resumo-item {
  padding: 0.75rem;
  background: #fff;
  border-radius: 8px;
  border: 1px solid #e2e8f0;
}
.carrinho-dominios-resumo-nome {
  font-weight: 600;
  color: #0030b9;
  font-size: 0.95rem;
}
.carrinho-dominios-resumo-periodo {
  font-size: 0.8rem;
  margin-top: 0.15rem;
}
.carrinho-dominios-resumo-preco {
  color: var(--text);
  font-size: 1rem;
}
.carrinho-dominios-resumo-excluir {
  opacity: 0.7;
}
.carrinho-dominios-resumo-excluir:hover {
  opacity: 1;
}

/* Order bumps - hospedagem */
.orderbump-card {
  border-radius: 12px;
  transition: transform 0.2s, box-shadow 0.2s;
}
.orderbump-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.1) !important;
}
.orderbump-card-icon {
  font-size: 1.75rem;
  color: var(--accent);
}
.orderbump-card-nome {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 0.5rem;
}
.orderbump-card-desc {
  font-size: 0.85rem;
  margin-bottom: 0.75rem;
  min-height: 2.5em;
}
.orderbump-card-preco {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--text);
}
.orderbump-card-periodo {
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--text-muted);
}
.orderbump-btn-add {
  background: var(--accent) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 100px;
  padding: 0.5rem 1rem;
  font-size: 0.9rem;
  font-weight: 600;
}
.orderbump-btn-add:hover,
.orderbump-btn-add:focus,
.orderbump-btn-add:active {
  background: var(--accent-hover) !important;
  color: #fff !important;
}
.orderbump-btn-added {
  background: #e9ecef !important;
  color: #6c757d !important;
  border: none;
  border-radius: 100px;
  padding: 0.5rem 1rem;
  font-size: 0.9rem;
}
.carrinho-dominios-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.carrinho-dominios-btn-continuar {
  border-radius: 12px !important;
  color: #fff !important;
}
.carrinho-dominios-btn-continuar:hover {
  color: #fff !important;
}

/* Cupom - carrinho domínios */
.carrinho-dominios-cupom-label {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text);
}
.carrinho-dominios-cupom-row {
  align-items: stretch;
}
.carrinho-dominios-cupom-input {
  min-height: 44px;
  border-radius: 100px !important;
  padding-left: 1.25rem;
  padding-right: 1.25rem;
  flex: 1;
  text-transform: uppercase;
}
.carrinho-dominios-cupom-input::placeholder {
  text-transform: none;
}
.carrinho-dominios-cupom-btn {
  min-height: 44px;
  border-radius: 100px !important;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  font-weight: 600;
  white-space: nowrap;
  color: #fff !important;
}
.carrinho-dominios-cupom-btn:hover {
  color: #fff !important;
}
.carrinho-dominios-cupom-feedback.text-success { color: #198754 !important; }
.carrinho-dominios-cupom-feedback.text-danger { color: #dc3545 !important; }

/* ===== Seção Serviços ===== */
.fds-services {
  background: #ffffff;
}
.fds-services-title {
  font-size: 2.1rem;
  font-weight: 700;
  color: var(--text);
  max-width: 560px;
}
.fds-services-nav {
  flex-shrink: 0;
}
.fds-services-btn {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid #e2e8f0;
  background: transparent;
  color: #cbd5e1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  cursor: pointer;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.fds-services-btn:disabled {
  cursor: not-allowed;
  background: transparent;
  color: #e2e8f0;
  border-color: #e2e8f0;
}
.fds-services-btn:not(:disabled) {
  background: #0030b9;
  color: #fff;
  border-color: #0030b9;
}
.fds-services-btn:not(:disabled):hover {
  background: #0044dd;
  color: #fff;
  border-color: #0044dd;
}
.fds-services-track-wrap {
  width: 100%;
  overflow-x: auto;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding: 2rem 0;
}
.fds-services-track {
  display: flex;
  gap: 1rem;
  width: max-content;
  box-sizing: border-box;
  padding: 0.25rem 2.5rem;
}
.fds-services-track::-webkit-scrollbar {
  display: none;
}

/* Seção Suporte humanizado */
.support-promo {
  background: #ffffff;
}
.support-promo-tag {
  font-size: 0.75rem;
  font-weight: 600;
  color: #9ca3af;
  letter-spacing: 0.08em;
}
.support-promo-title {
  font-size: 2rem;
  font-weight: 700;
  color: #111827;
}
.support-promo-desc {
  color: #4b5563;
  line-height: 1.6;
}
.support-promo-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.support-promo-list li {
  display: flex;
  align-items: flex-start;
  margin-bottom: 0.5rem;
}
.support-promo-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 1.25rem 1rem;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.06);
  text-decoration: none;
  color: #374151;
  font-weight: 500;
  font-size: 0.95rem;
  text-align: center;
  transition: box-shadow 0.2s, border-color 0.2s, color 0.2s;
}
.support-promo-box:hover {
  box-shadow: 0 4px 12px rgba(0,0,0,0.08);
  border-color: #d1d5db;
  color: var(--accent);
}
.support-promo-box-icon {
  width: 48px;
  height: 48px;
  background: #eff6ff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  font-size: 1.35rem;
  margin-bottom: 0.75rem;
  transition: background 0.2s, color 0.2s;
}
.support-promo-box:hover .support-promo-box-icon {
  background: #dbeafe;
  color: var(--accent);
}
.support-promo-col-img {
  align-self: stretch;
  display: flex;
}
.support-promo-visual {
  position: relative;
  width: 100%;
  display: flex;
  flex: 1;
  min-height: 420px;
}
.support-promo-img-single {
  width: 100%;
  flex: 1;
  min-height: 420px;
  border-radius: 16px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
.support-promo-img-single img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 420px;
  object-fit: contain;
  object-position: left center;
}

@media (max-width: 991px) {
  .support-promo-col-img { display: block; }
  .support-promo-visual { min-height: 360px; }
  .support-promo-img-single { min-height: 360px; }
  .support-promo-img-single img { min-height: 360px; }
}

/* Portfólio - mockup Safari clean */
.fds-portfolio-safari {
  position: relative;
  overflow: hidden;
  background: #fafafa;
  padding-top: 4.5rem;
  padding-bottom: 4.5rem;
}
.fds-portfolio-safari::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 100%;
  height: 300px;
  background: #ffffff;
  clip-path: polygon(0 8%, 100% 98%, 100% 100%, 0 100%);
  z-index: 1;
}
.fds-portfolio-safari .container {
  position: relative;
  z-index: 2;
}
@media (min-width: 992px) {
  .fds-portfolio-safari .container {
    padding-left: var(--bs-gutter-x, 0.75rem);
    padding-right: var(--bs-gutter-x, 0.75rem);
  }
}
.fds-portfolio-head {
  text-align: center;
  margin-bottom: 1.2rem;
}
.fds-portfolio-kicker {
  margin: 0 0 0.45rem;
  font-size: 1.02rem;
  font-weight: 500;
  color: #334155;
}
.fds-portfolio-kicker span {
  font-weight: 700;
  background: linear-gradient(90deg, #31414F, #EA1947);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.fds-portfolio-title {
  margin: 0;
  font-size: clamp(1.75rem, 3vw, 2.45rem);
  font-weight: 600;
  color: #111827;
}
.fds-portfolio-tabs {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 0.75rem;
  margin-bottom: 1.8rem;
}
.fds-portfolio-tab {
  border: 1px solid #d8d8d8;
  background: #f3f3f3;
  border-radius: 14px;
  min-height: 56px;
  font-size: 0.95rem;
  font-weight: 500;
  color: #334155;
  padding: 0.65rem 0.85rem;
  transition: all 0.2s ease;
}
.fds-portfolio-tab:hover {
  border-color: color-mix(in srgb, var(--accent) 35%, #d8d8d8);
  background: #ffffff;
}
.fds-portfolio-tab.is-active {
  border-color: color-mix(in srgb, var(--accent) 45%, #d8d8d8);
  color: var(--accent);
  background: #ffffff;
}
.fds-portfolio-image-wrap {
  width: 100%;
  max-width: 680px;
  margin: 0 auto;
  border-radius: 14px;
  background: transparent;
  border: none;
  overflow: hidden;
  box-shadow: none;
  display: block;
  position: relative;
}
.fds-portfolio-image-wrap::after {
  content: "\f470";
  font-family: "bootstrap-icons";
  font-size: 1.2rem;
  line-height: 1;
  color: #ffffff;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: var(--accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) scale(0.9);
  opacity: 0;
  transition: opacity 0.2s ease, transform 0.2s ease;
  pointer-events: none;
}
.fds-portfolio-image-wrap:hover::after {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}
.fds-portfolio-image-wrap img {
  width: 100%;
  height: 100%;
  min-height: 260px;
  object-fit: contain;
  display: block;
}
.fds-portfolio-note {
  margin: 0.75rem auto 0;
  max-width: 680px;
  text-align: center;
  font-size: 0.76rem;
  color: #6b7280;
}
.fds-portfolio-note-logo {
  height: 16px;
  width: auto;
  max-width: 88px;
  object-fit: contain;
  margin-left: 0.35rem;
  vertical-align: -2px;
}
.fds-portfolio-note-tip {
  border: none;
  background: transparent;
  color: var(--accent);
  padding: 0;
  margin-left: 0.3rem;
  line-height: 1;
  vertical-align: middle;
}
.fds-portfolio-note-tip i {
  font-size: 0.86rem;
}

/* Cards de projetos na home */
.fds-home-portfolio-cards {
  background: #ffffff;
  margin-top: 0;
  padding-top: 1.8rem;
  padding-bottom: 3rem;
}
.fds-home-portfolio-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}
@media (min-width: 992px) {
  .fds-home-portfolio-cards .container {
    padding-left: var(--bs-gutter-x, 0.75rem);
    padding-right: var(--bs-gutter-x, 0.75rem);
  }
}
.fds-home-portfolio-card {
  display: block;
  text-decoration: none;
  background: #ffffff;
  border-radius: 14px;
  padding: 0.55rem 0.55rem 0.9rem;
  border: 1px solid rgba(148, 163, 184, 0.22);
  box-shadow: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}
.fds-home-portfolio-card:hover {
  transform: translateY(-2px);
  border-color: rgba(148, 163, 184, 0.3);
  box-shadow: none;
}
.fds-home-portfolio-card.is-disabled {
  pointer-events: none;
}
.fds-home-portfolio-browser {
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid #e5e7eb;
  background: #f8fafc;
  box-shadow: none;
}
.fds-home-portfolio-browser-top {
  height: 30px;
  background: linear-gradient(180deg, #f8fafc 0%, #eef2f7 100%);
  border-bottom: 1px solid #dbe3ee;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0 0.55rem;
}
.fds-home-portfolio-browser-dots {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  flex-shrink: 0;
}
.fds-home-portfolio-browser-dots i {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: block;
}
.fds-home-portfolio-browser-dots i:nth-child(1) { background: #ff5f57; }
.fds-home-portfolio-browser-dots i:nth-child(2) { background: #febc2e; }
.fds-home-portfolio-browser-dots i:nth-child(3) { background: #28c840; }
.fds-home-portfolio-browser-url {
  display: inline-block;
  min-width: 0;
  max-width: 100%;
  padding: 0.16rem 0.5rem;
  border-radius: 999px;
  background: #ffffff;
  border: 1px solid #dbe3ee;
  color: #475569;
  font-size: 0.68rem;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.fds-home-portfolio-media {
  border-radius: 0;
  background: #f8fafc;
  aspect-ratio: 16 / 10;
  display: flex;
  align-items: center;
  justify-content: center;
}
.fds-home-portfolio-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.fds-home-portfolio-fallback {
  font-size: 0.95rem;
  color: #475569;
  padding: 0 0.8rem;
  text-align: center;
}
.fds-home-portfolio-title {
  margin-top: 0.65rem;
  color: #0f172a;
  font-weight: 700;
  font-size: 0.95rem;
  line-height: 1.25;
  text-align: left;
}
.fds-home-portfolio-more {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  background: var(--accent);
  color: #ffffff;
  text-decoration: none;
  border-radius: 12px;
  padding: 0.85rem 2rem;
  font-weight: 700;
  font-size: 1.05rem;
}
.fds-home-portfolio-more:hover {
  color: #ffffff;
  background: var(--accent-secondary);
  filter: none;
}
.fds-home-portfolio-cards .text-center.mt-4 {
  margin-top: 3rem !important;
}

/* Página Portfólio (listagem completa) */
.page-portfolio .fds-portfolio-page.section-padding {
  padding-bottom: clamp(3rem, 6vw, 5.5rem);
}
.page-portfolio .fds-portfolio-pagination {
  margin-top: 0.5rem;
}
.fds-portfolio-page-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1.25rem;
}
.fds-portfolio-filter-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.45rem 1rem;
  border-radius: 999px;
  font-size: 0.9rem;
  font-weight: 600;
  text-decoration: none;
  color: #475569;
  background: #f1f5f9;
  border: 1px solid transparent;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.fds-portfolio-filter-pill:hover {
  color: var(--accent);
  background: #e8f4fc;
}
.fds-portfolio-filter-pill.is-active {
  color: #fff;
  background: var(--accent);
  border-color: var(--accent);
}
.fds-portfolio-page-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.25rem;
}
@media (max-width: 991px) {
  .fds-portfolio-page-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
  }
}
@media (max-width: 575px) {
  .fds-portfolio-page-grid {
    grid-template-columns: 1fr;
  }
}
.fds-portfolio-pagination .page-link {
  border-radius: 10px;
  margin: 0 0.15rem;
  color: #334155;
  border-color: #e2e8f0;
}
.fds-portfolio-pagination .page-item.active .page-link {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.fds-portfolio-pagination .page-item:not(.disabled) .page-link:hover {
  background: #f8fafc;
  color: var(--accent);
  border-color: var(--accent);
}

@media (max-width: 767px) {
  .fds-home-portfolio-cards {
    margin-top: 0;
    padding-top: 1.4rem;
    padding-bottom: 2.2rem;
  }
  .fds-home-portfolio-grid {
    grid-template-columns: 1fr;
    gap: 0.8rem;
  }
  .fds-home-portfolio-title {
    font-size: 0.9rem;
  }
  .fds-home-portfolio-browser-top {
    height: 28px;
  }
  .fds-home-portfolio-browser-url {
    font-size: 0.64rem;
  }
  .fds-home-portfolio-more {
    width: 100%;
    justify-content: center;
    font-size: 1rem;
  }
  .fds-home-portfolio-cards .text-center.mt-4 {
    margin-top: 2.1rem !important;
  }
}

/* Features - sessão clean (igual ao layout do print) */
.fds-features-clean {
  background: #ffffff;
  padding-top: 4.8rem;
  padding-bottom: 4.8rem;
}

.fds-feature-card {
  background: #ffffff;
  border: 1px solid #e9edf4;
  border-radius: 14px;
  padding: 1.05rem 1rem;
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.05);
  height: 100%;
  display: flex;
  flex-direction: column;
}
.fds-features-clean .col-md-4 {
  display: flex;
}

.fds-feature-top {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}

.fds-feature-ico {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  background: #f3f4f6;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 40px;
}
.fds-feature-ico i {
  color: #111827;
  font-size: 1.2rem;
  line-height: 1;
}

.fds-feature-title {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 800;
  text-transform: uppercase;
  color: #334155;
  letter-spacing: 0.02em;
}

.fds-feature-desc {
  margin: 0;
  font-size: 0.98rem;
  line-height: 1.75;
  color: #6b7280;
  max-width: 100%;
}
@media (min-width: 992px) {
  .fds-features-clean .container {
    padding-left: var(--bs-gutter-x, 0.75rem);
    padding-right: var(--bs-gutter-x, 0.75rem);
  }
}

@media (max-width: 767px) {
  .fds-features-clean {
    padding-top: 2.9rem;
    padding-bottom: 2.9rem;
    background: linear-gradient(180deg, #f8fafc 0%, #ffffff 42%);
  }
  .fds-features-clean .row {
    row-gap: 0.9rem !important;
  }
  .fds-features-clean .col-md-4 {
    width: 100%;
    flex: 0 0 100%;
  }
  .fds-feature-card {
    background: #ffffff;
    border: 1px solid #e7ebf2;
    border-radius: 16px;
    padding: 1rem 0.95rem 0.95rem;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
  }
  .fds-feature-top {
    gap: 0.62rem;
    margin-bottom: 0.62rem;
  }
  .fds-feature-ico {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    background: rgba(46, 147, 238, 0.1);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 38px;
  }
  .fds-feature-ico i {
    font-size: 1.2rem;
  }
  .fds-feature-title {
    font-size: 1rem;
    letter-spacing: 0.015em;
    color: #1e293b;
  }
  .fds-feature-desc {
    font-size: 1.04rem;
    line-height: 1.52;
    color: #475569;
    max-width: 100%;
  }
}

/* Plataforma - abas com imagem lateral */
.fds-platform-tabs {
  background: #ffffff;
  padding-top: 4.2rem;
  padding-bottom: 4.2rem;
}
.fds-platform-menu {
  border: 0;
  border-radius: 0;
  overflow: visible;
  background: transparent;
  padding: 0 0.35rem;
}
.fds-platform-tab {
  width: 100%;
  border: 0;
  border-bottom: 1px solid #e5e7eb;
  background: transparent;
  text-align: left;
  padding: 0.95rem 0;
  font-size: 1rem;
  color: #374151;
  display: flex;
  align-items: center;
  gap: 0.85rem;
  transition: background-color 0.2s ease, color 0.2s ease;
}
.fds-platform-tab:last-child {
  border-bottom: 0;
}
.fds-platform-tab:hover {
  background: transparent;
}
.fds-platform-tab.is-active {
  background: transparent;
  color: var(--accent);
  font-weight: 800;
}
.fds-platform-content {
  padding-top: 0.2rem;
}
.fds-platform-title {
  margin: 0 0 0.7rem;
  font-size: clamp(1.75rem, 3vw, 2.6rem);
  font-weight: 800;
  color: #111827;
  text-transform: none;
}
.fds-platform-desc {
  margin: 0 0 1.2rem;
  font-size: 1.05rem;
  color: #374151;
  line-height: 1.7;
}
.fds-platform-image-wrap {
  width: 100%;
  border-radius: 16px;
  overflow: hidden;
  max-width: 640px;
  margin: 0 auto;
  background: transparent;
}
.fds-platform-image-wrap img {
  width: 100%;
  height: auto;
  display: block;
  max-height: 420px;
  object-fit: contain;
}

.fds-platform-tab-ico {
  font-size: 1.25rem;
  line-height: 1;
  color: var(--accent);
}

.fds-platform-icons-grid {
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem 0.9rem;
}
.fds-platform-icon-box {
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 0.2rem 0.1rem;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  min-height: auto;
}
.fds-platform-icon-box i {
  color: var(--accent);
  font-size: 1.7rem;
}

/* Depoimentos - histórias de clientes */
.fds-testimonials {
  background: linear-gradient(180deg, #eef4ff 0%, #e9f1ff 100%);
  color: #0f172a;
  position: relative;
  overflow: hidden;
}
.fds-testimonials.section-padding {
  padding-top: 7.5rem;
  padding-bottom: 7.5rem;
}
.fds-testimonials .container {
  position: relative;
}
.fds-testimonials-bg {
  position: absolute;
  inset: 0;
  background-attachment: fixed;
  background-size: cover;
  background-position: center;
  z-index: 0;
}
.fds-testimonials-track-wrap {
  overflow: hidden;
  /* estende o carrossel até a borda direita do viewport,
     mantendo o título dentro da largura padrão do container */
  margin-right: calc((100vw - 100%) / -2);
}
.fds-testimonials .col-lg-8 {
  padding-right: 0;
}
.fds-testimonials-left {
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100%;
  /* deixa a coluna de texto um pouco mais larga
     para os cards não ficarem tão compridos */
  max-width: 460px;
  position: relative;
  z-index: 2;
}
.fds-testimonials-headline {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.fds-testimonials-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(226, 232, 240, 0.9);
  padding: 0.2rem 0.9rem;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.45);
}
.fds-testimonials-rating {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}
.fds-testimonials-rating-score {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--accent);
}
.fds-testimonials-rating-stars {
  font-size: 0.95rem;
  letter-spacing: 0.12em;
  color: var(--accent);
}
.fds-testimonials-title {
  font-size: 2.4rem;
  font-weight: 600;
  line-height: 1.3;
  letter-spacing: -0.02em;
  max-width: 22ch;
  color: #0f172a;
}
.fds-testimonials-nav {
  display: flex;
  gap: 0.75rem;
  margin-top: 2.5rem;
}
.fds-testimonials-arrow {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  border: none;
  background: var(--accent);
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  cursor: pointer;
  box-shadow: none;
  transition: transform 0.15s ease, background-color 0.15s ease, color 0.15s ease;
}
.fds-testimonials-arrow i {
  line-height: 1;
}
.fds-testimonials-arrow:hover {
  background: var(--accent-hover);
  color: #ffffff;
  transform: translateY(-1px);
  box-shadow: none;
}
.fds-testimonials-track {
  display: flex;
  align-items: stretch;
  gap: 1rem;
  padding-right: 0;
  transition: transform 0.45s cubic-bezier(0.22, 0.61, 0.36, 1);
  position: relative;
  z-index: 2;
}
.fds-testimonial-card {
  background: #ffffff;
  color: #0f172a;
  border-radius: 20px;
  border: 1px solid #dbe7ff;
  /* mais alto e um pouco mais compacto na largura */
  padding: 2.5rem 2.4rem 2.25rem;
  flex-direction: column;
  height: 100%;
  min-height: 260px;
  box-shadow: none;
  display: flex;
  /* largura pensada para 3 cards visíveis (2 inteiros + 1 cortado) */
  flex: 0 0 46%;
  max-width: 46%;
  transform: none;
  transition: transform 0.45s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.fds-testimonial-card.is-active {
  opacity: 1;
}
.fds-testimonial-card.is-next,
.fds-testimonial-card.is-next2 {
  opacity: 1;
  box-shadow: none;
}
.fds-testimonial-quote {
  font-size: 3rem;
  line-height: 1;
  color: #0f172a;
  margin-bottom: 0.75rem;
}
.fds-testimonial-text {
  font-size: 1.05rem;
  line-height: 1.7;
  margin: 0 0 1.75rem;
}
.fds-testimonial-footer {
  margin-top: auto;
  display: flex;
  align-items: center;
  gap: 1rem;
}
.fds-testimonial-avatar {
  width: 56px;
  height: 56px;
  border-radius: 999px;
  background: linear-gradient(135deg, #0ea5e9, #1d4ed8);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  color: #e0f2fe;
  font-size: 1.1rem;
}
.fds-testimonial-meta {
  display: flex;
  flex-direction: column;
}
.fds-testimonial-name {
  font-weight: 600;
  margin: 0;
}
.fds-testimonial-brand {
  margin: 0;
  font-size: 0.9rem;
  color: #64748b;
}

/* Ajustes mobile para depoimentos */
@media (max-width: 767px) {
  .fds-testimonials.section-padding {
    padding-top: 3.25rem;
    padding-bottom: 3.25rem;
  }
  .fds-testimonials-track-wrap {
    margin-right: 0;
  }
  .fds-testimonials-title {
    font-size: 1.6rem;
  }
  .fds-testimonials-track {
    display: flex;
    align-items: stretch;
    gap: 0.75rem;
  }
  .fds-testimonial-card {
    flex: 0 0 100%;
    max-width: 100%;
    width: 100%;
    min-height: auto;
    padding: 1.1rem 1rem;
  }
  .fds-testimonial-quote {
    font-size: 1.8rem;
    margin-bottom: 0.5rem;
  }
  .fds-testimonial-text {
    font-size: 0.9rem;
    line-height: 1.55;
  }
}

/* ===== Showcase / Portfólio (estilo Nuvemshop simplificado) ===== */
.fds-showcase {
  position: relative;
  background: var(--fds-showcase-bg, #020617);
  color: #e5e7eb;
  overflow: hidden;
}
.fds-showcase.section-padding {
  padding-top: 4rem;
  padding-bottom: 4rem;
}
.fds-showcase-bg {
  position: absolute;
  inset: 0;
  background: var(--fds-showcase-bg, #020617);
  clip-path: ellipse(80% 100% at 50% 100%);
  transform: translateY(100vh);
  transition: transform 0.9s cubic-bezier(0.16, 1, 0.3, 1);
}
.fds-showcase-bg.has-image {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.fds-showcase-overlay {
  position: absolute;
  inset: 0;
  background: rgba(2, 6, 23, 0.62);
  z-index: 0;
}
.fds-showcase.is-visible .fds-showcase-bg {
  transform: translateY(0);
}
.fds-showcase-title {
  position: relative;
  z-index: 1;
  font-size: 2.2rem;
  font-weight: 600;
  color: #1f2044;
  margin-bottom: 2rem;
  text-align: center;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}

/* Grid de cards (mostra todos) */
.fds-showcase-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
}
.fds-showcase-item {
  min-width: 0;
}

/* Layout “Nuvemshop” (previews grandes, limpo) */
.fds-showcase-ns-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.75rem;
  align-items: stretch;
}
.fds-showcase-ns-item { min-width: 0; }

/* Portfólio - carrossel (mesmo modelo dos depoimentos) */
.fds-showcase-head {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 1.25rem;
}
.fds-showcase-head .fds-showcase-title { margin-bottom: 0; }
.fds-showcase-nav {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.fds-showcase-arrow {
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid rgba(31, 32, 68, 0.18);
  background: rgba(255, 255, 255, 0.72);
  color: #1f2044;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.10);
  transition: transform 0.18s ease, background 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}
.fds-showcase-arrow:hover {
  transform: translateY(-1px);
  border-color: rgba(37, 99, 235, 0.35);
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.14);
}
.fds-showcase-arrow:active {
  transform: translateY(0);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.10);
}
.fds-showcase-arrow:disabled {
  opacity: 0.45;
}
.fds-showcase-arrow:focus-visible {
  outline: 3px solid rgba(37, 99, 235, 0.22);
  outline-offset: 3px;
}
.fds-showcase-track-wrap {
  position: relative;
  z-index: 1;
  overflow: hidden;
}
.fds-showcase-track {
  display: flex;
  gap: 1.5rem;
  transform: translateX(0);
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}
.fds-showcase-item {
  /* 2 cards visíveis (cálculo exato) */
  flex: 0 0 calc((100% - 1.5rem) / 2);
  max-width: calc((100% - 1.5rem) / 2);
  opacity: 0.45;
  transition: opacity 0.35s ease, transform 0.35s ease;
}
.fds-showcase-item.is-active {
  opacity: 1;
}
.fds-showcase-item.is-next,
.fds-showcase-item.is-next2 {
  opacity: 1;
}

/* Toggles (pílulas -> círculo no ativo) */
.fds-showcase-dots {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: -52px;
  flex-wrap: wrap;
  align-items: center; /* mantém tudo na mesma linha/altura */
}
.fds-showcase-dot {
  width: 28px;
  height: 14px; /* mesma altura do ativo */
  border-radius: 999px;
  border: 1px solid rgba(31, 32, 68, 0.18);
  background: rgba(255, 255, 255, 0.72);
  padding: 0;
  cursor: pointer;
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
  transition: width 0.22s ease, height 0.22s ease, background 0.22s ease, border-color 0.22s ease, border-radius 0.22s ease, box-shadow 0.22s ease, transform 0.22s ease;
}
.fds-showcase-dot:hover {
  border-color: rgba(37, 99, 235, 0.45);
  background: rgba(37, 99, 235, 0.10);
  transform: translateY(-1px);
}
.fds-showcase-dot.is-active {
  width: 14px;
  height: 14px;
  border-radius: 999px;
  background: linear-gradient(135deg, #2563eb, #1d4ed8);
  border-color: rgba(37, 99, 235, 0.85);
  box-shadow: 0 14px 30px rgba(37, 99, 235, 0.24);
}
.fds-showcase-dot:focus-visible {
  outline: 3px solid rgba(37, 99, 235, 0.25);
  outline-offset: 3px;
}
.fds-showcase-ns-card {
  position: relative;
  display: flex;
  flex-direction: column;
  border-radius: 0;
  overflow: hidden;
  background: rgba(255,255,255,0.03);
  border: 0;
  box-shadow: none;
  transform: translateZ(0);
  transition: none;
}
.fds-showcase-ns-card:hover {
  transform: none;
}
.fds-showcase-ns-media {
  position: relative;
  overflow: hidden;
}
.fds-showcase-ns-media-link {
  display: block;
  color: inherit;
  text-decoration: none;
  cursor: pointer;
}
.fds-showcase-ns-img {
  width: 100%;
  height: clamp(220px, 28vw, 440px);
  object-fit: cover;
  display: block;
  border-radius: 0;
  transform: scale(1);
  transition: transform 0.45s cubic-bezier(0.16, 1, 0.3, 1);
}
.fds-showcase-ns-card:hover .fds-showcase-ns-img {
  transform: scale(1.05);
}

/* Ícone de link no hover (fundo azul) */
.fds-showcase-ns-linkicon {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 54px;
  height: 54px;
  margin-left: -27px;
  margin-top: -27px;
  border-radius: 999px;
  background: linear-gradient(135deg, #2563eb, #1d4ed8);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transform: scale(0.92);
  box-shadow: 0 16px 34px rgba(37, 99, 235, 0.28);
  transition: opacity 0.22s ease, transform 0.22s ease, box-shadow 0.22s ease;
  pointer-events: none;
}
.fds-showcase-ns-linkicon i {
  font-size: 1.35rem;
  line-height: 1;
}
.fds-showcase-ns-card:hover .fds-showcase-ns-linkicon {
  opacity: 1;
  transform: scale(1);
}
.fds-showcase-ns-gradient {
  display: none;
}
.fds-showcase-ns-arrow {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 52px;
  height: 52px;
  margin-left: -26px;
  margin-top: -26px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.55);
  border: 1px solid rgba(148, 163, 184, 0.22);
  color: #f8fafc;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: none;
  transform: none;
  transition: none;
}
.fds-showcase-ns-card:hover .fds-showcase-ns-arrow {
  transform: none;
  background: rgba(15, 23, 42, 0.55);
  border-color: rgba(148, 163, 184, 0.22);
}
.fds-showcase-ns-arrow i { font-size: 1.1rem; }

.fds-showcase-ns-body {
  /* leve deslocamento para a direita */
  padding: 14px 6px 0 18px;
  display: block;
  flex: 0 0 auto;
  min-height: 230px; /* mantém altura estável entre cards */
}
.fds-showcase-ns-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.fds-showcase-ns-left {
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
}
.fds-showcase-ns-title {
  margin: 0;
  font-size: 1.15rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: #1f2044;
  max-width: 100%;
  line-height: 1.25;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Ajustes mobile para portfólio / showcase */
@media (max-width: 767px) {
  .fds-showcase.section-padding {
    padding-top: 3rem;
    padding-bottom: 3rem;
  }
  .fds-showcase-track {
    gap: 1rem;
  }
  .fds-showcase-item {
    flex: 0 0 100%;
    max-width: 100%;
  }
  .fds-showcase-dots {
    margin-top: 1.5rem;
  }
}
.fds-showcase-ns-techimg-wrap {
  display: flex;
  align-items: center;
  min-height: 52px; /* reserva espaço mesmo sem tecnologia */
}
.fds-showcase-ns-techimg {
  width: auto;
  height: auto;
  max-height: 46px;
  max-width: 280px;
  object-fit: contain;
  display: block;
}

.fds-showcase-ns-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 8px;
  padding: 12px 18px;
  border-radius: 999px;
  border: 1px solid rgba(37, 99, 235, 0.22);
  background: rgba(37, 99, 235, 0.08);
  color: #1f2044;
  font-weight: 600;
  text-decoration: none;
  width: fit-content;
  transition: transform 0.18s ease, background 0.18s ease, border-color 0.18s ease;
  align-self: flex-start;
}

@media (max-width: 767px) {
  /* Mobile: botão abaixo do logo de tecnologias, ocupando a largura do conteúdo */
  .fds-showcase-ns-row {
    flex-direction: column;
    align-items: stretch;
  }
  .fds-showcase-ns-left {
    width: 100%;
    align-items: center;
    text-align: center;
  }
  .fds-showcase-ns-title {
    max-width: 100%;
  }
  .fds-showcase-ns-techimg-wrap {
    width: 100%;
    justify-content: center;
  }
  .fds-showcase-ns-btn {
    align-self: stretch;
    width: 100%;
    text-align: center;
  }
}
.fds-showcase-ns-btn:hover {
  transform: translateY(-1px);
  background: rgba(37, 99, 235, 0.12);
  border-color: rgba(37, 99, 235, 0.35);
}
.fds-showcase-ns-btn:active {
  transform: translateY(0);
}


/* Card (estilo da referência) */
.fds-showcase-card {
  height: 100%;
  display: flex;
  flex-direction: column;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(148, 163, 184, 0.14);
  overflow: hidden;
  box-shadow: none;
  transition: transform 0.25s ease, border-color 0.25s ease, background 0.25s ease;
}
.fds-showcase-card:hover {
  transform: translateY(-2px);
  border-color: rgba(56, 189, 248, 0.28);
  background: rgba(255, 255, 255, 0.055);
}
.fds-showcase-card-media {
  position: relative;
  background: transparent;
  padding: 14px 14px 0;
}
.fds-showcase-card-media::after {
  content: "";
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 0;
  height: 85px;
  border-radius: 16px;
  background: linear-gradient(to top, rgba(2, 6, 23, 0.72), rgba(2, 6, 23, 0));
  pointer-events: none;
}
.fds-showcase-card-img {
  width: 100%;
  aspect-ratio: 16 / 9;
  height: auto;
  object-fit: cover;
  border-radius: 16px;
  display: block;
  transform: translateZ(0);
}
.fds-showcase-card-body {
  padding: 16px 18px 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.fds-showcase-card-title {
  margin: 0;
  font-size: 1.2rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: #f9fafb;
}
.fds-showcase-card-desc {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.55;
  color: rgba(226, 232, 240, 0.74);
  min-height: 3.1em; /* consistência */
}
.fds-showcase-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 4px;
}
.fds-showcase-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(148, 163, 184, 0.14);
  color: rgba(241, 245, 249, 0.92);
  font-size: 0.85rem;
  font-weight: 500;
}
.fds-showcase-tag-icon {
  display: none;
}
.fds-showcase-card-btn {
  margin-top: auto;
  align-self: flex-start;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(148, 163, 184, 0.18);
  color: #f9fafb;
  text-decoration: none;
  font-weight: 600;
  font-size: 0.9rem;
  display: inline-flex;
  align-items: center;
  backdrop-filter: blur(10px);
  transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}
.fds-showcase-card-btn:hover {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(56, 189, 248, 0.40);
}
@media (max-width: 767px) {
  .fds-showcase.section-padding {
    padding-top: 5.5rem;
    padding-bottom: 5.5rem;
  }
  .fds-showcase-title {
    font-size: 1.7rem;
  }
  .fds-showcase-grid {
    grid-template-columns: 1fr;
    gap: 1.1rem;
  }
  .fds-showcase-head {
    justify-content: center;
    margin-bottom: 1rem;
  }
  .fds-showcase-arrow {
    width: 44px;
    height: 44px;
  }
  .fds-showcase-track {
    gap: 1rem;
  }
  .fds-showcase-item {
    flex: 0 0 100%;
    max-width: 100%;
  }
  .fds-showcase-ns-img {
    width: 100%;
    height: auto;
    object-fit: cover;
  }
  .fds-showcase-dots {
    gap: 8px;
    margin-top: 12px; /* espaço menor entre botão e bolinhas no mobile */
  }
  .fds-showcase-dot { width: 24px; height: 13px; }
  .fds-showcase-dot.is-active { width: 13px; height: 13px; }
  .fds-showcase-ns-linkicon {
    width: 48px;
    height: 48px;
    margin-left: -24px;
    margin-top: -24px;
  }
  .fds-showcase-ns-body {
    min-height: 210px;
  }
  .fds-showcase-ns-row {
    align-items: flex-start;
    gap: 12px;
  }
  .fds-showcase-ns-left {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .fds-showcase-ns-title {
    font-size: 1.05rem;
    margin-top: 0;
  }
  .fds-showcase-ns-techimg {
    max-height: 42px;
    max-width: 240px;
  }
  .fds-showcase-ns-btn {
    margin-top: 10px;
    padding: 11px 16px;
  }
  .fds-showcase-card {
    border-radius: 18px;
  }
  .fds-showcase-card-media {
    padding: 12px 12px 0;
  }
  .fds-showcase-card-img {
    border-radius: 14px;
  }
  .fds-showcase-card-body {
    padding: 14px;
    gap: 8px;
  }
  .fds-showcase-card-title {
    font-size: 1.05rem;
  }
  .fds-showcase-card-desc {
    font-size: 0.92rem;
    min-height: 2.8em;
  }
}

@media (max-width: 991px) {
  .fds-showcase-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .fds-showcase-ns-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 991px) {
  .fds-platform-tabs {
    padding-top: 3rem;
    padding-bottom: 3rem;
  }
  .fds-platform-icons-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .fds-platform-title {
    font-size: 1.55rem;
  }
  .fds-platform-desc {
    font-size: 0.98rem;
  }
  .fds-portfolio-tabs {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .fds-portfolio-image-wrap img {
    min-height: 190px;
  }
  .fds-testimonials.section-padding {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }
  .fds-testimonials-track {
    gap: 1.25rem;
  }
}
@media (max-width: 767px) {
  .fds-platform-tab {
    padding: 0.8rem 0;
    font-size: 0.95rem;
  }
  .fds-platform-icons-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding: 0;
  }
  .fds-platform-icon-box {
    min-height: auto;
    padding: 0.25rem 0.1rem;
  }
  .fds-platform-title {
    font-size: 1.25rem;
  }
  .fds-platform-desc {
    font-size: 0.92rem;
    line-height: 1.6;
  }
  .fds-portfolio-tabs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .fds-portfolio-tab {
    min-height: 48px;
    font-size: 0.85rem;
  }
  .fds-testimonials-title {
    font-size: 1.7rem;
    margin-bottom: 1.75rem;
  }
  .fds-testimonials-track {
    flex-direction: column;
  }
  .fds-testimonial-card {
    padding: 1.9rem 1.75rem 1.75rem;
  }
  .fds-testimonial-card.is-next {
    opacity: 1;
  }
}

/* Depoimentos mobile premium (override final) */
@media (max-width: 767px) {
  .fds-testimonials {
    background: linear-gradient(180deg, #f3f7ff 0%, #edf3ff 100%);
  }
  .fds-testimonials.section-padding {
    padding-top: 2.7rem;
    padding-bottom: 2.7rem;
  }
  .fds-testimonials .row {
    row-gap: 1rem;
  }
  .fds-testimonials-left {
    max-width: 100%;
  }
  .fds-testimonials-headline {
    gap: 0.5rem;
  }
  .fds-testimonials-rating-score,
  .fds-testimonials-rating-stars {
    font-size: 1.05rem;
  }
  .fds-testimonials-title {
    font-size: clamp(1.95rem, 8.3vw, 2.35rem);
    line-height: 1.08;
    letter-spacing: -0.02em;
    margin: 0;
  }
  .fds-testimonials-nav {
    margin-top: 1.15rem;
    gap: 0.6rem;
  }
  .fds-testimonials-arrow {
    width: 50px;
    height: 50px;
    border-radius: 13px;
    box-shadow: 0 10px 22px rgba(225, 7, 67, 0.22);
  }
  .fds-testimonials-track-wrap {
    margin-right: 0;
    overflow: hidden;
    padding-left: 0.35rem;
    padding-right: 0.35rem;
  }
  .fds-testimonials-track {
    flex-direction: row !important; /* mantém carrossel horizontal no mobile */
    align-items: stretch;
    gap: 0.9rem;
    will-change: transform;
  }
  .fds-testimonial-card {
    flex: 0 0 100%;
    max-width: 100%;
    width: 100%;
    box-sizing: border-box;
    min-height: 210px;
    border-radius: 18px;
    border: 1px solid #dbe7ff;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
    padding: 1.35rem 1.15rem 1.1rem;
  }
  .fds-testimonial-quote {
    font-size: 2.2rem;
    margin-bottom: 0.35rem;
    color: #0f172a;
  }
  .fds-testimonial-text {
    font-size: 1.03rem;
    line-height: 1.52;
    color: #1e293b;
    margin-bottom: 1.15rem;
  }
  .fds-testimonial-avatar {
    width: 50px;
    height: 50px;
  }
  .fds-testimonial-name {
    font-size: 1.05rem;
    color: #0f172a;
  }
  .fds-testimonial-brand {
    font-size: 0.9rem;
  }
}

/* FAQ - Perguntas frequentes (clean) */
.fds-faq {
  position: relative;
  overflow: hidden;
  background: #ffffff;
  color: #0f172a;
  min-height: 420px;
}
.fds-faq::before {
  content: "";
  position: absolute;
  top: -84px;
  left: 0;
  width: 100%;
  height: 84px;
  background: linear-gradient(174deg, #f5f3f2 49%, #ffffff 50%);
  z-index: 1;
}
.fds-faq.section-padding {
  padding-top: 6rem;
  padding-bottom: 6rem;
}
.fds-faq .container.fds-faq-container {
  z-index: 2;
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
}
@media (min-width: 992px) {
  .fds-faq .container.fds-faq-container {
    padding-left: var(--bs-gutter-x, 0.75rem);
    padding-right: var(--bs-gutter-x, 0.75rem);
  }
}
.fds-faq-col-title {
  padding-top: 0.25rem;
  margin-bottom: 1rem;
}
.fds-faq .col-lg-7.offset-lg-1 {
  padding-top: 0.5rem;
}
.fds-faq-heading {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  color: #0f172a;
  line-height: 1.2;
}
.fds-faq-title-line {
  display: block;
  font-size: clamp(1.6rem, 3.2vw, 2.3rem);
  font-weight: 700;
  font-family: inherit;
  color: #0f172a;
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin-bottom: 0.25rem;
}
.fds-faq-subtitle-line {
  display: block;
  font-size: clamp(1.5rem, 3vw, 2.1rem);
  font-weight: 400;
  font-family: Georgia, "Times New Roman", serif;
  font-style: italic;
  color: #475569;
  line-height: 1.35;
}
.fds-faq-login-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.85rem;
  margin-top: 1.3rem;
}
.fds-faq-login-card {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.9rem 1rem;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: #f8f8f8;
  color: #0f172a;
  text-decoration: none;
  transition: border-color 0.2s ease, background-color 0.2s ease, transform 0.2s ease;
}
.fds-faq-login-card:hover {
  border-color: color-mix(in srgb, var(--accent) 28%, #e5e7eb);
  background: #ffffff;
  transform: translateY(-1px);
  color: #0f172a;
}
.fds-faq-login-ico {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 10%, #ffffff);
  flex: 0 0 30px;
}
.fds-faq-login-ico i {
  font-size: 0.9rem;
  line-height: 1;
}
.fds-faq-login-txt {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.fds-faq-login-title {
  font-size: 0.98rem;
  font-weight: 600;
  line-height: 1.15;
  color: #111827;
}
.fds-faq-login-sub {
  font-size: 0.78rem;
  color: #64748b;
  margin-top: 0.18rem;
  line-height: 1.25;
}
.fds-faq-accordion {
  --bs-accordion-bg: transparent;
  --bs-accordion-border-color: transparent;
  --bs-accordion-btn-bg: transparent;
  --bs-accordion-active-bg: transparent;
  --bs-accordion-active-color: #0f172a;
  --bs-accordion-btn-color: #0f172a;
  --bs-accordion-btn-focus-box-shadow: none;
  --bs-accordion-border-width: 0;
  display: grid;
  gap: 1.15rem;
}
.fds-faq-item {
  background: #f8f8f8;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  margin: 0;
  overflow: hidden;
}
.fds-faq .faq-title.h4 {
  font-size: 1.2rem;
  font-weight: 600;
  margin: 0;
}
.fds-faq-accordion .accordion-header {
  margin: 0;
}
.fds-faq-accordion .accordion-button {
  color: #0f172a;
  font-weight: 500;
  padding: 1.45rem 1.5rem;
  background: #fcfcfc;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  text-align: left;
  gap: 1rem;
}
.fds-faq-accordion .accordion-button::after {
  display: none;
}
.fds-faq-accordion .accordion-button .section-title.strong {
  flex: 1;
  font-size: 1.12rem;
  font-weight: 500;
  line-height: 1.35;
}
.fds-faq-accordion .accordion-button .d-flex {
  flex-shrink: 0;
}
.fds-faq .faq-title-icon.icon-circle {
  width: auto;
  height: auto;
  min-width: 0;
  min-height: 0;
  border-radius: 0;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.25s ease, color 0.2s ease;
  color: #334155;
}
.fds-faq-accordion .accordion-button:not(.collapsed) .faq-title-icon.icon-circle {
  transform: rotate(180deg);
  background: transparent;
  color: var(--accent);
}
.fds-faq .faq-title-icon.icon-circle svg {
  display: block;
  width: 24px;
  height: 24px;
}
.fds-faq-accordion .accordion-button:not(.collapsed) {
  background: #fcfcfc;
  box-shadow: none;
}
.fds-faq-accordion .accordion-button:not(.collapsed) .section-title.strong {
  color: var(--accent);
}
.fds-faq .section-body.faq-body.accordion-body {
  color: #334155;
  padding: 22px;
  line-height: 1.65;
  font-size: 1rem;
  border-top: 0;
  background: #ffffff;
  text-align: left;
}
.fds-faq .faq-body.accordion-body p {
  margin-bottom: 1rem;
}
.fds-faq .faq-body.accordion-body p:last-child {
  margin-bottom: 0;
}
.fds-faq .faq-body.accordion-body ul,
.fds-faq .faq-body.accordion-body ol {
  margin: 1rem 0 1rem 1.25rem;
  padding-left: 1.25rem;
}
.fds-faq .faq-body.accordion-body li {
  margin-bottom: 0.6rem;
}
.fds-faq .faq-body.accordion-body li:last-child {
  margin-bottom: 0;
}
.fds-faq .faq-body.accordion-body a {
  color: var(--accent);
  text-decoration: underline;
}
.fds-faq .faq-body.accordion-body a:hover {
  color: var(--accent-hover);
}
@media (max-width: 991px) {
  .fds-faq-item {
    margin: 0;
  }
  .fds-faq-accordion .accordion-button {
    padding-left: 1.1rem;
    padding-right: 1.1rem;
  }
  .fds-faq-accordion .accordion-button .section-title.strong {
    font-size: 1.05rem;
  }
  .fds-faq-login-cards {
    grid-template-columns: 1fr;
  }
  .fds-faq .section-body.faq-body.accordion-body {
    font-size: 0.95rem;
    padding: 0 1.1rem 1.1rem;
  }
  .fds-faq .section-body.faq-body.accordion-body,
  .fds-faq .faq-body.accordion-body.pe-0.pe-sm-5 {
    padding-left: 1.1rem;
    padding-right: 1.1rem;
  }
}
@media (max-width: 575px) {
  .fds-faq .col-lg-7.offset-lg-1 {
    margin-left: 0;
  }
  .fds-faq-accordion .accordion-button {
    padding-left: 1rem;
    padding-right: 3rem;
  }
  .fds-faq-accordion .accordion-button .section-title.strong {
    font-size: 1rem;
  }
  .fds-faq .section-body.faq-body.accordion-body,
  .fds-faq .faq-body.accordion-body.pe-0.pe-sm-5 {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

/* Ajustes mobile para FAQ (evita cortes e travamentos) */
@media (max-width: 991px) {
  .fds-faq.section-padding {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }
  .fds-faq::before {
    top: -56px;
    height: 56px;
  }
}

/* CTA simples acima da FAQ */
.pre-faq-cta {
  background: #ffffff;
}
.pre-faq-cta.section-padding {
  padding-top: 9rem;
  padding-bottom: 8.5rem;
}
.pre-faq-cta-inner {
  text-align: center;
  max-width: 680px;
  margin: 0 auto;
}
.pre-faq-cta-title {
  font-size: 3.5rem;
  font-weight: 500;
  color: #111827;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin-bottom: 0;
}
.pre-faq-cta-subtitle {
  display: block;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 3.7rem;
  font-weight: 300;
  font-style: italic;
  color: #111827;
  letter-spacing: 0;
  margin-top: -0.6rem;
  margin-bottom: 1.75rem;
}
.pre-faq-cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 52px;
  padding: 0 1.25rem;
  border-radius: 10px;
  background-color: var(--accent, #001074);
  color: #ffffff;
  font-weight: 600;
  font-size: 1rem;
  text-decoration: none;
  border: none;
  box-shadow: none;
  transition: transform 0.25s ease, opacity 0.2s ease, background-color 0.2s ease;
}
.pre-faq-cta-btn:hover {
  background-color: var(--accent-hover, #001b57);
  color: #ffffff;
  opacity: 0.95;
  transform: translateY(-3px);
}
@media (max-width: 575px) {
  .pre-faq-cta.section-padding {
    padding-top: 4rem;
    padding-bottom: 3.5rem;
  }
  .pre-faq-cta-title {
    font-size: 1.9rem;
  }
  .pre-faq-cta-subtitle {
    font-size: 2.2rem;
  }
  .pre-faq-cta-btn {
    padding: 0 1rem;
    font-size: 0.98rem;
  }
}
.cta-banner-card {
  background: #0032ba;
  border-radius: 24px;
  padding: 3.5rem 3rem;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: relative;
  overflow: hidden;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}
.cta-banner-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 50% at 50% -20%, rgba(57, 202, 242, 0.15), transparent);
  pointer-events: none;
}
.cta-banner-accent {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 120px;
  height: 3px;
  background: linear-gradient(90deg, transparent, #39caf2, transparent);
  border-radius: 0 0 3px 3px;
}
.cta-banner-content {
  width: 100%;
  max-width: 640px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.cta-banner-label {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #39caf2;
  margin-bottom: 0.75rem;
}
.cta-banner-title {
  font-size: 2rem;
  font-weight: 700;
  color: #ffffff;
  line-height: 1.25;
  margin-bottom: 1rem;
  letter-spacing: -0.02em;
}
.cta-banner-desc {
  color: rgba(255, 255, 255, 0.75);
  font-size: 1.05rem;
  line-height: 1.65;
  margin-bottom: 1.75rem;
}
.cta-banner-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 1rem;
}
.cta-banner-btn-primary {
  display: inline-flex;
  align-items: center;
  padding: 0.85rem 1.75rem;
  font-size: 1rem;
  font-weight: 500;
  color: #fff;
  background: transparent;
  border: 2px solid #fff;
  border-radius: 999px;
  text-decoration: none;
  transition: all 0.25s ease;
}
.cta-banner-btn-primary:hover {
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
  border-color: #fff;
  transform: translateY(-2px);
}
.cta-banner-link {
  color: rgba(255, 255, 255, 0.9);
  font-weight: 600;
  font-size: 1rem;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  transition: color 0.2s;
}
.cta-banner-link:hover {
  color: #39caf2;
}
@media (max-width: 767px) {
  .cta-banner-card { padding: 2.5rem 1.5rem; }
  .cta-banner-actions { justify-content: center; }
}
@media (max-width: 575px) {
  .cta-banner-title { font-size: 1.5rem; }
}

/* ===== Páginas legais / mapa do site (simples) ===== */
.legal-page {
  background: #f8fafc;
  padding-top: 0;
  margin-top: -2.5rem;
}
.legal-title-wrap {
  background: #0030b9;
  color: #fff;
  padding: 2.5rem 1.5rem 1.75rem;
  border-radius: 0 0 33px 33px;
  margin: 0 0 1.5rem 0;
  position: sticky;
  top: 64px;
  z-index: 90;
}
.legal-title {
  font-size: 1.5rem;
  font-weight: 600;
  margin: 0;
  text-align: center;
}
.legal-intro {
  font-size: 0.98rem;
  color: #64748b;
  max-width: 720px;
}
.legal-block {
  margin-bottom: 1.75rem;
}
.legal-block h2 {
  font-size: 1.05rem;
  font-weight: 600;
  color: #111827;
  margin-bottom: 0.5rem;
}
.legal-block p,
.legal-block ul li {
  font-size: 0.95rem;
  color: #4b5563;
  line-height: 1.7;
}
.legal-block ul {
  padding-left: 1.1rem;
  margin-bottom: 0.5rem;
}
.legal-updated {
  font-size: 0.85rem;
}

.sitemap-modern {
  background: transparent;
}
.sitemap-card {
  background: #fff;
  border-radius: 14px;
  padding: 1.25rem 1.35rem;
  height: 100%;
  border: 1px solid #e2e8f0;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
  transition: box-shadow 0.25s, border-color 0.25s;
}
.sitemap-card:hover {
  box-shadow: 0 8px 24px rgba(0, 48, 185, 0.08);
  border-color: rgba(0, 48, 185, 0.15);
}
.sitemap-card-title {
  font-size: 0.95rem;
  font-weight: 600;
  color: #0030b9;
  margin: 0 0 1rem 0;
  padding-bottom: 0.65rem;
  border-bottom: 1px solid #f1f5f9;
  letter-spacing: 0.01em;
}
.sitemap-card-list li {
  margin-bottom: 0.5rem;
}
.sitemap-card-list li:last-child {
  margin-bottom: 0;
}
.sitemap-card-link {
  display: inline-block;
  color: #64748b;
  font-size: 0.9rem;
  font-weight: 500;
  padding: 0.25rem 0;
  transition: color 0.2s, padding-left 0.2s;
}
.sitemap-card-link:hover {
  color: #0030b9;
  padding-left: 4px;
}

/* Mapa do site — visual neutro, sem cor primária */
.page-mapa-do-site .templates-hero {
  background: #ffffff;
}
.page-mapa-do-site .templates-hero .templates-hero-title,
.page-legal-institucional .templates-hero .templates-hero-title {
  text-align: left;
  color: #0f172a;
  font-size: 1.625rem;
  font-weight: 600;
}
@media (max-width: 575px) {
  .page-mapa-do-site .templates-hero .templates-hero-title,
  .page-legal-institucional .templates-hero .templates-hero-title {
    font-size: 1.4rem;
  }
}

/* Hero + secção: menos espaço entre o título da página e o texto abaixo */
.page-mapa-do-site .templates-hero,
.page-legal-institucional .templates-hero {
  padding-bottom: 28px;
}
.page-mapa-do-site .wp-care-section.py-5.bg-white,
.page-legal-institucional .wp-care-section.py-5.bg-white {
  padding-top: 1rem;
  padding-bottom: 2.5rem;
}

.page-mapa-do-site .sitemap-card {
  border-color: #e5e7eb;
}
.page-mapa-do-site .sitemap-card:hover {
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
  border-color: #d1d5db;
}
.page-mapa-do-site .sitemap-card-title {
  color: #111827;
  font-size: 0.875rem;
  font-weight: 600;
  margin-bottom: 0.65rem;
  padding-bottom: 0.45rem;
}
.page-mapa-do-site .sitemap-card-link {
  color: #4b5563;
}
.page-mapa-do-site .sitemap-card-link:hover {
  color: #1f2937;
}

/* Páginas legais (Termos, Privacidade, Cookies) — mesmo modelo do mapa do site */
.page-legal-institucional .templates-hero {
  background: #ffffff;
}
.page-legal-institucional .legal-intro {
  color: #64748b;
  margin-bottom: 1rem !important;
}
.page-legal-institucional .legal-block {
  margin-bottom: 1.25rem;
}
.page-legal-institucional .legal-block h2 {
  color: #111827;
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 0.35rem;
  margin-top: 0;
}
.page-legal-institucional .legal-block h2 + p,
.page-legal-institucional .legal-block h2 + ul {
  margin-top: 0;
}
.page-legal-institucional .legal-block p + p {
  margin-top: 0.65rem;
}
.page-legal-institucional .legal-block p,
.page-legal-institucional .legal-block ul li {
  color: #4b5563;
}
.page-legal-institucional .legal-block a {
  color: #374151;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.page-legal-institucional .legal-block a:hover {
  color: #111827;
}

/* Carrossel de Clientes e Parceiros */
.brand-strip {
  background: #ffffff;
}
.brand-strip-header {
  margin-bottom: 2.5rem;
}
.brand-strip-subtitle {
  font-size: 0.95rem;
  font-weight: 400;
  color: #6b7280;
}
.brand-strip-title {
  font-size: 2.1rem;
  font-weight: 700;
  color: #111827;
  line-height: 1.3;
}
.brand-strip-track-wrap {
  overflow: hidden;
  padding: 0.75rem 0 1.25rem;
}
.brand-strip-track {
  display: flex;
  align-items: center;
  gap: 3rem;
  animation: none;
  will-change: transform;
}
.brand-strip-item {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
.brand-strip-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}
.brand-strip-link img {
  max-height: 56px;
  width: auto;
  object-fit: contain;
  filter: grayscale(1);
  opacity: 0.7;
  transition: filter 0.2s ease-out, opacity 0.2s ease-out, transform 0.2s ease-out;
}
.brand-strip-link:hover img {
  filter: grayscale(0);
  opacity: 1;
  transform: translateY(-1px);
}

/* Central do cliente — bloco abaixo de parceiros (home) */
.fds-central-cliente {
  background: transparent;
  border-top: none;
}
.fds-central-cliente.section-padding {
  padding-top: 6rem;
  padding-bottom: 6rem;
}
/* Largura igual às demais secções (.container do Bootstrap, como portfólio / FAQ) */
.fds-central-cliente .container {
  position: relative;
}
@media (min-width: 992px) {
  .fds-central-cliente .container {
    padding-left: var(--bs-gutter-x, 0.75rem);
    padding-right: var(--bs-gutter-x, 0.75rem);
  }
}
/* Sem “card”: fundo transparente, sem borda nem moldura na imagem */
.fds-central-cliente-visual {
  background: transparent;
  border: none;
  border-radius: 0;
  box-shadow: none;
  overflow: visible;
  width: 100%;
}
.fds-central-cliente-img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: middle;
  object-fit: contain;
}
/* Mesmo patamar tipográfico da seção "Por que a Fábrica dos Sites?" (.fds-why-title), com peso extra */
.fds-central-cliente-title {
  margin: 0 0 1rem;
  font-size: clamp(1.9rem, 3.9vw, 2.7rem);
  line-height: 1.04;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #0f172a;
}
.fds-central-cliente-text {
  font-size: 1.1rem;
  line-height: 1.65;
  color: #4b5563;
  max-width: none;
}
.fds-central-cliente-cta {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0;
  font-weight: 600;
  font-size: 1rem;
  color: var(--accent, #2e93ee);
  background: none;
  border: none;
  text-decoration: none;
  transition: color 0.2s ease;
}
.fds-central-cliente-cta:hover,
.fds-central-cliente-cta:focus-visible {
  color: #000000;
}
.fds-central-cliente-cta-ico {
  font-size: 1.05em;
  line-height: 1;
  transition: color 0.2s ease;
}
@media (max-width: 767px) {
  .fds-central-cliente.section-padding {
    padding-top: 3.25rem;
    padding-bottom: 3.25rem;
  }
  .fds-central-cliente-title {
    font-size: clamp(1.9rem, 8.2vw, 2.2rem);
    line-height: 1.06;
  }
}
@media (max-width: 991px) {
  .fds-central-cliente {
    text-align: center;
  }
  .fds-central-cliente-text {
    margin-left: auto;
    margin-right: auto;
  }
}

/* Sitefy — vitrine site por aluguel (home) */
.sitefy-home-section {
  background: linear-gradient(180deg, #f8fafc 0%, #ffffff 45%);
  border-top: 0;
}
@media (min-width: 992px) {
  .sitefy-home-section .container {
    padding-left: var(--bs-gutter-x, 0.75rem);
    padding-right: var(--bs-gutter-x, 0.75rem);
  }
}
.sitefy-home-kicker {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
}
.sitefy-home-title {
  font-size: clamp(1.5rem, 4vw, 2rem);
  font-weight: 700;
  color: #0f172a;
  letter-spacing: -0.02em;
}
.sitefy-home-cat-title {
  color: #334155;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid var(--accent-light, rgba(46, 147, 238, 0.2));
  display: inline-block;
}
.sitefy-home-card-inner {
  background: #fff;
  border: 1px solid #e9ecef;
  border-radius: 16px;
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: box-shadow 0.25s ease, border-color 0.2s ease, transform 0.2s ease;
}
.sitefy-home-card-btn:hover .sitefy-home-card-inner,
.sitefy-home-card-btn:focus-visible .sitefy-home-card-inner,
.sitefy-home-card-open:hover .sitefy-home-card-inner,
.sitefy-home-card-open:focus-visible .sitefy-home-card-inner {
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.08);
  border-color: rgba(46, 147, 238, 0.35);
  transform: translateY(-3px);
}
.sitefy-home-card-btn:focus-visible,
.sitefy-home-card-open:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.sitefy-home-card-footer {
  padding: 0.5rem 1rem 1rem;
  margin-top: auto;
}
.sitefy-home-card-suffix {
  font-weight: 600;
  color: #64748b;
  font-size: 0.8rem;
}
.sitefy-home-card-cta {
  font-weight: 600;
  border-radius: 12px;
  padding-top: 0.85rem;
  padding-bottom: 0.85rem;
  font-size: 0.9rem;
  line-height: 1.35;
  box-shadow: none;
  /* cor principal do painel (config cor_principal → --accent no header) */
  background-color: var(--accent);
  border: 1px solid var(--accent);
  color: #fff;
}
.sitefy-home-card-cta:hover,
.sitefy-home-card-cta:focus {
  background-color: var(--accent-hover);
  border-color: var(--accent-hover);
  color: #fff;
  filter: none;
}
.sitefy-home-card-cta:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.sitefy-modelos-page .sitefy-home-head {
  text-align: left;
}
.sitefy-modelos-search .form-control {
  border-radius: 10px;
}
.sitefy-section-disclaimer {
  font-size: 0.68rem;
  line-height: 1.45;
  color: #94a3b8;
  max-width: 36rem;
  margin-left: auto;
  margin-right: auto;
  padding-top: 1.5rem;
  margin-top: 0.25rem;
}
.sitefy-home-card-media {
  aspect-ratio: 16 / 10;
  background: #f1f5f9;
}
.sitefy-home-card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.sitefy-home-card-placeholder {
  width: 100%;
  height: 100%;
  min-height: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #94a3b8;
  font-size: 2rem;
}
.sitefy-home-card-body {
  padding: 0.85rem 1rem 0.95rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.sitefy-home-card-title {
  font-size: 0.95rem;
  font-weight: 600;
  color: #111827;
  margin: 0;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.sitefy-home-card-price {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--accent);
  margin: 0;
  padding-top: 0.05rem;
}
.sitefy-home-card-rec {
  font-weight: 500;
  font-size: 0.8rem;
  color: #64748b;
}
.sitefy-modal-content {
  border-radius: 1rem;
  border: none;
  box-shadow: 0 20px 50px rgba(15, 23, 42, 0.12);
}
.sitefy-modal-kicker:empty {
  display: none;
}
.sitefy-modal-facts {
  font-size: 0.78rem;
  line-height: 1.45;
  color: #94a3b8;
}
.sitefy-modal-fact {
  display: flex;
  align-items: flex-start;
  gap: 0.4rem;
}
.sitefy-modal-fact-icon {
  flex-shrink: 0;
  margin-top: 0.1rem;
  font-size: 0.85rem;
  opacity: 0.55;
  color: #94a3b8;
}
.sitefy-modal-fact-label {
  font-weight: 500;
  color: #7c8a9a;
}
.sitefy-modal-cta {
  border-radius: 12px !important;
  background: var(--accent) !important;
  border: none !important;
  color: #fff !important;
}
.sitefy-modal-cta:hover,
.sitefy-modal-cta:focus-visible {
  background: var(--accent-hover) !important;
  color: #fff !important;
}
.sitefy-modal-media-side {
  border: 1px solid rgba(15, 23, 42, 0.08);
}
.sitefy-modal-img-side {
  display: block;
  max-height: min(320px, 55vh);
  object-fit: cover;
  aspect-ratio: 4 / 3;
}
@media (max-width: 767.98px) {
  .sitefy-modal-img-side {
    max-height: 200px;
    aspect-ratio: 16 / 9;
  }
}
.sitefy-modal-demo {
  border-radius: 12px !important;
  border: 2px solid var(--accent) !important;
  background: transparent !important;
  color: var(--accent) !important;
}
.sitefy-modal-demo:hover,
.sitefy-modal-demo:focus-visible {
  background: #e9ecef !important;
  color: #495057 !important;
  border-color: #adb5bd !important;
}

.fds-service-card {
  flex: 0 0 var(--service-card-width, 300px);
  width: var(--service-card-width, 300px);
  min-width: 240px;
  flex-shrink: 0;
  scroll-snap-align: start;
  background: #fff;
  border: 1px solid #e9ecef;
  border-radius: 16px;
  padding: 1.5rem;
  position: relative;
  box-shadow: 0 4px 16px rgba(0,0,0,0.04);
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.2s;
}
.fds-service-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 8px 24px rgba(46,147,238,0.12);
  border-color: rgba(46,147,238,0.4);
}
.fds-service-featured {
  border-color: var(--accent);
  box-shadow: 0 4px 20px rgba(46,147,238,0.12);
}
.fds-service-featured:hover {
  box-shadow: 0 10px 28px rgba(46,147,238,0.18);
}
.fds-service-badge {
  position: absolute;
  top: 1rem;
  right: 1rem;
  font-size: 0.7rem;
  font-weight: 600;
  padding: 0.25rem 0.5rem;
  border-radius: 9999px;
}
.fds-service-badge-ai {
  background: #fff;
  border: 1px solid var(--accent);
  color: var(--accent);
}
.fds-service-badge-new {
  background: var(--accent-secondary);
  color: #fff;
  border: none;
}
.fds-service-icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(46,147,238,0.1);
  color: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  margin-bottom: 1rem;
}
.fds-service-name {
  font-size: 1.15rem;
  font-weight: 700;
  color: #202145;
  margin-bottom: 0.5rem;
}
.fds-service-subtitle {
  font-size: 0.8rem;
  color: var(--accent);
  font-weight: 600;
  margin: -0.25rem 0 0.25rem 0;
}
.fds-service-desc {
  font-size: 0.9rem;
  color: #6c757d;
  line-height: 1.5;
  margin-bottom: 1rem;
}
.fds-service-price {
  font-size: 0.9rem;
  color: #495057;
  margin-bottom: 0.75rem;
}
.fds-service-price strong,
.fds-service-price .text-primary {
  color: #2e93ee !important;
}
.fds-service-link {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  transition: gap 0.2s;
}
.fds-service-link:hover {
  color: var(--accent-hover);
  gap: 0.5rem;
}

/* ===== Seção Planos ===== */
.section-title-host {
  font-size: 2rem;
  font-weight: 700;
  color: var(--text);
}
.host-plan-card {
  transition: transform 0.2s, box-shadow 0.2s;
  border-radius: 12px;
}
.host-plan-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 30px rgba(0,0,0,0.12) !important;
}
.host-plan-featured {
  transform: scale(1.02);
}
.host-plan-featured:hover {
  transform: scale(1.02) translateY(-4px);
}
.host-plan-name {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 0.5rem;
}
.host-plan-price {
  font-size: 2rem;
  font-weight: 700;
  color: var(--text);
}
.host-plan-price .currency {
  font-size: 1rem;
  font-weight: 600;
}
.host-plan-price .period {
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--text-muted);
}
.host-plan-features li {
  padding: 0.35rem 0;
  font-size: 0.95rem;
}
.host-plan-features li i {
  margin-right: 0.5rem;
}

/* ===== Benefícios ===== */
.host-benefit-icon {
  font-size: 2.5rem;
  color: var(--accent);
  margin-bottom: 1rem;
}
.host-benefit-title {
  font-size: 1.1rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
}
.host-benefit-desc {
  font-size: 0.9rem;
}

/* ===== Avaliações Google Meu Negócio ===== */
.google-reviews-section {
  background: #fff;
}
.google-reviews-badge {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--accent);
  letter-spacing: 0.02em;
}
.google-reviews-title {
  font-size: 1.75rem;
  font-weight: 700;
  color: #1f2044;
  max-width: 640px;
}
.google-reviews-track-wrap {
  overflow-x: auto;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding: 0.5rem 0;
}
.google-reviews-track-wrap::-webkit-scrollbar {
  display: none;
}
.google-reviews-track {
  display: flex;
  gap: 1rem;
  width: max-content;
  box-sizing: border-box;
}
.google-review-card {
  flex: 0 0 380px;
  min-width: 320px;
  scroll-snap-align: start;
  background: #fff;
  border: 1px solid #e9ecef;
  border-radius: 12px;
  padding: 1.5rem;
  position: relative;
  box-sizing: border-box;
}
.google-review-card .review-quote {
  color: var(--accent);
  font-size: 2.5rem;
  line-height: 1;
  margin-bottom: 0.5rem;
}
.google-review-card .review-text {
  font-size: 0.95rem;
  color: #1f2044;
  line-height: 1.55;
  margin-bottom: 1rem;
}
.google-review-card .review-stars {
  color: #f0b429;
  font-size: 1rem;
  letter-spacing: 0.1em;
  margin-bottom: 0.5rem;
}
.google-review-card .review-link {
  font-size: 0.85rem;
  color: var(--accent);
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}
.google-review-card .review-link:hover {
  color: var(--accent-hover);
}
.google-review-card.google-review-empty {
  min-width: 320px;
  max-width: 480px;
}

/* ===== CTA Section ===== */
.fds-cta {
  background: var(--btn-bg, var(--accent-secondary));
}

/* ===== Footer ===== */
.fds-footer {
  background: #eaf4fd;
  color: #1f2044;
  border-radius: 44px 44px 0 0;
  padding-top: 30px;
}
.fds-footer-logo-img {
  max-height: 34px;
  width: auto;
  max-width: 100%;
}
.fds-footer-logo-text {
  font-size: 1.25rem;
  font-weight: 700;
  color: #1f2044;
}
.fds-footer-social {
  display: flex;
  gap: 0.75rem;
}
.fds-footer-social a {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(0,16,116,0.08);
  color: #001074;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  transition: background 0.2s, color 0.2s;
}
.fds-footer-social a:hover {
  background: rgba(0,16,116,0.15);
  color: #001074;
}
.fds-footer-pag-label {
  font-size: 0.8rem;
  font-weight: 600;
  color: #374151;
}
.fds-footer-pag-logos {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.fds-footer-logo-pag {
  height: 28px;
  width: auto;
  max-width: 50px;
  object-fit: contain;
}
.fds-footer-title {
  font-size: 0.95rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
  margin-top: 0;
  color: #1f2044;
}
.fds-footer-row {
  display: flex;
  flex-wrap: wrap;
}
.fds-footer-col {
  flex: 1 1 auto;
  min-width: 0;
}
@media (min-width: 992px) {
  .fds-footer-col {
    flex: 1 1 0;
    max-width: none;
  }
}
@media (max-width: 767px) {
  .fds-footer-col {
    flex: 0 0 100%;
  }
}
.fds-footer .fds-footer-menu,
.fds-footer .fds-footer-contato {
  margin: 0;
  padding-left: 0;
  list-style: none;
}
.fds-footer h4.fds-footer-title {
  line-height: 1.3;
}
.fds-footer-logo-col {
  padding-top: 0;
  min-width: 0;
  overflow: hidden;
  flex: 0 1 auto;
}
@media (min-width: 992px) {
  .fds-footer-logo-col {
    flex: 0 0 auto;
    max-width: 280px;
  }
}
.fds-footer-menu li {
  margin-bottom: 0.4rem;
}
.fds-footer-menu a {
  color: #4b5563;
  font-size: 0.9rem;
  text-decoration: none;
  transition: color 0.2s;
}
.fds-footer-menu a:hover {
  color: var(--accent);
}
.fds-footer-contato a,
.fds-footer-contato .fds-footer-contato-placeholder {
  color: #4b5563;
  font-size: 0.9rem;
  text-decoration: none;
  transition: color 0.2s;
}
.fds-footer-contato a:hover {
  color: var(--accent);
}
.fds-footer-contato li {
  margin-bottom: 0.4rem;
}
.fds-footer-copy {
  color: #64748b;
}
.fds-footer-dev {
  font-size: 0.85rem;
  opacity: 0.9;
}
.fds-footer-dev a {
  color: var(--accent);
  text-decoration: none;
}
.fds-footer-dev a:hover {
  text-decoration: underline;
}
.fds-footer-legal a {
  color: #4b5563;
  font-size: 0.9rem;
  text-decoration: none;
  transition: color 0.2s;
}
.fds-footer-legal a:hover {
  color: var(--accent);
}
.fds-footer {
  position: relative;
}
.fds-footer-container {
  padding-top: 2.5rem !important;
}
.fds-scroll-top-wrap {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 5;
}
.fds-scroll-top {
  width: 48px;
  height: 48px;
  background: #3490ff;
  color: #fff;
  font-size: 1.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s, transform 0.2s;
  cursor: pointer;
}
.fds-scroll-top:hover {
  background: #2270e6;
  color: #fff;
  transform: translateY(-2px);
}
.fds-footer-after {
  border-top: 1px solid rgba(0,0,0,0.08);
}
.fds-footer-links-row a {
  color: #4b5563;
  font-size: 0.9rem;
  text-decoration: none;
  transition: color 0.2s;
}
.fds-footer-links-row a:hover {
  color: var(--accent);
}
.fds-footer-sep {
  color: #9ca3af;
  margin: 0 0.5rem;
  font-size: 0.85rem;
}
.fds-footer-endereco {
  color: #6b7280;
  font-size: 0.85rem;
}

/* ===== Footer v2 (estilo clean) ===== */
.fds-footer {
  background: #f5f3f2;
  color: #1f2937;
  border-radius: 0;
  margin-top: 0;
  padding-top: 0;
  border-top: 0;
  clip-path: none;
}
.fds-footer::before {
  content: none;
}
.fds-scroll-top-wrap {
  display: none;
}
.fds-footer-container {
  padding-top: 1.8rem !important;
  padding-bottom: 1.4rem !important;
}
@media (min-width: 992px) {
  .fds-footer .container.fds-footer-container {
    padding-left: var(--bs-gutter-x, 0.75rem);
    padding-right: var(--bs-gutter-x, 0.75rem);
  }
}
.fds-footer-logo-img {
  max-height: 34px;
}
.fds-footer-social {
  gap: 0.5rem;
}
.fds-footer-social a {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  background: #f3f4f6;
  color: #111827;
  font-size: 0.95rem;
}
.fds-footer-social a:hover {
  background: #e5e7eb;
  color: #111827;
}
.fds-footer-row {
  border-top: 0;
  margin-top: 1rem;
  padding-top: 1.25rem;
}
.fds-footer-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: #1f2937;
  margin-bottom: 0.7rem;
}
.fds-footer-menu li,
.fds-footer-contato li {
  margin-bottom: 0.35rem;
}
.fds-footer-menu a,
.fds-footer-contato a,
.fds-footer-contato .fds-footer-contato-placeholder {
  color: #4b5563;
  font-size: 0.9rem;
}
.fds-footer-menu a:hover,
.fds-footer-contato a:hover {
  color: #111827;
}
.fds-footer-after {
  border-top: 0;
  margin-top: 1.25rem !important;
  padding-top: 1.1rem !important;
}
.fds-footer-links-row {
  text-align: center !important;
  margin-bottom: 1rem !important;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem;
}
.fds-footer-links-row a {
  color: #4b5563;
  font-size: 0.9rem;
}
.fds-footer-links-row a:hover {
  color: #111827;
}
.fds-footer-sep {
  color: #9ca3af;
}
.fds-footer-pag-label {
  font-size: 0.78rem;
  font-weight: 600;
  color: #6b7280;
}
.fds-footer-logo-pag {
  height: 30px;
  max-width: 56px;
}

.fds-footer-copy-row {
  text-align: left !important;
}
.fds-footer-copy {
  color: #6b7280;
  font-size: 0.8rem;
  line-height: 1.45;
}
.fds-footer-unicsites {
  margin-top: 1.6rem;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
.fds-footer-unicsites-label {
  font-size: 0.74rem;
  color: #6b7280;
  line-height: 1.2;
}
.fds-footer-unicsites-logo {
  max-height: 19px;
  width: auto;
  max-width: 98px;
  object-fit: contain;
}
.fds-footer-dev {
  font-size: 0.8rem;
}
.fds-footer-dev a {
  color: #374151;
}

/* ===== Banner de Cookies ===== */
.cookies-banner {
  position: fixed;
  inset-inline: 0;
  bottom: 0;
  z-index: 1400;
  padding: 0.75rem 0 0.9rem;
  background: #ffffff;
  color: #0f172a;
  transform: translateY(100%);
  opacity: 0;
  pointer-events: none;
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.25s ease;
}
.cookies-banner.is-visible {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}
.cookies-banner-inner {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.cookies-banner-icon {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  background: var(--accent-light, rgba(46, 147, 238, 0.08));
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent, #2e93ee);
  font-size: 1.4rem;
  flex-shrink: 0;
}
.cookies-banner-text {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  font-size: 0.86rem;
}
.cookies-banner-text strong {
  font-size: 0.9rem;
  font-weight: 600;
  color: #111827;
}
.cookies-banner-text span {
  color: #4b5563;
}
.cookies-banner-text a {
  color: var(--accent, #2e93ee);
  font-weight: 500;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.cookies-banner-text a:hover {
  color: var(--accent-hover, #1a7bd4);
}
.cookies-banner-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-left: auto;
}
.cookies-btn-primary {
  border-radius: 12px;
  background: var(--btn-bg, var(--accent-secondary, #1a7bd4));
  border-color: var(--btn-bg, var(--accent-secondary, #1a7bd4));
  color: #ffffff;
  font-size: 0.85rem;
  font-weight: 600;
  padding: 0.45rem 1.3rem;
  box-shadow: 0 8px 22px rgba(var(--bs-primary-rgb, 46, 147, 238), 0.22);
}
.cookies-btn-primary:hover {
  background: var(--btn-hover, var(--accent-hover, #1576c4));
  border-color: var(--btn-hover, var(--accent-hover, #1576c4));
  color: #ffffff;
}
.cookies-btn-link {
  font-size: 0.8rem;
  color: #4b5563;
  padding-inline: 0;
}
.cookies-btn-link:hover {
  color: var(--accent, #2e93ee);
}
@media (max-width: 767px) {
  .cookies-banner {
    padding-bottom: max(0.85rem, env(safe-area-inset-bottom));
  }
  .cookies-banner-inner {
    flex-direction: column;
    align-items: stretch;
  }
  .cookies-banner-actions {
    justify-content: flex-start;
  }
}

/* ===== WhatsApp flutuante ===== */
.whatsapp-float-btn {
  position: fixed;
  bottom: 24px;
  left: 24px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #25d366;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1100;
  font-size: 1.75rem;
  box-shadow: 0 4px 20px rgba(37, 211, 102, 0.5);
  transition: transform 0.2s;
}
.whatsapp-float-btn:hover {
  color: #fff;
  transform: scale(1.05);
}

/* ===== Botão flutuante WhatsApp (balão + foto + online; clique → wa.me) ===== */
.chat-float-root {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 1100;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 10px;
  pointer-events: none;
}
.chat-float-root .chat-float-wrap,
.chat-float-root .chat-float-label {
  pointer-events: auto;
}
.chat-float-label {
  background: #ffffff;
  color: #475569;
  border-radius: 999px;
  padding: 8px 12px 8px 14px;
  box-shadow: 0 14px 35px rgba(0, 0, 0, 0.18);
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.875rem;
  font-weight: 400;
  max-width: min(280px, calc(100vw - 120px));
  line-height: 1.35;
}
.chat-float-label span {
  white-space: normal;
}
.chat-float-label-close {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: none;
  background: transparent;
  color: #98a2b3;
  font-size: 1.1rem;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  flex-shrink: 0;
  cursor: pointer;
}
.chat-float-label-close:hover {
  background: #f1f5f9;
  color: #475569;
}
.chat-float-wrap {
  cursor: pointer;
  outline: none;
  flex-shrink: 0;
}
.chat-float-wrap:focus-visible {
  outline: 2px solid #25d366;
  outline-offset: 4px;
  border-radius: 50%;
}
.chat-float-btn {
  position: relative;
  width: 76px;
  height: 76px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: #25d366;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: none;
  transition: transform 0.2s ease;
}
.chat-float-btn:hover {
  transform: scale(1.05);
}
.chat-float-btn:has(.chat-float-avatar-img) {
  background: transparent;
  overflow: visible;
}
.chat-float-avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 50%;
}
.chat-float-wa-icon {
  width: 36px;
  height: 36px;
  flex-shrink: 0;
}
/* Centro do ponto sobre a borda do círculo (~metade dentro, metade fora) */
.chat-float-online-dot {
  position: absolute;
  top: 6%;
  right: 6%;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background: #22c55e;
  border: 2px solid #fff;
  box-shadow: none;
  transform: translate(50%, -50%);
  pointer-events: none;
  z-index: 1;
}

@media (max-width: 575px) {
  .brand-strip-title { font-size: 1.5rem; }
  .chat-float-root {
    right: 14px;
    bottom: 14px;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px;
  }
  .chat-float-label {
    max-width: calc(100vw - 28px);
  }
}

/* ===== Utilitários Bootstrap override - botões usam cor secundária ===== */
.btn-primary {
  background: var(--btn-bg, var(--accent-secondary));
  border-color: var(--btn-bg, var(--accent-secondary));
  color: #1f2044;
}
.btn-primary:hover {
  background: var(--btn-hover, var(--accent-hover));
  border-color: var(--btn-hover, var(--accent-hover));
  color: #1f2044;
}
.btn-outline-primary {
  border-color: var(--btn-bg, var(--accent-secondary));
  color: var(--btn-bg, var(--accent-secondary));
}
.btn-outline-primary:hover {
  background: var(--btn-bg, var(--accent-secondary));
  border-color: var(--btn-bg, var(--accent-secondary));
  color: #1f2044;
}

/* ===== Responsivo ===== */
@media (max-width: 991px) {
  /* Mobile: deixa o banner crescer conforme o conteúdo (sem cortar imagem) */
  .fds-slider .carousel-inner,
  .fds-slider .carousel-item {
    aspect-ratio: auto;
    min-height: auto;
    max-height: none;
    height: auto;
  }
  .fds-slide-title { font-size: 1.9rem; }
  .fds-slide-subtitle { font-size: 1.2rem; }
  .fds-services-title,
  .brand-strip-title { font-size: 1.75rem; }
  .fds-service-card { min-width: 220px; }
  .host-plan-featured { transform: none; }
  .host-plan-featured:hover { transform: translateY(-4px); }
}

/* ===== Central de ajuda (alinhada ao templates-hero + contact-card) ===== */
.fds-help-section {
  background: linear-gradient(180deg, #f8fafc 0%, #ffffff 48%);
}

.help-main-wrap {
  background: transparent;
  border-radius: 0;
  padding: 0;
  margin: 0;
  box-shadow: none;
}

/* --- Central de ajuda: layout tipo knowledge base (recomendados + cards) --- */
.help-home-layout {
  max-width: 960px;
  margin-left: auto;
  margin-right: auto;
}

.help-reco-card {
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  padding: 1.35rem 1.5rem 1.5rem;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
}

.help-reco-title {
  font-size: 1.125rem;
  font-weight: 700;
  color: #111827;
  margin: 0 0 1rem;
  letter-spacing: -0.02em;
}

.help-reco-spark {
  margin-right: 0.2rem;
}

.help-reco-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border: 1px solid #ececec;
  border-radius: 12px;
  overflow: hidden;
  background: #fafafa;
}

@media (max-width: 767.98px) {
  .help-reco-grid {
    grid-template-columns: 1fr;
  }
}

.help-reco-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 1rem 1.15rem;
  margin: 0;
  text-decoration: none;
  color: #111827;
  font-weight: 500;
  font-size: 0.9375rem;
  line-height: 1.35;
  background: #ffffff;
  border-right: 1px solid #ececec;
  border-bottom: 1px solid #ececec;
  transition: background-color 0.15s ease;
}

.help-reco-link:hover {
  background: #f8fafc;
  color: #111827;
}

.help-reco-link:nth-child(2n) {
  border-right: none;
}

@media (min-width: 768px) {
  .help-reco-link:last-child:nth-child(odd) {
    grid-column: 1 / -1;
    border-right: none;
  }
}

@media (max-width: 767.98px) {
  .help-reco-link {
    border-right: none;
  }
  .help-reco-link:last-child {
    border-bottom: none;
  }
}

.help-reco-link-text {
  text-align: left;
  min-width: 0;
}

.help-reco-chevron {
  flex-shrink: 0;
  font-size: 0.95rem;
  color: #94a3b8;
}

.help-cat-cards-row {
  margin-top: 0.25rem;
}

.help-cat-card-v2 {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 1.75rem 1.35rem 1.45rem;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  text-decoration: none;
  color: inherit;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.help-cat-card-v2:hover {
  border-color: #d1d5db;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.1);
  transform: translateY(-2px);
  color: inherit;
}

.help-cat-icon-v2 {
  width: 56px;
  height: 56px;
  border-radius: 12px;
  background: #fff1f2;
  color: #111827;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.45rem;
  margin-bottom: 1rem;
}

.help-cat-icon-v2 i {
  color: #111827;
}

.help-cat-title-v2 {
  font-size: 1.0625rem;
  font-weight: 700;
  color: #111827;
  margin: 0 0 0.5rem;
  line-height: 1.3;
  letter-spacing: -0.02em;
}

.help-cat-desc-v2 {
  font-size: 0.875rem;
  color: #6b7280;
  line-height: 1.5;
  margin: 0 0 1rem;
  flex-grow: 1;
}

.help-cat-count-v2 {
  font-size: 0.8125rem;
  color: #9ca3af;
  margin: 0;
  font-weight: 500;
}

.help-card {
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  padding: 0 0 1.5rem;
  position: static;
  z-index: auto;
}
.help-card-recommended {
  margin-top: 0;
  padding: 2rem 2rem 1.75rem;
  border-radius: 20px;
  background: #ffffff;
  border: 1px solid #eef0f6;
  box-shadow: 0 12px 40px rgba(15, 23, 42, 0.08);
}
.help-section-title {
  font-size: 1.35rem;
  font-weight: 650;
  color: #0f172a;
  letter-spacing: -0.02em;
}
.help-section-title .help-recommended-icon {
  font-size: 1.25rem;
  margin-right: 0.4rem;
}
.help-article-link {
  display: block;
  padding: 0.55rem 0;
  text-decoration: none;
  color: inherit;
  position: relative;
}
.help-article-link:hover {
  color: #111827;
}
.help-article-link-title {
  font-size: 1rem;
  margin-bottom: 0.25rem;
}
.help-article-link-summary {
  font-size: 0.85rem;
  color: #6b7280;
}
.help-article-link::after {
  content: none;
}

/* estilo pill apenas na lista de recomendados */
.help-card-recommended .help-article-link {
  padding: 0.75rem 1rem;
  border-radius: 999px;
  display: flex;
  align-items: center;
}
.help-card-recommended .help-article-link:hover {
  background: var(--accent-light, rgba(46, 147, 238, 0.08));
  color: #0f172a;
}
.help-article-link-icon {
  margin-left: auto;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  border: 2px solid var(--accent, #2e93ee);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-light, rgba(46, 147, 238, 0.08));
  color: var(--accent, #2e93ee);
  flex-shrink: 0;
}
.help-article-link-icon i {
  font-size: 1.1rem;
}
.help-card-recommended .help-article-link-summary {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  font-size: 0.88rem;
}
.help-category-grid {
  margin-top: 0.25rem;
}
.help-category-card {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  height: 100%;
  border-radius: 16px;
  padding: 1.35rem 1.25rem 1.25rem;
  background: #ffffff;
  border: 1px solid #eef0f6;
  text-decoration: none;
  color: inherit;
  box-shadow: 0 8px 28px rgba(15, 23, 42, 0.06);
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}
.help-category-card:hover {
  color: inherit;
  border-color: var(--accent-light-2, rgba(46, 147, 238, 0.15));
  box-shadow: 0 14px 36px rgba(15, 23, 42, 0.1);
  transform: translateY(-2px);
}
.help-category-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-light, rgba(46, 147, 238, 0.1));
  color: var(--accent, #2e93ee);
  margin-bottom: 0.15rem;
  font-size: 1.25rem;
}
.help-category-title {
  font-size: 1rem;
  margin: 0;
}
.help-category-desc {
  font-size: 0.85rem;
  color: #6b7280;
  margin-bottom: 0.15rem;
}
.help-category-count {
  font-size: 0.8rem;
  color: #9ca3af;
  margin: 0;
}
.help-list {
  border-radius: 16px;
  background: #ffffff;
  border: 1px solid #eef0f6;
  box-shadow: 0 8px 28px rgba(15, 23, 42, 0.06);
  overflow: hidden;
}
.help-list-item {
  display: block;
  padding: 1rem 1.35rem;
  border-bottom: 1px solid #eef0f6;
  text-decoration: none;
  color: inherit;
  transition: background 0.15s ease;
}
.help-list-item:last-child {
  border-bottom: none;
}
.help-list-item:hover {
  background: var(--accent-light, rgba(46, 147, 238, 0.06));
}
.help-list-title {
  font-size: 1rem;
  margin: 0 0 0.15rem;
}
.help-list-summary {
  font-size: 0.85rem;
  color: #6b7280;
  margin: 0;
}
.help-search-results {
  border-radius: 16px;
  background: #ffffff;
  border: 1px solid #eef0f6;
  box-shadow: 0 8px 28px rgba(15, 23, 42, 0.06);
  overflow: hidden;
}
.help-result-item {
  display: block;
  padding: 1rem 1.35rem;
  border-bottom: 1px solid #eef0f6;
  text-decoration: none;
  color: inherit;
  transition: background 0.15s ease;
}
.help-result-item:last-child {
  border-bottom: none;
}
.help-result-item:hover {
  background: var(--accent-light, rgba(46, 147, 238, 0.06));
}
.help-result-title {
  font-size: 1rem;
  margin: 0 0 0.1rem;
}
.help-result-meta {
  font-size: 0.8rem;
  color: var(--accent, #2e93ee);
  font-weight: 600;
  margin: 0 0 0.2rem;
}
.help-result-summary {
  font-size: 0.85rem;
  color: #6b7280;
  margin: 0;
}
.help-article-card {
  background: transparent;
  border-radius: 0;
  padding: 0;
  box-shadow: none;
}
.help-article-card--inner {
  background: #ffffff;
  border-radius: 20px;
  padding: 2rem 2.25rem 2.25rem;
  border: 1px solid #eef0f6;
  box-shadow: 0 12px 40px rgba(15, 23, 42, 0.08);
}
.help-article-title {
  font-size: 1.6rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}
.help-article-summary {
  font-size: 0.95rem;
  color: #6b7280;
}
.help-article-content {
  margin-top: 1.2rem;
  font-size: 0.95rem;
  line-height: 1.7;
}
.help-article-content p {
  margin-bottom: 0.75rem;
}
.help-article-content ul {
  padding-left: 1.2rem;
}
.help-breadcrumb {
  font-size: 0.875rem;
  color: #64748b;
}
.help-breadcrumb a {
  color: var(--accent, #2e93ee);
  text-decoration: none;
  font-weight: 500;
}
.help-breadcrumb a:hover {
  text-decoration: underline;
  color: var(--accent-hover, #1a7bd4);
}
.help-breadcrumb span:not(:last-child) {
  margin: 0 0.2rem;
}
.help-breadcrumb-sep {
  margin: 0 0.25rem;
  color: #cbd5e1;
}

/* Navegação rápida + lista simples de tutoriais */
.help-quick-label {
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #64748b;
}
.help-quick-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.help-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.45rem 0.9rem;
  border-radius: 999px;
  background: #ffffff;
  border: 1px solid #e2e8f0;
  color: #0f172a;
  font-size: 0.9rem;
  font-weight: 500;
  text-decoration: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.help-pill:hover {
  border-color: var(--accent, #2e93ee);
  color: #0f172a;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.08);
}
.help-pill-count {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--accent, #2e93ee);
  background: var(--accent-light, rgba(46, 147, 238, 0.12));
  padding: 0.1rem 0.45rem;
  border-radius: 999px;
}
.help-tutorial-block {
  padding: 1.25rem 1.35rem;
  background: #ffffff;
  border: 1px solid #eef0f6;
  border-radius: 16px;
  box-shadow: 0 4px 18px rgba(15, 23, 42, 0.04);
}
.help-tutorial-cat-title {
  font-size: 1.15rem;
  font-weight: 650;
  color: #0f172a;
  letter-spacing: -0.02em;
}
.help-see-all {
  color: var(--accent, #2e93ee);
  text-decoration: none;
  font-weight: 500;
}
.help-see-all:hover {
  text-decoration: underline;
}
.help-tutorial-list li + li {
  border-top: 1px solid #f1f5f9;
}
.help-tutorial-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.65rem 0;
  color: #1e293b;
  text-decoration: none;
  font-weight: 500;
}
.help-tutorial-link:hover {
  color: var(--accent, #2e93ee);
}
.help-tutorial-link-ico {
  flex-shrink: 0;
  opacity: 0.45;
  font-size: 0.9rem;
}
.help-back-link {
  color: var(--accent, #2e93ee);
  text-decoration: none;
  font-weight: 500;
}
.help-back-link:hover {
  text-decoration: underline;
}
.help-youtube-embed {
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 8px 28px rgba(15, 23, 42, 0.1);
}
.help-youtube-embed iframe {
  border: 0;
}
.fds-help-prose {
  max-width: 100%;
}
.fds-help-prose img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
}
.help-gallery-thumb:hover img {
  opacity: 0.95;
}

@media (max-width: 575px) {
  .help-article-card--inner {
    padding: 1.35rem 1.15rem 1.5rem;
  }
  .help-card-recommended {
    padding: 1.35rem 1.15rem 1.25rem;
  }
  .help-category-card {
    padding: 1.15rem 1rem 1.1rem;
  }
}

@media (max-width: 767px) {
  .fds-services-title { font-size: 1.5rem; }
  .fds-service-card { min-width: 220px; }
  .fds-topbar .d-flex { flex-direction: column; align-items: flex-start !important; }
  /* Evita linha/faixa clara entre header e hero em alguns aparelhos */
  .fds-slider { margin-top: -6px; }
  .fds-slider .carousel-inner,
  .fds-slider .carousel-item { min-height: auto; }
  .fds-slide-hero .container {
    /* aproxima o hero do topo sem colar no header fixo */
    padding-top: 2.4rem;
    padding-bottom: 1.6rem;
  }
  .fds-slide-hero {
    position: relative;
    isolation: isolate;
  }
  .fds-slide-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.62) 0%, rgba(0, 0, 0, 0.22) 32%, rgba(0, 0, 0, 0) 70%);
    z-index: 1;
    pointer-events: none;
  }
  .fds-slide-hero .container {
    position: relative;
    z-index: 2;
  }
  .fds-slide-hero .row {
    row-gap: 1rem !important;
  }
  .fds-slide-hero .col-lg-6,
  .fds-slide-hero .col-lg-6:first-child,
  .fds-slide-hero .col-lg-6:last-child {
    align-items: center !important;
    justify-content: center;
    text-align: center;
  }
  .fds-slide-kicker {
    font-size: 0.76rem;
    padding: 0.38rem 0.78rem;
    margin-top: 0.15rem;
    margin-bottom: 0.75rem;
  }
  .fds-slide-sub2 {
    font-size: clamp(1.65rem, 7.4vw, 2.05rem);
    line-height: 1.12;
    margin-bottom: 0.28rem;
  }
  .fds-slide-title2 {
    font-size: clamp(1.9rem, 8.2vw, 2.35rem);
    line-height: 1.06;
    margin-bottom: 0.78rem;
  }
  .fds-slide-desc {
    font-size: 1.02rem;
    line-height: 1.35;
    margin-bottom: 0.95rem;
    max-width: 31ch;
    margin-left: auto;
    margin-right: auto;
  }
  .fds-slide-btn {
    width: 100%;
    max-width: 320px;
    height: 50px;
    border-radius: 12px;
    font-size: 1.05rem;
    margin-left: auto;
    margin-right: auto;
  }
  .fds-slide-media-img {
    border-radius: 12px;
  }
  .fds-slide-title { font-size: 1.6rem; }
  .fds-slide-subtitle { font-size: 1.1rem; }
  .fds-slider .carousel-control-prev,
  .fds-slider .carousel-control-next { width: 56px; height: 56px; border-radius: 12px; }
  .fds-slider .carousel-control-prev { left: 8px; }
  .fds-slider .carousel-control-next { right: 8px; }
  .fds-slider .carousel-control-prev i,
  .fds-slider .carousel-control-next i { font-size: 1.95rem; font-weight: 400; }
  .section-title-host { font-size: 1.5rem; }
  .fds-footer-col { flex: 0 0 100% !important; }
  .fds-footer-links-row .fds-footer-sep { display: none; }
  .fds-footer-links-row { display: flex; flex-wrap: wrap; justify-content: center; gap: 0.5rem; }
}

@media (max-width: 575px) {
  .fds-slider .carousel-inner,
  .fds-slider .carousel-item { min-height: auto; }
  .fds-slide-title { font-size: 1.4rem; }
  .fds-slide-subtitle { font-size: 1rem; }
  .fds-domain-search .d-flex { flex-direction: column; }
  .fds-domain-search .btn { width: 100%; }
  .domain-search-inner { flex-wrap: nowrap; border-radius: 999px; min-height: 52px; }
  .fds-hero-wrap.has-slider .fds-domain-bar { margin-top: -32px; }
  .host-plan-price { font-size: 1.75rem; }
  .whatsapp-float-btn { width: 52px; height: 52px; bottom: 16px; left: 16px; }
}

/* ===== Plataforma: menu + imagem interativa ===== */
.plataforma-section {
  background: #fff;
  color: var(--text);
}
.plataforma-title {
  font-size: 1.9rem;
  font-weight: 700;
  color: var(--text);
  line-height: 1.25;
}
.plataforma-accordion {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.plataforma-menu-item {
  border-bottom: 1px solid #e9ecef;
}
.plataforma-menu-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.85rem 0;
  cursor: pointer;
  transition: color 0.2s, background 0.2s;
  user-select: none;
}
.plataforma-menu-item:hover .plataforma-menu-header {
  color: var(--accent);
}
.plataforma-menu-item.active .plataforma-menu-header {
  color: var(--accent);
  font-weight: 500;
}
.plataforma-menu-icon {
  font-size: 1.2rem;
  flex-shrink: 0;
}
.plataforma-menu-text {
  flex: 1;
}
.plataforma-menu-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}
.plataforma-menu-item.active .plataforma-menu-content {
  max-height: 350px;
}
.plataforma-menu-desc {
  font-size: 0.95rem;
  color: var(--text-muted);
  line-height: 1.6;
  padding: 0 0 0 2rem;
  padding-bottom: 1rem;
}
.plataforma-progress-wrap {
  margin: 0.5rem 0 0.5rem 2rem;
  height: 4px;
  background: #e9ecef;
  border-radius: 4px;
  overflow: hidden;
}
.plataforma-progress-bar {
  height: 100%;
  width: 0%;
  background: var(--accent);
  border-radius: 4px;
}
.plataforma-image-wrap {
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(31, 32, 68, 0.12);
  max-width: 560px;
  width: 100%;
}
.plataforma-image {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}
@media (max-width: 991px) {
  .plataforma-title { font-size: 1.6rem; }
}
@media (max-width: 575px) {
  .plataforma-title { font-size: 1.4rem; }
  .plataforma-image-wrap { max-width: 100%; }
}

/* ===== Minha Conta - Login estilo Appmax ===== */
.account-login-body {
  background: #f7f8fc;
}
.account-login-page {
  min-height: 100vh;
  display: flex;
  align-items: stretch;
  justify-content: center;
  background: transparent;
}
.account-login-inner {
  max-width: 1080px;
  width: 100%;
  margin: 3rem auto;
  background: #fff;
  border-radius: 24px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.08);
  display: grid;
  grid-template-columns: minmax(0, 420px) minmax(0, 1fr);
  overflow: hidden;
}
.account-login-left {
  padding: 3rem 3.5rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: #fff;
}
.account-login-logo {
  font-weight: 700;
  font-size: 1.1rem;
  margin-bottom: 2.5rem;
  color: var(--text);
}
.account-login-title {
  font-size: 2rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 0.5rem;
}
.account-login-title span {
  color: var(--accent-secondary);
}
.account-login-subtitle {
  font-size: 1.1rem;
  color: var(--text-muted);
}
.account-login-right {
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #e9edf5;
  position: relative;
}
.account-login-card {
  width: 100%;
  max-width: 360px;
}
.account-login-label {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--text);
}
.account-login-input {
  border-radius: 8px;
  padding: 0.6rem 0.9rem;
  border: 1px solid #dee2e6;
  font-size: 0.9rem;
}
.account-login-input:focus {
  border-color: var(--accent-secondary);
  box-shadow: 0 0 0 3px rgba(26,123,212,0.15);
}
.account-login-btn {
  border-radius: 999px;
  padding: 0.7rem;
  font-weight: 600;
  font-size: 0.95rem;
  background: var(--accent-secondary);
  border: none;
}
.account-login-btn:hover {
  background: var(--accent-hover);
}
.account-login-footer-text {
  font-size: 0.8rem;
  color: var(--text-muted);
}
/* área ilustrativa à direita (sem imagem real) */
.account-login-hero {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2.5rem 3rem;
}
.account-login-hero-box {
  width: 100%;
  max-width: 520px;
  aspect-ratio: 16 / 9;
  border-radius: 18px;
  background: linear-gradient(135deg, var(--accent-secondary), var(--accent-hover));
  box-shadow: 0 20px 40px rgba(0,0,0,0.18);
}
@media (max-width: 991px) {
  .account-login-inner {
    margin: 2rem 1rem;
    grid-template-columns: 1fr;
  }
  .account-login-left {
    padding: 2rem 1.75rem 0;
  }
  .account-login-right {
    padding: 2rem 1.75rem 2.5rem;
    border-left: none;
    border-top: 1px solid #f1f3f5;
  }
}

/* ===== Carrinho lateral (drawer) ===== */
.fds-nav-icon.fds-cart-trigger {
  border: 0;
  background: none;
  cursor: pointer;
  position: relative;
}
.cart-badge {
  position: absolute;
  top: -2px;
  right: -2px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  font-size: 0.7rem;
  font-weight: 600;
  color: #002051;
  background: #35c4f0;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cart-badge:empty,
.cart-badge[data-count="0"] {
  display: none;
}

.cart-sticky-cta {
  display: none !important;
  position: fixed;
  inset-inline: 16px;
  bottom: 18px;
  z-index: 1200;
  max-width: 460px;
  margin-inline: auto;
  pointer-events: none;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.25s ease, transform 0.25s ease;
}
.cart-sticky-cta.is-visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.cart-sticky-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.9rem;
  padding: 0.85rem 1.1rem;
  border-radius: 999px;
  background: rgba(255,255,255,0.96);
  box-shadow: 0 14px 40px rgba(15,23,42,0.25);
  border: 1px solid rgba(0,48,185,0.12);
  backdrop-filter: blur(10px);
}
.cart-sticky-text {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
  min-width: 0;
}
.cart-sticky-label {
  font-size: 0.85rem;
  font-weight: 600;
  color: #111827;
}
.cart-sticky-info {
  font-size: 0.8rem;
  color: #4b5563;
}
.cart-sticky-info strong {
  color: #111827;
}
.cart-sticky-btn {
  border-radius: 999px;
  background: #0030b9;
  border-color: #0030b9;
  color: #ffffff;
  font-size: 0.85rem;
  font-weight: 600;
  padding: 0.55rem 1.2rem;
  white-space: nowrap;
}
.cart-sticky-btn:hover {
  background: #0044dd;
  border-color: #0044dd;
  color: #ffffff;
}

/* Mobile: estilo app – barra full width, safe area, toque grande */
@media (max-width: 767px) {
  .cart-sticky-cta {
    inset-inline: 0;
    left: 0;
    right: 0;
    bottom: 0;
    max-width: none;
    margin: 0;
    padding: 0 12px;
    padding-bottom: max(12px, env(safe-area-inset-bottom));
    transform: translateY(100%);
    transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s ease;
  }
  .cart-sticky-cta.is-visible {
    transform: translateY(0);
  }
  .cart-sticky-inner {
    position: relative;
    flex-direction: column;
    align-items: stretch;
    gap: 1rem;
    padding: 1.25rem 1.25rem 1rem;
    padding-top: 1.5rem;
    border-radius: 20px 20px 0 0;
    box-shadow: 0 -8px 32px rgba(0,0,0,0.18), 0 -2px 12px rgba(0,48,185,0.08);
    border: none;
    border-top: 1px solid rgba(0,48,185,0.15);
    background: #ffffff;
    backdrop-filter: none;
  }
  .cart-sticky-inner::before {
    content: '';
    position: absolute;
    top: 8px;
    left: 50%;
    transform: translateX(-50%);
    width: 36px;
    height: 4px;
    border-radius: 999px;
    background: #e5e7eb;
  }
  .cart-sticky-text {
    gap: 0.25rem;
  }
  .cart-sticky-label {
    font-size: 1rem;
    font-weight: 600;
    color: #111827;
  }
  .cart-sticky-info {
    font-size: 0.9rem;
    color: #4b5563;
  }
  .cart-sticky-info strong {
    font-size: 1.05rem;
    color: #0030b9;
  }
  .cart-sticky-btn {
    width: 100%;
    justify-content: center;
    padding: 0.95rem 1.25rem;
    font-size: 1rem;
    font-weight: 600;
    border-radius: 14px;
    min-height: 52px;
    display: inline-flex;
    align-items: center;
    box-shadow: 0 4px 14px rgba(0,48,185,0.35);
  }
  .cart-sticky-btn:active {
    transform: scale(0.98);
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .cart-sticky-cta {
    inset-inline: 20px;
    bottom: 20px;
  }
}

.cart-drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.4);
  /* acima do header */
  z-index: 7500;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.25s, visibility 0.25s;
}
.cart-drawer-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.cart-drawer {
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  max-width: 320px;
  height: 100vh;
  height: 100dvh;
  background: #fff;
  border-top-left-radius: 22px;
  border-bottom-left-radius: 22px;
  /* acima do header */
  z-index: 7510;
  display: flex;
  flex-direction: column;
  box-shadow: -4px 0 24px rgba(0,0,0,0.12);
  transform: translateX(100%);
  transition: transform 0.3s ease;
}
.cart-drawer.is-open {
  transform: translateX(0);
}

@keyframes fdsCartIconBump {
  0% { transform: translateY(0) scale(1); }
  35% { transform: translateY(-1px) scale(1.12); }
  100% { transform: translateY(0) scale(1); }
}
.fds-cart-trigger.is-bumping i {
  animation: fdsCartIconBump 420ms ease-out;
}

.cart-drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid #eee;
  flex-shrink: 0;
}
.cart-drawer-title {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--text);
  margin: 0;
}
.cart-drawer-title i {
  color: var(--accent);
}
.cart-drawer-close {
  width: 36px;
  height: 36px;
  border: 0;
  background: none;
  border-radius: 8px;
  color: var(--text);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s, color 0.2s;
}
.cart-drawer-close:hover {
  background: var(--accent-light);
  color: var(--accent);
}

.cart-drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: 1rem;
}

.cart-drawer-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 3rem 1rem;
  color: var(--text-muted);
}
.cart-drawer-empty-icon {
  width: auto;
  height: auto;
  border-radius: 0;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.25rem;
}
.cart-drawer-empty-icon i {
  font-size: 3.2rem;
  color: #111827;
  opacity: 1;
}
.cart-drawer-empty-actions {
  margin-top: 1.1rem;
}
.cart-drawer-empty-actions .cart-add-btn {
  background: var(--accent);
  color: #ffffff;
}
.cart-drawer-empty-actions .cart-add-btn:hover {
  background: var(--accent-hover);
  color: #ffffff;
}
.cart-drawer-empty p {
  margin-bottom: 0;
  font-size: 0.95rem;
}

.cart-drawer-items {
  display: none;
}
.cart-drawer-items:not(:empty) {
  display: block;
}

.cart-item {
  display: flex;
  gap: 1rem;
  padding: 1rem 0;
  border-bottom: 1px solid #f0f0f0;
}
.cart-item:last-child {
  border-bottom: none;
}
.cart-item-thumb {
  width: 72px;
  height: 72px;
  flex-shrink: 0;
  border-radius: 8px;
  overflow: hidden;
  background: #f5f5f5;
}
.cart-item-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.cart-item-thumb--domain {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(145deg, #f0f9ff 0%, #e0f2fe 100%);
  color: var(--accent);
  font-size: 1.75rem;
}
.cart-item-meta {
  font-size: 0.8rem;
  color: var(--text-muted);
  word-break: break-all;
  margin-bottom: 0.15rem;
}
.cart-item-tag {
  color: #64748b;
  margin-bottom: 0.25rem;
}
.cart-item-body {
  flex: 1;
  min-width: 0;
}
.cart-item-title {
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--text);
  margin: 0 0 0.25rem 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.cart-item-price {
  font-size: 1rem;
  font-weight: 600;
  color: var(--accent);
}
.cart-item-remove {
  border: 0;
  background: none;
  color: var(--text-muted);
  padding: 0.25rem;
  cursor: pointer;
  border-radius: 6px;
  transition: color 0.2s, background 0.2s;
}
.cart-item-remove:hover {
  color: #dc3545;
  background: rgba(220,53,69,0.08);
}

.cart-drawer-footer {
  padding: 1rem 1.25rem;
  border-top: 1px solid #eee;
  flex-shrink: 0;
  background: #fff;
}
.cart-drawer-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
  font-size: 1.1rem;
}
.cart-drawer-total strong {
  color: var(--accent);
  font-size: 1.25rem;
}
.cart-drawer-checkout-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 1rem 1.75rem;
  font-size: 1.15rem;
  font-weight: 600;
  background: var(--accent);
  color: #fff !important;
  border: none;
  border-radius: 12px;
  transition: background 0.2s, box-shadow 0.2s;
}
.cart-drawer-checkout-btn:hover {
  background: var(--accent-hover);
  color: #fff !important;
}

/* Botão Adicionar ao carrinho (página do produto) */
.product-license-btn-add {
  width: 100%;
  border-radius: 12px;
}
.btn-add-to-cart {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.9rem 1.25rem;
  font-weight: 500;
  background: #0030b9;
  color: #ffffff;
  border: 2px solid #0030b9;
  border-radius: 100px;
  justify-content: center;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
}
.btn-add-to-cart:hover {
  background: #0044dd;
  border-color: #0044dd;
  color: #ffffff !important;
}
/* Página do produto: mesmo padrão da loja (cores primárias do admin) */
.btn-add-to-cart.product-license-btn-add {
  font-weight: 600;
  border-width: 1px;
  border-radius: 12px;
  background: var(--accent);
  border-color: var(--accent);
  color: #ffffff !important;
  box-shadow: 0 8px 20px rgba(var(--bs-primary-rgb, 46, 147, 238), 0.25);
  transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease;
}
.btn-add-to-cart.product-license-btn-add:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
  color: #ffffff !important;
  box-shadow: 0 10px 24px rgba(var(--bs-primary-rgb, 46, 147, 238), 0.32);
  transform: translateY(-1px);
}

/* Ícone de carrinho apenas nos cards da Loja de Templates */
.btn-add-to-cart.template-btn-add-cart {
  width: 40px;
  height: 40px;
  padding: 0 !important;
  border-radius: 0;
  border: none;
  background: transparent;
  justify-content: center;
  gap: 0;
  color: #334155;
}
.btn-add-to-cart.template-btn-add-cart i {
  font-size: 1.1rem;
}
.btn-add-to-cart.template-btn-add-cart:hover {
  background: transparent;
  color: var(--accent) !important;
}
@media (max-width: 767px) {
  /* Loja em formato app: 2 cards por linha no mobile */
  #templatesGrid {
    --bs-gutter-x: 0.75rem;
    --bs-gutter-y: 0.85rem;
  }
  #templatesGrid > [class*="col-"] {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .template-card-body {
    padding: 0.8rem 0.8rem 0.85rem;
  }
  .template-card-title {
    font-size: 0.95rem;
  }
  .template-btn-primary,
  .template-btn-outline {
    min-height: 38px;
    font-size: 0.82rem;
    padding-left: 0.75rem;
    padding-right: 0.75rem;
  }
  .template-card-actions {
    gap: 0.4rem;
    align-items: center;
  }
  .template-btn-primary {
    flex: 0 0 auto;
    min-width: 0;
    white-space: nowrap;
    border-radius: 10px;
    background: var(--accent);
    border-color: var(--accent);
    font-weight: 700;
    font-size: 0.8rem;
    padding-left: 0.68rem;
    padding-right: 0.68rem;
    letter-spacing: 0.01em;
  }
  .template-btn-label-full {
    display: none;
  }
  .template-btn-label-mobile {
    display: inline;
  }
  .template-btn-primary:hover {
    background: var(--accent-hover);
    border-color: var(--accent-hover);
  }
  .template-btn-outline {
    border-radius: 10px;
  }
  .btn-add-to-cart.template-btn-add-cart {
    width: 38px;
    height: 38px;
    border-radius: 0;
  }
}
