/* ============================================

   GPRINT PUBLICO - base publica dark-first

   CSS publico separado para reduzir carga fora do painel

   ============================================ */

/* ============================================
   GPrint - CSS Global Unificado
   Marketing + Painel SPA
   ============================================ */

/* ============================================
   VARIAVEIS CSS
   ============================================ */
:root {
  /* Acento/semantico unificados com a paleta RD (mesma familia claro/escuro).
     Laranja de marca mantido (identidade publica, nao e o embacado). */
  --primary: #2f81f7;
  --primary-dark: #1f6feb;
  --primary-hover: #1f6feb;
  --primary-rgb: 47, 129, 247;
  --secondary: #64748b;
  --accent: #f26522;
  --success: #16a34a;
  --success-rgb: 22, 163, 74;
  --warning: #d99a16;
  --warning-rgb: 217, 154, 22;
  --error: #e5484d;
  --error-rgb: 229, 72, 77;
  --danger: var(--error);
  --danger-rgb: 239, 68, 68;
  --info: #3b82f6;
  --bg: #f8fafc;
  --bg-secondary: #f1f5f9;
  --bg-card: #ffffff;
  --text: #1e293b;
  --text-muted: #64748b;
  --text-light: #94a3b8;
  --border: #e2e8f0;
  --border-light: #f1f5f9;
  --brand-frame-gradient: linear-gradient(
    135deg,
    rgba(29, 46, 108, 0.98) 0%,
    rgba(37, 99, 235, 0.96) 54%,
    rgba(249, 115, 22, 0.92) 100%
  );
  --brand-frame-fill: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.985),
    rgba(248, 250, 252, 0.965)
  );
  --brand-frame-shadow:
    0 18px 40px -34px rgba(15, 23, 42, 0.34),
    0 12px 22px -22px rgba(249, 115, 22, 0.2);
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow:
    0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-lg:
    0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --spacing-xs: 0.25rem;
  --spacing-sm: 0.5rem;
  --spacing-md: 1rem;
  --spacing-lg: 1.5rem;
  --spacing-xl: 2rem;
  --radius-sm: 0.375rem;
  --radius-md: 0.5rem;
  --radius-lg: 0.75rem;
  --header-height: 64px;
  --sidebar-width: 280px;
}

/* ============================================
   MODO NOTURNO (DARK THEME)
   ============================================ */
html.dark-theme, body.dark-theme {
  /* Paleta exata do instalador RD (nitidez/contraste, near-black estreito).
     Acento/semantico unificados com o painel e o agent C#. */
  --primary: #2f81f7;
  --primary-dark: #1f6feb;
  --primary-hover: #58a6ff;
  --primary-rgb: 47, 129, 247;
  --success: #22c55e;
  --success-rgb: 34, 197, 94;
  --warning: #fcd34d;
  --warning-rgb: 252, 211, 77;
  --error: #ff5f56;
  --error-rgb: 255, 95, 86;
  --danger: var(--error);
  --danger-rgb: 255, 95, 86;
  --bg: #0b0d10;
  --bg-secondary: #15191e;
  --bg-card: #101214;
  --text: #f5f7fb;
  --text-muted: #a8b3c2;
  --text-light: #768292;
  --border: #30363d;
  --border-light: #23282f;
  --brand-frame-fill: linear-gradient(
    180deg,
    rgba(30, 41, 59, 0.985),
    rgba(15, 23, 42, 0.965)
  );
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.5);
  --shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.5), 0 2px 4px -1px rgba(0, 0, 0, 0.3);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.5), 0 4px 6px -2px rgba(0, 0, 0, 0.3);
}

/* ============================================
   RESET
   ============================================ */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family:
    -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue",
    Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.5;
  font-size: 13px;
  -webkit-font-smoothing: auto;
  -moz-osx-font-smoothing: auto;
  text-rendering: auto;
  min-height: 100vh;
}

a {
  color: var(--primary);
  text-decoration: none;
}
a:hover {
  color: var(--primary-hover);
}

/* ============================================
   MARKETING - LAYOUT PUBLICO
   ============================================ */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.25rem;
}

/* Header/Navbar Publico */
header {
  background: var(--bg-card);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 100;
  backdrop-filter: none;
}

.navbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.375rem 0;
}

.logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 0.1rem 0.28rem;
  border-radius: 0.38rem;
  border: 2px solid transparent;
  background:
    var(--brand-frame-fill) padding-box,
    var(--brand-frame-gradient) border-box;
  box-shadow: var(--brand-frame-shadow);
  text-decoration: none;
  transition:
    box-shadow 0.2s ease,
    transform 0.2s ease;
}

.logo:hover {
  transform: translateY(-1px);
  box-shadow: 0 22px 42px -32px rgba(15, 23, 42, 0.3);
}

.logo-img {
  height: 30px;
  width: auto;
  display: block;
  border-radius: 0.26rem;
}

header nav {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

header nav a {
  color: var(--text-muted);
  text-decoration: none;
  font-weight: 500;
  font-size: 0.813rem;
  padding: 0.45rem 0.8rem;
  border-radius: 0.5rem;
  transition: all 0.2s ease;
}

header nav a:hover {
  color: var(--primary);
  background: var(--bg-secondary);
}

header nav a.btn-primary {
  background: var(--primary);
  color: white;
}

header nav a.btn-primary:hover {
  background: var(--primary-dark);
  color: white;
}

/* Hero */
.hero {
  padding: 2rem 0;
  background: linear-gradient(
    135deg,
    var(--bg-secondary) 0%,
    var(--bg-card) 100%
  );
}

.hero-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  align-items: center;
}

.hero h1 {
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 0.6rem;
}

.hero h1 span {
  color: var(--primary);
}

.hero p {
  font-size: 0.875rem;
  color: var(--text-muted);
  margin-bottom: 1rem;
  line-height: 1.45;
}

.hero-cta {
  display: flex;
  gap: 0.75rem;
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.55rem 1.05rem;
  border-radius: 0.5rem;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.2s ease;
  cursor: pointer;
  border: none;
  font-size: 0.875rem;
}

.btn-primary-lg {
  background: var(--primary);
  color: white;
  box-shadow: 0 4px 14px 0 rgba(37, 99, 235, 0.4);
}

.btn-primary-lg:hover {
  background: var(--primary-dark);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px 0 rgba(37, 99, 235, 0.5);
}

.btn-outline {
  background: transparent;
  color: var(--primary);
  border: 2px solid var(--primary);
}

.btn-outline:hover {
  background: var(--primary);
  color: white;
}

.hero-visual {
  display: flex;
  justify-content: center;
  align-items: center;
}

.hero-graphic {
  width: 100%;
  max-width: 330px;
  aspect-ratio: 1;
  background: linear-gradient(135deg, var(--primary) 0%, var(--success) 100%);
  border-radius: 1.25rem;
  border: 1px solid rgba(15, 23, 42, 0.16);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow);
  padding: 1rem;
  overflow: hidden;
}

.hero-logo-img {
  width: 100%;
  max-width: 292px;
  max-height: 100%;
  object-fit: contain;
  display: block;
  border-radius: 0.95rem;
  filter: drop-shadow(0 6px 12px rgba(0, 0, 0, 0.12));
}

/* Features */
.features,
.page-section {
  padding: 2rem 0;
}

.section-title {
  text-align: center;
  margin-bottom: 1.35rem;
}

.section-title h2 {
  font-size: 1.35rem;
  font-weight: 700;
  margin-bottom: 0.375rem;
}

.section-title p {
  color: var(--text-muted);
  font-size: 0.813rem;
  max-width: 500px;
  margin: 0 auto;
}

.features-grid,
.help-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1rem;
}

.feature-card {
  background: var(--bg-card);
  padding: 1rem;
  border-radius: 0.75rem;
  border: 1px solid var(--border);
  transition: all 0.3s ease;
}

.feature-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: var(--primary);
}

.feature-icon {
  width: 2.25rem;
  height: 2.25rem;
  background: linear-gradient(135deg, var(--primary) 0%, var(--success) 100%);
  border-radius: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.6rem;
  font-size: 1rem;
}

.feature-card h3 {
  font-size: 0.938rem;
  font-weight: 600;
  margin-bottom: 0.375rem;
}

.feature-card p {
  font-size: 0.775rem;
}

.feature-card p,
.form-footer-divider p,
.text-muted,
.page-chat .message-item.received .message-sender {
  color: var(--text-muted);
}

/* Stats */
.stats {
  background: var(--bg-secondary);
  padding: 1.5rem 0;
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  text-align: center;
}

.stat-item h3 {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--primary);
  margin-bottom: 0.25rem;
}

.stat-item p {
  color: var(--text-muted);
  font-weight: 500;
  font-size: 0.813rem;
}

/* CTA */
.cta {
  padding: 2rem 0;
  background: linear-gradient(135deg, var(--primary) 0%, var(--success) 100%);
  color: white;
  text-align: center;
}

.cta h2 {
  font-size: 1.35rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
}

.cta p {
  font-size: 0.813rem;
  opacity: 0.9;
  margin-bottom: 1rem;
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}

.cta .btn {
  background: white;
  color: var(--primary);
}

.cta .btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px 0 rgba(0, 0, 0, 0.2);
}

/* Footer Publico */
footer {
  background: var(--text);
  color: white;
  padding: 1.6rem 0 0.9rem;
}

.footer-content {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1.15rem;
  margin-bottom: 1.15rem;
}

.footer-section h4 {
  font-size: 0.875rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
}

.footer-section p,
.footer-section a {
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
  display: block;
  margin-bottom: 0.375rem;
  font-size: 0.813rem;
}

.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: 1rem;
  text-align: center;
  color: rgba(255, 255, 255, 0.5);
  font-size: 0.75rem;
}

/* Forms */
.form-container {
  max-width: 440px;
  margin: 0 auto;
  background: var(--bg-card);
  padding: 1.35rem;
  border-radius: 0.9rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 16px 38px -30px rgba(15, 23, 42, 0.5);
}

.form-group {
  margin-bottom: 0.85rem;
}

.form-group label {
  display: block;
  font-weight: 500;
  font-size: 0.813rem;
  margin-bottom: 0.35rem;
  color: var(--text);
}

.form-group input,
.form-group select,
.form-input,
.form-select {
  width: 100%;
  padding: 0.5rem 0.7rem;
  border: 1px solid var(--border);
  border-radius: 0.375rem;
  font-size: 0.813rem;
  transition: all 0.2s ease;
  background: var(--bg-card);
}

.form-group input:focus,
.form-group select:focus,
.form-input:focus,
.form-select:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

.form-group small,
.form-hint {
  display: block;
  margin-top: 0.25rem;
  color: var(--text-muted);
  font-size: 0.75rem;
}

.form-row {
  display: flex;
  gap: var(--spacing-md);
}

.form-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.25rem;
  max-width: 600px;
}

.form-actions,
.modal-actions {
  display: flex;
  gap: 0.75rem;
  justify-content: flex-end;
}

.form-group-checkbox {
  margin-bottom: 1.25rem;
}

.checkbox-group,
.checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
}

.checkbox-group input[type="checkbox"],
.checkbox-label input[type="checkbox"] {
  width: auto;
  margin-top: 0.25rem;
  cursor: pointer;
}

.checkbox-group label,
.checkbox-label span {
  margin-bottom: 0;
  font-weight: normal;
  font-size: 0.875rem;
}

.cnpj-loader {
  display: none;
  color: var(--primary);
  font-size: 0.875rem;
  margin-top: 0.5rem;
}

.cnpj-loader.active {
  display: block;
}

/* Textarea em formularios */
.form-group textarea {
  width: 100%;
  padding: 0.5rem 0.7rem;
  border: 1px solid var(--border);
  border-radius: 0.375rem;
  font-size: 0.813rem;
  font-family: inherit;
  transition: all 0.2s ease;
  background: var(--bg-card);
  resize: vertical;
}

.form-group textarea:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

.page-section-alt {
  padding: 2rem 0;
  background: var(--bg-secondary);
}

.page-section-full {
  padding: 2rem 0;
  background: var(--bg-secondary);
  min-height: calc(100vh - 160px);
}

/* Separador de formulario */
.form-separator {
  margin: 1.25rem 0;
  border: none;
  border-top: 1px solid var(--border);
}

.form-subtitle {
  margin-bottom: 0.75rem;
  font-size: 0.938rem;
}

/* Campos readonly autopreenchidos */
.input-readonly {
  background: var(--bg-secondary);
}

/* Botao full width */
.btn-block {
  width: 100%;
}

/* Links centralizados abaixo de formularios */
.form-footer-link {
  text-align: center;
  margin-top: 1rem;
}

.form-footer-link a:hover {
  text-decoration: underline;
}

.form-footer-divider {
  text-align: center;
  margin-top: 1.25rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--border);
}

.form-footer-divider .btn {
  margin-top: 0.5rem;
}

/* Mensagem de sucesso oculta */
.success-message {
  display: none;
  text-align: center;
  padding: 1.5rem;
}

.success-message.visible {
  display: block;
}

.success-icon {
  font-size: 2rem;
  margin-bottom: 0.75rem;
}

.success-title {
  color: var(--success);
  margin-bottom: 1rem;
}

.success-text {
  color: var(--text-muted);
  margin-bottom: 1.5rem;
}

.success-hint {
  color: var(--text-muted);
  font-size: 0.875rem;
}

/* Link invalido / erro */
.error-block {
  text-align: center;
  padding: 2rem;
  color: var(--error);
}

.error-block .btn {
  margin-top: 1rem;
}

/* Documento legal renderizado */
.legal-container {
  max-width: 720px;
  margin: 0 auto;
  background: var(--bg-card);
  padding: 1.75rem;
  border-radius: 0.75rem;
  box-shadow: var(--shadow);
}

.legal-container h1 {
  font-size: 1.375rem;
  font-weight: 700;
  margin-bottom: 1.25rem;
  color: var(--text);
}

.legal-content h2 {
  font-size: 1.125rem;
  margin: 1.5rem 0 0.75rem;
}
.legal-content h3 {
  font-size: 1rem;
  margin: 1rem 0 0.5rem;
}
.legal-content p {
  margin-bottom: 1rem;
  line-height: 1.8;
  color: var(--text-muted);
}
.legal-content ul,
.legal-content ol {
  margin-bottom: 1rem;
  padding-left: 1.5rem;
}
.legal-content li {
  margin-bottom: 0.5rem;
  color: var(--text-muted);
}
.legal-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.25rem 0;
  font-size: 0.95rem;
}
.legal-content th,
.legal-content td {
  padding: 0.85rem 1rem;
  border: 1px solid var(--border);
  text-align: left;
  vertical-align: top;
}
.legal-content th {
  background: var(--bg-secondary);
  color: var(--text);
  font-weight: 700;
}
.legal-content strong,
.pricing-note-bar strong {
  color: var(--text);
}

.legal-meta {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin: -0.75rem 0 1.75rem;
}

.legal-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.45rem 0.8rem;
  border-radius: 999px;
  background: var(--bg-secondary);
  color: var(--text-muted);
  font-size: 0.82rem;
  font-weight: 600;
}

.legal-note {
  margin: 1.25rem 0 0;
  padding: 1rem 1.1rem;
  border: 1px solid rgba(var(--warning-rgb), 0.35);
  border-radius: 0.85rem;
  background: rgba(var(--warning-rgb), 0.08);
  color: var(--text);
}

.legal-actions {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-bottom: 1.75rem;
}

.legal-tabs {
  display: flex;
  gap: 1rem;
  margin-bottom: 2rem;
  flex-wrap: wrap;
}

.legal-tab {
  padding: 0.5rem 1rem;
  border-radius: 0.5rem;
  border: 2px solid var(--border);
  background: var(--bg-card);
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-muted);
  transition: all 0.2s ease;
}

.legal-tab:hover {
  border-color: var(--primary);
  color: var(--primary);
}

.legal-tab.active,
.filter-btn.active {
  background: var(--primary);
  color: white;
  border-color: var(--primary);
}

.legal-loading {
  text-align: center;
  padding: 3rem;
  color: var(--text-muted);
}

/* LGPD Notice */
.lgpd-notice {
  background: var(--bg-secondary);
  padding: 1rem;
  border-radius: 0.5rem;
  font-size: 0.875rem;
  color: var(--text-muted);
  margin-top: 1rem;
}

.lgpd-notice a {
  color: var(--primary);
}

/* Menu Hamburguer Mobile */
.menu-toggle {
  display: none;
  flex-direction: column;
  gap: 0.35rem;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
}

.menu-toggle span {
  display: block;
  width: 25px;
  height: 3px;
  background: var(--text);
  border-radius: 2px;
  transition: all 0.3s ease;
}

.mobile-nav-public {
  display: none;
  position: fixed;
  top: 73px;
  left: 0;
  right: 0;
  background: var(--bg-card);
  border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow-lg);
  z-index: 999;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.mobile-nav-public.active {
  max-height: 500px;
}

.mobile-nav-public nav {
  display: flex;
  flex-direction: column;
  padding: 1rem;
  gap: 0.5rem;
}

.mobile-nav-public nav a {
  padding: 0.75rem 1rem;
  text-align: center;
}

/* Toast Notification */
.toast-container {
  position: fixed;
  top: 20px;
  right: 20px;
  z-index: 99999;
  display: flex;
  flex-direction: column;
  gap: 10px;
  pointer-events: none;
}

.toast {
  min-width: 300px;
  max-width: 500px;
  padding: 1rem 1.5rem;
  background: white;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  display: flex;
  align-items: center;
  gap: 12px;
  opacity: 0;
  transform: translateX(400px);
  transition: all 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  pointer-events: auto;
  border-left: 4px solid var(--primary);
}

.toast.show {
  opacity: 1;
  transform: translateX(0);
}
.toast.hide {
  opacity: 0;
  transform: translateX(400px);
}

.toast-icon {
  font-size: 24px;
  flex-shrink: 0;
}
.toast-content,
.card-content,
.form-group-fill {
  flex: 1;
}
.toast-title {
  font-weight: 600;
  margin-bottom: 4px;
}
.toast-message,
.page-subtitle {
  font-size: 0.78rem;
  color: var(--text-muted);
  line-height: 1.35;
}

.toast.success {
  border-left-color: var(--success);
}
.toast.error {
  border-left-color: var(--error);
}
.toast.warning {
  border-left-color: #f59e0b;
}
.toast.info {
  border-left-color: var(--primary);
}

/* Animations */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.animate-fade-in {
  animation: fadeInUp 0.6s ease forwards;
}

body.marketing-page .animate-fade-in {
  opacity: 1;
  transform: none;
  animation: marketingFadeLift 0.34s ease-out both;
}

@keyframes marketingFadeLift {
  from {
    opacity: 0.94;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  body.marketing-page .animate-fade-in {
    animation: none;
  }
}

/* Pricing Page */
.pricing-section {
  padding: 1.5rem 0;
}

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1rem;
  max-width: 900px;
  margin: 0 auto;
}

.pricing-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 0.75rem;
  padding: 1.25rem;
  text-align: center;
  position: relative;
  transition: all 0.3s ease;
}

.pricing-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.pricing-card.featured {
  border-color: var(--primary);
  box-shadow:
    0 0 0 1px var(--primary),
    var(--shadow-lg);
}

.pricing-badge {
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--primary);
  color: white;
  padding: 0.2rem 0.75rem;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.pricing-card h3 {
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: 0.25rem;
}

.pricing-price {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--primary);
  margin: 0.5rem 0;
}

.pricing-price small {
  font-size: 0.75rem;
  font-weight: 400;
  color: var(--text-muted);
}

.pricing-features {
  list-style: none;
  padding: 0;
  margin: 0.75rem 0;
  text-align: left;
}

.pricing-features li {
  padding: 0.3rem 0;
  font-size: 0.8rem;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.pricing-features li::before {
  content: "\2713";
  color: var(--success);
  font-weight: 700;
  font-size: 0.7rem;
  flex-shrink: 0;
}

/* Resources Page */
.resources-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1rem;
}

.resource-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 0.75rem;
  padding: 1.25rem;
  transition: all 0.3s ease;
}

.resource-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-lg);
  border-color: var(--primary);
}

.resource-icon {
  width: 2.5rem;
  height: 2.5rem;
  background: linear-gradient(135deg, var(--primary) 0%, #6366f1 100%);
  border-radius: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.6rem;
  font-size: 1.1rem;
  color: white;
}

.resource-card h3 {
  font-size: 0.938rem;
  font-weight: 600;
  margin-bottom: 0.3rem;
}
.resource-card p {
  font-size: 0.775rem;
  color: var(--text-muted);
}

/* Help Center */
.help-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 0.75rem;
  padding: 1rem;
  text-align: center;
  transition: all 0.2s ease;
}

.help-card:hover {
  border-color: var(--primary);
  box-shadow: var(--shadow);
}

.help-card-icon {
  font-size: 1.5rem;
  margin-bottom: 0.5rem;
}
.help-card h3 {
  font-size: 0.875rem;
  font-weight: 600;
  margin-bottom: 0.25rem;
}
.help-card p,
.contact-info-card p,
.step-item p {
  font-size: 0.75rem;
  color: var(--text-muted);
}

/* Status Page */
.status-banner {
  text-align: center;
  padding: 1rem;
  border-radius: 0.75rem;
  margin-bottom: 1rem;
  font-weight: 600;
  font-size: 0.875rem;
}

.status-banner.operational {
  background: rgba(16, 185, 129, 0.1);
  border: 1px solid rgba(16, 185, 129, 0.3);
  color: #059669;
}

.status-list {
  max-width: 700px;
  margin: 0 auto;
}

.status-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.6rem 0.75rem;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 0.5rem;
  margin-bottom: 0.5rem;
  font-size: 0.813rem;
}

.status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
  margin-right: 0.5rem;
  flex-shrink: 0;
}

.status-dot.green {
  background: var(--success);
}
.status-dot.yellow {
  background: var(--warning);
}
.status-dot.red {
  background: var(--error);
}

.status-label {
  display: flex;
  align-items: center;
}
.status-value {
  color: var(--text-muted);
  font-size: 0.75rem;
}

/* Split layout for login/contact with side marketing */
.split-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  min-height: calc(100vh - 120px);
}

.split-form {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
}

.split-marketing {
  background: linear-gradient(135deg, #0f172a 0%, #1e293b 50%, #0f172a 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  color: white;
  position: relative;
  overflow: hidden;
}

.split-marketing::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle at 30% 50%,
    rgba(37, 99, 235, 0.15) 0%,
    transparent 60%
  );
}

.split-marketing-content {
  position: relative;
  z-index: 1;
  text-align: center;
  max-width: 380px;
}

.split-marketing-content h2 {
  font-size: 1.25rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
}

.split-marketing-content p {
  font-size: 0.813rem;
  opacity: 0.8;
  margin-bottom: 1rem;
  line-height: 1.5;
}

.split-marketing-content img {
  max-width: 220px;
  padding: 0.24rem;
  border-radius: 0.9rem;
  border: 2px solid transparent;
  background:
    var(--brand-frame-fill) padding-box,
    var(--brand-frame-gradient) border-box;
  box-shadow: var(--brand-frame-shadow);
  margin-bottom: 1rem;
}

.split-marketing-features {
  list-style: none;
  padding: 0;
  text-align: left;
}

.split-marketing-features li {
  padding: 0.25rem 0;
  font-size: 0.775rem;
  opacity: 0.85;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.split-marketing-features li::before {
  content: "\2713";
  color: var(--success);
  font-weight: 700;
}

/* Contact info grid */
.contact-info-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 0.75rem;
  margin-bottom: 1.25rem;
}

.contact-info-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 0.5rem;
  padding: 0.75rem;
  text-align: center;
}

.contact-info-card h4 {
  font-size: 0.813rem;
  font-weight: 600;
  margin-bottom: 0.2rem;
}

/* How it works section */
.steps-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
  text-align: center;
}

.step-item {
  position: relative;
}

.step-number {
  width: 2rem;
  height: 2rem;
  background: var(--primary);
  color: white;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 0.813rem;
  margin-bottom: 0.5rem;
}

.step-item h3 {
  font-size: 0.875rem;
  font-weight: 600;
  margin-bottom: 0.2rem;
}
/* Trusted by / Social proof */
.trust-bar {
  padding: 1rem 0;
  text-align: center;
  background: var(--bg-card);
  border-bottom: 1px solid var(--border);
}

.trust-bar p {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-light);
  font-weight: 600;
}

/* Mobile responsive for new sections */
@media (max-width: 768px) {
  .split-layout {
    grid-template-columns: 1fr;
  }
  .split-marketing {
    display: none;
  }
  .pricing-grid {
    grid-template-columns: 1fr;
    max-width: 340px;
  }
  .hero-content {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .hero-visual {
    order: -1;
  }
  .hero-cta {
    justify-content: center;
  }
  .stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .steps-grid {
    grid-template-columns: 1fr 1fr;
  }
}


/* ============================================
   MODAL SYSTEM
   ============================================ */
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: modalFadeIn 0.2s ease-out;
}

.modal-overlay[hidden] {
  display: none !important;
}

.modal-box {
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: 2rem;
  max-width: 480px;
  width: 90%;
  animation: modalSlideIn 0.2s ease-out;
}

.modal-box h3 {
  font-size: 1.25rem;
  font-weight: 700;
  margin-bottom: 1rem;
  color: var(--text);
}

.modal-box p {
  color: var(--text-muted);
  margin-bottom: 1.5rem;
  line-height: 1.6;
}

.modal-input {
  width: 100%;
  padding: 0.75rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 0.95rem;
  margin-bottom: 1rem;
}

.modal-input:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

@keyframes modalFadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes modalSlideIn {
  from {
    opacity: 0;
    transform: translateY(-20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ============================================
   DATA TABLES
   ============================================ */
.data-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--bg-card);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.data-table thead {
  background: var(--bg-secondary);
}

.data-table th {
  padding: 0.5rem 0.7rem;
  text-align: left;
  font-weight: 600;
  font-size: 0.7rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-bottom: 1px solid var(--border);
}

.data-table td {
  padding: 0.5rem 0.7rem;
  border-bottom: 1px solid var(--border);
  font-size: 0.78rem;
  color: var(--text);
}

.data-table tbody tr:hover {
  background: var(--bg-secondary);
}

.data-table tbody tr:last-child td {
  border-bottom: none;
}

/* ============================================
   EMPTY STATE
   ============================================ */
.empty-state {
  text-align: center;
  padding: 3rem 1rem;
  color: var(--text-muted);
}

.empty-state .empty-icon {
  font-size: 3rem;
  margin-bottom: 1rem;
  opacity: 0.5;
}

.empty-state p {
  font-size: 1rem;
  margin-bottom: 0.5rem;
}

.empty-state small {
  font-size: 0.85rem;
  color: var(--text-light);
}

.full-span {
  grid-column: 1 / -1;
}

/* ============================================
   MODAL OVERLAY + BOX
   ============================================ */
@keyframes modalSlide {
  from {
    opacity: 0;
    transform: translateY(-20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  backdrop-filter: none;
}

.modal-overlay[hidden] {
  display: none !important;
}

.modal-box {
  background: var(--bg-card);
  border-radius: 1rem;
  width: 90%;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
  overflow: hidden;
  animation: modalSlide 0.2s ease;
}

.modal-box-sm {
  max-width: 400px;
}
.modal-box-md {
  max-width: 450px;
}
.modal-box-lg {
  max-width: 600px;
}
.modal-box-scroll {
  max-height: 90vh;
  overflow-y: auto;
}

.modal-header {
  padding: 1.5rem 1.5rem 1rem;
  border-bottom: 1px solid var(--border);
}

.modal-header-row {
  padding: 1.5rem 1.5rem 1rem;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.modal-header h3,
.modal-header-row h3 {
  font-size: 1.25rem;
  font-weight: 600;
  margin: 0;
  color: var(--text);
}

.modal-header-row .modal-icon {
  font-size: 1.5rem;
}

.modal-body {
  padding: 1.5rem;
  color: var(--text-muted);
}

.modal-body p {
  margin: 0;
  line-height: 1.6;
}

.modal-body-prompt p {
  margin: 0 0 1rem 0;
  line-height: 1.6;
  color: var(--text-muted);
}

.modal-footer {
  padding: 1rem 1.5rem;
  display: flex;
  gap: 1rem;
  justify-content: flex-end;
  background: var(--bg-secondary);
}

.btn-modal-cancel {
  padding: 0.6rem 1.25rem;
  border: 1px solid var(--border);
  background: var(--bg-card);
  border-radius: 0.5rem;
  cursor: pointer;
  font-weight: 500;
}

.btn-modal-confirm,
.btn-modal-ok {
  padding: 0.6rem 1.25rem;
  border: none;
  border-radius: 0.5rem;
  cursor: pointer;
  font-weight: 600;
  color: white;
}

.btn-modal-ok {
  padding: 0.6rem 1.5rem;
  background: var(--primary);
}
.btn-confirm-danger {
  background: #dc2626;
}
.btn-confirm-primary {
  background: var(--primary);
}
.btn-confirm-success {
  background: #16a34a;
}

.modal-input {
  width: 100%;
  padding: 0.75rem;
  border: 1px solid var(--border);
  border-radius: 0.5rem;
  font-size: 0.875rem;
}

/* ============================================
   TOAST
   ============================================ */
.toast-container {
  position: fixed;
  top: 1rem;
  right: 1rem;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.toast-msg {
  padding: 1rem;
  border-radius: 0.5rem;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  min-width: 250px;
  opacity: 0;
  transition: opacity 0.3s;
}

.toast-msg.toast-visible {
  opacity: 1;
}

.toast-msg.toast-error {
  background: #fee;
  border-left: 4px solid #c33;
}
.toast-msg.toast-success {
  background: #efe;
  border-left: 4px solid #3c3;
}
.toast-msg.toast-info {
  background: #eef;
  border-left: 4px solid #33c;
}

.toast-title {
  font-weight: 700;
  margin-bottom: 0.25rem;
}


/* ============================================
   MARKETING REDESIGN - HOME + PRECOS
   ============================================ */
body.marketing-page {
  background:
    radial-gradient(
      circle at top left,
      rgba(var(--primary-rgb), 0.08),
      transparent 28%
    ),
    linear-gradient(180deg, #f8fafc 0%, #eef4ff 30%, #f8fafc 100%);
}

body.marketing-page main {
  overflow-x: hidden;
}

body.marketing-page .btn {
  border-radius: 999px;
  padding: 0.72rem 1.15rem;
  font-size: 0.82rem;
  font-weight: 700;
}

body.marketing-page .btn-primary-solid {
  background: #0f172a;
  color: #fff;
  box-shadow: 0 14px 28px -18px rgba(15, 23, 42, 0.9);
}

body.marketing-page .btn-primary-solid:hover {
  color: #fff;
  background: #020617;
  transform: translateY(-1px);
}

body.marketing-page .btn-secondary-soft {
  background: rgba(var(--primary-rgb), 0.09);
  color: var(--primary);
  border: 1px solid rgba(var(--primary-rgb), 0.18);
}

body.marketing-page .btn-secondary-soft:hover {
  color: var(--primary-dark);
  background: rgba(var(--primary-rgb), 0.14);
  border-color: rgba(var(--primary-rgb), 0.26);
}

body.marketing-page .btn-light-solid {
  background: #fff;
  color: #0f172a;
}

body.marketing-page .btn-light-solid:hover {
  color: #0f172a;
  background: rgba(255, 255, 255, 0.92);
}

body.marketing-page .btn-light-outline {
  background: transparent;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.36);
}

body.marketing-page .btn-light-outline:hover {
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
}

.marketing-section,
.marketing-pricing-hero,
.marketing-hero {
  position: relative;
}

.marketing-section {
  padding: 2.75rem 0;
}

.marketing-section-alt {
  background: linear-gradient(
    180deg,
    rgba(var(--primary-rgb), 0.035),
    rgba(255, 255, 255, 0)
  );
}

.marketing-section-head {
  max-width: 740px;
  margin: 0 auto 1.4rem;
  text-align: center;
}

.marketing-section-head h1,
.marketing-section-head h2 {
  font-size: 1.9rem;
  line-height: 1.15;
  margin-bottom: 0.65rem;
  letter-spacing: 0;
}

.marketing-section-head h2 {
  font-size: 1.55rem;
}

.marketing-section-head p {
  color: var(--text-muted);
  font-size: 0.88rem;
  line-height: 1.65;
}

.marketing-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.38rem 0.8rem;
  border-radius: 999px;
  border: 1px solid rgba(var(--primary-rgb), 0.14);
  background: rgba(var(--primary-rgb), 0.08);
  color: var(--primary-dark);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.marketing-eyebrow-light {
  border-color: rgba(255, 255, 255, 0.24);
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.92);
}

.marketing-hero {
  padding: 3rem 0 2rem;
}

.marketing-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
  gap: 1.5rem;
  align-items: stretch;
}

.marketing-hero-copy {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  justify-content: center;
}

.marketing-hero-copy h1 {
  font-size: 2.4rem;
  line-height: 1.02;
  letter-spacing: 0;
}

.marketing-hero-copy p {
  font-size: 0.94rem;
  color: var(--text-muted);
  max-width: 620px;
  line-height: 1.7;
}

.marketing-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.marketing-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.62rem 0.9rem;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.88);
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 600;
  box-shadow: 0 10px 28px -24px rgba(15, 23, 42, 0.5);
}

.marketing-hero-actions,
.pricing-hero-actions,
.marketing-cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.marketing-hero-board {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1.25rem;
  border-radius: 1.35rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: linear-gradient(
    160deg,
    rgba(var(--primary-rgb), 0.14) 0%,
    rgba(255, 255, 255, 0.92) 38%,
    rgba(255, 255, 255, 1) 100%
  );
  box-shadow: 0 32px 60px -42px rgba(15, 23, 42, 0.45);
}

.marketing-board-highlight {
  padding: 1.1rem;
  border-radius: 1.05rem;
  background: #0f172a;
  color: #fff;
}

.marketing-board-label {
  display: inline-flex;
  margin-bottom: 0.45rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.68);
}

.marketing-board-highlight strong {
  display: block;
  font-size: 1.2rem;
  line-height: 1.2;
  margin-bottom: 0.5rem;
}

.marketing-board-highlight p {
  color: rgba(255, 255, 255, 0.76);
  font-size: 0.82rem;
  line-height: 1.65;
}

.marketing-board-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

.marketing-board-card {
  padding: 0.95rem;
  border-radius: 0.95rem;
  border: 1px solid rgba(15, 23, 42, 0.07);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 18px 35px -32px rgba(15, 23, 42, 0.42);
}

.marketing-board-tag {
  display: inline-flex;
  margin-bottom: 0.55rem;
  color: var(--primary-dark);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.marketing-board-card h2 {
  font-size: 0.98rem;
  line-height: 1.25;
  margin-bottom: 0.3rem;
}

.marketing-board-card p {
  color: var(--text-muted);
  font-size: 0.77rem;
  line-height: 1.6;
}

.marketing-proof {
  padding: 0 0 2rem;
}

.marketing-proof-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.95rem;
}

.marketing-proof-card {
  padding: 1.1rem;
  border-radius: 1rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 20px 38px -34px rgba(15, 23, 42, 0.45);
}

.marketing-proof-card h2 {
  font-size: 0.95rem;
  line-height: 1.3;
  margin-bottom: 0.35rem;
}

.marketing-proof-card p {
  color: var(--text-muted);
  font-size: 0.79rem;
  line-height: 1.6;
}

.marketing-feature-grid,
.marketing-structure-grid,
.pricing-faq-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.marketing-feature-card,
.marketing-structure-card,
.pricing-faq-card {
  padding: 1.15rem;
  border-radius: 1rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 22px 40px -34px rgba(15, 23, 42, 0.38);
}

.marketing-feature-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.85rem;
}

.marketing-feature-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 0.8rem;
  background: rgba(var(--primary-rgb), 0.11);
  color: var(--primary-dark);
  font-size: 0.77rem;
  font-weight: 700;
}

.marketing-feature-pill {
  display: inline-flex;
  padding: 0.34rem 0.68rem;
  border-radius: 999px;
  background: var(--bg-secondary);
  color: var(--text-muted);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.marketing-feature-card h3,
.marketing-structure-card h3,
.pricing-faq-card h3 {
  font-size: 1rem;
  line-height: 1.3;
  margin-bottom: 0.4rem;
}

.marketing-feature-card p,
.marketing-structure-card p,
.pricing-faq-card p {
  color: var(--text-muted);
  font-size: 0.8rem;
  line-height: 1.65;
}

.marketing-steps-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.marketing-step-card {
  position: relative;
  padding: 1.3rem 1.15rem 1.15rem;
  border-radius: 1rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 24px 44px -34px rgba(15, 23, 42, 0.35);
}

.marketing-step-number,
.pricing-model-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.35rem;
  height: 2.35rem;
  padding: 0 0.8rem;
  border-radius: 999px;
  background: #0f172a;
  color: #fff;
  font-size: 0.76rem;
  font-weight: 700;
  margin-bottom: 0.85rem;
}

.marketing-step-card h3,
.pricing-model-card h2 {
  font-size: 1rem;
  line-height: 1.3;
  margin-bottom: 0.35rem;
}

.marketing-step-card p,
.pricing-model-card p {
  color: var(--text-muted);
  font-size: 0.8rem;
  line-height: 1.65;
}

.marketing-pricing-hero {
  padding: 2.9rem 0 1.7rem;
}

.pricing-hero-head {
  margin-bottom: 1.3rem;
}

.pricing-model-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin-bottom: 1.1rem;
}

.pricing-model-card {
  padding: 1.15rem;
  border-radius: 1rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 24px 44px -34px rgba(15, 23, 42, 0.35);
}

.modular-grid {
  max-width: 100%;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: stretch;
}

.modular-card {
  display: flex;
  flex-direction: column;
  gap: 0.95rem;
  padding: 1.25rem;
  text-align: left;
  border-radius: 1rem;
  box-shadow: 0 28px 48px -36px rgba(15, 23, 42, 0.4);
}

.modular-card.featured {
  border-color: rgba(var(--primary-rgb), 0.3);
  background: linear-gradient(
    180deg,
    rgba(var(--primary-rgb), 0.08),
    rgba(255, 255, 255, 0.98)
  );
  box-shadow:
    0 0 0 1px rgba(var(--primary-rgb), 0.12),
    0 32px 54px -38px rgba(37, 99, 235, 0.34);
}

.pricing-card-head {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.pricing-plan-tag {
  display: inline-flex;
  align-self: flex-start;
  padding: 0.34rem 0.72rem;
  border-radius: 999px;
  background: rgba(var(--primary-rgb), 0.09);
  color: var(--primary-dark);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.modular-card .pricing-card-head p {
  color: var(--text-muted);
  font-size: 0.8rem;
  line-height: 1.6;
}

.modular-card .pricing-features {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.28rem;
  flex: 1;
}

.modular-card .pricing-features li {
  font-size: 0.8rem;
  line-height: 1.5;
}

.pricing-card-note {
  display: flex;
  flex-direction: column;
  gap: 0.22rem;
  padding: 0.9rem;
  border-radius: 0.9rem;
  background: var(--bg-secondary);
}

.pricing-card-note strong {
  font-size: 0.78rem;
  color: var(--text);
}

.pricing-card-note span {
  font-size: 0.77rem;
  color: var(--text-muted);
  line-height: 1.55;
}

.pricing-note-bar {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  flex-wrap: wrap;
  margin-top: 1.1rem;
  padding: 0.95rem 1rem;
  border-radius: 1rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.86);
  color: var(--text-muted);
  font-size: 0.8rem;
}

.pricing-faq-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.marketing-cta {
  padding: 2.5rem 0;
  background:
    radial-gradient(
      circle at top right,
      rgba(255, 255, 255, 0.14),
      transparent 24%
    ),
    linear-gradient(135deg, #0f172a 0%, #1e3a8a 100%);
}

.marketing-cta h2 {
  font-size: 1.65rem;
  line-height: 1.15;
  margin-top: 0.55rem;
}

.marketing-cta p {
  max-width: 700px;
}

@media (max-width: 1100px) {
  .marketing-proof-grid,
  .modular-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .marketing-feature-grid,
  .marketing-structure-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .marketing-hero-grid,
  .pricing-model-grid,
  .marketing-steps-grid,
  .pricing-faq-grid {
    grid-template-columns: 1fr;
  }

  .marketing-section-head h1 {
    font-size: 2rem;
  }

  .marketing-hero-copy h1 {
    font-size: 2rem;
  }

  .marketing-feature-grid,
  .marketing-structure-grid,
  .marketing-proof-grid,
  .modular-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  .marketing-hero {
    padding-top: 2.3rem;
  }

  .marketing-section,
  .marketing-pricing-hero {
    padding: 2.25rem 0;
  }

  .marketing-chip-list,
  .marketing-hero-actions,
  .pricing-hero-actions,
  .marketing-cta-actions {
    flex-direction: column;
  }

  .marketing-board-grid,
  .marketing-feature-grid,
  .marketing-structure-grid,
  .marketing-proof-grid,
  .modular-grid,
  .pricing-faq-grid {
    grid-template-columns: 1fr;
  }

  .marketing-feature-card,
  .marketing-proof-card,
  .marketing-step-card,
  .marketing-structure-card,
  .pricing-model-card,
  .pricing-faq-card,
  .modular-card {
    padding: 1rem;
  }
}

@media (max-width: 480px) {
  .marketing-section-head h1,
  .marketing-hero-copy h1 {
    font-size: 1.72rem;
  }

  .marketing-section-head h2,
  .marketing-cta h2 {
    font-size: 1.35rem;
  }

  .marketing-board-grid {
    grid-template-columns: 1fr;
  }
}

/* ============================================
   MARKETING PUBLIC STANDARDIZATION OVERRIDES
   ============================================ */
body.marketing-page {
  background: linear-gradient(180deg, #f8fafc 0%, #f5f7fb 38%, #f8fafc 100%);
}

body.marketing-page .btn {
  border: 1px solid rgba(var(--primary-rgb), 0.14);
  background: transparent;
  color: var(--text);
}

body.marketing-page .btn:hover {
  background: rgba(var(--primary-rgb), 0.08);
  border-color: rgba(var(--primary-rgb), 0.26);
  color: var(--primary-dark);
}

body.marketing-page .btn-primary-solid {
  background: var(--primary);
  color: #fff;
  border-color: var(--primary);
  box-shadow: 0 14px 28px -18px rgba(37, 99, 235, 0.55);
}

body.marketing-page .btn-primary-solid:hover {
  background: var(--primary-dark);
  border-color: var(--primary-dark);
  color: #fff;
}

body.marketing-page .btn-secondary-soft {
  background: rgba(255, 255, 255, 0.96);
  color: var(--text);
  border-color: var(--border);
}

body.marketing-page .btn-secondary-soft:hover {
  background: rgba(var(--primary-rgb), 0.08);
  color: var(--primary-dark);
  border-color: rgba(var(--primary-rgb), 0.24);
}

body.marketing-page .btn-light-solid {
  background: #fff;
  color: var(--primary-dark);
  border-color: rgba(255, 255, 255, 0.4);
}

body.marketing-page .btn-light-solid:hover {
  background: rgba(255, 255, 255, 0.92);
  color: var(--primary-dark);
}

body.marketing-page .btn-light-outline {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.38);
}

body.marketing-page .btn-light-outline:hover {
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
}

.marketing-section-head h1,
.public-page-copy h1 {
  color: #111827;
}

.marketing-hero-grid-visual {
  grid-template-columns: minmax(0, 1.02fr) minmax(320px, 0.98fr);
}

.marketing-home .marketing-hero {
  padding: 1.1rem 0 2rem;
}

.marketing-home .marketing-hero-grid-visual {
  grid-template-columns: minmax(340px, 0.9fr) minmax(0, 1.1fr);
  align-items: start;
}

.marketing-hero-banner {
  width: min(90vw, 1240px);
  margin: 0 auto 1.85rem;
}

.marketing-home .marketing-hero-banner {
  margin: 0 auto 1.35rem;
}

.marketing-hero-visual {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}

.marketing-home .marketing-hero-visual {
  order: 1;
  margin-top: 2.25rem;
}

.marketing-home .marketing-hero-copy {
  order: 2;
  padding-left: 0.4rem;
}

body.marketing-page {
  --primary: #2f81f7;
  --primary-dark: #1f6feb;
  --primary-hover: #58a6ff;
  --primary-rgb: 47, 129, 247;
  --accent: #f78100;
  --success: #0dbb84;
  --success-rgb: 13, 187, 132;
  --warning: #f7b955;
  --warning-rgb: 247, 185, 85;
  --error: #ff5f6d;
  --error-rgb: 255, 95, 109;
  --bg: #050505;
  --bg-secondary: #0b0b0c;
  --bg-card: #151516;
  --text: #f7f7f8;
  --text-muted: #a3a3a7;
  --text-light: #737379;
  --border: rgba(255, 255, 255, 0.12);
  --border-light: rgba(255, 255, 255, 0.08);
  --shadow-sm: 0 1px 0 rgba(255, 255, 255, 0.04);
  --shadow: 0 18px 44px rgba(0, 0, 0, 0.32);
  --shadow-lg: 0 30px 80px rgba(0, 0, 0, 0.46);
  background:
    radial-gradient(circle at 18% -12%, rgba(247, 129, 0, 0.17), transparent 34rem),
    radial-gradient(circle at 86% 6%, rgba(47, 129, 247, 0.15), transparent 32rem),
    #050505;
  color: var(--text);
}

/* Aviso removivel da home publica. Copiado do Webmail CDMR para manter consistencia entre plataformas em lancamento. */
.development-banner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  width: min(100%, 760px);
  margin: 0 auto 22px;
  padding: 16px 24px;
  border-radius: 20px;
  border: 1px solid rgba(59, 130, 246, 0.72);
  background:
    linear-gradient(135deg, rgba(37, 99, 235, 0.24), rgba(14, 165, 233, 0.18)),
    rgba(5, 10, 22, 0.82);
  color: #eff6ff;
  box-shadow: 0 0 0 1px rgba(96, 165, 250, 0.25), 0 0 46px rgba(37, 99, 235, 0.34);
  animation: none;
  filter: none;
  transform: none;
}

.development-banner strong {
  font-size: clamp(22px, 3.2vw, 36px);
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
}

.development-banner span {
  max-width: 620px;
  color: rgba(219, 234, 254, 0.92);
  font-size: clamp(13px, 1.4vw, 16px);
  font-weight: 700;
  line-height: 1.45;
}

@keyframes developmentBlink {
  0%, 100% {
    filter: none;
    transform: translateY(0);
  }

  50% {
    filter: none;
    transform: translateY(0);
  }
}

body.marketing-page header,
body.marketing-page footer,
body.marketing-page .form-shell,
body.marketing-page .marketing-proof-card,
body.marketing-page .marketing-mini-card,
body.marketing-page .marketing-image-card,
body.marketing-page .marketing-feature-card,
body.marketing-page .marketing-plan-card,
body.marketing-page .marketing-contact-card,
body.marketing-page .marketing-faq-card,
body.marketing-page .marketing-legal-card,
body.marketing-page .modal-box {
  border-color: var(--border);
  background: rgba(21, 21, 22, 0.86);
  color: var(--text);
  box-shadow: var(--shadow);
}

body.marketing-page header {
  background: rgba(5, 5, 5, 0.88);
  backdrop-filter: none;
}

body.marketing-page header nav a,
body.marketing-page .footer-section p,
body.marketing-page .footer-section a,
body.marketing-page .marketing-hero-copy p,
body.marketing-page .marketing-section-head p,
body.marketing-page .form-group label,
body.marketing-page .section-title p {
  color: var(--text-muted);
}

body.marketing-page header nav a:hover,
body.marketing-page .footer-section a:hover {
  color: var(--text);
  background: rgba(255, 255, 255, 0.07);
}

body.marketing-page input,
body.marketing-page select,
body.marketing-page textarea {
  border-color: var(--border);
  background: #0d0d0e;
  color: var(--text);
}

body.marketing-page input:focus,
body.marketing-page select:focus,
body.marketing-page textarea:focus {
  border-color: rgba(var(--primary-rgb), 0.66);
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.18);
}

body.marketing-page .marketing-hero {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0)),
    transparent;
}

body.marketing-page .marketing-hero-copy h1,
body.marketing-page .section-title h2,
body.marketing-page .marketing-section-head h2,
body.marketing-page .footer-section h4 {
  color: var(--text);
}

body.marketing-page .marketing-chip,
body.marketing-page .login-dropdown-box,
body.marketing-page .mobile-nav-public {
  border-color: var(--border);
  background: rgba(21, 21, 22, 0.94);
  color: var(--text);
}

body.marketing-page .btn-secondary-soft {
  border-color: var(--border);
  background: rgba(255, 255, 255, 0.07);
  color: var(--text);
}

body.marketing-page {
  overflow-x: hidden;
}

@media (max-width: 760px) {
  html,
  body.marketing-page {
    width: 100%;
    max-width: 100%;
  }

  body.marketing-page .container {
    width: 100%;
    max-width: 100%;
    padding-left: 1rem;
    padding-right: 1rem;
  }

  body.marketing-page .marketing-hero,
  body.marketing-page.marketing-home .marketing-hero-grid-visual,
  body.marketing-page .marketing-hero-grid-visual,
  body.marketing-page .marketing-hero-grid {
    width: 100%;
    grid-template-columns: minmax(0, 1fr);
    max-width: 100%;
    min-width: 0;
    overflow-x: hidden;
  }

  body.marketing-page.marketing-home .marketing-hero-copy,
  body.marketing-page .marketing-hero-copy,
  body.marketing-page .marketing-chip,
  body.marketing-page .marketing-hero-actions .btn {
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  body.marketing-page .marketing-hero-copy h1,
  body.marketing-page .marketing-hero-copy p,
  body.marketing-page .marketing-chip,
  body.marketing-page .marketing-hero-actions .btn {
    max-width: 100%;
    white-space: normal;
    overflow-wrap: anywhere;
  }
}

.marketing-image-card {
  padding: 0.2rem;
  border-radius: 1.3rem;
  border: 2px solid transparent;
  background:
    var(--brand-frame-fill) padding-box,
    var(--brand-frame-gradient) border-box;
  box-shadow: var(--brand-frame-shadow);
}

.marketing-hero-image {
  width: 100%;
  display: block;
  border-radius: 1rem;
}

.marketing-banner-card {
  padding: 0.18rem;
  box-shadow:
    0 22px 44px -34px rgba(15, 23, 42, 0.42),
    0 14px 26px -22px rgba(249, 115, 22, 0.22);
}

.marketing-banner-image {
  width: 100%;
  display: block;
  border-radius: 1rem;
  border: 1px solid rgba(255, 255, 255, 0.22);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.marketing-hero-mini-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
}

.marketing-hero-mini-grid-full {
  width: 100%;
  margin-top: 1rem;
}

.marketing-mini-card {
  padding: 0.95rem;
  border-radius: 1rem;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 20px 36px -34px rgba(15, 23, 42, 0.45);
}

.marketing-mini-card span {
  display: inline-flex;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--primary-dark);
}

.marketing-mini-card strong {
  display: block;
  margin: 0.35rem 0;
  font-size: 0.92rem;
  line-height: 1.25;
}

.marketing-mini-card p {
  font-size: 0.76rem;
  color: var(--text-muted);
  line-height: 1.55;
}

.marketing-cta {
  background: linear-gradient(135deg, #1d4ed8 0%, #0ea5e9 100%);
}

.marketing-step-number,
.pricing-model-number {
  background: var(--primary);
}

.pricing-reference {
  color: var(--text-muted);
  font-size: 0.82rem;
}

.pricing-reference strong {
  display: block;
  margin-top: 0.18rem;
  color: var(--primary-dark);
  font-size: 1.18rem;
  line-height: 1.1;
}

.pricing-note-bar-center {
  justify-content: center;
  text-align: center;
}

.public-page-hero {
  padding: 2.65rem 0 1.7rem;
}

.public-page-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 0.9fr);
  gap: 1.2rem;
  align-items: stretch;
}

.public-page-grid-contact {
  align-items: start;
}

.public-page-copy {
  display: flex;
  flex-direction: column;
  gap: 0.95rem;
  justify-content: center;
}

.public-page-copy h1 {
  font-size: 2rem;
  line-height: 1.08;
  letter-spacing: 0;
}

.public-page-copy p {
  color: var(--text-muted);
  font-size: 0.9rem;
  line-height: 1.7;
}

.public-media-card {
  padding: 0.24rem;
  border-radius: 1.2rem;
  border: 2px solid transparent;
  background:
    var(--brand-frame-fill) padding-box,
    var(--brand-frame-gradient) border-box;
  box-shadow: var(--brand-frame-shadow);
}

.public-aside-panel {
  padding: 1rem;
  border-radius: 1.2rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 28px 54px -42px rgba(15, 23, 42, 0.34);
}

.public-media-card-soft {
  background:
    linear-gradient(
        180deg,
        rgba(var(--primary-rgb), 0.06),
        rgba(255, 255, 255, 0.98)
      )
      padding-box,
    var(--brand-frame-gradient) border-box;
}

.public-media-image {
  display: block;
  width: 100%;
  border-radius: 1rem;
  border: 1px solid rgba(255, 255, 255, 0.22);
}

.public-note-list {
  display: grid;
  gap: 0.8rem;
}

.public-note-item {
  padding: 0.9rem 1rem;
  border-radius: 0.95rem;
  border: 1px solid var(--border);
  background: #fff;
}

.public-note-item strong {
  display: block;
  margin-bottom: 0.25rem;
  font-size: 0.9rem;
}

.public-note-item span {
  font-size: 0.79rem;
  color: var(--text-muted);
  line-height: 1.55;
}

.public-card-grid {
  display: grid;
  gap: 1rem;
}

.public-card-grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.compact-grid {
  gap: 0.8rem;
}

.public-card {
  padding: 1.05rem;
  border-radius: 1rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 20px 36px -34px rgba(15, 23, 42, 0.4);
}

.public-card h3 {
  font-size: 0.95rem;
  line-height: 1.3;
  margin-bottom: 0.35rem;
}

.public-card p {
  font-size: 0.8rem;
  color: var(--text-muted);
  line-height: 1.6;
}

.faq-stack {
  max-width: 780px;
  margin: 0 auto;
  display: grid;
  gap: 0.85rem;
}

.faq-card {
  padding: 1rem 1.05rem;
  border-radius: 1rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 18px 34px -34px rgba(15, 23, 42, 0.42);
}

.faq-card h3 {
  font-size: 0.92rem;
  margin-bottom: 0.35rem;
}

.faq-card p {
  font-size: 0.8rem;
  color: var(--text-muted);
  line-height: 1.6;
}

.form-shell {
  width: 100%;
  max-width: 400px;
}

.form-shell-wide {
  max-width: 470px;
}

.section-title-left {
  text-align: left;
  margin-bottom: 0.9rem;
}

.form-container-flat {
  padding: 0;
  border: none;
  box-shadow: none;
  background: transparent;
}

.form-group-grow {
  flex: 1 1 auto;
}

.form-group-uf {
  flex: 0 0 72px;
}
.form-group-fixed-160 {
  flex: 0 0 160px;
}
.signup-stage-helper {
  align-self: center;
  padding-top: 0.5rem;
}

.public-aside-panel {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.contact-info-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.8rem;
}

.marketing-auth .split-layout {
  min-height: calc(100vh - 64px);
}

.marketing-auth .split-form {
  background: transparent;
}

.marketing-auth .split-marketing {
  background: linear-gradient(155deg, #173a8f 0%, #1d4ed8 52%, #0ea5e9 100%);
}

.marketing-auth .split-marketing::before {
  background: radial-gradient(
    circle at top left,
    rgba(255, 255, 255, 0.18) 0%,
    transparent 45%
  );
}

.marketing-auth .split-marketing-content {
  max-width: 420px;
}

.marketing-auth .split-marketing-content img {
  padding: 0.24rem;
  border-radius: 0.95rem;
  border: 2px solid transparent;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.04))
      padding-box,
    var(--brand-frame-gradient) border-box;
  box-shadow: var(--brand-frame-shadow);
}

.marketing-auth .split-marketing-content h2 {
  font-size: 1.55rem;
}

.marketing-auth .split-marketing-features li {
  background: rgba(255, 255, 255, 0.11);
  border-color: rgba(255, 255, 255, 0.14);
}

.marketing-auth-lite .page-section-full {
  padding: 2.5rem 0;
  min-height: auto;
}

/* Signup page — professional centered layout */
.signup-hero {
  background: linear-gradient(135deg, #0f172a 0%, #1e3a5f 100%);
  color: #fff;
  padding: 2.4rem 0 1.8rem;
  text-align: center;
}

.signup-hero h1 {
  font-size: 1.65rem;
  font-weight: 700;
  letter-spacing: 0;
  margin-bottom: 0.35rem;
}

.signup-hero p {
  font-size: 0.875rem;
  opacity: 0.75;
  max-width: 480px;
  margin: 0 auto;
  line-height: 1.5;
}

.signup-card {
  max-width: 720px;
  margin: 0 auto;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 0.75rem;
  padding: 2rem 2.25rem;
  box-shadow: 0 4px 24px -8px rgba(15, 23, 42, 0.08);
}

.signup-fieldset {
  border: none;
  padding: 0;
  margin: 0 0 1.5rem;
}

.signup-fieldset legend {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding-bottom: 0.6rem;
  margin-bottom: 1rem;
  border-bottom: 1px solid var(--border);
  width: 100%;
}

.signup-row-2 {
  display: flex;
  gap: 1rem;
}

.signup-footer {
  border-top: 1px solid var(--border);
  padding-top: 1.25rem;
}

.signup-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  margin-top: 1rem;
}

.signup-actions .btn {
  min-width: 150px;
}

.signup-auth-warning {
  margin-top: 0.25rem;
  padding: 1rem 1.05rem;
  border-radius: 1rem;
  border: 1px solid rgba(var(--primary-rgb), 0.16);
  background: linear-gradient(180deg, rgba(var(--primary-rgb), 0.06), rgba(255, 255, 255, 0.96));
}

.signup-auth-warning strong {
  display: block;
  font-size: 0.98rem;
  line-height: 1.35;
  color: var(--primary-dark);
}

.signup-auth-warning p {
  margin: 0.45rem 0 0;
  font-size: 0.84rem;
  color: var(--text-muted);
  line-height: 1.6;
}

.signup-auth-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 0.85rem;
}

.signup-auth-links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.65rem 0.9rem;
  border-radius: 999px;
  border: 1px solid rgba(var(--primary-rgb), 0.14);
  background: rgba(255, 255, 255, 0.9);
  color: var(--primary-dark);
  font-size: 0.78rem;
  font-weight: 700;
  text-decoration: none;
}

.modal-box-auth {
  max-width: 520px;
}

.modal-box-auth-wide {
  max-width: 840px;
}

.security-modal--auth {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}

.security-modal__note--auth {
  margin-bottom: 0;
  font-size: 0.84rem;
}

.security-modal__qr--auth {
  grid-template-columns: minmax(0, 220px) minmax(0, 1fr);
  gap: 0.9rem;
}

.security-modal--auth .security-modal__qr-box {
  min-height: 170px;
  padding: 0.8rem;
}

.security-modal--auth .security-modal__qr-box svg {
  max-width: 150px;
}

@media (max-width: 768px) {
  .signup-card {
    padding: 1.25rem;
    border-radius: 0;
    border-left: 0;
    border-right: 0;
  }

  .signup-row-2 {
    flex-direction: column;
    gap: 0;
  }

  .signup-row-2 .form-group-fixed-160 {
    flex: unset !important;
  }

  .signup-actions {
    flex-direction: column-reverse;
  }

  .signup-actions .btn {
    width: 100%;
    min-width: unset;
  }

  .signup-auth-links {
    flex-direction: column;
  }

  .signup-auth-links a {
    width: 100%;
  }

  .security-modal__qr--auth {
    grid-template-columns: 1fr;
  }
}

.public-status-grid {
  max-width: 780px;
  margin: 1rem auto 0;
  display: grid;
  gap: 0.75rem;
}

.public-status-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.05rem;
  border-radius: 1rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 20px 36px -34px rgba(15, 23, 42, 0.38);
}

.public-inline-note {
  max-width: 780px;
  margin: 1rem auto 0;
  text-align: center;
  font-size: 0.8rem;
  color: var(--text-muted);
}

.public-inline-note a {
  color: var(--primary-dark);
  font-weight: 700;
}

.marketing-legal-page .legal-container {
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 1.5rem;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 26px 60px -42px rgba(15, 23, 42, 0.38);
  padding: 2rem;
}

.marketing-legal-page .legal-content a {
  color: var(--primary-dark);
  font-weight: 600;
  text-decoration: none;
  border-bottom: 1px solid rgba(var(--primary-rgb), 0.24);
}

.marketing-legal-page .legal-content a:hover {
  color: var(--primary);
  border-bottom-color: rgba(var(--primary-rgb), 0.42);
}

.legal-hub-grid {
  margin-top: 1.75rem;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.legal-hub-card {
  padding: 1.35rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 20px 40px -34px rgba(15, 23, 42, 0.32);
}

.legal-hub-card h3 {
  margin: 0 0 0.75rem;
  font-size: 1.05rem;
  color: var(--text);
}

.legal-hub-card p {
  margin: 0 0 1rem;
  color: var(--text-muted);
  line-height: 1.7;
}

body.modal-open {
  overflow: hidden;
}

.contract-clause-card {
  margin: 1.5rem 0;
  border: 1px solid rgba(var(--primary-rgb), 0.14);
  border-radius: 1.35rem;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.98),
    rgba(234, 242, 255, 0.62)
  );
  box-shadow: 0 26px 56px -42px rgba(15, 23, 42, 0.34);
  overflow: hidden;
}

.contract-clause-card--panel {
  margin-top: 1rem;
}

.contract-clause-card__head {
  padding: 1.15rem 1.25rem 1rem;
  border-bottom: 1px solid rgba(var(--primary-rgb), 0.12);
  background: rgba(var(--primary-rgb), 0.045);
}

.contract-clause-card__eyebrow {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.7rem;
  border-radius: 999px;
  background: rgba(var(--primary-rgb), 0.09);
  color: var(--primary-dark);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  text-transform: uppercase;
}

.contract-clause-card__head h3 {
  margin: 0.8rem 0 0;
  font-size: 1.08rem;
  color: var(--text);
}

.contract-clause-card__body {
  padding: 1.2rem 1.25rem 1.25rem;
}

.contract-clause-card__lead {
  margin: 0 0 1rem;
  color: var(--text-muted);
  line-height: 1.7;
}

.contract-clause-card__text {
  width: 100%;
  min-height: 176px;
  padding: 1rem 1.05rem;
  border: 1px solid rgba(15, 23, 42, 0.1);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.95);
  color: var(--text);
  font: inherit;
  line-height: 1.7;
  resize: vertical;
}

.contract-clause-card__actions {
  margin-top: 1rem;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.contract-clause-card__disclaimer {
  margin: 0;
  max-width: 520px;
  color: var(--text-muted);
  font-size: 0.84rem;
  line-height: 1.6;
}

.contract-clause-card__controls {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.contract-clause-card__feedback {
  min-height: 1.2rem;
  color: var(--text-muted);
  font-size: 0.83rem;
  font-weight: 600;
}

.contract-clause-card__feedback[data-state="error"] {
  color: var(--error);
}

.legal-retention-grid {
  margin-top: 1rem;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
}

.legal-retention-card {
  padding: 1rem 1.05rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 18px 34px -28px rgba(15, 23, 42, 0.22);
}

.legal-retention-card h3 {
  margin: 0 0 0.55rem;
  font-size: 0.95rem;
  color: var(--text);
}

.legal-retention-card p {
  margin: 0;
  color: var(--text-muted);
  line-height: 1.65;
}

.terms-consent-inline-note {
  display: block;
  margin-top: 0.45rem;
  padding-left: 2rem;
  color: var(--text-muted);
  font-size: 0.8rem;
  line-height: 1.55;
}

.signup-stage-notice {
  margin: 0;
  color: var(--text-muted);
  text-align: left;
  font-size: 0.775rem;
  font-weight: 500;
  line-height: 1.55;
}

.terms-consent-modal {
  background: rgba(15, 23, 42, 0.34);
  backdrop-filter: none;
}

.terms-consent-modal .modal-box {
  max-width: 680px;
  border: 1px solid rgba(var(--primary-rgb), 0.12);
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  box-shadow: 0 40px 80px -48px rgba(15, 23, 42, 0.45);
}

.terms-consent-modal .modal-header-row {
  padding: 1.15rem 1.35rem 0.9rem;
}

.terms-consent-modal .modal-body {
  padding: 1rem 1.35rem 1.05rem;
}

.terms-consent-modal .modal-footer {
  padding: 0.9rem 1.35rem;
}

.terms-consent-modal__icon {
  width: 2.2rem;
  height: 2.2rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(var(--primary-rgb), 0.12);
  color: var(--primary-dark);
  font-weight: 700;
  font-size: 1.05rem;
}

.terms-consent-modal__body {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.terms-consent-modal__body p {
  margin: 0;
}

.terms-consent-modal__secondary {
  color: var(--text);
  font-weight: 600;
}

.terms-consent-modal__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

.terms-consent-modal__chips span {
  display: inline-flex;
  align-items: center;
  padding: 0.5rem 0.75rem;
  border-radius: 999px;
  border: 1px solid rgba(var(--primary-rgb), 0.11);
  background: rgba(var(--primary-rgb), 0.05);
  color: var(--text);
  font-size: 0.82rem;
  font-weight: 600;
}

.terms-consent-modal__link-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.terms-consent-inline-link {
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--primary-dark);
  font: inherit;
  font-size: 0.83rem;
  font-weight: 700;
  cursor: pointer;
}

.terms-consent-inline-link:hover {
  color: var(--primary);
}

@media (max-width: 1100px) {
  .marketing-hero-mini-grid,
  .public-card-grid-3,
  .contact-info-grid,
  .legal-hub-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .marketing-home .marketing-hero-grid-visual {
    grid-template-columns: 1fr;
  }

  .marketing-hero-grid-visual,
  .public-page-grid,
  .public-page-grid-contact {
    grid-template-columns: 1fr;
  }

  .marketing-home .marketing-hero-copy,
  .marketing-home .marketing-hero-visual {
    padding-left: 0;
  }

  .marketing-home .marketing-hero-copy {
    order: 1;
  }

  .marketing-home .marketing-hero-banner {
    margin-bottom: 1.1rem;
  }

  .marketing-home .marketing-hero-visual {
    order: 2;
    width: 100%;
    max-width: 760px;
    margin: 0.9rem auto 0;
  }

  .marketing-home .marketing-hero-mini-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.55rem;
  }

  .marketing-hero-mini-grid,
  .public-card-grid-3,
  .contact-info-grid,
  .legal-hub-grid {
    grid-template-columns: 1fr;
  }

  .form-shell,
  .form-shell-wide {
    max-width: 100%;
  }
}

@media (max-width: 768px) {
  .public-page-hero {
    padding: 2.3rem 0 1.25rem;
  }

  .marketing-home .marketing-hero {
    padding-top: 0.8rem;
  }

  .marketing-hero-banner {
    width: min(92vw, 1240px);
  }

  .marketing-home .marketing-hero-visual {
    gap: 0.55rem;
    margin-top: 0.8rem;
  }

  .marketing-home .marketing-image-card {
    padding: 0.2rem;
    border-radius: 1rem;
  }

  .marketing-home .marketing-hero-image,
  .marketing-home .marketing-banner-image {
    border-radius: 0.8rem;
  }

  .marketing-home .marketing-hero-mini-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.45rem;
  }

  .marketing-home .marketing-mini-card {
    padding: 0.72rem 0.5rem;
    border-radius: 0.9rem;
  }

  .marketing-home .marketing-mini-card span {
    font-size: 0.5rem;
  }

  .marketing-home .marketing-mini-card strong {
    margin: 0.22rem 0 0;
    font-size: 0.66rem;
    line-height: 1.18;
  }

  .marketing-home .marketing-mini-card p {
    display: none;
  }

  .public-page-copy h1 {
    font-size: 1.72rem;
  }

  .marketing-hero-mini-grid {
    grid-template-columns: 1fr;
  }

  .form-row {
    flex-direction: column;
  }

  .marketing-legal-page .legal-container {
    padding: 1.35rem;
  }

  .contract-clause-card__body,
  .contract-clause-card__head {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .legal-retention-grid {
    grid-template-columns: 1fr;
  }

  .contract-clause-card__actions,
  .terms-consent-modal__link-row {
    align-items: flex-start;
    flex-direction: column;
  }

  .public-status-card {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* ============================================
   LOGIN DROPDOWN - Header publico compacto
   ============================================ */

.login-toggle {
  cursor: pointer;
  border: none;
  font: inherit;
}

.login-dropdown {
  position: fixed;
  top: 56px;
  right: 16px;
  z-index: 9998;
  opacity: 0;
  transform: translateY(-8px);
  transition: opacity 0.2s ease, transform 0.2s ease;
  pointer-events: none;
}

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

.login-dropdown-box {
  position: relative;
  width: 310px;
  padding: 1rem;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 1rem;
  box-shadow: 0 20px 48px -16px rgba(15, 23, 42, 0.22);
}

.login-dropdown-close {
  position: absolute;
  top: 0.55rem;
  right: 0.65rem;
  width: 1.6rem;
  height: 1.6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  background: transparent;
  color: var(--text-muted);
  font-size: 1.2rem;
  cursor: pointer;
  border-radius: 0.4rem;
  transition: background 0.15s ease;
}

.login-dropdown-close:hover {
  background: var(--bg-secondary);
  color: var(--text);
}

.login-dropdown-title {
  margin: 0 0 0.7rem;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--text);
}

.login-dropdown-fields {
  display: grid;
  gap: 0.5rem;
}

.login-dropdown-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem;
}

.login-dropdown-fields input,
.login-dropdown-fields select {
  width: 100%;
  padding: 0.5rem 0.65rem;
  border: 1px solid var(--border);
  border-radius: 0.55rem;
  background: var(--bg-card);
  color: var(--text);
  font-size: 0.78rem;
  font-family: inherit;
  outline: none;
  transition: border-color 0.15s ease;
  box-sizing: border-box;
}

.login-dropdown-fields input::placeholder {
  color: var(--text-light);
}

.login-dropdown-fields input:focus,
.login-dropdown-fields select:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.12);
}

.login-dropdown-fields select {
  cursor: pointer;
  appearance: auto;
}

.login-dropdown-status {
  min-height: 1.1rem;
  margin-top: 0.15rem;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--text-muted);
  text-align: center;
  transition: color 0.15s ease;
}

.login-dropdown-status.error {
  color: var(--error);
}

.login-dropdown-status.loading {
  color: var(--primary);
}

.login-dropdown-links {
  margin-top: 0.65rem;
  padding-top: 0.55rem;
  border-top: 1px solid var(--border);
  display: flex;
  flex-wrap: wrap;
  gap: 0.15rem 0.7rem;
}

.login-dropdown-links a {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--primary-dark);
  text-decoration: none;
  padding: 0.15rem 0;
  transition: color 0.15s ease;
}

.login-dropdown-links a:hover {
  color: var(--primary);
}

/* ============================================
   LOGIN DROPDOWN - Mobile (modal centralizado)
   ============================================ */

@media (max-width: 768px) {
  .login-dropdown {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.45);
    backdrop-filter: none;
    transform: none;
  }

  .login-dropdown.open {
    transform: none;
  }

  .login-dropdown-box {
    width: 90%;
    max-width: 360px;
  }
}

[hidden] {
  display: none !important;
}

.page-chat .messages-header-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.page-chat .chat-linked-call {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.35rem 0.6rem;
  border-radius: 999px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 600;
}

.page-chat .chat-attachment-thumb {
  max-width: 160px;
  border-radius: 8px;
  display: block;
  margin-bottom: 8px;
}

.page-client-create {
  padding: 0;
}

.page-client-create form {
  display: block;
}

.client-create-empty-state {
  padding: 4rem 1.5rem;
}

.client-create-empty-title {
  margin-bottom: 0.5rem;
}

.client-create-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem;
  margin-bottom: 1.5rem;
}

.client-create-grid .span-2,
.form-grid .span-2 {
  grid-column: 1 / -1;
}

.client-create-grid-offset {
  margin-top: 1.5rem;
}

.client-create-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.client-create-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(var(--primary-rgb), 0.05), rgba(var(--primary-rgb), 0.02));
}

.client-create-head h2 {
  margin: 0 0 0.25rem;
  font-size: 1rem;
  font-weight: 700;
  color: var(--text);
}

.client-create-head p {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.875rem;
}

.client-create-body {
  padding: 1.5rem;
}

.quick-doc-input {
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.doc-type-toggle {
  display: inline-flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.doc-type-button.active {
  background: rgba(var(--primary-rgb), 0.14);
  border-color: rgba(var(--primary-rgb), 0.28);
  color: var(--primary);
}

.field-note,
.field-status {
  font-size: 0.78rem;
  line-height: 1.4;
  color: var(--text-muted);
}

.field-status.success {
  color: var(--success);
}

.field-status.error {
  color: var(--error);
}

.field-status.info {
  color: var(--primary);
}

.lookup-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0.35rem 0.75rem;
  border-radius: 999px;
  border: 1px solid rgba(var(--primary-rgb), 0.14);
  background: rgba(var(--primary-rgb), 0.08);
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 700;
  text-align: center;
}

.lookup-chip.success {
  background: rgba(16, 185, 129, 0.12);
  border-color: rgba(16, 185, 129, 0.22);
  color: #047857;
}

.lookup-chip.error {
  background: rgba(239, 68, 68, 0.1);
  border-color: rgba(239, 68, 68, 0.18);
  color: #b91c1c;
}

.lookup-chip.info {
  background: rgba(var(--primary-rgb), 0.12);
  border-color: rgba(var(--primary-rgb), 0.2);
  color: var(--primary);
}

.units-section .client-create-head {
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.03), rgba(15, 23, 42, 0.01));
}

.units-stack {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.unit-card {
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(var(--primary-rgb), 0.02), rgba(255, 255, 255, 0));
}

.unit-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--border);
  background: rgba(var(--primary-rgb), 0.04);
}

.unit-card-header h3 {
  margin: 0 0 0.25rem;
  font-size: 0.95rem;
  font-weight: 700;
}

.unit-card-header p {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.8rem;
}

.unit-card-actions {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.btn-subtle-danger {
  border-color: rgba(var(--danger-rgb), 0.2);
  color: var(--danger);
  background: rgba(var(--danger-rgb), 0.06);
}

.btn-subtle-danger:hover {
  background: rgba(var(--danger-rgb), 0.1);
  border-color: rgba(var(--danger-rgb), 0.28);
}

.unit-card-body {
  padding: 1.25rem;
}

.units-empty {
  padding: 1.25rem;
  border: 1px dashed var(--border);
  border-radius: 8px;
  text-align: center;
  color: var(--text-muted);
  background: var(--bg-secondary);
}

.units-empty.hidden {
  display: none !important;
}

.units-footer {
  margin-top: 1rem;
  display: flex;
  justify-content: flex-start;
}

.client-create-flow {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
  margin: 0 0 1rem;
}

.client-step-pill {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 0;
  padding: 0.8rem 0.9rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg-card);
  color: var(--text-muted);
  text-align: left;
  cursor: pointer;
}

.client-step-pill.is-active {
  border-color: var(--primary);
  color: var(--text);
  box-shadow: 0 0 0 1px rgba(var(--primary-rgb), 0.25);
}

.client-step-pill.is-complete {
  border-color: rgba(16, 185, 129, 0.35);
}

.client-step-pill__index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 32px;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  background: rgba(var(--primary-rgb), 0.12);
  color: var(--primary);
  font-weight: 700;
}

.client-step-pill strong,
.client-step-pill small {
  display: block;
  min-width: 0;
}

.client-step-pill small {
  margin-top: 0.15rem;
  font-size: 0.76rem;
  color: var(--text-muted);
  overflow-wrap: anywhere;
}

.client-create-step-panel[hidden] {
  display: none !important;
}

.commercial-equipment-search {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.75rem;
  align-items: end;
}

.equipment-suggestions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.75rem;
  margin: 0.75rem 0;
}

.equipment-suggestion {
  display: grid;
  gap: 0.2rem;
  padding: 0.8rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg-secondary);
  color: var(--text);
  text-align: left;
  cursor: pointer;
}

.equipment-suggestion:hover {
  border-color: var(--primary);
}

.equipment-suggestion span,
.equipment-suggestion small {
  color: var(--text-muted);
  font-size: 0.78rem;
}

.contract-equipment-list {
  margin-top: 1rem;
}

.contract-equipment-table {
  display: grid;
  gap: 0.75rem;
}

.contract-equipment-row {
  display: grid;
  grid-template-columns: minmax(180px, 0.9fr) minmax(0, 3fr) auto;
  gap: 0.75rem;
  align-items: center;
  padding: 0.8rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg-secondary);
}

.contract-equipment-id {
  display: grid;
  gap: 0.15rem;
  min-width: 0;
}

.contract-equipment-id strong,
.contract-equipment-id span,
.contract-equipment-id small {
  overflow-wrap: anywhere;
}

.contract-equipment-id small {
  color: var(--text-muted);
  font-size: 0.74rem;
}

.contract-equipment-values {
  display: grid;
  grid-template-columns: repeat(5, minmax(88px, 1fr));
  gap: 0.45rem;
}

.contract-line-field {
  display: grid;
  gap: 0.2rem;
  min-width: 0;
}

.contract-line-field span {
  color: var(--text-muted);
  font-size: 0.68rem;
  font-weight: 700;
}

.contract-line-field input {
  width: 100%;
  min-width: 0;
  height: 36px;
  padding: 0.35rem 0.45rem;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--bg-card);
  color: var(--text);
  font-size: 0.82rem;
  font-weight: 700;
}

.contract-editor-grid {
  display: grid;
  gap: 1rem;
}

.client-portal-preview {
  min-height: 44px;
  padding: 0.75rem 0.85rem;
  border: 1px dashed rgba(var(--primary-rgb), 0.35);
  border-radius: 8px;
  background: rgba(var(--primary-rgb), 0.08);
  color: var(--text);
  font-size: 0.85rem;
  font-weight: 700;
  overflow-wrap: anywhere;
}

.client-temporary-contract {
  align-self: center;
}

.page-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 1.5rem;
}

.page-actions-left,
.page-actions-right {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.submit-hint {
  color: var(--text-muted);
  font-size: 0.8rem;
}

.page-contadores {
  padding: 0;
}

.mes-selector {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.mes-selector .form-input {
  min-width: 180px;
}

.totais-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.total-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 0.75rem;
  padding: 1.25rem;
  text-align: center;
}

.total-card .valor {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--primary);
}

.total-card .label {
  font-size: 0.75rem;
  color: var(--text-muted);
  text-transform: uppercase;
  margin-top: 0.25rem;
}

.total-card.pb {
  border-left: 3px solid #6b7280;
}

.total-card.cor {
  border-left: 3px solid #f59e0b;
}

.total-card.total {
  border-left: 3px solid var(--primary);
}

.contadores-table {
  width: 100%;
  border-collapse: collapse;
}

.contadores-table thead {
  background: var(--bg-secondary);
}

.contadores-table th {
  padding: 0.75rem 1rem;
  text-align: left;
  font-weight: 600;
  font-size: 0.8rem;
  color: var(--text-muted);
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}

.contadores-table td {
  padding: 0.75rem 1rem;
  font-size: 0.875rem;
  border-bottom: 1px solid var(--border-light);
}

.contadores-table .valor-num {
  font-weight: 700;
  color: var(--primary);
}

.chart-wrapper.chart-wrapper-tall {
  height: 300px;
}

.session-badge {
  display: inline-block;
  padding: 0.25rem 0.5rem;
  border-radius: 0.25rem;
  font-size: 0.7rem;
  font-weight: 600;
}

.session-badge.active {
  background: #dcfce7;
  color: #166534;
}

.session-badge.expired {
  background: #fef2f2;
  color: #991b1b;
}

@media (max-width: 980px) {
  .client-create-flow,
  .client-create-grid,
  .form-grid {
    grid-template-columns: 1fr;
  }

  .client-create-grid .span-2,
  .form-grid .span-2 {
    grid-column: auto;
  }

  .commercial-equipment-search,
  .contract-equipment-row {
    grid-template-columns: 1fr;
  }

  .contract-equipment-values {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .client-create-head,
  .unit-card-header,
  .page-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .lookup-chip,
  .commercial-equipment-search .btn-secondary,
  .page-actions-right .btn-primary,
  .page-actions-right .btn-secondary,
  .unit-card-actions .filter-btn,
  .units-footer .btn-primary {
    width: 100%;
  }
}

@media (max-width: 760px) {
  body.marketing-page,
  body.marketing-page main,
  body.marketing-page section,
  body.marketing-page .container,
  body.marketing-page .marketing-hero,
  body.marketing-page .marketing-hero-grid,
  body.marketing-page .marketing-hero-grid-visual,
  body.marketing-page .marketing-hero-copy,
  body.marketing-page .marketing-hero-actions,
  body.marketing-page .marketing-chip-list {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow-x: hidden;
  }

  body.marketing-page .marketing-hero-copy h1,
  body.marketing-page .marketing-hero-copy p,
  body.marketing-page .marketing-chip,
  body.marketing-page .marketing-hero-actions .btn {
    width: 100%;
    max-width: 22rem;
    white-space: normal;
    overflow-wrap: anywhere;
  }

  body.marketing-page .marketing-hero-copy h1 {
    font-size: 1.62rem;
    line-height: 1.12;
  }

  body.marketing-page header nav {
    display: none;
  }

  body.marketing-page .menu-toggle {
    display: inline-flex !important;
    position: fixed;
    top: 0.55rem;
    right: auto;
    left: min(21rem, calc(100vw - 3.5rem));
    z-index: 1001;
    width: 2.35rem;
    height: 2.35rem;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--border);
    border-radius: 0.6rem;
    background: rgba(21, 21, 22, 0.92);
    color: var(--text);
    opacity: 1 !important;
    visibility: visible !important;
  }

  body.marketing-page .menu-toggle::before {
    content: "\2630";
    display: block;
    font-size: 1.25rem;
    line-height: 1;
  }

  body.marketing-page .menu-toggle span {
    display: none;
  }

  body.marketing-page .mobile-nav-public {
    display: block;
  }

  body.marketing-page .logo {
    max-width: 9rem;
  }

  body.marketing-page .logo-img {
    max-width: 100%;
    object-fit: contain;
  }
}

/* GPrint 2026 - primeira dobra publica alinhada ao painel operacional. */
.marketing-home .marketing-hero-grid-visual {
  grid-template-columns: minmax(0, 1.02fr) minmax(320px, 0.98fr);
  gap: 2rem;
}

.marketing-home .marketing-hero-copy {
  order: 1;
  padding-left: 0;
}

.marketing-home .marketing-hero-visual {
  order: 2;
  margin-top: 0;
}

@media (max-width: 980px) {
  .marketing-home .marketing-hero-grid-visual {
    grid-template-columns: minmax(0, 1fr);
  }

  .marketing-home .marketing-hero-copy {
    order: 1;
  }

  .marketing-home .marketing-hero-visual {
    order: 2;
  }
}

/* GPrint 2026 - acesso rapido inteligente. */
body.marketing-page .login-dropdown {
  inset: 0;
  top: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: calc(var(--header-height, 4.5rem) + 1rem) clamp(1rem, 4vw, 3.2rem) 1.2rem;
  background:
    linear-gradient(90deg, rgba(0, 0, 0, 0.28), rgba(0, 0, 0, 0.72)),
    rgba(0, 0, 0, 0.18);
  backdrop-filter: none;
  transform: none;
}

body.marketing-page .logo[data-logo-fallback] {
  display: inline-flex;
  min-width: 4.6rem;
  min-height: 2.35rem;
  align-items: center;
  justify-content: center;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.96)) padding-box,
    linear-gradient(135deg, #2563eb, #f97316) border-box;
}

body.marketing-page .logo[data-logo-fallback]::after {
  content: attr(data-logo-fallback);
  color: #2563eb;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1;
}

body.marketing-page .login-dropdown.open {
  transform: none;
}

body.marketing-page .login-dropdown-box {
  width: min(100%, 27.5rem);
  padding: 1rem;
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.13);
  background:
    linear-gradient(180deg, rgba(24, 24, 25, 0.98), rgba(10, 10, 11, 0.98)),
    #111;
  color: #f5f7fb;
  box-shadow:
    0 28px 70px rgba(0, 0, 0, 0.48),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
  overflow: hidden;
  transform: translateY(10px);
  transition:
    transform 0.18s ease,
    border-color 0.18s ease,
    box-shadow 0.18s ease;
}

body.marketing-page .login-dropdown.open .login-dropdown-box {
  transform: translateY(0);
}

body.marketing-page .login-dropdown-box::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: linear-gradient(90deg, #f97316, #3b82f6 46%, #10b981);
}

body.marketing-page .login-dropdown-title {
  margin: 0 2rem 0.85rem 0;
  color: #fff;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0;
}

body.marketing-page .login-dropdown-title::before {
  content: "Acesso rapido";
  display: block;
  margin-bottom: 0.22rem;
  color: #f97316;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

body.marketing-page .login-dropdown-title::after {
  content: "Escolha perfil e tempo de sessao. Administrativo abre 2FA automaticamente.";
  display: block;
  margin-top: 0.34rem;
  color: #a7b0c0;
  font-size: 0.78rem;
  font-weight: 500;
  line-height: 1.35;
}

body.marketing-page .login-dropdown-close {
  top: 0.72rem;
  right: 0.72rem;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.05);
  color: #b8c0cc;
}

body.marketing-page .login-dropdown-close:hover {
  background: rgba(249, 115, 22, 0.14);
  color: #fff;
}

body.marketing-page .login-dropdown-fields {
  gap: 0.68rem;
}

body.marketing-page .login-dropdown-fields input,
body.marketing-page .login-dropdown-fields select {
  min-height: 2.55rem;
  padding: 0.72rem 0.78rem;
  border-radius: 8px;
  border-color: rgba(255, 255, 255, 0.13);
  background: rgba(255, 255, 255, 0.055);
  color: #fff;
  font-size: 0.86rem;
}

body.marketing-page .login-dropdown-fields select {
  color-scheme: dark;
}

body.marketing-page .login-dropdown-fields input::placeholder {
  color: #8f98a7;
}

body.marketing-page .login-dropdown-fields input:focus,
body.marketing-page .login-dropdown-fields select:focus {
  border-color: rgba(249, 115, 22, 0.75);
  box-shadow:
    0 0 0 3px rgba(249, 115, 22, 0.16),
    0 12px 26px rgba(0, 0, 0, 0.24);
}

body.marketing-page .login-dropdown-row {
  grid-template-columns: 1fr 1fr;
}

body.marketing-page .login-dropdown-status {
  min-height: 1.4rem;
  margin-top: 0.52rem;
  color: #a7b0c0;
  text-align: left;
}

body.marketing-page .login-dropdown-status.error {
  color: #ff8a4c;
}

body.marketing-page .login-dropdown-status.loading {
  color: #60a5fa;
}

body.marketing-page .login-dropdown-links {
  margin-top: 0.58rem;
  padding-top: 0.7rem;
  border-top-color: rgba(255, 255, 255, 0.1);
}

body.marketing-page .login-dropdown-links a {
  color: #93c5fd;
  font-size: 0.75rem;
}

body.marketing-page .login-dropdown-links a:hover {
  color: #fed7aa;
}

body.marketing-page.marketing-auth-command {
  background:
    radial-gradient(circle at 16% 12%, rgba(249, 115, 22, 0.18), transparent 28rem),
    radial-gradient(circle at 88% 6%, rgba(37, 99, 235, 0.18), transparent 30rem),
    #050506;
}

body.marketing-page .auth-command-section {
  padding: clamp(5.2rem, 7vw, 7.5rem) 0 3rem;
}

body.marketing-page .auth-command-shell {
  max-width: 61rem;
  padding: 1rem;
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.11);
  background:
    linear-gradient(180deg, rgba(24, 24, 25, 0.96), rgba(9, 9, 10, 0.98)),
    #101011;
  box-shadow: 0 26px 72px rgba(0, 0, 0, 0.42);
}

body.marketing-page .auth-command-shell .section-title {
  margin-bottom: 1rem;
  text-align: left;
}

body.marketing-page .auth-command-shell .section-title h2 {
  color: #fff;
  font-size: clamp(1.55rem, 3vw, 2.1rem);
  line-height: 1.05;
}

body.marketing-page .auth-command-shell .section-title p {
  color: #a7b0c0;
}

.auth-command-grid {
  display: grid;
  grid-template-columns: minmax(17rem, 0.82fr) minmax(0, 1.18fr);
  gap: 1rem;
}

.auth-command-panel,
.auth-command-form {
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.045);
}

.auth-command-panel {
  display: flex;
  min-height: 100%;
  flex-direction: column;
  gap: 0.9rem;
  padding: 1rem;
}

.auth-command-panel__badge {
  align-self: flex-start;
  padding: 0.34rem 0.54rem;
  border-radius: 8px;
  background: rgba(249, 115, 22, 0.14);
  color: #fdba74;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.auth-command-panel h3 {
  color: #fff;
  font-size: 1.2rem;
  line-height: 1.15;
}

.auth-command-panel p {
  color: #a7b0c0;
  line-height: 1.5;
}

.auth-command-steps,
.auth-command-signal-grid {
  display: grid;
  gap: 0.45rem;
}

.auth-command-steps span,
.auth-command-signal-grid span {
  display: flex;
  align-items: center;
  min-height: 2.35rem;
  border-radius: 8px;
  color: #d8dde7;
}

.auth-command-steps span {
  gap: 0.55rem;
  padding: 0.42rem 0.56rem;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(0, 0, 0, 0.18);
  font-weight: 700;
}

.auth-command-steps strong {
  display: inline-flex;
  width: 1.3rem;
  height: 1.3rem;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #f97316;
  color: #111;
  font-size: 0.72rem;
}

.auth-command-signal-grid {
  grid-template-columns: 1fr 1fr;
  margin-top: auto;
}

.auth-command-signal-grid span {
  justify-content: center;
  padding: 0.4rem 0.5rem;
  background: rgba(37, 99, 235, 0.13);
  color: #bfdbfe;
  font-size: 0.72rem;
  font-weight: 700;
}

body.marketing-page .auth-command-form {
  padding: 1rem;
}

body.marketing-page .auth-command-form .form-row {
  gap: 0.78rem;
}

body.marketing-page .auth-command-form label {
  color: #cbd5e1;
  font-size: 0.76rem;
  font-weight: 700;
}

body.marketing-page .auth-command-form input,
body.marketing-page .auth-command-form select {
  min-height: 2.7rem;
  border-radius: 8px;
  border-color: rgba(255, 255, 255, 0.13);
  background: rgba(0, 0, 0, 0.28);
  color: #fff;
}

body.marketing-page .auth-command-form select {
  color-scheme: dark;
}

body.marketing-page .auth-command-form input:focus,
body.marketing-page .auth-command-form select:focus {
  border-color: rgba(249, 115, 22, 0.72);
  box-shadow: 0 0 0 3px rgba(249, 115, 22, 0.16);
}

body.marketing-page .auth-command-form .btn {
  min-height: 2.7rem;
  border-radius: 8px;
}

body.marketing-page .auth-command-form a {
  color: #93c5fd;
}

@media (max-width: 860px) {
  body.marketing-page .login-dropdown {
    justify-content: center;
    padding: 1rem;
  }

  body.marketing-page .login-dropdown-box {
    width: min(100%, 24rem);
  }

  .auth-command-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 560px) {
  body.marketing-page .login-dropdown-row,
  .auth-command-signal-grid,
  body.marketing-page .auth-command-form .form-row {
    grid-template-columns: minmax(0, 1fr);
  }
}

/* GPrint public polish 2026-05-19: home, shared public pages and compact login. */
body.marketing-page {
  --primary: #4aa3ff;
  --primary-dark: #7dbdff;
  --primary-hover: #a6d3ff;
  --primary-rgb: 74, 163, 255;
  --accent: #d7dde5;
  --success: #53d990;
  --success-rgb: 83, 217, 144;
  --warning: #f2c66d;
  --warning-rgb: 242, 198, 109;
  --error: #ff7a72;
  --error-rgb: 255, 122, 114;
  --bg: #121922;
  --bg-secondary: #172230;
  --bg-card: #1a2634;
  --text: #edf4fb;
  --text-muted: #bfccd8;
  --text-light: #8fa0b2;
  --border: rgba(154, 173, 194, 0.25);
  --border-light: rgba(154, 173, 194, 0.16);
  --shadow-sm: 0 1px 0 rgba(255, 255, 255, 0.04);
  --shadow: 0 18px 42px rgba(0, 0, 0, 0.26);
  --shadow-lg: 0 30px 70px rgba(0, 0, 0, 0.34);
  background:
    radial-gradient(circle at 22% -18%, rgba(166, 179, 193, 0.16), transparent 34rem),
    radial-gradient(circle at 88% 4%, rgba(74, 99, 128, 0.16), transparent 32rem),
    linear-gradient(180deg, #151e28 0%, #111923 44%, #141d27 100%);
  color: var(--text);
  text-rendering: auto;
  -webkit-font-smoothing: auto;
  -moz-osx-font-smoothing: auto;
}

body.marketing-page * {
  text-shadow: none;
}

body.marketing-page header {
  border-color: rgba(164, 180, 198, 0.2);
  background: rgba(18, 25, 34, 0.97);
  backdrop-filter: none;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.22);
}

body.marketing-page .navbar {
  min-height: 54px;
  padding: 0.32rem 0;
}

body.marketing-page header nav {
  gap: 0.42rem;
}

body.marketing-page header nav a,
body.marketing-page .login-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  min-height: 32px;
  padding: 0.38rem 0.62rem;
  border: 1px solid rgba(154, 173, 194, 0.16);
  border-radius: 9px;
  background: rgba(255, 255, 255, 0.035);
  color: var(--text-muted);
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1;
}

body.marketing-page header nav a::before,
body.marketing-page .login-toggle::before {
  content: "";
  width: 0.58rem;
  height: 0.58rem;
  flex: 0 0 auto;
  border: 1px solid rgba(166, 211, 255, 0.62);
  background: linear-gradient(135deg, rgba(166, 211, 255, 0.28), rgba(237, 244, 251, 0.06));
}

body.marketing-page header nav a[href="/recursos"]::before {
  border-radius: 2px;
  box-shadow: inset 0 0 0 2px rgba(166, 211, 255, 0.12);
}

body.marketing-page header nav a[href="/precos"]::before {
  width: 0.6rem;
  border-radius: 50%;
}

body.marketing-page header nav a[href="/contato"]::before {
  height: 0.46rem;
  border-radius: 2px;
}

body.marketing-page header nav a[href="/ajuda"]::before {
  border-radius: 50% 50% 50% 2px;
}

body.marketing-page .login-toggle {
  border-color: rgba(var(--primary-rgb), 0.36);
  background: linear-gradient(180deg, rgba(var(--primary-rgb), 0.28), rgba(var(--primary-rgb), 0.16));
  color: #f7fbff;
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.22);
}

body.marketing-page .login-toggle::before {
  border-radius: 50%;
  background:
    radial-gradient(circle at center, #f7fbff 0 24%, transparent 26%),
    linear-gradient(135deg, rgba(166, 211, 255, 0.7), rgba(74, 163, 255, 0.2));
}

body.marketing-page header nav a:hover,
body.marketing-page .login-toggle:hover {
  color: #ffffff;
  background: rgba(var(--primary-rgb), 0.16);
  border-color: rgba(var(--primary-rgb), 0.38);
  transform: translateY(-1px);
}

body.marketing-page .marketing-hero {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0)),
    transparent;
}

body.marketing-page.marketing-home .marketing-hero {
  padding: 0.72rem 0 1.55rem;
}

body.marketing-page .marketing-hero-banner {
  width: min(86vw, 1040px);
  margin: 0 auto 1.05rem;
}

body.marketing-page .marketing-banner-card {
  padding: clamp(0.46rem, 1.4vw, 1.05rem);
  border: 1px solid rgba(210, 218, 228, 0.22);
  border-radius: 1.15rem;
  background:
    radial-gradient(ellipse at center, rgba(248, 250, 252, 0.28) 0%, rgba(190, 198, 208, 0.22) 42%, rgba(74, 84, 96, 0.28) 69%, rgba(18, 25, 34, 0.96) 100%),
    linear-gradient(180deg, rgba(222, 229, 237, 0.12), rgba(18, 25, 34, 0.9));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 24px 56px rgba(0, 0, 0, 0.24);
}

body.marketing-page .marketing-banner-image {
  border: 0;
  border-radius: 0.82rem;
  box-shadow: 0 16px 38px rgba(0, 0, 0, 0.18);
}

body.marketing-page.marketing-home .marketing-hero-grid-visual {
  grid-template-columns: minmax(0, 920px);
  justify-content: center;
  max-width: 960px;
  margin: 0 auto;
}

body.marketing-page.marketing-home .marketing-hero-copy {
  order: 1;
  align-items: center;
  padding-left: 0;
  text-align: center;
}

body.marketing-page.marketing-home .marketing-hero-copy h1 {
  max-width: 760px;
}

body.marketing-page .marketing-hero-copy h1,
body.marketing-page .marketing-section-head h1,
body.marketing-page .marketing-section-head h2,
body.marketing-page .public-page-copy h1,
body.marketing-page .section-title h2,
body.marketing-page .footer-section h4 {
  color: var(--text);
  letter-spacing: 0;
}

body.marketing-page .marketing-hero-copy h1 {
  font-size: clamp(1.55rem, 2.9vw, 2.05rem);
  line-height: 1.08;
}

body.marketing-page .public-page-copy h1 {
  font-size: clamp(1.38rem, 2.6vw, 1.85rem);
}

body.marketing-page .marketing-section-head h1,
body.marketing-page .marketing-section-head h2 {
  font-size: clamp(1.25rem, 2.5vw, 1.65rem);
}

body.marketing-page .development-banner {
  width: min(100%, 720px);
  margin: 0 auto 1rem;
  padding: 0.78rem 1.1rem;
  border-radius: 12px;
  background:
    linear-gradient(135deg, rgba(74, 163, 255, 0.2), rgba(140, 154, 170, 0.14)),
    rgba(18, 25, 34, 0.88);
  box-shadow: 0 0 0 1px rgba(166, 211, 255, 0.18), 0 18px 40px rgba(0, 0, 0, 0.24);
  animation: none;
}

body.marketing-page .development-banner strong {
  font-size: clamp(0.9rem, 1.7vw, 1.2rem);
  letter-spacing: 0.06em;
}

body.marketing-page .development-banner span {
  font-size: 0.76rem;
}

body.marketing-page .marketing-proof-card,
body.marketing-page .marketing-mini-card,
body.marketing-page .marketing-image-card,
body.marketing-page .marketing-feature-card,
body.marketing-page .marketing-structure-card,
body.marketing-page .marketing-plan-card,
body.marketing-page .marketing-contact-card,
body.marketing-page .marketing-faq-card,
body.marketing-page .marketing-legal-card,
body.marketing-page .pricing-card,
body.marketing-page .pricing-model-card,
body.marketing-page .pricing-faq-card,
body.marketing-page .public-card,
body.marketing-page .public-aside-panel,
body.marketing-page .public-note-item,
body.marketing-page .faq-card,
body.marketing-page .form-shell,
body.marketing-page .signup-card,
body.marketing-page .signup-auth-warning,
body.marketing-page .public-status-card,
body.marketing-page .legal-hub-card,
body.marketing-page .legal-retention-card,
body.marketing-page .contract-clause-card,
body.marketing-page .marketing-legal-page .legal-container {
  border-color: rgba(154, 173, 194, 0.23);
  background:
    linear-gradient(180deg, rgba(30, 43, 58, 0.94), rgba(23, 34, 48, 0.96)),
    var(--bg-card);
  color: var(--text);
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.22);
}

body.marketing-page .marketing-mini-card,
body.marketing-page .marketing-proof-card,
body.marketing-page .public-card,
body.marketing-page .faq-card,
body.marketing-page .public-status-card,
body.marketing-page .legal-hub-card,
body.marketing-page .legal-retention-card {
  border-radius: 0.85rem;
}

body.marketing-page .marketing-chip,
body.marketing-page .marketing-feature-pill,
body.marketing-page .legal-pill,
body.marketing-page .pricing-badge {
  border-color: rgba(154, 173, 194, 0.2);
  background: rgba(255, 255, 255, 0.06);
  color: var(--text);
}

body.marketing-page .marketing-eyebrow {
  border-color: rgba(var(--primary-rgb), 0.32);
  background: rgba(var(--primary-rgb), 0.11);
  color: #b9dbff;
}

body.marketing-page .marketing-feature-number,
body.marketing-page .marketing-step-number,
body.marketing-page .pricing-model-number {
  background: rgba(var(--primary-rgb), 0.2);
  color: #d9ecff;
}

body.marketing-page .marketing-mini-card span,
body.marketing-page .marketing-board-tag,
body.marketing-page .pricing-reference strong,
body.marketing-page .public-inline-note a,
body.marketing-page .marketing-legal-page .legal-content a {
  color: var(--primary-dark);
}

body.marketing-page .marketing-proof-card p,
body.marketing-page .marketing-mini-card p,
body.marketing-page .marketing-feature-card p,
body.marketing-page .public-card p,
body.marketing-page .public-page-copy p,
body.marketing-page .marketing-section-head p,
body.marketing-page .faq-card p,
body.marketing-page .legal-hub-card p,
body.marketing-page .legal-retention-card p,
body.marketing-page .footer-section p,
body.marketing-page .footer-section a,
body.marketing-page .public-note-item span,
body.marketing-page .contract-clause-card__lead,
body.marketing-page .contract-clause-card__disclaimer {
  color: var(--text-muted);
}

body.marketing-page .public-page-hero {
  padding: 2.05rem 0 1.45rem;
}

body.marketing-page .public-page-grid {
  gap: 1rem;
}

body.marketing-page.marketing-contact .public-page-grid-contact {
  grid-template-columns: minmax(0, 0.82fr) minmax(360px, 0.9fr);
  align-items: start;
}

body.marketing-page .contact-info-card {
  padding: 0.78rem;
  border: 1px solid rgba(154, 173, 194, 0.2);
  border-radius: 0.8rem;
  background: rgba(255, 255, 255, 0.045);
}

body.marketing-page .contact-info-card h4 {
  color: #f5f9fd;
}

body.marketing-page input,
body.marketing-page select,
body.marketing-page textarea,
body.marketing-page .contract-clause-card__text {
  border-color: rgba(154, 173, 194, 0.26);
  background: rgba(10, 16, 23, 0.7);
  color: var(--text);
}

body.marketing-page input:focus,
body.marketing-page select:focus,
body.marketing-page textarea:focus,
body.marketing-page .contract-clause-card__text:focus {
  border-color: rgba(var(--primary-rgb), 0.64);
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.14);
}

body.marketing-page .btn-primary-solid {
  background: linear-gradient(180deg, rgba(var(--primary-rgb), 0.96), rgba(43, 120, 220, 0.96));
  color: #f7fbff;
  box-shadow: 0 15px 30px rgba(0, 0, 0, 0.24);
}

body.marketing-page .btn-primary-solid:hover {
  background: linear-gradient(180deg, #7dbdff, #3c91ee);
}

body.marketing-page .btn-secondary-soft {
  border-color: rgba(154, 173, 194, 0.24);
  background: rgba(255, 255, 255, 0.06);
  color: #e5f1ff;
}

body.marketing-page footer {
  background: rgba(17, 24, 34, 0.98);
  border-color: rgba(154, 173, 194, 0.18);
}

body.marketing-page .status-banner.operational {
  border: 1px solid rgba(83, 217, 144, 0.36);
  background: rgba(83, 217, 144, 0.1);
  color: #bff5d7;
}

body.marketing-page .login-dropdown {
  inset: auto clamp(0.75rem, 2vw, 1.35rem) auto auto;
  top: calc(var(--header-height, 64px) + 0.35rem);
  z-index: 9998;
  display: block;
  width: auto;
  max-width: calc(100vw - 1.5rem);
  padding: 0;
  background: transparent;
  backdrop-filter: none;
  opacity: 0;
  transform: translateY(-6px);
  transition:
    opacity 0.16s ease,
    transform 0.16s ease;
  pointer-events: none;
}

body.marketing-page .login-dropdown.open {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

body.marketing-page .login-dropdown-box {
  width: min(255px, calc(100vw - 1.5rem));
  padding: 0.62rem;
  border-radius: 10px;
  border: 1px solid rgba(154, 173, 194, 0.28);
  background:
    linear-gradient(180deg, rgba(30, 43, 58, 0.98), rgba(17, 24, 34, 0.98)),
    #172230;
  color: var(--text);
  box-shadow:
    0 20px 44px rgba(0, 0, 0, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.07);
  overflow: hidden;
  transform: none;
}

body.marketing-page .login-dropdown.open .login-dropdown-box {
  transform: none;
}

body.marketing-page .login-dropdown-box::before {
  height: 2px;
  background: linear-gradient(90deg, rgba(210, 218, 228, 0.6), rgba(var(--primary-rgb), 0.65), rgba(210, 218, 228, 0.35));
}

body.marketing-page .login-dropdown-title {
  margin: 0 1.6rem 0.45rem 0;
  color: #f7fbff;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0;
}

body.marketing-page .login-dropdown-title::before {
  content: "Acesso rapido";
  margin-bottom: 0.12rem;
  color: #b9dbff;
  font-size: 0.55rem;
  letter-spacing: 0.09em;
}

body.marketing-page .login-dropdown-title::after {
  content: none;
}

body.marketing-page .login-dropdown-close {
  top: 0.48rem;
  right: 0.48rem;
  width: 1.35rem;
  height: 1.35rem;
  border: 1px solid rgba(154, 173, 194, 0.22);
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.045);
  color: var(--text-muted);
  font-size: 0.95rem;
}

body.marketing-page .login-dropdown-fields {
  gap: 0.38rem;
}

body.marketing-page .login-dropdown-row {
  gap: 0.38rem;
}

body.marketing-page .login-dropdown-fields input,
body.marketing-page .login-dropdown-fields select {
  min-height: 1.88rem;
  padding: 0.34rem 0.48rem;
  border-radius: 7px;
  font-size: 0.72rem;
}

body.marketing-page .login-dropdown-status {
  min-height: 0.95rem;
  margin-top: 0.24rem;
  color: var(--text-muted);
  font-size: 0.68rem;
  text-align: left;
}

body.marketing-page .login-dropdown-links {
  margin-top: 0.34rem;
  padding-top: 0.42rem;
  gap: 0.12rem 0.46rem;
}

body.marketing-page .login-dropdown-links a {
  color: #b9dbff;
  font-size: 0.66rem;
  line-height: 1.25;
}

@media (max-width: 860px) {
  body.marketing-page .login-dropdown {
    inset: auto 0.8rem auto auto;
    top: calc(var(--header-height, 64px) + 0.35rem);
    justify-content: initial;
    padding: 0;
    background: transparent;
  }

  body.marketing-page .login-dropdown-box {
    width: min(255px, calc(100vw - 1.6rem));
  }
}

@media (max-width: 760px) {
  body.marketing-page header nav a::before,
  body.marketing-page .login-toggle::before {
    display: none;
  }

  body.marketing-page .marketing-hero-banner {
    width: min(92vw, 560px);
    margin-bottom: 0.85rem;
  }

  body.marketing-page .marketing-banner-card {
    padding: 0.42rem;
    border-radius: 0.9rem;
  }

  body.marketing-page.marketing-home .marketing-hero-copy {
    text-align: left;
    align-items: stretch;
  }

  body.marketing-page.marketing-home .development-banner {
    align-items: flex-start;
    text-align: left;
  }

  body.marketing-page.marketing-contact .public-page-grid-contact,
  body.marketing-page .public-page-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  body.marketing-page .contact-info-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

/* GPrint home premium pass 2026-05-19: compacta, lateral e dark-first. */
body.marketing-page.marketing-home {
  background:
    radial-gradient(circle at 18% 18%, rgba(47, 129, 247, 0.15), transparent 28rem),
    radial-gradient(circle at 86% 8%, rgba(242, 101, 34, 0.08), transparent 24rem),
    linear-gradient(180deg, #111a25 0%, #0e1721 42%, #0b1118 100%);
}

body.marketing-page.marketing-home .marketing-hero {
  padding: 0.95rem 0 1rem;
}

body.marketing-page.marketing-home header .container {
  max-width: 1840px;
}

body.marketing-page.marketing-home .marketing-proof .container,
body.marketing-page.marketing-home .marketing-section .container {
  max-width: 1540px;
}

body.marketing-page.marketing-home .marketing-hero .container {
  max-width: 1540px;
}

body.marketing-page.marketing-home .marketing-hero-grid-visual {
  grid-template-columns: minmax(640px, 1.08fr) minmax(360px, 0.62fr);
  max-width: 1580px;
  gap: clamp(0.95rem, 1.9vw, 1.45rem);
  align-items: center;
  margin: 0 auto;
}

body.marketing-page.marketing-home .marketing-hero-banner {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  order: 1;
  width: 100%;
  margin: 0;
}

body.marketing-page.marketing-home .marketing-banner-card {
  display: flex;
  flex: 0 1 auto;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1533 / 613;
  min-height: 0;
  padding: 0.62rem;
  border-radius: 16px;
  border-color: rgba(154, 173, 194, 0.26);
  background:
    radial-gradient(ellipse at 50% 50%, rgba(248, 250, 252, 0.36) 0%, rgba(198, 207, 218, 0.2) 38%, rgba(54, 66, 82, 0.28) 66%, rgba(9, 14, 20, 0.98) 100%),
    linear-gradient(180deg, rgba(40, 55, 72, 0.76), rgba(11, 17, 24, 0.94));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 22px 50px rgba(0, 0, 0, 0.24);
  overflow: hidden;
}

body.marketing-page.marketing-home .marketing-banner-image {
  display: block;
  width: 100%;
  height: 100%;
  max-height: none;
  min-height: 0;
  object-fit: contain;
  object-position: center;
  background: rgba(238, 243, 249, 0.96);
  border-radius: 11px;
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.2);
}

body.marketing-page.marketing-home .marketing-hero-copy {
  order: 2;
  align-items: flex-start;
  justify-content: center;
  gap: 0.62rem;
  max-width: 620px;
  padding: 0.92rem 0.05rem;
  text-align: left;
}

body.marketing-page.marketing-home .development-banner {
  width: auto;
  max-width: 100%;
  margin: 0;
  padding: 0.5rem 0.64rem;
  align-items: flex-start;
  border-radius: 10px;
  background: rgba(31, 45, 60, 0.82);
  box-shadow:
    inset 3px 0 0 rgba(47, 129, 247, 0.72),
    0 0 0 1px rgba(154, 173, 194, 0.18);
}

body.marketing-page.marketing-home .development-banner strong {
  font-size: 0.78rem;
  letter-spacing: 0.04em;
}

body.marketing-page.marketing-home .development-banner span {
  font-size: 0.66rem;
  line-height: 1.42;
}

body.marketing-page.marketing-home .marketing-eyebrow {
  padding: 0.28rem 0.56rem;
  font-size: 0.61rem;
}

body.marketing-page.marketing-home .marketing-hero-copy h1 {
  max-width: 470px;
  font-size: clamp(1.38rem, 2vw, 1.72rem);
  line-height: 1.13;
}

body.marketing-page.marketing-home .marketing-hero-copy p {
  max-width: 510px;
  font-size: 0.78rem;
  line-height: 1.58;
}

body.marketing-page.marketing-home .marketing-chip-list {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  width: min(100%, 510px);
  gap: 0.38rem;
}

body.marketing-page.marketing-home .marketing-chip {
  position: relative;
  width: 100%;
  padding: 0.43rem 0.58rem 0.43rem 1.62rem;
  border-radius: 9px;
  border-color: rgba(154, 173, 194, 0.2);
  background: rgba(255, 255, 255, 0.055);
  color: #e4edf7;
  font-size: 0.69rem;
  line-height: 1.28;
  box-shadow: none;
}

body.marketing-page.marketing-home .marketing-chip::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0.62rem;
  width: 0.42rem;
  height: 0.42rem;
  border-radius: 999px;
  background: #58a6ff;
  box-shadow: 0 0 0 3px rgba(88, 166, 255, 0.12);
  transform: translateY(-50%);
}

body.marketing-page.marketing-home .marketing-hero-actions {
  gap: 0.48rem;
  margin-top: 0.1rem;
}

body.marketing-page.marketing-home .marketing-hero-actions .btn {
  min-height: 2.28rem;
  padding: 0.56rem 0.82rem;
  border-radius: 10px;
  font-size: 0.71rem;
}

body.marketing-page.marketing-home .marketing-hero-mini-grid-full {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  max-width: 1540px;
  margin: 0.78rem auto 0;
  gap: 0.62rem;
}

body.marketing-page.marketing-home .marketing-mini-card,
body.marketing-page.marketing-home .marketing-proof-card,
body.marketing-page.marketing-home .marketing-feature-card,
body.marketing-page.marketing-home .marketing-structure-card,
body.marketing-page.marketing-home .marketing-step-card {
  border-color: rgba(154, 173, 194, 0.22);
  background:
    linear-gradient(180deg, rgba(25, 38, 52, 0.96), rgba(15, 24, 34, 0.97)),
    #101820;
  color: #f2f7fd;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.055),
    0 16px 34px rgba(0, 0, 0, 0.22);
}

body.marketing-page.marketing-home .marketing-mini-card {
  min-height: 112px;
  padding: 0.78rem 0.82rem;
  border-radius: 12px;
}

body.marketing-page.marketing-home .marketing-mini-card span,
body.marketing-page.marketing-home .marketing-feature-pill,
body.marketing-page.marketing-home .marketing-feature-number {
  color: #83c2ff;
}

body.marketing-page.marketing-home .marketing-mini-card strong,
body.marketing-page.marketing-home .marketing-proof-card h2,
body.marketing-page.marketing-home .marketing-feature-card h3,
body.marketing-page.marketing-home .marketing-structure-card h3,
body.marketing-page.marketing-home .marketing-step-card h3 {
  color: #f4f8fd;
}

body.marketing-page.marketing-home .marketing-mini-card p,
body.marketing-page.marketing-home .marketing-proof-card p,
body.marketing-page.marketing-home .marketing-feature-card p,
body.marketing-page.marketing-home .marketing-structure-card p,
body.marketing-page.marketing-home .marketing-step-card p {
  color: #b4c1d0;
}

body.marketing-page.marketing-home .marketing-proof {
  padding: 1rem 0 1.1rem;
}

body.marketing-page.marketing-home .marketing-proof-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.7rem;
}

body.marketing-page.marketing-home .marketing-proof-card,
body.marketing-page.marketing-home .marketing-feature-card,
body.marketing-page.marketing-home .marketing-structure-card {
  padding: 0.9rem;
  border-radius: 12px;
}

body.marketing-page.marketing-home .marketing-section {
  padding: 1.65rem 0;
}

body.marketing-page.marketing-home .marketing-section-alt {
  background:
    linear-gradient(180deg, rgba(23, 36, 50, 0.92), rgba(13, 21, 30, 0.92));
}

body.marketing-page.marketing-home .marketing-section-head {
  max-width: 680px;
  margin-bottom: 1rem;
}

body.marketing-page.marketing-home .marketing-section-head h2 {
  font-size: clamp(1.16rem, 2vw, 1.42rem);
}

body.marketing-page.marketing-home .marketing-section-head p {
  font-size: 0.78rem;
  line-height: 1.55;
}

body.marketing-page.marketing-home .marketing-feature-grid,
body.marketing-page.marketing-home .marketing-structure-grid {
  gap: 0.75rem;
}

body.marketing-page.marketing-home .marketing-steps-grid {
  position: relative;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
}

body.marketing-page.marketing-home .marketing-step-card {
  min-height: 178px;
  padding: 0.95rem;
}

body.marketing-page.marketing-home .marketing-step-number {
  min-width: 2rem;
  height: 2rem;
  margin-bottom: 0.58rem;
  background: rgba(88, 166, 255, 0.16);
  color: #d9ecff;
  box-shadow: inset 0 0 0 1px rgba(128, 190, 255, 0.2);
}

body.marketing-page .login-dropdown {
  top: calc(var(--header-height, 64px) + 0.3rem);
}

body.marketing-page .login-dropdown-box {
  width: min(218px, calc(100vw - 1.5rem));
  padding: 0.54rem;
}

body.marketing-page .login-dropdown-fields input,
body.marketing-page .login-dropdown-fields select {
  min-height: 1.7rem;
  padding: 0.27rem 0.42rem;
  font-size: 0.69rem;
}

body.marketing-page .login-dropdown-title {
  margin-bottom: 0.34rem;
  font-size: 0.72rem;
}

body.marketing-page .login-dropdown-title::before {
  font-size: 0.52rem;
}

body.marketing-page .login-dropdown-status {
  min-height: 0.72rem;
  margin-top: 0.18rem;
  font-size: 0.62rem;
}

body.marketing-page .login-dropdown-links {
  margin-top: 0.22rem;
  padding-top: 0.32rem;
  gap: 0.1rem 0.34rem;
}

body.marketing-page .login-dropdown-links a {
  font-size: 0.61rem;
}

body.marketing-page .toast-container {
  top: calc(var(--header-height, 64px) + 0.58rem);
  right: clamp(0.75rem, 2vw, 1.2rem);
  gap: 0.48rem;
}

body.marketing-page .toast {
  min-width: min(340px, calc(100vw - 1.5rem));
  max-width: min(440px, calc(100vw - 1.5rem));
  padding: 0.72rem 0.82rem;
  gap: 0.68rem;
  border-radius: 12px;
  border: 1px solid rgba(154, 173, 194, 0.24);
  border-left: 4px solid #58a6ff;
  background:
    linear-gradient(180deg, rgba(31, 45, 60, 0.98), rgba(14, 22, 31, 0.98)),
    #121b26;
  color: #f5f7fb;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 18px 42px rgba(0, 0, 0, 0.34);
}

body.marketing-page .toast-icon {
  display: inline-flex;
  width: 1.55rem;
  height: 1.55rem;
  align-items: center;
  justify-content: center;
  border-radius: 0.42rem;
  background: rgba(88, 166, 255, 0.14);
  font-size: 0.78rem;
  line-height: 1;
  box-shadow: inset 0 0 0 1px rgba(128, 190, 255, 0.2);
}

body.marketing-page .toast-title {
  margin-bottom: 0.16rem;
  color: #f5f7fb;
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}

body.marketing-page .toast-message {
  color: #b9c7d6;
  font-size: 0.68rem;
  line-height: 1.38;
}

body.marketing-page .toast.success {
  border-left-color: #22c55e;
}

body.marketing-page .toast.success .toast-icon {
  background: rgba(34, 197, 94, 0.16);
  box-shadow: inset 0 0 0 1px rgba(84, 242, 157, 0.28);
}

body.marketing-page .toast.error {
  border-left-color: #ff5f56;
}

body.marketing-page .toast.warning {
  border-left-color: #fcd34d;
}

body.marketing-page .signup-auth-links a {
  min-height: 2.05rem;
  padding: 0.44rem 0.68rem;
  border-color: rgba(154, 173, 194, 0.26);
  background:
    linear-gradient(180deg, rgba(38, 53, 70, 0.94), rgba(20, 31, 43, 0.96)),
    #142033;
  color: #dceaff;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.06),
    0 10px 24px rgba(0, 0, 0, 0.18);
}

body.marketing-page .signup-auth-links a::before {
  content: "";
  width: 0.5rem;
  height: 0.5rem;
  margin-right: 0.45rem;
  border-radius: 999px;
  background: #58a6ff;
  box-shadow: 0 0 0 3px rgba(88, 166, 255, 0.13);
}

body.marketing-page .signup-auth-links a:hover {
  border-color: rgba(88, 166, 255, 0.5);
  color: #f5f7fb;
  transform: translateY(-1px);
}

body.marketing-page .public-system-card {
  display: flex;
  min-height: 260px;
  flex-direction: column;
  gap: 0.72rem;
  justify-content: space-between;
  padding: 0.85rem;
  border: 1px solid rgba(154, 173, 194, 0.24);
  border-radius: 16px;
  background:
    radial-gradient(circle at 20% 18%, rgba(88, 166, 255, 0.18), transparent 13rem),
    radial-gradient(circle at 90% 88%, rgba(34, 197, 94, 0.1), transparent 13rem),
    linear-gradient(180deg, rgba(28, 41, 56, 0.98), rgba(13, 20, 28, 0.98));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 22px 52px rgba(0, 0, 0, 0.28);
}

body.marketing-page .public-system-top,
body.marketing-page .public-system-grid,
body.marketing-page .public-system-flow {
  position: relative;
}

body.marketing-page .public-system-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.7rem;
}

body.marketing-page .public-system-kicker,
body.marketing-page .public-system-status {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
}

body.marketing-page .public-system-kicker {
  color: #b9dbff;
}

body.marketing-page .public-system-status {
  padding: 0.35rem 0.55rem;
  background: rgba(34, 197, 94, 0.13);
  color: #bdfbd3;
  box-shadow: inset 0 0 0 1px rgba(84, 242, 157, 0.2);
}

body.marketing-page .public-system-status::before {
  content: "";
  width: 0.42rem;
  height: 0.42rem;
  margin-right: 0.35rem;
  border-radius: 999px;
  background: #22c55e;
  box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.15);
}

body.marketing-page .public-system-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) repeat(2, minmax(0, 0.8fr));
  gap: 0.56rem;
}

body.marketing-page .public-system-metric,
body.marketing-page .public-system-flow div {
  border: 1px solid rgba(154, 173, 194, 0.2);
  border-radius: 11px;
  background: rgba(255, 255, 255, 0.055);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.045);
}

body.marketing-page .public-system-metric {
  padding: 0.68rem 0.7rem;
}

body.marketing-page .public-system-metric span,
body.marketing-page .public-system-flow small {
  color: #9fb0c2;
  font-size: 0.62rem;
  line-height: 1.35;
}

body.marketing-page .public-system-metric strong {
  display: block;
  margin: 0.12rem 0;
  color: #f5f7fb;
  font-size: 1.52rem;
  line-height: 1;
}

body.marketing-page .public-system-metric small {
  display: block;
  color: #b9c7d6;
  font-size: 0.61rem;
  line-height: 1.35;
}

body.marketing-page .public-system-flow {
  display: grid;
  gap: 0.5rem;
}

body.marketing-page .public-system-flow div {
  display: grid;
  grid-template-columns: auto minmax(0, 0.42fr) minmax(0, 1fr);
  gap: 0.5rem;
  align-items: center;
  padding: 0.54rem 0.62rem;
}

body.marketing-page .public-system-flow div > span {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 999px;
  background: #58a6ff;
  box-shadow: 0 0 0 3px rgba(88, 166, 255, 0.12);
}

body.marketing-page .public-system-flow strong {
  color: #f5f7fb;
  font-size: 0.7rem;
  line-height: 1.2;
}

@media (max-width: 1080px) {
  body.marketing-page.marketing-home .marketing-hero-grid-visual {
    grid-template-columns: minmax(0, 1fr);
    max-width: 860px;
  }

  body.marketing-page.marketing-home .marketing-hero-copy {
    order: 1;
    padding-top: 0;
  }

  body.marketing-page.marketing-home .marketing-hero-banner {
    order: 2;
  }

  body.marketing-page.marketing-home .marketing-banner-image {
    max-height: none;
  }
}

@media (max-width: 860px) {
  body.marketing-page.marketing-home .marketing-proof-grid,
  body.marketing-page.marketing-home .marketing-feature-grid,
  body.marketing-page.marketing-home .marketing-structure-grid,
  body.marketing-page.marketing-home .marketing-steps-grid,
  body.marketing-page.marketing-home .marketing-hero-mini-grid-full {
    grid-template-columns: minmax(0, 1fr);
  }

  body.marketing-page .login-dropdown-box {
    width: min(218px, calc(100vw - 1.6rem));
  }

  body.marketing-page .public-system-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  body.marketing-page .public-system-flow div {
    grid-template-columns: auto minmax(0, 1fr);
  }

  body.marketing-page .public-system-flow small {
    grid-column: 2;
  }
}

@media (max-width: 760px) {
  body.marketing-page.marketing-home .marketing-hero {
    padding-top: 0.65rem;
  }

  body.marketing-page.marketing-home .marketing-hero-copy {
    align-items: stretch;
    text-align: left;
  }

  body.marketing-page.marketing-home .development-banner {
    align-items: flex-start;
    text-align: left;
  }

  body.marketing-page.marketing-home .marketing-banner-card {
    min-height: 0;
    padding: 0.44rem;
  }

  body.marketing-page.marketing-home .marketing-banner-image {
    min-height: 0;
    object-fit: contain;
  }
}

/* Ajuste 2026-05-22: contraste firme no seletor de autenticacao publica. */
body.marketing-page .login-dropdown-fields input,
body.marketing-page .login-dropdown-fields select {
  border: 1px solid rgba(154, 173, 194, 0.42);
  background: #0f1722;
  color: #f5f7fb;
  box-shadow: none;
}

body.marketing-page .login-dropdown-fields input::placeholder {
  color: #93a4b8;
}

body.marketing-page .login-dropdown-fields select option {
  background: #0f1722;
  color: #f5f7fb;
}

body.marketing-page .login-dropdown-fields input:focus,
body.marketing-page .login-dropdown-fields select:focus {
  border-color: #58a6ff;
  background: #111c2a;
  outline: none;
  box-shadow: 0 0 0 3px rgba(88, 166, 255, 0.2);
}

/* Fechamento 2026-05-22: nitidez tipografica Windows/ClearType.
   A GPrint nao deve forcar antialias em cinza nem pesos 850/950, porque isso
   deixa o texto tremido em monitores Windows. */
body.marketing-page,
body.marketing-page *,
body.marketing-page *::before,
body.marketing-page *::after {
  font-family: "Segoe UI", Tahoma, Arial, sans-serif !important;
  font-synthesis: none !important;
  -webkit-font-smoothing: auto !important;
  -moz-osx-font-smoothing: auto !important;
  text-rendering: auto !important;
  text-shadow: none !important;
  letter-spacing: 0 !important;
}

body.marketing-page h1,
body.marketing-page h2,
body.marketing-page h3,
body.marketing-page h4,
body.marketing-page strong,
body.marketing-page b,
body.marketing-page .btn,
body.marketing-page header nav a,
body.marketing-page .login-toggle,
body.marketing-page .marketing-eyebrow,
body.marketing-page .marketing-feature-number,
body.marketing-page .marketing-step-number,
body.marketing-page .pricing-model-number,
body.marketing-page .development-banner strong {
  font-weight: 700 !important;
}

body.marketing-page header,
body.marketing-page header nav a,
body.marketing-page .login-dropdown,
body.marketing-page .login-toggle,
body.marketing-page .modal,
body.marketing-page .modal-content,
body.marketing-page .toast,
body.marketing-page .card,
body.marketing-page .feature-card,
body.marketing-page .pricing-card {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  filter: none !important;
}

body.marketing-page .btn,
body.marketing-page button,
body.marketing-page .development-banner,
body.marketing-page .card,
body.marketing-page .feature-card,
body.marketing-page .pricing-card,
body.marketing-page .login-dropdown,
body.marketing-page .modal,
body.marketing-page .modal-content,
body.marketing-page .toast {
  filter: none !important;
  transform: none !important;
  translate: none !important;
  scale: none !important;
  rotate: none !important;
  animation: none !important;
  will-change: auto !important;
}

.client-signup-page {
  min-height: 100vh;
  background: #0b0d10;
  color: #f5f7fb;
}

.client-signup-shell {
  display: grid;
  grid-template-columns: minmax(280px, 0.9fr) minmax(320px, 1.1fr);
  gap: 32px;
  width: min(1180px, calc(100% - 32px));
  min-height: 100vh;
  margin: 0 auto;
  padding: 40px 0;
  align-items: center;
}

.client-signup-hero {
  display: grid;
  gap: 18px;
  align-content: center;
}

.client-signup-brand {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  gap: 12px;
  color: #f5f7fb;
  text-decoration: none;
}

.client-signup-brand img {
  width: 42px;
  height: 42px;
  object-fit: contain;
}

.client-signup-brand span {
  font-size: 1rem;
  font-weight: 700;
}

.client-signup-kicker {
  margin: 0;
  color: #58a6ff;
  font-size: 0.85rem;
  font-weight: 700;
  text-transform: uppercase;
}

.client-signup-hero h1 {
  margin: 0;
  max-width: 620px;
  color: #ffffff;
  font-size: clamp(2.1rem, 5vw, 4.6rem);
  line-height: 1.02;
}

.client-signup-copy {
  margin: 0;
  max-width: 620px;
  color: #a8b3c2;
  font-size: 1.05rem;
  line-height: 1.62;
}

.client-signup-status {
  width: fit-content;
  max-width: 100%;
  padding: 10px 12px;
  border: 1px solid #30363d;
  border-radius: 8px;
  background: #101214;
  color: #a8b3c2;
  font-size: 0.9rem;
}

.client-signup-status.is-success {
  border-color: rgba(34, 197, 94, 0.45);
  color: #86efac;
}

.client-signup-status.is-warning {
  border-color: rgba(252, 211, 77, 0.45);
  color: #fde68a;
}

.client-signup-status.is-error {
  border-color: rgba(255, 95, 86, 0.45);
  color: #ffb4ad;
}

.client-signup-panel {
  border: 1px solid #30363d;
  border-radius: 8px;
  background: #101214;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.28);
}

.client-signup-form {
  display: grid;
  gap: 18px;
  padding: 24px;
}

.client-signup-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.client-signup-form label {
  display: grid;
  gap: 7px;
  color: #a8b3c2;
  font-size: 0.88rem;
  font-weight: 700;
}

.client-signup-form input,
.client-signup-form select,
.client-signup-form textarea {
  width: 100%;
  min-height: 42px;
  border: 1px solid #30363d;
  border-radius: 8px;
  background: #0b0d10;
  color: #f5f7fb;
  padding: 10px 12px;
  font: inherit;
  font-weight: 400 !important;
}

.client-signup-form textarea {
  resize: vertical;
}

.client-signup-form input:focus,
.client-signup-form select:focus,
.client-signup-form textarea:focus {
  border-color: #58a6ff;
  outline: none;
  box-shadow: 0 0 0 3px rgba(88, 166, 255, 0.18);
}

.client-signup-wide,
.client-signup-consent {
  grid-column: 1 / -1;
}

.client-signup-consent {
  display: flex !important;
  grid-template-columns: none !important;
  align-items: flex-start;
  gap: 10px !important;
  font-weight: 400 !important;
}

.client-signup-consent input {
  width: 18px;
  min-width: 18px;
  height: 18px;
  min-height: 18px;
  margin-top: 2px;
}

.client-signup-actions {
  display: flex;
  justify-content: flex-end;
}

.client-signup-submit {
  min-height: 44px;
  border: 0;
  border-radius: 8px;
  background: #2f81f7;
  color: #ffffff;
  padding: 0 18px;
  font-weight: 700;
  cursor: pointer;
}

.client-signup-submit:disabled {
  cursor: wait;
  opacity: 0.7;
}

.client-signup-secondary {
  min-height: 44px;
  border: 1px solid #30363d;
  border-radius: 8px;
  background: #161b22;
  color: #f5f7fb;
  padding: 0 18px;
  font-weight: 700;
  cursor: pointer;
}

.client-contract-portal {
  display: grid;
  gap: 18px;
  padding: 24px;
}

.client-contract-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 14px;
  border: 1px solid #30363d;
  border-radius: 8px;
  background: #0b0d10;
}

.client-contract-toolbar strong,
.client-contract-toolbar span {
  display: block;
}

.client-contract-toolbar span {
  margin-top: 3px;
  color: #a8b3c2;
  font-size: 0.82rem;
}

.client-contract-section {
  display: grid;
  gap: 10px;
}

.client-contract-section h2 {
  margin: 0;
  color: #ffffff;
  font-size: 1rem;
}

.client-contract-equipment-list {
  display: grid;
  gap: 10px;
}

.client-contract-equipment {
  display: grid;
  gap: 5px;
  padding: 12px;
  border: 1px solid #30363d;
  border-radius: 8px;
  background: #0b0d10;
}

.client-contract-equipment small,
.client-contract-equipment span {
  color: #a8b3c2;
}

.client-contract-equipment-values {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 6px;
  margin-top: 5px;
}

.client-contract-text {
  max-height: 520px;
  overflow: auto;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  padding: 14px;
  border: 1px solid #30363d;
  border-radius: 8px;
  background: #0b0d10;
  color: #f5f7fb;
  font-family: "Segoe UI", Tahoma, Arial, sans-serif;
  font-size: 0.92rem;
  line-height: 1.55;
}

.client-contract-warning {
  padding: 14px;
  border: 1px solid rgba(252, 211, 77, 0.35);
  border-radius: 8px;
  background: rgba(252, 211, 77, 0.08);
}

.client-contract-warning p {
  margin: 0;
  color: #fde68a;
}

.client-contract-sign-form {
  display: grid;
  gap: 16px;
  padding-top: 4px;
}

.client-signature-pad {
  min-height: 180px;
  border: 1px dashed #58a6ff;
  border-radius: 8px;
  background: #ffffff;
  overflow: hidden;
}

.client-signature-pad canvas {
  display: block;
  width: 100%;
  height: 180px;
  touch-action: none;
}

.client-contract-signed {
  padding: 14px;
  border: 1px solid rgba(34, 197, 94, 0.35);
  border-radius: 8px;
  background: rgba(34, 197, 94, 0.1);
  color: #86efac;
  font-weight: 700;
}

.client-contract-empty {
  padding: 14px;
  border: 1px dashed #30363d;
  border-radius: 8px;
  color: #a8b3c2;
}

.client-signup-hp {
  position: fixed;
  left: -9999px;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

@media (max-width: 860px) {
  .client-signup-shell {
    grid-template-columns: 1fr;
    gap: 22px;
    padding: 24px 0;
  }

  .client-signup-grid {
    grid-template-columns: 1fr;
  }

  .client-signup-form {
    padding: 18px;
  }

  .client-contract-portal {
    padding: 18px;
  }

  .client-contract-toolbar,
  .client-signup-actions {
    flex-direction: column;
    align-items: stretch;
  }
}

@media print {
  .client-signup-page {
    background: #ffffff;
    color: #111827;
  }

  .client-signup-shell {
    display: block;
    width: 100%;
    min-height: auto;
    padding: 0;
  }

  .client-signup-brand,
  .client-signup-status,
  .client-contract-toolbar,
  .client-contract-sign-form,
  .client-contract-signed {
    display: none !important;
  }

  .client-signup-hero,
  .client-signup-panel {
    border: 0;
    background: #ffffff;
    box-shadow: none;
  }

  .client-contract-text {
    max-height: none;
    overflow: visible;
    color: #111827;
    background: #ffffff;
  }
}
