/* ============================================================
   Layout — Page Sections
   ============================================================ */

/* ---------- Header ---------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: color-mix(in srgb, var(--color-bg-base) 85%, transparent);
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid transparent;
  transition: border-color var(--duration-base) var(--ease-out),
              background var(--duration-base) var(--ease-out);
}
.site-header.is-scrolled {
  border-bottom-color: var(--color-border-subtle);
}

.site-header .container {
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}
@media (max-width: 767px) {
  .site-header .container { height: 60px; }
}

/* Wordmark */
.wordmark {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  flex-shrink: 0;
}

.wordmark__mono {
  width: 36px;
  height: 36px;
  background: linear-gradient(135deg, var(--indigo-500), var(--indigo-700));
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: var(--font-bold);
  font-size: 14px;
  letter-spacing: -0.02em;
  box-shadow: var(--shadow-sm), inset 0 1px 0 rgba(255,255,255,0.18);
  flex-shrink: 0;
}

.wordmark__text {
  display: flex;
  flex-direction: column;
  line-height: 1.1;
}
.wordmark__name {
  font-weight: var(--font-bold);
  font-size: 15px;
  color: var(--color-text-primary);
  letter-spacing: -0.01em;
}
.wordmark__role {
  font-weight: var(--font-medium);
  font-size: 12px;
  color: var(--color-text-secondary);
}

@media (max-width: 359px) {
  .wordmark__role { display: none; }
}

/* Nav */
.site-nav {
  display: none;
  align-items: center;
  gap: var(--space-5);
}
@media (min-width: 768px) {
  .site-nav { display: flex; }
}

.site-nav a {
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-text-secondary);
  transition: color var(--duration-fast) var(--ease-out);
  position: relative;
  padding: var(--space-2) 0;
}
.site-nav a:hover { color: var(--color-text-primary); }
.site-nav a::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--color-brand);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform var(--duration-base) var(--ease-out);
}
.site-nav a:hover::after { transform: scaleX(1); }

.header-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

/* Theme toggle button */
.theme-toggle {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-secondary);
  transition: background var(--duration-fast) var(--ease-out),
              color var(--duration-fast) var(--ease-out);
}
.theme-toggle:hover {
  background: var(--color-bg-subtle);
  color: var(--color-text-primary);
}
.theme-toggle .icon { width: 18px; height: 18px; }
.theme-toggle .icon-moon { display: none; }
[data-theme="dark"] .theme-toggle .icon-sun  { display: none; }
[data-theme="dark"] .theme-toggle .icon-moon { display: block; }
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .theme-toggle .icon-sun  { display: none; }
  :root:not([data-theme="light"]) .theme-toggle .icon-moon { display: block; }
}

.header-cta-mobile { display: none; }
@media (max-width: 767px) {
  .header-cta-mobile { display: inline-flex; }
  .header-cta-desktop { display: none; }
}

/* ---------- Hero ---------- */
.hero {
  position: relative;
  overflow: hidden;
  padding-block: var(--space-8) var(--space-9);
}
@media (min-width: 768px) {
  .hero { padding-block: var(--space-9) var(--space-10); }
}

.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(900px 500px at 85% 10%, rgba(99, 102, 241, 0.14), transparent 60%),
    radial-gradient(700px 400px at 10% 90%, rgba(14, 165, 233, 0.08), transparent 60%),
    radial-gradient(600px 600px at 50% 120%, rgba(99, 102, 241, 0.1), transparent 50%);
  pointer-events: none;
}

[data-theme="dark"] .hero__bg {
  background:
    radial-gradient(900px 500px at 85% 10%, rgba(99, 102, 241, 0.22), transparent 60%),
    radial-gradient(700px 400px at 10% 90%, rgba(14, 165, 233, 0.14), transparent 60%),
    radial-gradient(600px 600px at 50% 120%, rgba(99, 102, 241, 0.12), transparent 50%);
}

.hero .container {
  position: relative;
  z-index: 1;
}

.hero__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  align-items: center;
}
@media (min-width: 1024px) {
  .hero__layout {
    grid-template-columns: 1.05fr 0.95fr;
    gap: var(--space-8);
  }
}

.hero__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  max-width: 640px;
}

.hero__title {
  font-size: var(--text-display);
  font-weight: var(--font-bold);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--color-text-primary);
}

.hero__title em {
  font-style: normal;
  background: linear-gradient(135deg, var(--indigo-500), var(--indigo-700));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.hero__sub {
  font-size: var(--text-lg);
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
  max-width: 560px;
}

.hero__sub strong {
  color: var(--color-text-primary);
  font-weight: var(--font-semibold);
}

.hero__ctas {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-top: var(--space-2);
}
@media (min-width: 480px) {
  .hero__ctas { flex-direction: row; flex-wrap: wrap; }
}

/* Trust strip */
.trust-strip {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
  margin-top: var(--space-5);
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-border-subtle);
}
@media (min-width: 640px) {
  .trust-strip { grid-template-columns: repeat(4, 1fr); gap: var(--space-3); }
}

.trust-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.trust-item .icon {
  width: 20px;
  height: 20px;
  color: var(--color-brand);
  flex-shrink: 0;
}
.trust-item__label {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  font-weight: var(--font-medium);
  line-height: 1.3;
}

/* Hero visual */
.hero__visual {
  position: relative;
  display: none;
}
@media (min-width: 1024px) {
  .hero__visual { display: block; }
}

/* ---------- Services Grid ---------- */
.services-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 640px) {
  .services-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .services-grid { grid-template-columns: repeat(4, 1fr); gap: var(--space-5); }
}

.service-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  height: 100%;
}

.service-card__icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-md);
  background: var(--color-brand-subtle);
  color: var(--color-text-brand);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.service-card__icon .icon { width: 26px; height: 26px; }

.service-card__title {
  font-size: var(--text-xl);
  font-weight: var(--font-semibold);
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-snug);
}

.service-card__desc {
  font-size: var(--text-base);
  color: var(--color-text-secondary);
  line-height: var(--leading-normal);
  flex-grow: 1;
}

.service-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-top: var(--space-2);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border-subtle);
  flex-wrap: wrap;
}

.service-card__cta {
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--color-text-brand);
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  transition: gap var(--duration-fast) var(--ease-out);
}
.service-card__cta:hover { gap: var(--space-2); }
.service-card__cta .icon { width: 14px; height: 14px; }

/* ---------- How it Works ---------- */
.steps {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
  position: relative;
}
@media (min-width: 1024px) {
  .steps { grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
}

.step {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-4);
  align-items: start;
}
@media (min-width: 1024px) {
  .step { grid-template-columns: 1fr; }
}

.step__num {
  font-family: var(--font-mono);
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  line-height: 1;
  color: var(--color-text-brand);
  letter-spacing: -0.04em;
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
}
.step__num::after {
  content: "";
  display: block;
  width: 32px;
  height: 2px;
  background: var(--color-border-default);
  margin-left: var(--space-2);
}
@media (max-width: 1023px) {
  .step__num::after { display: none; }
}

.step__body { display: flex; flex-direction: column; gap: var(--space-2); }

.step__title {
  font-size: var(--text-xl);
  font-weight: var(--font-semibold);
  letter-spacing: var(--tracking-tight);
}
.step__desc {
  font-size: var(--text-base);
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
}

/* ---------- Why me grid ---------- */
.why-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 640px) {
  .why-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .why-grid { grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }
}

.why-item {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5);
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-lg);
  transition: border-color var(--duration-fast) var(--ease-out),
              box-shadow var(--duration-fast) var(--ease-out);
}
.why-item:hover {
  border-color: var(--color-border-default);
  box-shadow: var(--shadow-sm);
}

.why-item__check {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  background: var(--color-success-subtle);
  color: var(--green-700);
  display: flex;
  align-items: center;
  justify-content: center;
}
[data-theme="dark"] .why-item__check { color: var(--green-500); }
.why-item__check .icon { width: 18px; height: 18px; }

.why-item__body { display: flex; flex-direction: column; gap: var(--space-1); }
.why-item__title {
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
  line-height: var(--leading-snug);
}
.why-item__desc {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--leading-normal);
}

/* ---------- Areas section ---------- */
.areas-section {
  background: var(--color-bg-subtle);
  border-block: 1px solid var(--color-border-subtle);
}

.areas-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  align-items: center;
}
@media (min-width: 1024px) {
  .areas-layout { grid-template-columns: 1fr 1fr; gap: var(--space-8); }
}

.areas-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.area-card {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-5);
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-lg);
  transition: all var(--duration-fast) var(--ease-out);
}
.area-card:hover {
  border-color: var(--color-brand);
  transform: translateX(4px);
  box-shadow: var(--shadow-sm);
}

.area-card__pin {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  background: var(--color-brand-subtle);
  color: var(--color-text-brand);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.area-card__pin .icon { width: 20px; height: 20px; }

.area-card__body { flex-grow: 1; }
.area-card__city {
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
}
.area-card__detail {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  margin-top: 2px;
}

.area-card__chevron {
  color: var(--color-text-tertiary);
  flex-shrink: 0;
}
.area-card__chevron .icon { width: 16px; height: 16px; }

/* Map visual */
.map-visual {
  position: relative;
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-xl);
  padding: var(--space-5);
  aspect-ratio: 4 / 3;
  overflow: hidden;
  display: none;
}
@media (min-width: 1024px) { .map-visual { display: block; } }

/* ---------- FAQ ---------- */
.faq-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  max-width: 820px;
}

.faq-item {
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color var(--duration-fast) var(--ease-out),
              box-shadow var(--duration-fast) var(--ease-out);
}

.faq-item[open] {
  border-color: var(--color-border-default);
  box-shadow: var(--shadow-sm);
}

.faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: var(--space-4) var(--space-5);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
  color: var(--color-text-primary);
  line-height: var(--leading-snug);
  transition: color var(--duration-fast) var(--ease-out);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary:hover { color: var(--color-text-brand); }

.faq-item__icon {
  flex-shrink: 0;
  width: 28px; height: 28px;
  border-radius: var(--radius-full);
  background: var(--color-bg-subtle);
  color: var(--color-text-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform var(--duration-base) var(--ease-out),
              background var(--duration-fast) var(--ease-out),
              color var(--duration-fast) var(--ease-out);
}
.faq-item__icon .icon { width: 14px; height: 14px; }
.faq-item[open] .faq-item__icon {
  transform: rotate(45deg);
  background: var(--color-brand);
  color: var(--color-text-on-brand);
}

.faq-item__body {
  padding: 0 var(--space-5) var(--space-5);
  color: var(--color-text-secondary);
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
}
.faq-item__body p + p { margin-top: var(--space-3); }

/* ---------- Final CTA ----------
   ADR 0004: Final CTA é SEMPRE escuro, independente do tema.
   Decisão visual intencional para momento de tensão pré-conversão.
   Usar valores primitivos diretos (slate-*) em vez de tokens semânticos. */
.final-cta {
  background: var(--slate-900);
  color: var(--slate-50);
  position: relative;
  overflow: hidden;
}

.final-cta__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(700px 400px at 80% 30%, rgba(99, 102, 241, 0.35), transparent 60%),
    radial-gradient(500px 300px at 10% 80%, rgba(14, 165, 233, 0.18), transparent 60%);
  pointer-events: none;
}

.final-cta .container { position: relative; z-index: 1; }

.final-cta .section-head h2 { color: var(--slate-50); }
.final-cta .section-head p { color: var(--slate-300); }

.contact-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  margin-top: var(--space-6);
}
@media (min-width: 768px) {
  .contact-grid { grid-template-columns: repeat(3, 1fr); }
}

.contact-card {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  backdrop-filter: blur(8px);
  transition: background var(--duration-fast) var(--ease-out),
              border-color var(--duration-fast) var(--ease-out),
              transform var(--duration-fast) var(--ease-out);
}
.contact-card:hover {
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(255, 255, 255, 0.16);
  transform: translateY(-2px);
}

.contact-card__icon {
  width: 44px; height: 44px;
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.contact-card__icon--wa { background: rgba(16, 185, 129, 0.18); color: #34d399; }
.contact-card__icon--form { background: rgba(99, 102, 241, 0.22); color: #a5b4fc; }
.contact-card__icon--mail { background: rgba(14, 165, 233, 0.2); color: #7dd3fc; }
.contact-card__icon .icon { width: 22px; height: 22px; }

.contact-card__label {
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--slate-400);
}
.contact-card__value {
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  color: var(--slate-50);
  margin-top: 4px;
}
.contact-card__cta {
  margin-top: auto;
}

.contact-hours {
  margin-top: var(--space-6);
  padding: var(--space-4) var(--space-5);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-sm);
  color: var(--slate-300);
}
.contact-hours .icon { width: 18px; height: 18px; color: var(--slate-400); }
.contact-hours strong { color: var(--slate-50); font-weight: var(--font-semibold); }

/* ---------- Footer ---------- */
.site-footer {
  background: var(--color-bg-base);
  border-top: 1px solid var(--color-border-subtle);
  padding-block: var(--space-7) var(--space-5);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  margin-bottom: var(--space-6);
}
@media (min-width: 768px) {
  .footer-grid { grid-template-columns: 1.4fr 1fr 1fr; gap: var(--space-7); }
}

.footer-col h4 {
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--color-text-tertiary);
  margin-bottom: var(--space-3);
}

.footer-col p {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
  margin-top: var(--space-3);
  max-width: 320px;
}

.footer-links {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.footer-links a {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  transition: color var(--duration-fast) var(--ease-out);
}
.footer-links a:hover { color: var(--color-text-primary); }

.footer-bottom {
  border-top: 1px solid var(--color-border-subtle);
  padding-top: var(--space-5);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-3);
  font-size: var(--text-xs);
  color: var(--color-text-tertiary);
}

/* ---------- Floating WhatsApp ---------- */
.wa-float {
  position: fixed;
  bottom: var(--space-4);
  right: var(--space-4);
  width: 56px;
  height: 56px;
  border-radius: var(--radius-full);
  background: var(--color-success);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-lg);
  z-index: 40;
  opacity: 0;
  transform: scale(0.85) translateY(8px);
  pointer-events: none;
  transition: opacity var(--duration-base) var(--ease-out),
              transform var(--duration-base) var(--ease-spring),
              box-shadow var(--duration-fast) var(--ease-out);
}
.wa-float.is-visible {
  opacity: 1;
  transform: scale(1) translateY(0);
  pointer-events: auto;
}
.wa-float:hover {
  box-shadow: var(--shadow-xl), 0 0 0 6px rgba(16, 185, 129, 0.18);
}
.wa-float .icon { width: 26px; height: 26px; }
.wa-float .pulse {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: var(--color-success);
  opacity: 0.5;
  animation: wa-pulse 2.4s var(--ease-out) infinite;
}
@keyframes wa-pulse {
  0% { transform: scale(1); opacity: 0.5; }
  100% { transform: scale(1.7); opacity: 0; }
}

/* ---------- Hero Diagnostic Ticket (visual decorativo do hero) ---------- */
.diag-ticket {
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-xl);
  padding: var(--space-5);
  box-shadow: var(--shadow-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  max-width: 380px;
  margin-left: auto;
  position: relative;
  transform: rotate(-1.5deg);
}

.diag-ticket__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: var(--space-3);
  border-bottom: 1px dashed var(--color-border-subtle);
}
.diag-ticket__id {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  display: flex;
  gap: 2px;
}
.diag-ticket__hash { color: var(--color-text-tertiary); }
.diag-ticket__num {
  color: var(--color-text-primary);
  font-weight: var(--font-semibold);
  letter-spacing: 0.04em;
}

.diag-ticket__device {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.diag-ticket__device-icon {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  background: var(--color-brand-subtle);
  color: var(--color-text-brand);
  display: flex;
  align-items: center;
  justify-content: center;
}
.diag-ticket__device-icon svg { width: 24px; height: 24px; }
.diag-ticket__model {
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
  color: var(--color-text-primary);
}
.diag-ticket__note {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}

.diag-ticket__steps {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  position: relative;
}
.diag-ticket__steps::before {
  content: "";
  position: absolute;
  left: 7px;
  top: 14px;
  bottom: 14px;
  width: 2px;
  background: var(--color-border-subtle);
  z-index: 0;
}
.diag-step {
  display: grid;
  grid-template-columns: 16px 1fr auto;
  gap: var(--space-3);
  align-items: center;
  position: relative;
  z-index: 1;
}
.diag-step__dot {
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--color-bg-surface);
  border: 2px solid var(--color-border-default);
}
.diag-step.is-done .diag-step__dot {
  background: var(--color-brand);
  border-color: var(--color-brand);
  box-shadow: 0 0 0 0 var(--color-brand-subtle);
}
.diag-step.is-active .diag-step__dot {
  background: var(--color-bg-surface);
  border-color: var(--color-brand);
  box-shadow: 0 0 0 4px var(--color-brand-subtle);
  animation: pulse-dot 2s var(--ease-in-out) infinite;
}
@keyframes pulse-dot {
  0%, 100% { box-shadow: 0 0 0 4px var(--color-brand-subtle); }
  50% { box-shadow: 0 0 0 7px rgba(99, 102, 241, 0.16); }
}
.diag-step__label {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  font-weight: var(--font-medium);
}
.diag-step.is-done .diag-step__label,
.diag-step.is-active .diag-step__label {
  color: var(--color-text-primary);
}
.diag-step__time {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-tertiary);
  letter-spacing: 0.02em;
}
.diag-step.is-active .diag-step__time {
  color: var(--color-brand);
  font-weight: var(--font-semibold);
}

.diag-ticket__foot {
  display: flex;
  justify-content: space-between;
  align-items: end;
  padding-top: var(--space-3);
  border-top: 1px dashed var(--color-border-subtle);
}
.diag-ticket__label {
  font-size: var(--text-xs);
  color: var(--color-text-tertiary);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  font-weight: var(--font-semibold);
}
.diag-ticket__val {
  font-size: var(--text-lg);
  font-weight: var(--font-bold);
  color: var(--color-text-primary);
  letter-spacing: var(--tracking-tight);
  margin-top: 4px;
}

/* Floating chips around the ticket */
.floating-chip {
  position: absolute;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-full);
  padding: 8px 14px;
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-text-primary);
  box-shadow: var(--shadow-md);
}
.floating-chip svg { width: 14px; height: 14px; color: var(--color-success); }
.floating-chip__dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--color-brand);
  box-shadow: 0 0 0 3px var(--color-brand-subtle);
}
.floating-chip--1 {
  top: -10px;
  left: -8px;
  transform: rotate(-4deg);
}
.floating-chip--2 {
  bottom: -12px;
  right: -8px;
  transform: rotate(3deg);
}

/* Eyebrow no Final CTA — sempre indigo claro (ADR 0004) */
.final-cta .eyebrow { color: var(--indigo-300); }

/* ---------- LGPD Banner ---------- */
.consent-banner {
  position: fixed;
  bottom: var(--space-4);
  left: var(--space-4);
  right: calc(var(--space-4) + 72px);
  max-width: 520px;
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  padding: var(--space-4);
  z-index: 45;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transform: translateY(120%);
  transition: transform var(--duration-slow) var(--ease-out);
}
.consent-banner.is-visible { transform: translateY(0); }
.consent-banner p {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--leading-normal);
}
.consent-banner a { color: var(--color-text-brand); text-decoration: underline; }
.consent-actions {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}
@media (max-width: 640px) {
  .consent-banner {
    right: var(--space-4);
    bottom: 88px;
  }
}
