/* ============================================================
   7esphere · Design System v2
   Paleta: Mono (charcoal + off-white) com accent terra discreto
   Tipografia: Cormorant Garamond (display) + Inter (UI) + JetBrains Mono (meta)
   ============================================================ */

:root {
  /* —— Variáveis estruturais (não mudam com tema) —— */
  --font-display: 'Cormorant Garamond', 'Times New Roman', serif;
  --font-body:    'Inter', -apple-system, system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, 'Menlo', monospace;

  --fs-meta:    11px;
  --fs-small:   13px;
  --fs-body:    15px;
  --fs-lead:    18px;
  --fs-h6:      14px;
  --fs-h5:      18px;
  --fs-h4:      24px;
  --fs-h3:      32px;
  --fs-h2:      44px;
  --fs-h1:      clamp(40px, 5.5vw, 72px);
  --fs-display: clamp(44px, 6vw, 84px);

  --space-xs:   8px;
  --space-sm:   16px;
  --space-md:   24px;
  --space-lg:   48px;
  --space-xl:   80px;
  --space-xxl:  120px;
  --space-section: clamp(80px, 12vw, 160px);

  --container:  1280px;
  --container-wide: 1440px;
  --gutter:     32px;

  --radius:     2px;
  --transition: 220ms cubic-bezier(0.4, 0, 0.2, 1);
  --ease-out:   cubic-bezier(0.16, 1, 0.3, 1);

  /* —— Cores light (default) —— */
  --bg:         #F7F5F2;
  --bg-2:       #ECE8E1;
  --bg-dark:    #1A1A1A;
  --ink:        #1A1A1A;
  --ink-soft:   #4A4A4A;
  --ink-mute:   #8B8580;
  --rule:       #D6D2CB;
  --rule-soft:  #E8E4DE;
  --accent:     #8B7E6F;
  --accent-tint:#B5A593;
  --invert:     #F7F5F2;
  /* Cores fixas, NÃO mudam no dark mode — usar em seções com fundo escuro forçado (footer, hero dark, testimonials) */
  --on-dark:        #F7F5F2;
  --on-dark-soft:   #B8B4AB;
  --on-dark-mute:   rgba(247,245,242,0.6);
  --on-dark-faint:  rgba(247,245,242,0.25);
  --shadow-rgb: 0,0,0;
  --header-bg:  rgba(247,245,242,0.92);
  --header-bg-strong: rgba(247,245,242,0.98);
}

[data-theme="light"] {
  --bg:         #F7F5F2;
  --bg-2:       #ECE8E1;
  --bg-dark:    #1A1A1A;
  --ink:        #1A1A1A;
  --ink-soft:   #4A4A4A;
  --ink-mute:   #8B8580;
  --rule:       #D6D2CB;
  --rule-soft:  #E8E4DE;
  --accent:     #8B7E6F;
  --accent-tint:#B5A593;
  --invert:     #F7F5F2;
  --on-dark:        #F7F5F2;
  --on-dark-soft:   #B8B4AB;
  --on-dark-mute:   rgba(247,245,242,0.6);
  --on-dark-faint:  rgba(247,245,242,0.25);
  --header-bg:  rgba(247,245,242,0.92);
  --header-bg-strong: rgba(247,245,242,0.98);
}

[data-theme="dark"] {
  --bg:         #131313;
  --bg-2:       #1C1C1B;
  --bg-dark:    #0A0A0A;
  --ink:        #F0EDE6;
  --ink-soft:   #B8B4AB;
  --ink-mute:   #807C73;
  --rule:       #2A2A28;
  --rule-soft:  #232321;
  --accent:     #B5A593;
  --accent-tint:#8B7E6F;
  --invert:     #131313;
  /* on-dark NÃO muda no dark mode — sempre cores claras pra fundos escuros */
  --on-dark:        #F0EDE6;
  --on-dark-soft:   #B8B4AB;
  --on-dark-mute:   rgba(240,237,230,0.6);
  --on-dark-faint:  rgba(240,237,230,0.25);
  --header-bg:  rgba(19,19,19,0.92);
  --header-bg-strong: rgba(19,19,19,0.98);
}

/* ============================================================
   Base reset (sobrepondo Bootstrap quando preciso)
   ============================================================ */

html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

body {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  font-weight: 400;
  line-height: 1.65;
  color: var(--ink-soft);
  background-color: var(--bg);
  letter-spacing: 0;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-family: var(--font-display);
  font-weight: 300;
  letter-spacing: -0.01em;
  line-height: 1.1;
  color: var(--ink);
  margin-bottom: var(--space-sm);
}
h1, .h1 { font-size: var(--fs-h1); font-weight: 300; }
h2, .h2 { font-size: var(--fs-h2); font-weight: 400; }
h3, .h3 { font-size: var(--fs-h3); font-weight: 400; }
h4, .h4 { font-size: var(--fs-h4); font-weight: 500; }
h5, .h5 { font-size: var(--fs-h5); font-weight: 500; }
h6, .h6 { font-size: var(--fs-h6); font-weight: 500; }

h1 em, h2 em, h3 em {
  font-style: italic;
  color: var(--accent);
  font-weight: 300;
}

p {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: 1.65;
  color: var(--ink-soft);
  margin-bottom: var(--space-sm);
}

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

/* Metadata tipográfica mono */
.ds-meta {
  font-family: var(--font-mono);
  font-size: var(--fs-meta);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.ds-meta--accent { color: var(--accent); }

/* Eyebrow label (rótulo de seção) */
.ds-eyebrow {
  font-family: var(--font-mono);
  font-size: var(--fs-meta);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  display: inline-block;
  margin-bottom: var(--space-sm);
}

/* ============================================================
   Botões
   ============================================================ */

.ds-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 14px 24px;
  border: 1px solid var(--ink);
  background: transparent;
  color: var(--ink);
  cursor: pointer;
  transition: all var(--transition);
  text-decoration: none;
  border-radius: 0;
  line-height: 1;
}
.ds-btn:hover {
  background: var(--ink);
  color: var(--bg);
}
.ds-btn--primary {
  background: var(--ink);
  color: var(--bg);
}
.ds-btn--primary:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--bg);
}
.ds-btn--invert {
  border-color: var(--bg);
  color: var(--bg);
}
.ds-btn--invert:hover {
  background: var(--bg);
  color: var(--ink);
}
.ds-btn--ghost {
  border-color: transparent;
  padding-left: 0;
  padding-right: 0;
}
.ds-btn--ghost:hover {
  background: transparent;
  color: var(--accent);
}
.ds-btn::after {
  content: "";
  width: 0;
  transition: width 220ms var(--ease-out);
}
.ds-btn:hover::after { width: 0; }

/* ============================================================
   Container & Grid
   ============================================================ */

.ds-container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}
.ds-container--wide { max-width: var(--container-wide); }
.ds-container--narrow { max-width: 880px; }

.ds-section { padding: var(--space-section) 0; }
.ds-section--tight { padding: var(--space-lg) 0; }

/* ============================================================
   HERO — Editorial fullscreen com slider Before/After
   ============================================================ */

.ds-hero {
  position: relative;
  width: 100%;
  height: 100vh;
  height: 100svh;
  min-height: 600px;
  overflow: hidden;
  background-color: var(--bg-dark);
  user-select: none;
  touch-action: pan-y;
}

/* Comparison container — duas imagens sobrepostas, before clipada por --pos */
.ds-hero__compare {
  position: absolute;
  inset: 0;
  z-index: 0;
  cursor: ew-resize;
}
.ds-hero__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
/* "Antes" (wireframe / pré) — fica atrás */
.ds-hero__img--before {
  z-index: 1;
}
/* "Depois" (renderizado final) — clipado em cima do "antes" */
.ds-hero__img--after {
  z-index: 2;
  clip-path: inset(0 0 0 var(--ds-pos, 50%));
  -webkit-clip-path: inset(0 0 0 var(--ds-pos, 50%));
  transition: clip-path 80ms linear;
}
/* Quando user está arrastando, sem transition (responsivo) */
.ds-hero[data-dragging="true"] .ds-hero__img--after {
  transition: none;
}

/* Divisor vertical */
.ds-hero__divider {
  position: absolute;
  top: 0; bottom: 0;
  left: var(--ds-pos, 50%);
  width: 2px;
  background: rgba(255,255,255,0.92);
  box-shadow: 0 0 16px rgba(0,0,0,0.4);
  z-index: 5;
  transform: translateX(-50%);
  pointer-events: none;
}

/* Handle (círculo arrastável com setas) — posicionado abaixo do nome */
.ds-hero__handle {
  position: absolute;
  top: 72%;
  left: var(--ds-pos, 50%);
  transform: translate(-50%, -50%);
  width: 56px;
  height: 56px;
  background: rgba(255,255,255,0.95);
  color: var(--ink);
  border-radius: 999px;
  box-shadow: 0 6px 24px rgba(0,0,0,0.4);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 6;
  cursor: ew-resize;
  font-family: var(--font-mono);
  font-size: 16px;
  letter-spacing: -2px;
  transition: transform 200ms var(--ease-out), box-shadow 200ms;
}
.ds-hero__handle:hover {
  transform: translate(-50%, -50%) scale(1.08);
  box-shadow: 0 10px 32px rgba(0,0,0,0.5);
}
.ds-hero__handle::before {
  content: "‹  ›";
  letter-spacing: 4px;
  font-weight: 700;
  font-size: 18px;
  color: var(--ink);
}

/* Pulse ring quando autoplay está rolando */
.ds-hero[data-autoplay="true"] .ds-hero__handle::after {
  content: "";
  position: absolute; inset: -8px;
  border-radius: 999px;
  border: 1.5px solid rgba(255,255,255,0.55);
  animation: ds-handle-pulse 2.2s ease-out infinite;
}
@keyframes ds-handle-pulse {
  0%   { transform: scale(0.85); opacity: 0.9; }
  70%  { transform: scale(1.7);  opacity: 0; }
  100% { transform: scale(1.7);  opacity: 0; }
}

/* Texto sobreposto: título + caption — alinhado ao terço superior */
.ds-hero__overlay-text {
  position: absolute;
  inset: 0;
  z-index: 4;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  padding: 28vh var(--space-md) 0;
  pointer-events: none;
  text-align: center;
  text-shadow:
    0 2px 16px rgba(0,0,0,0.45),
    0 8px 32px rgba(0,0,0,0.35);
}
@media (max-width: 768px) {
  .ds-hero__overlay-text { padding-top: 24vh; }
}
.ds-hero__brand {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(42px, 11vw, 168px);
  line-height: 1;
  letter-spacing: 0.06em;
  color: #fff;
  margin: 0 0 var(--space-md);
  user-select: none;
  max-width: 95vw;
  text-align: center;
  text-shadow:
    0 2px 24px rgba(0,0,0,0.55),
    0 12px 48px rgba(0,0,0,0.4),
    0 0 1px rgba(0,0,0,0.8);
}
@media (max-width: 400px) {
  .ds-hero__brand {
    font-size: 40px;
    letter-spacing: 0.04em;
  }
}
.ds-hero__caption {
  font-family: var(--font-mono);
  font-size: clamp(10px, 1.2vw, 13px);
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: #fff;
  padding: 8px 18px;
  background: rgba(26,26,26,0.45);
  backdrop-filter: blur(8px) saturate(1.1);
  -webkit-backdrop-filter: blur(8px) saturate(1.1);
  border-radius: 100px;
}

/* Eyebrow no topo (small label) — cápsula discreta pra legibilidade */
.ds-hero__top {
  position: absolute;
  top: 130px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 4;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: #fff;
  padding: 8px 16px;
  background: rgba(26,26,26,0.42);
  backdrop-filter: blur(8px) saturate(1.1);
  -webkit-backdrop-filter: blur(8px) saturate(1.1);
  border-radius: 100px;
  pointer-events: none;
  white-space: nowrap;
}
@media (max-width: 768px) {
  .ds-hero__top { top: 110px; font-size: 9px; letter-spacing: 0.22em; padding: 6px 12px; }
}

/* CTAs no rodapé do hero */
.ds-hero__cta-row {
  position: absolute;
  bottom: var(--space-lg);
  left: 50%;
  transform: translateX(-50%);
  z-index: 5;
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  justify-content: center;
}
/* Hero CTAs: cores fixas pra funcionar igual em light e dark mode.
   O hero tem imagem como background, então sempre fundo escuro/contrastado. */
.ds-hero__cta-row .ds-btn {
  border-color: rgba(247,245,242,0.7);
  color: #F7F5F2;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  background: rgba(26,26,26,0.45);
  font-weight: 500;
}
.ds-hero__cta-row .ds-btn:hover {
  background: #F7F5F2;
  color: #1A1A1A;
  border-color: #F7F5F2;
}
.ds-hero__cta-row .ds-btn--primary {
  background: #F7F5F2;
  color: #1A1A1A;
  border-color: #F7F5F2;
}
.ds-hero__cta-row .ds-btn--primary:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: #F7F5F2;
}

/* Instruction hint embaixo do hero (some quando user arrasta) */
.ds-hero__hint {
  position: absolute;
  bottom: var(--space-sm);
  right: var(--space-md);
  z-index: 5;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #fff;
  padding: 6px 12px;
  background: rgba(26,26,26,0.42);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: 100px;
  pointer-events: none;
  transition: opacity 220ms;
}
.ds-hero[data-interacted="true"] .ds-hero__hint { opacity: 0; }

@media (max-width: 768px) {
  .ds-hero__handle { width: 48px; height: 48px; top: 64%; }
  .ds-hero__handle::before { font-size: 14px; }
  .ds-hero__top { top: 85px; font-size: 9px; }
  .ds-hero__caption { letter-spacing: 0.22em; }
  .ds-hero__cta-row {
    bottom: var(--space-md);
    flex-direction: column;
    width: calc(100% - 2 * var(--space-md));
  }
  .ds-hero__cta-row .ds-btn { width: 100%; justify-content: center; padding: 14px 18px; }
  .ds-hero__hint { display: none; }
}
.ds-hero__eyebrow {
  font-family: var(--font-mono);
  font-size: var(--fs-meta);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(247,245,242,0.78);
  margin-bottom: var(--space-md);
  display: inline-block;
}
.ds-hero__title {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-display);
  line-height: 1.02;
  letter-spacing: -0.015em;
  color: var(--invert);
  max-width: 20ch;
  margin-bottom: var(--space-md);
}
.ds-hero__title em {
  font-style: italic;
  color: var(--accent-tint);
  font-weight: 300;
}
.ds-hero__lead {
  font-family: var(--font-body);
  font-size: var(--fs-lead);
  font-weight: 300;
  line-height: 1.5;
  color: rgba(247,245,242,0.86);
  max-width: 44ch;
  margin-bottom: var(--space-lg);
}
.ds-hero__cta-row {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
  align-items: center;
}
.ds-hero__cta-row .ds-btn {
  border-color: rgba(247,245,242,0.7);
  color: var(--invert);
}
.ds-hero__cta-row .ds-btn:hover {
  background: var(--invert);
  color: var(--ink);
  border-color: var(--invert);
}
.ds-hero__cta-row .ds-btn--primary {
  background: var(--invert);
  color: var(--ink);
  border-color: var(--invert);
}
.ds-hero__cta-row .ds-btn--primary:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--invert);
}

/* Scroll indicator */
.ds-hero__scroll {
  position: absolute;
  bottom: var(--space-md);
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(247,245,242,0.7);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  text-decoration: none;
}
.ds-hero__scroll::after {
  content: "";
  width: 1px;
  height: 40px;
  background: rgba(247,245,242,0.5);
  animation: ds-scroll-pulse 2.4s ease-in-out infinite;
  transform-origin: top;
}
@keyframes ds-scroll-pulse {
  0%, 100% { transform: scaleY(0.3); opacity: 0.4; }
  50%      { transform: scaleY(1.0); opacity: 1.0; }
}

@media (max-width: 768px) {
  .ds-hero__inner {
    padding: 100px var(--space-md) 80px;
  }
  .ds-hero__title { max-width: 100%; }
  .ds-hero__lead { font-size: 16px; }
  .ds-hero__cta-row { gap: 12px; }
  .ds-hero__cta-row .ds-btn { padding: 12px 18px; font-size: 11px; }
  .ds-hero__scroll { display: none; }
}

/* ============================================================
   Header sticky off-white minimalista
   ============================================================ */

#main-header .main-bar.bg-white,
#main-header .sticky-header .main-bar {
  background: var(--header-bg) !important;
  backdrop-filter: blur(14px) saturate(1.05);
  -webkit-backdrop-filter: blur(14px) saturate(1.05);
  border-bottom: 1px solid var(--rule-soft);
  transition: background var(--transition), border-color var(--transition), box-shadow var(--transition);
}

body.scrolled #main-header .main-bar {
  background: var(--header-bg-strong) !important;
  box-shadow: 0 1px 0 var(--rule-soft);
}

/* Logo: inverte em dark mode pra ficar legível */
[data-theme="dark"] #main-header .logo-header img {
  filter: brightness(0) invert(1);
}

#main-header .nav.navbar-nav > li > a {
  color: var(--ink) !important;
  font-family: var(--font-mono);
  font-size: var(--fs-meta);
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 28px 14px !important;
  transition: color var(--transition);
}
#main-header .nav.navbar-nav > li > a:hover {
  color: var(--accent) !important;
}

#main-header .logo-header { padding: 12px 0; }
#main-header .logo-header img {
  max-width: 120px;
  height: auto;
}
#mobile-side-drawer .icon-bar { background: var(--ink) !important; }

/* Sticky header float over content */
#main-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  width: 100%;
}
#main-header .sticky-header { position: static; }

/* Compensate fixed header on every section EXCEPT hero (hero is 100vh from top) */
body { padding-top: 0; }

/* ============================================================
   Footer rico (F8)
   ============================================================ */

.ds-footer {
  background: var(--bg-dark);
  color: rgba(247,245,242,0.7);
  padding: var(--space-xl) 0 var(--space-md);
  font-family: var(--font-body);
}
.ds-footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: var(--space-lg);
  margin-bottom: var(--space-xl);
}
@media (max-width: 980px) {
  .ds-footer__grid { grid-template-columns: 1fr 1fr; gap: var(--space-lg); }
}
@media (max-width: 520px) {
  .ds-footer__grid { grid-template-columns: 1fr; gap: var(--space-md); }
}

.ds-footer__brand h2 {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: 36px;
  letter-spacing: 0.04em;
  color: var(--invert);
  margin: 0 0 var(--space-sm);
}
.ds-footer__tagline {
  font-family: var(--font-body);
  font-style: italic;
  font-weight: 300;
  font-size: var(--fs-small);
  color: rgba(247,245,242,0.5);
  max-width: 32ch;
}

.ds-footer h4 {
  color: var(--accent-tint);
  font-family: var(--font-mono);
  font-size: var(--fs-meta);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 500;
  margin-bottom: var(--space-md);
}
.ds-footer ul { list-style: none; padding: 0; margin: 0; }
.ds-footer li { margin-bottom: 8px; }
.ds-footer a {
  color: rgba(247,245,242,0.7);
  font-family: var(--font-body);
  font-size: var(--fs-small);
  text-decoration: none;
  transition: color var(--transition);
}
.ds-footer a:hover { color: var(--accent-tint); }

.ds-footer__social {
  display: flex;
  gap: 12px;
  margin-top: var(--space-sm);
}
.ds-footer__social a {
  width: 36px; height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(247,245,242,0.18);
  border-radius: 999px;
  transition: all var(--transition);
}
.ds-footer__social a:hover {
  border-color: var(--accent);
  background: var(--accent);
  color: var(--bg);
}
.ds-footer__social svg { width: 16px; height: 16px; fill: currentColor; }

.ds-footer__bottom {
  border-top: 1px solid rgba(247,245,242,0.1);
  padding-top: var(--space-md);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(247,245,242,0.4);
}

/* ============================================================
   Mobile menu fullscreen com blur (F8)
   ============================================================ */

@media (max-width: 991px) {
  /* Mostra o burger button */
  #mobile-side-drawer { display: inline-flex !important; }

  /* Hide desktop nav na largura mobile */
  #main-header .header-nav.navbar-collapse { display: none !important; }

  /* Quando user clica no burger, body recebe .ds-menu-open */
  body.ds-menu-open #ds-mobile-menu { opacity: 1; visibility: visible; pointer-events: auto; }
  body.ds-menu-open { overflow: hidden; }
}

#ds-mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: rgba(26,26,26,0.92);
  backdrop-filter: blur(20px) saturate(1.05);
  -webkit-backdrop-filter: blur(20px) saturate(1.05);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 320ms var(--ease-out), visibility 320ms;
  display: flex;
  align-items: center;
  justify-content: center;
}
#ds-mobile-menu::before {
  content: "";
  position: absolute;
  top: 24px; left: 24px;
  width: 80px; height: 1px;
  background: var(--accent-tint);
  opacity: 0.5;
}
.ds-mobile-menu__close {
  position: absolute;
  top: 16px;
  right: 20px;
  width: 44px; height: 44px;
  background: transparent;
  border: 0;
  color: var(--invert);
  font-family: var(--font-mono);
  font-size: 22px;
  cursor: pointer;
  z-index: 1;
}
.ds-mobile-menu__nav {
  list-style: none;
  padding: 0;
  margin: 0;
  text-align: center;
}
.ds-mobile-menu__nav li {
  margin-bottom: var(--space-md);
}
.ds-mobile-menu__nav a {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(28px, 6vw, 48px);
  letter-spacing: -0.015em;
  color: var(--invert);
  text-decoration: none;
  position: relative;
  transition: color var(--transition);
}
.ds-mobile-menu__nav a:hover { color: var(--accent-tint); }
.ds-mobile-menu__nav a::after {
  content: "";
  position: absolute;
  bottom: -4px; left: 50%;
  width: 0; height: 1px;
  background: var(--accent-tint);
  transition: width 250ms var(--ease-out), left 250ms var(--ease-out);
}
.ds-mobile-menu__nav a:hover::after {
  width: 50%; left: 25%;
}

.ds-mobile-menu__footer {
  position: absolute;
  bottom: 32px;
  left: 24px; right: 24px;
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(247,245,242,0.5);
}

/* Burger button — esconde no desktop */
@media (min-width: 992px) {
  #mobile-side-drawer { display: none !important; }
}
#mobile-side-drawer {
  background: transparent;
  border: 0;
  padding: 10px;
  cursor: pointer;
  width: 44px; height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
#mobile-side-drawer .icon-bar {
  display: block;
  width: 22px;
  height: 1.5px;
  background: var(--ink);
  margin: 3px 0;
  transition: transform var(--transition), opacity var(--transition);
}

/* ============================================================
   Reveal on scroll (F8)
   ============================================================ */

.ds-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 700ms var(--ease-out), transform 700ms var(--ease-out);
}
.ds-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  .ds-reveal { opacity: 1; transform: none; }
}

/* ============================================================
   Project card editorial
   ============================================================ */

.ds-project-card {
  display: block;
  text-decoration: none;
  color: var(--ink);
  cursor: pointer;
}
.ds-project-card__thumb {
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--bg-2);
  overflow: hidden;
  margin-bottom: var(--space-sm);
}
.ds-project-card__thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 600ms var(--ease-out);
}
.ds-project-card:hover .ds-project-card__thumb img {
  transform: scale(1.04);
}
.ds-project-card__thumb::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(26,26,26,0.4) 100%);
  opacity: 0;
  transition: opacity var(--transition);
}
.ds-project-card:hover .ds-project-card__thumb::after { opacity: 1; }

.ds-project-card__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 26px;
  line-height: 1.1;
  letter-spacing: -0.005em;
  color: var(--ink);
  margin-bottom: 6px;
  transition: color var(--transition);
}
.ds-project-card:hover .ds-project-card__title { color: var(--accent); }

.ds-project-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 0;
  font-family: var(--font-mono);
  font-size: var(--fs-meta);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.ds-project-card__meta span:not(:last-child)::after {
  content: " ·";
  margin-right: 6px;
}

/* ============================================================
   Section head + filter chips + projects grid
   ============================================================ */

.ds-section-head {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  margin-bottom: var(--space-lg);
}
.ds-section-head--center {
  align-items: center;
  text-align: center;
}
.ds-section-title {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-h1);
  line-height: 1.05;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: 0;
}
.ds-section-title em {
  font-style: italic;
  color: var(--accent);
  font-weight: 300;
}
.ds-section-foot {
  margin-top: var(--space-lg);
  text-align: center;
}

.ds-filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: var(--space-lg);
  align-items: center;
}
.ds-filter-chip {
  font-family: var(--font-mono);
  font-size: var(--fs-meta);
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 9px 16px;
  border: 1px solid var(--rule);
  border-radius: 100px;
  color: var(--ink-soft);
  background: transparent;
  cursor: pointer;
  transition: all var(--transition);
}
.ds-filter-chip:hover {
  border-color: var(--ink);
  color: var(--ink);
}
.ds-filter-chip.is-active {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--bg);
}
.ds-filter-count {
  font-family: var(--font-mono);
  font-size: var(--fs-meta);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-left: auto;
}

.ds-projects-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg) var(--space-md);
}
@media (max-width: 980px) {
  .ds-projects-grid { grid-template-columns: repeat(3, 1fr); gap: var(--space-md); }
}
@media (max-width: 720px) {
  .ds-projects-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-md) 12px; }
}
@media (max-width: 480px) {
  .ds-projects-grid { grid-template-columns: 1fr; gap: var(--space-md); }
}

.ds-project-card.is-hidden {
  display: none;
}
.ds-project-card {
  opacity: 1;
  transition: opacity 300ms var(--ease-out);
}
.ds-project-card.is-entering {
  opacity: 0;
}
.ds-project-card__thumb {
  aspect-ratio: 4 / 5;   /* portrait — mais editorial pra arq */
}
@media (max-width: 480px) {
  .ds-project-card__thumb { aspect-ratio: 4 / 3; }
}

/* ============================================================
   ABOUT — Quem Somos (texto + tipologias)
   ============================================================ */

.ds-about {
  background: var(--bg);
  padding: var(--space-section) 0;
}
.ds-about__grid {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: var(--space-xl);
  align-items: start;
}
@media (max-width: 980px) {
  .ds-about__grid { grid-template-columns: 1fr; gap: var(--space-lg); }
}
.ds-about__text h2 {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-h1);
  line-height: 1.05;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: var(--space-sm) 0 var(--space-md);
}
.ds-about__text h2 em { font-style: italic; color: var(--accent); font-weight: 300; }
.ds-about__text p {
  font-family: var(--font-body);
  font-size: var(--fs-lead);
  line-height: 1.6;
  color: var(--ink-soft);
  margin-bottom: var(--space-md);
  max-width: 44ch;
}
.ds-about__typologies {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 4px;
}
@media (max-width: 720px) {
  .ds-about__typologies { grid-template-columns: 1fr; }
}
.ds-typology {
  position: relative;
  aspect-ratio: 3 / 4;
  background: var(--bg-2);
  overflow: hidden;
}
.ds-typology img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: grayscale(0.15) contrast(1.02);
  transition: transform 600ms var(--ease-out), filter 400ms;
}
.ds-typology:hover img { transform: scale(1.04); filter: grayscale(0) contrast(1.05); }
.ds-typology__info {
  position: absolute;
  inset: auto 0 0 0;
  padding: var(--space-md);
  background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.7) 100%);
  color: var(--invert);
}
.ds-typology__info h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 24px;
  letter-spacing: -0.005em;
  margin-bottom: 6px;
  color: var(--invert);
}
.ds-typology__info p {
  font-family: var(--font-body);
  font-size: var(--fs-small);
  color: rgba(247,245,242,0.86);
  line-height: 1.5;
  margin: 0;
}

/* ============================================================
   TEAM — Grid B&W uniforme com hover color
   ============================================================ */

.ds-team {
  background: var(--bg-2);
  padding: var(--space-section) 0;
}
.ds-team-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg) var(--space-md);
}
@media (max-width: 980px) { .ds-team-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 720px) { .ds-team-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 420px) { .ds-team-grid { grid-template-columns: 1fr; } }

.ds-team-card {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
}
.ds-team-card__photo {
  aspect-ratio: 3 / 4;
  background: var(--bg);
  overflow: hidden;
  margin-bottom: var(--space-sm);
  position: relative;
}
.ds-team-card__photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: grayscale(1) contrast(1.05);
  transition: filter 500ms var(--ease-out), transform 600ms var(--ease-out);
}
.ds-team-card:hover .ds-team-card__photo img {
  filter: grayscale(0) contrast(1.02);
  transform: scale(1.03);
}
.ds-team-card__photo::after {
  content: "";
  position: absolute;
  bottom: 12px; right: 12px;
  width: 32px; height: 32px;
  border-radius: 999px;
  background: var(--invert);
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%231a1a1a" stroke-width="1.8" stroke-linecap="round" stroke-linejoin="round"><rect x="2" y="2" width="20" height="20" rx="5"/><path d="M16 11.37A4 4 0 1 1 12.63 8 4 4 0 0 1 16 11.37z"/><line x1="17.5" y1="6.5" x2="17.51" y2="6.5"/></svg>');
  background-size: 18px;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 250ms, transform 250ms;
}
.ds-team-card:hover .ds-team-card__photo::after { opacity: 1; transform: translateY(0); }

.ds-team-card__name {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 20px;
  letter-spacing: -0.005em;
  color: var(--ink);
  margin: 0 0 4px;
  line-height: 1.2;
}
.ds-team-card__role {
  font-family: var(--font-body);
  font-size: var(--fs-small);
  color: var(--ink-soft);
  margin: 0 0 8px;
  line-height: 1.4;
}
.ds-team-card__city {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

/* ============================================================
   SERVICES — lista numerada editorial em fundo escuro
   ============================================================ */

.ds-services {
  background: var(--bg-dark);
  color: var(--invert);
  padding: var(--space-section) 0;
}
.ds-services .ds-section-title {
  color: var(--invert);
}
.ds-services .ds-eyebrow {
  color: var(--accent-tint);
}
.ds-services-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.ds-service-row {
  display: grid;
  grid-template-columns: 80px 1fr 2fr;
  gap: var(--space-md);
  padding: var(--space-md) 0;
  border-top: 1px solid rgba(247,245,242,0.12);
  align-items: start;
  transition: background var(--transition);
}
.ds-service-row:last-child {
  border-bottom: 1px solid rgba(247,245,242,0.12);
}
.ds-service-row:hover {
  background: rgba(247,245,242,0.03);
}
.ds-service-row__num {
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.14em;
  color: var(--accent-tint);
}
.ds-service-row__name {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(24px, 3vw, 32px);
  line-height: 1.15;
  letter-spacing: -0.005em;
  color: var(--invert);
}
.ds-service-row__desc {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  color: rgba(247,245,242,0.72);
  line-height: 1.6;
  margin: 0;
}
.ds-service-row__arrow {
  margin-left: auto;
  align-self: center;
  color: rgba(247,245,242,0.4);
  transition: color var(--transition), transform var(--transition);
  font-family: var(--font-mono);
  font-size: 14px;
}
.ds-service-row:hover .ds-service-row__arrow {
  color: var(--accent-tint);
  transform: translateX(6px);
}

@media (max-width: 768px) {
  .ds-service-row {
    grid-template-columns: 48px 1fr;
    gap: var(--space-sm);
  }
  .ds-service-row__desc {
    grid-column: 2 / -1;
    margin-top: 6px;
    font-size: var(--fs-small);
  }
  .ds-service-row__name { font-size: 22px; }
}

/* ============================================================
   MANIFESTO — Frase grande editorial
   ============================================================ */

.ds-manifesto {
  background: var(--bg-2);
  padding: var(--space-section) 0;
}
.ds-manifesto__inner {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 var(--gutter);
  text-align: center;
}
.ds-manifesto__quote {
  font-family: var(--font-display);
  font-weight: 300;
  font-style: italic;
  font-size: clamp(32px, 4.5vw, 64px);
  line-height: 1.15;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: 0 0 var(--space-md);
}
.ds-manifesto__quote em {
  font-style: normal;
  color: var(--accent);
}
.ds-manifesto__attr {
  font-family: var(--font-mono);
  font-size: var(--fs-meta);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

/* ============================================================
   PROCESSO — Etapas numeradas (timeline horizontal)
   ============================================================ */

.ds-process {
  background: var(--bg);
  padding: var(--space-section) 0;
}
.ds-process-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-md);
  position: relative;
}
.ds-process-grid::before {
  content: "";
  position: absolute;
  top: 22px;
  left: 0; right: 0;
  height: 1px;
  background: var(--rule);
  z-index: 0;
}
@media (max-width: 980px) {
  .ds-process-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-lg) var(--space-md); }
  .ds-process-grid::before { display: none; }
}
@media (max-width: 520px) {
  .ds-process-grid { grid-template-columns: 1fr; }
}

.ds-process-step {
  position: relative;
  z-index: 1;
}
.ds-process-step__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: var(--bg);
  border: 1px solid var(--rule);
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  color: var(--ink);
  margin-bottom: var(--space-sm);
}
.ds-process-step__name {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 22px;
  line-height: 1.2;
  letter-spacing: -0.005em;
  color: var(--ink);
  margin: 0 0 8px;
}
.ds-process-step__desc {
  font-family: var(--font-body);
  font-size: var(--fs-small);
  color: var(--ink-soft);
  line-height: 1.55;
  margin: 0;
}

/* ============================================================
   DEPOIMENTOS — Citação grande rotativa
   ============================================================ */

.ds-testimonials {
  background: var(--bg-dark);
  color: var(--invert);
  padding: var(--space-section) 0;
}
.ds-testimonials .ds-eyebrow { color: var(--accent-tint); }
.ds-testimonials .ds-section-title { color: var(--invert); }

.ds-testimonial-stage {
  position: relative;
  max-width: 920px;
  margin: 0 auto;
  min-height: 340px;
}
.ds-testimonial {
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 450ms var(--ease-out), transform 600ms var(--ease-out);
  pointer-events: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.ds-testimonial.is-active {
  opacity: 1;
  transform: translateY(0);
  position: relative;
  pointer-events: auto;
}
.ds-testimonial__quote {
  font-family: var(--font-display);
  font-weight: 300;
  font-style: italic;
  font-size: clamp(22px, 2.8vw, 34px);
  line-height: 1.35;
  letter-spacing: -0.005em;
  color: var(--invert);
  margin: 0 0 var(--space-lg);
  max-width: 760px;
}
.ds-testimonial__quote::before { content: "\201C"; color: var(--accent-tint); margin-right: 4px; }
.ds-testimonial__quote::after  { content: "\201D"; color: var(--accent-tint); margin-left: 4px; }

.ds-testimonial__person {
  display: flex;
  align-items: center;
  gap: 12px;
}
.ds-testimonial__avatar {
  width: 44px; height: 44px;
  border-radius: 999px;
  background: var(--bg-2);
  object-fit: cover;
  filter: grayscale(0.4);
}
.ds-testimonial__name {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 14px;
  color: var(--invert);
  line-height: 1.2;
}
.ds-testimonial__role {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(247,245,242,0.6);
}

/* Dots */
.ds-testimonial-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: var(--space-lg);
}
.ds-testimonial-dot {
  width: 8px; height: 8px;
  border-radius: 999px;
  background: rgba(247,245,242,0.25);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background var(--transition), transform var(--transition);
}
.ds-testimonial-dot:hover { background: rgba(247,245,242,0.5); }
.ds-testimonial-dot.is-active {
  background: var(--accent-tint);
  transform: scale(1.3);
}

/* ============================================================
   PRESS / Parceiros — logos sutis
   ============================================================ */

.ds-press {
  background: var(--bg);
  padding: var(--space-lg) 0 var(--space-xl);
  border-bottom: 1px solid var(--rule-soft);
}
.ds-press__inner {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  justify-content: center;
  flex-wrap: wrap;
}
.ds-press__label {
  font-family: var(--font-mono);
  font-size: var(--fs-meta);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-mute);
  white-space: nowrap;
}
.ds-press__logos {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  flex-wrap: wrap;
  justify-content: center;
}
.ds-press__logo {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: 20px;
  color: var(--ink-soft);
  letter-spacing: 0.02em;
  opacity: 0.7;
  transition: opacity var(--transition), color var(--transition);
}
.ds-press__logo:hover { opacity: 1; color: var(--ink); }

/* ============================================================
   Watermarks "hilite-title" redesenhados
   ============================================================ */

.hilite-title {
  border: 0 !important;
  padding: var(--space-md) 0;
}
.hilite-title strong {
  font-family: var(--font-display);
  font-weight: 300;
  font-style: italic;
  font-size: clamp(36px, 5vw, 56px);
  line-height: 1;
  letter-spacing: -0.01em;
  color: var(--ink);
  display: block;
}
.hilite-title span,
.hilite-title .text-black {
  font-family: var(--font-mono) !important;
  font-size: var(--fs-meta) !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--accent) !important;
  line-height: 1.5 !important;
  display: block;
  margin-top: 8px;
}

/* ============================================================
   Sobrescritas finas do template Bootstrap antigo
   ============================================================ */

/* Section padding default override */
.section-full { padding: var(--space-section) 0; }

/* Backgrounds usados pelo template */
.bg-gray { background-color: var(--bg) !important; }
.bg-white { background-color: var(--bg) !important; }
.text-black { color: var(--ink) !important; }
.text-uppercase { letter-spacing: 0.05em; }

/* Headings com classes de tamanho específicas — força nossa hierarquia */
.font-40, .font-36 {
  font-family: var(--font-display) !important;
  font-weight: 300 !important;
  letter-spacing: -0.01em !important;
  text-transform: none !important;
  line-height: 1.05 !important;
}
.font-40 { font-size: var(--fs-h1) !important; }
.font-36 { font-size: var(--fs-h2) !important; }
.font-30 { font-size: var(--fs-h4) !important; font-weight: 400 !important; }

/* "BEM-VINDO" eyebrow style */
.section-content .font-30.d-block {
  font-family: var(--font-mono) !important;
  font-size: var(--fs-meta) !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--accent) !important;
  font-weight: 500 !important;
  margin-bottom: var(--space-md) !important;
}

/* Section heads do site */
.section-head h2 {
  font-family: var(--font-display) !important;
  font-weight: 300 !important;
  font-size: var(--fs-h1) !important;
  letter-spacing: -0.01em !important;
  text-transform: none !important;
  color: var(--ink) !important;
  line-height: 1.05 !important;
}
.section-head .wt-separator { background: var(--accent) !important; height: 1px !important; }

/* Botões legados do template */
.site-button, .btn-half {
  font-family: var(--font-body) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  padding: 14px 24px !important;
  border: 1px solid var(--ink) !important;
  background: var(--ink) !important;
  color: var(--bg) !important;
  border-radius: 0 !important;
  transition: all var(--transition) !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
}
.site-button:hover, .btn-half:hover {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: var(--invert) !important;
}

/* Tira a "perninha" estranha do btn-half antigo */
.btn-half em,
.btn-half:before,
.btn-half:after { display: none !important; }

/* Filtros dos projetos: chips em vez de texto + barra */
.masonry-filter li a {
  font-family: var(--font-mono) !important;
  font-size: var(--fs-meta) !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  padding: 8px 14px !important;
  border: 1px solid var(--rule) !important;
  border-radius: 100px !important;
  color: var(--ink-soft) !important;
  margin: 0 4px !important;
  transition: all var(--transition);
}
.masonry-filter li a:hover,
.masonry-filter li.active a {
  background: var(--ink) !important;
  border-color: var(--ink) !important;
  color: var(--bg) !important;
}
.masonry-filter li { margin: 0 !important; }
.masonry-filter li:not(:last-child)::after { content: none !important; }

/* Donut shapes / square_shape3 -> remove */
.square_shape3::before,
.square_shape3::after { display: none !important; }
.square_shape1,
.square_shape2,
.square_shape3 { background-image: none !important; }

/* Equipe — uniformidade B&W com hover color */
.our-team img,
.wt-team-1 img,
[class*="team"] img {
  filter: grayscale(0.6) contrast(1.02);
  transition: filter 400ms var(--ease-out);
}
.our-team:hover img,
.wt-team-1:hover img,
[class*="team"]:hover img {
  filter: grayscale(0) contrast(1.05);
}

/* Cards de serviços */
.service-card,
.wt-icon-box-wraper,
.wt-box.shadow-md {
  border: 1px solid var(--rule) !important;
  background: var(--bg) !important;
  padding: var(--space-md) !important;
  transition: border-color var(--transition);
}
.service-card:hover,
.wt-icon-box-wraper:hover {
  border-color: var(--accent) !important;
}

/* Footer original do template — esconde, usaremos novo */
footer.site-footer.bg-gray .footer-bottom { color: var(--ink-mute); }
footer.site-footer .footer-bottom-info p { color: var(--ink-mute); }
footer.site-footer ul.list-inline a { color: var(--ink-soft); }
footer.site-footer ul.list-inline a:hover { color: var(--accent); }

/* Tira cursor especial em links */
a, button, [role="button"] { cursor: pointer; }

/* WhatsApp flutuante — fixed bottom-left, SVG + ripple animado (substituiu webm 222KB) */
.whatsapp-button {
  position: fixed !important;
  bottom: 24px !important;
  left: 24px !important;
  width: 56px;
  height: 56px;
  border-radius: 999px;
  background: #25D366;
  z-index: 50;
  box-shadow: 0 8px 24px rgba(0,0,0,0.18);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.whatsapp-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(37,211,102,0.4);
}
.whatsapp-button svg {
  width: 28px;
  height: 28px;
  fill: #fff;
  pointer-events: none;
}
/* Ripple pulse — chamada visual sem peso */
.whatsapp-button::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: inherit;
  z-index: -1;
  animation: wa-pulse 2s infinite ease-out;
}
@keyframes wa-pulse {
  0%   { transform: scale(1);   opacity: 0.7; }
  100% { transform: scale(1.6); opacity: 0;   }
}
@media (prefers-reduced-motion: reduce) {
  .whatsapp-button::before { animation: none; }
}
/* Manter compatibilidade caso o <video> ainda esteja inline em alguma página */
.whatsapp-button video,
.whatsapp-button img {
  display: none;
}
@media (max-width: 768px) {
  .whatsapp-button {
    bottom: 16px !important;
    left: 16px !important;
    width: 50px;
    height: 50px;
  }
  .whatsapp-button svg { width: 24px; height: 24px; }
}

/* ============================================================
   Utilitários
   ============================================================ */

.ds-rule { width: 60px; height: 1px; background: var(--ink); margin: var(--space-md) 0; }
.ds-rule--accent { background: var(--accent); }
.ds-rule--center { margin-left: auto; margin-right: auto; }

.ds-text-mute { color: var(--ink-mute); }
.ds-text-accent { color: var(--accent); }

/* Loading area — esconde por default, JS reativa se quiser splash */
.loading-area { display: none !important; }

/* ============================================================
   THEME TOGGLE (F15) — botão sol/lua no header
   ============================================================ */

.theme-toggle {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  border: 1px solid var(--rule);
  background: transparent;
  color: var(--ink);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  margin-left: 8px;
  vertical-align: middle;
  transition: all var(--transition);
}
.theme-toggle:hover {
  border-color: var(--accent);
  color: var(--accent);
  transform: rotate(20deg);
}
.theme-toggle svg {
  width: 16px;
  height: 16px;
  display: block;
}
[data-theme="dark"] .theme-toggle__sun  { display: none; }
[data-theme="dark"] .theme-toggle__moon { display: block; }
[data-theme="light"] .theme-toggle__sun  { display: block; }
[data-theme="light"] .theme-toggle__moon { display: none; }
:root:not([data-theme]) .theme-toggle__sun  { display: block; }
:root:not([data-theme]) .theme-toggle__moon { display: none; }

/* Preserve theme transition smooth on body */
body { transition: background-color 300ms var(--ease-out), color 300ms var(--ease-out); }

/* Imagens dos cards: invert grayscale leve em dark pra harmonizar */
[data-theme="dark"] .ds-project-card__thumb img,
[data-theme="dark"] .ds-typology img {
  filter: brightness(0.92) contrast(1.05);
}
[data-theme="dark"] .ds-team-card__photo img {
  filter: grayscale(1) contrast(1.05) brightness(0.85);
}
[data-theme="dark"] .ds-team-card:hover .ds-team-card__photo img {
  filter: grayscale(0.2) contrast(1.05) brightness(0.95);
}
[data-theme="dark"] .ds-team-card__photo::after {
  background: var(--ink); /* avatar pill */
}

/* Hero before/after: imagens podem ficar muito escuras em dark — leve compensação */
[data-theme="dark"] .ds-hero__img {
  filter: brightness(0.92);
}

/* CTAs do hero em dark: o "Vamos conversar" tinha texto charcoal em backdrop transparente — invisível */
[data-theme="dark"] .ds-hero__cta-row .ds-btn {
  background: rgba(247,245,242,0.12);
  border-color: rgba(247,245,242,0.7);
  color: var(--invert) !important; /* invert é dark em dark mode = preto. Forço white aqui */
  color: #fff !important;
}
[data-theme="dark"] .ds-hero__cta-row .ds-btn:hover {
  background: #fff;
  color: var(--bg) !important;
}
[data-theme="dark"] .ds-hero__cta-row .ds-btn--primary {
  background: #fff;
  color: var(--bg) !important;
  border-color: #fff;
}
[data-theme="dark"] .ds-hero__cta-row .ds-btn--primary:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff !important;
}

/* Process step numbers: borda invisível em dark, fortalecer */
[data-theme="dark"] .ds-process-step__num {
  border-color: var(--rule);
  background: var(--bg-2);
  color: var(--ink);
}
[data-theme="dark"] .ds-process-grid::before {
  background: var(--rule);
}

/* Buttons do design system: garante contraste em dark */
[data-theme="dark"] .ds-btn {
  border-color: var(--ink);
  color: var(--ink);
}
[data-theme="dark"] .ds-btn:hover {
  background: var(--ink);
  color: var(--bg);
}
[data-theme="dark"] .ds-btn--primary {
  background: var(--ink);
  color: var(--bg);
}
[data-theme="dark"] .ds-btn--primary:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--bg-dark);
}

/* Filter chip ativo em dark */
[data-theme="dark"] .ds-filter-chip.is-active {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}

/* Reveal-on-scroll: opacity menos agressivo pra evitar "tudo apagado" em dark se JS demora */
.ds-reveal:not(.is-visible) {
  opacity: 0.15;
  transform: translateY(20px);
}
@media (prefers-reduced-motion: reduce) {
  .ds-reveal { opacity: 1 !important; transform: none !important; }
}

/* Service rows em dark: já têm bg-dark mas garante text visibility */
[data-theme="dark"] .ds-service-row__name { color: var(--ink); }
[data-theme="dark"] .ds-service-row__desc { color: var(--ink-soft); }

/* Login error/notice: usa colors que funcionam em ambos temas */
[data-theme="dark"] .login-error {
  color: #ff9090;
  background: rgba(255,144,144,0.08);
  border-color: rgba(255,144,144,0.3);
}
[data-theme="dark"] .login-notice {
  color: #7cd99e;
  background: rgba(124,217,158,0.08);
  border-color: rgba(124,217,158,0.3);
}

/* Voltar ao site (login) em dark */
[data-theme="dark"] .login-back { color: var(--ink); }

/* Hero handle em dark: já é branco, manter */
[data-theme="dark"] .ds-hero__handle {
  background: rgba(247,245,242,0.95);
  color: var(--bg);
}
[data-theme="dark"] .ds-hero__handle::before { color: var(--bg); }

/* Header overrides em dark: navegação inverte */
[data-theme="dark"] #main-header .nav.navbar-nav > li > a {
  color: var(--ink) !important;
}
[data-theme="dark"] #mobile-side-drawer .icon-bar { background: var(--ink) !important; }

/* SVG ícones do footer social: viram light em dark */
[data-theme="dark"] .ds-footer__social a {
  border-color: rgba(247,245,242,0.18);
}

/* Mobile menu já é dark, deixa intacto */

/* ============================================================
   end theme toggle
   ============================================================ */

/* ============================================================
   SCROLL TO TOP (F17) + SCROLL PROGRESS BAR
   ============================================================ */

.ds-scroll-top {
  position: fixed;
  bottom: 24px;
  right: 24px;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  background: var(--ink);
  color: var(--bg);
  border: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 50;
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity 220ms var(--ease-out), visibility 220ms, transform 220ms var(--ease-out), background var(--transition);
  box-shadow: 0 6px 20px rgba(0,0,0,0.15);
}
.ds-scroll-top.is-shown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.ds-scroll-top:hover { background: var(--accent); }
.ds-scroll-top svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.6;
  stroke-linecap: round;
  stroke-linejoin: round;
}
@media (max-width: 720px) {
  .ds-scroll-top { bottom: 88px; right: 16px; width: 40px; height: 40px; }
}

/* Scroll progress bar (top de página) */
.ds-scroll-progress {
  position: fixed;
  top: 0; left: 0;
  height: 2px;
  background: var(--accent);
  width: 0%;
  z-index: 1000;
  transition: width 80ms linear;
  pointer-events: none;
}

/* ============================================================
   FORM / Contact (F10)
   ============================================================ */

.ds-contact-grid {
  display: grid;
  grid-template-columns: 7fr 4fr;
  gap: var(--space-xl);
  align-items: start;
}
@media (max-width: 980px) {
  .ds-contact-grid { grid-template-columns: 1fr; gap: var(--space-lg); }
}

.ds-contact-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.ds-contact-form__intro {
  font-family: var(--font-body);
  font-size: var(--fs-lead);
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 0 0 var(--space-md);
  max-width: 52ch;
}
.ds-contact-form__status {
  font-family: var(--font-body);
  font-size: 0.95rem;
  line-height: 1.5;
  color: var(--ink-soft);
  margin: 12px 0 0;
  padding: 12px 16px;
  background: rgba(255,255,255,0.04);
  border-left: 2px solid var(--ink-soft);
  border-radius: 2px;
}
.ds-contact-form__status.is-error {
  border-left-color: #d96b6b;
  color: #d96b6b;
}
.ds-contact-form__status a {
  color: inherit;
  text-decoration: underline;
}

.ds-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ds-field__label {
  font-family: var(--font-mono);
  font-size: var(--fs-meta);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink);
}
.ds-field__optional {
  color: var(--ink-mute);
  text-transform: none;
  letter-spacing: 0.04em;
}
.ds-field input,
.ds-field textarea {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  color: var(--ink);
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--rule);
  padding: 10px 0;
  outline: none;
  transition: border-color var(--transition);
  resize: vertical;
}
.ds-field input::placeholder,
.ds-field textarea::placeholder { color: var(--ink-mute); }
.ds-field input:focus,
.ds-field textarea:focus { border-bottom-color: var(--accent); }

.ds-contact-side {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.ds-contact-card {
  padding: var(--space-md);
  border: 1px solid var(--rule);
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ds-contact-card .ds-eyebrow { margin: 0; }
.ds-contact-card a,
.ds-contact-card p {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  color: var(--ink);
  text-decoration: none;
  margin: 0;
  line-height: 1.5;
}
.ds-contact-card a:hover { color: var(--accent); }

/* ============================================================
   AUTH / Login + sem-acesso + obrigado (F11, F14)
   ============================================================ */

.ds-auth {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 100vh;
  min-height: 100svh;
  background: var(--bg);
}
@media (max-width: 980px) {
  .ds-auth { grid-template-columns: 1fr; }
  .ds-auth__media { display: none; }
}
.ds-auth--center {
  grid-template-columns: 1fr;
  place-items: center;
  text-align: center;
  padding: var(--space-lg);
}
.ds-auth__center {
  max-width: 600px;
}
.ds-auth__panel {
  display: flex;
  flex-direction: column;
  padding: var(--space-xl) var(--space-lg);
  max-width: 540px;
  margin: 0 auto;
  width: 100%;
  justify-content: center;
}
.ds-auth__brand { margin-bottom: var(--space-lg); }
.ds-auth__form-wrap {}
.ds-auth__title {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(36px, 4.5vw, 56px);
  line-height: 1.05;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: var(--space-sm) 0 var(--space-md);
}
.ds-auth__title em { font-style: italic; color: var(--accent); font-weight: 300; }
.ds-auth__lead {
  font-family: var(--font-body);
  font-size: var(--fs-lead);
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 0 0 var(--space-lg);
  max-width: 44ch;
}
.ds-auth__actions {
  display: flex;
  gap: var(--space-sm);
  align-items: center;
  flex-wrap: wrap;
  margin-top: var(--space-md);
}
.ds-auth__hint {
  font-family: var(--font-mono);
  font-size: var(--fs-meta);
  letter-spacing: 0.08em;
  color: var(--ink-mute);
  margin: 12px 0 0;
  min-height: 16px;
}
.ds-auth__footer {
  font-family: var(--font-body);
  font-size: var(--fs-small);
  color: var(--ink-mute);
  margin-top: var(--space-lg);
}
.ds-auth__footer a { color: var(--accent); }

.ds-auth__media {
  position: relative;
  overflow: hidden;
  background: var(--bg-dark);
}
.ds-auth__media img {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  filter: grayscale(0.2) contrast(1.05) brightness(0.85);
}
.ds-auth__media::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.05) 0%, rgba(0,0,0,0.65) 100%);
}
.ds-auth__media-quote {
  position: absolute;
  bottom: var(--space-lg);
  left: var(--space-lg);
  right: var(--space-lg);
  z-index: 2;
  color: var(--invert);
}
.ds-auth__media-quote p {
  font-family: var(--font-display);
  font-weight: 300;
  font-style: italic;
  font-size: clamp(22px, 2.5vw, 32px);
  line-height: 1.2;
  color: var(--invert);
  margin: 0 0 12px;
}
.ds-auth__media-quote span {
  font-family: var(--font-mono);
  font-size: var(--fs-meta);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent-tint);
}

/* ============================================================
   DASHBOARD shell (F12-F14)
   ============================================================ */

.ds-app {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: 100vh;
  background: var(--bg);
}
@media (max-width: 980px) {
  .ds-app { grid-template-columns: 1fr; }
  .ds-app__sidebar { display: none; }
}

.ds-app__sidebar {
  background: var(--bg-dark);
  color: var(--invert);
  padding: var(--space-md) var(--space-sm);
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
}
.ds-app__sidebar-brand {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: 22px;
  letter-spacing: 0.04em;
  color: var(--invert);
  padding: 8px 12px;
  text-decoration: none;
}
.ds-app__sidebar-nav {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.ds-app__sidebar-nav a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  font-family: var(--font-body);
  font-size: var(--fs-small);
  color: rgba(247,245,242,0.7);
  text-decoration: none;
  border-radius: 4px;
  transition: all var(--transition);
}
.ds-app__sidebar-nav a:hover { background: rgba(247,245,242,0.06); color: var(--invert); }
.ds-app__sidebar-nav a.is-active { background: var(--accent); color: var(--invert); }

.ds-app__sidebar-section {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(247,245,242,0.4);
  padding: 0 12px;
  margin: var(--space-sm) 0 8px;
}

.ds-app__sidebar-user {
  margin-top: auto;
  padding: var(--space-sm);
  border-top: 1px solid rgba(247,245,242,0.1);
  display: flex;
  align-items: center;
  gap: 10px;
}
.ds-app__sidebar-user__avatar {
  width: 36px; height: 36px;
  border-radius: 999px;
  background: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--invert);
  font-family: var(--font-mono);
  font-size: 13px;
}
.ds-app__sidebar-user__info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  flex: 1;
}
.ds-app__sidebar-user__name {
  font-family: var(--font-body);
  font-size: var(--fs-small);
  color: var(--invert);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ds-app__sidebar-user__role {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(247,245,242,0.5);
}

.ds-app__main {
  padding: var(--space-lg) var(--space-lg) var(--space-xl);
  background: var(--bg);
}
@media (max-width: 720px) { .ds-app__main { padding: var(--space-md); } }

.ds-app__topbar {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
  flex-wrap: wrap;
}
.ds-app__pagetitle {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-h2);
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: 0;
}
.ds-app__pagetitle em { font-style: italic; color: var(--accent); font-weight: 300; }

.ds-app__stats {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
}
@media (max-width: 980px) { .ds-app__stats { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .ds-app__stats { grid-template-columns: 1fr; } }
.ds-stat-card {
  padding: var(--space-md);
  border: 1px solid var(--rule);
  background: var(--bg);
  cursor: pointer;
  transition: border-color var(--transition);
}
.ds-stat-card:hover { border-color: var(--accent); }
.ds-stat-card.is-active { border-color: var(--ink); background: var(--bg-2); }
.ds-stat-card__label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 8px;
  display: block;
}
.ds-stat-card__value {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: 36px;
  line-height: 1;
  color: var(--ink);
}

.ds-card {
  background: var(--bg);
  border: 1px solid var(--rule);
  padding: var(--space-md);
}
.ds-card__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: var(--space-sm);
}
.ds-card__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 22px;
  letter-spacing: -0.005em;
  color: var(--ink);
}
.ds-card__action {
  font-family: var(--font-mono);
  font-size: var(--fs-meta);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  text-decoration: none;
}

.ds-table {
  width: 100%;
  border-collapse: collapse;
}
.ds-table th, .ds-table td {
  padding: 12px 8px;
  text-align: left;
  border-bottom: 1px solid var(--rule);
  font-family: var(--font-body);
  font-size: var(--fs-small);
  color: var(--ink);
}
.ds-table th {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 500;
}
.ds-table tbody tr { cursor: pointer; transition: background var(--transition); }
.ds-table tbody tr:hover { background: var(--bg-2); }

/* ============================================================
   DASHBOARD — TOKENS LOCAIS (F19)
   Painel tem seu próprio sistema de tokens (dashboard.css) com
   --bg escuro + --accent dourado + Space Grotesk. Aqui dentro de
   body.dashboard-body restauramos esses valores pra que qualquer
   regra que use var(--bg) etc não pegue as cores do site público.
   ============================================================ */

body.dashboard-body {
  /* Restaura tokens originais do dashboard.css */
  --bg:           #0c0f15;
  --bg-2:         rgba(255,255,255,0.03);
  --bg-dark:      #0c0f15;
  --ink:          #f6f7fb;
  --ink-soft:     #c8cdda;
  --ink-mute:     #a0a6b9;
  --rule:         rgba(255,255,255,0.10);
  --rule-soft:    rgba(255,255,255,0.06);
  --accent:       #e6c17a;
  --accent-tint:  #f3d99a;
  --invert:       #0c0f15;
  --header-bg:    rgba(12,15,21,0.92);
  --header-bg-strong: rgba(12,15,21,0.98);

  /* Fontes: dashboard usa Space Grotesk pra TUDO */
  --font-body:    'Space Grotesk', system-ui, sans-serif;
  --font-display: 'Space Grotesk', sans-serif;
  --font-mono:    'Space Grotesk', monospace;

  background: #0c0f15;
  color: #f6f7fb;
  font-family: 'Space Grotesk', system-ui, sans-serif;
}

/* Header sticky do site público não aparece no painel */
body.dashboard-body #main-header { display: none; }

/* Scroll utilities adaptados pro tema dourado */
body.dashboard-body .ds-scroll-progress { background: var(--accent); }
body.dashboard-body .ds-scroll-top {
  background: var(--accent);
  color: var(--bg);
}
body.dashboard-body .ds-scroll-top:hover { background: var(--accent-tint); }

/* Theme toggle dentro do painel: aparece no topbar */
body.dashboard-body .theme-toggle {
  display: inline-flex !important;
  width: 36px;
  height: 36px;
  border: 1px solid var(--rule);
  background: transparent;
  color: var(--ink);
  border-radius: 999px;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  margin-right: 8px;
  vertical-align: middle;
  transition: all 220ms cubic-bezier(0.4,0,0.2,1);
}
body.dashboard-body .theme-toggle:hover {
  border-color: var(--accent);
  color: var(--accent);
}
body.dashboard-body .theme-toggle svg { width: 16px; height: 16px; }

/* Painel em LIGHT MODE — overrides cuidadosos pra elementos com cor hardcoded */
[data-theme="light"] body.dashboard-body {
  --bg:           #F7F5F2;
  --bg-2:         rgba(0,0,0,0.04);
  --bg-dark:      #ECE8E1;
  --ink:          #1A1A1A;
  --ink-soft:     #4A4A4A;
  --ink-mute:     #6B6660;
  --rule:         rgba(0,0,0,0.10);
  --rule-soft:    rgba(0,0,0,0.06);
  --accent:       #8B7E6F;
  --accent-tint:  #6B5F52;
  --invert:       #F7F5F2;
  --header-bg:    rgba(247,245,242,0.92);
  background: #F7F5F2;
  color: #1A1A1A;
}
[data-theme="light"] body.dashboard-body .brand-logo {
  filter: brightness(0);
}

/* Topbar em light: fundo off-white com border */
[data-theme="light"] body.dashboard-body .topbar {
  background: rgba(247,245,242,0.94) !important;
  border-bottom: 1px solid rgba(0,0,0,0.08) !important;
}
[data-theme="light"] body.dashboard-body .nav-link {
  color: #4A4A4A !important;
}
[data-theme="light"] body.dashboard-body .nav-link.active {
  background: rgba(139,126,111,0.12) !important;
  color: #1A1A1A !important;
}
[data-theme="light"] body.dashboard-body .user-chip {
  background: rgba(0,0,0,0.04) !important;
  border-color: rgba(0,0,0,0.10) !important;
}
[data-theme="light"] body.dashboard-body .uc-name { color: #1A1A1A !important; }
[data-theme="light"] body.dashboard-body .uc-role { color: #6B6660 !important; }

/* Hero card em light: gradiente sutil terra */
[data-theme="light"] body.dashboard-body .hero-card {
  background: linear-gradient(135deg, #ECE8E1 0%, #DDD5C5 100%) !important;
  border-color: rgba(0,0,0,0.08) !important;
}
[data-theme="light"] body.dashboard-body .hc-blob { display: none !important; }
[data-theme="light"] body.dashboard-body .hc-eyebrow { color: #8B7E6F !important; }
[data-theme="light"] body.dashboard-body .hc-title { color: #1A1A1A !important; }
[data-theme="light"] body.dashboard-body .hc-sub,
[data-theme="light"] body.dashboard-body [data-hc-sub] { color: #4A4A4A !important; }
[data-theme="light"] body.dashboard-body .hc-chip {
  background: rgba(255,255,255,0.6) !important;
  border-color: rgba(0,0,0,0.10) !important;
  color: #1A1A1A !important;
}
[data-theme="light"] body.dashboard-body .hc-chip-num { color: #1A1A1A !important; }
[data-theme="light"] body.dashboard-body .hc-chip-lbl { color: #4A4A4A !important; }
[data-theme="light"] body.dashboard-body .hc-aside-card {
  background: rgba(255,255,255,0.5) !important;
  border-color: rgba(0,0,0,0.08) !important;
}
[data-theme="light"] body.dashboard-body .hc-aside-label,
[data-theme="light"] body.dashboard-body .hc-scope-label { color: #6B6660 !important; }
[data-theme="light"] body.dashboard-body .hc-aside-value { color: #1A1A1A !important; }
[data-theme="light"] body.dashboard-body .hc-scope {
  background: rgba(255,255,255,0.6) !important;
  border-color: rgba(0,0,0,0.10) !important;
  color: #1A1A1A !important;
}

/* KPI cards em light: cards brancos com border */
[data-theme="light"] body.dashboard-body .kpi {
  background: #FFFFFF !important;
  border: 1px solid rgba(0,0,0,0.08) !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04) !important;
}
[data-theme="light"] body.dashboard-body .kpi-label,
[data-theme="light"] body.dashboard-body .kpi-sub { color: #6B6660 !important; }
[data-theme="light"] body.dashboard-body .kpi-value { color: #1A1A1A !important; }

/* Painéis genéricos em light */
[data-theme="light"] body.dashboard-body .panel,
[data-theme="light"] body.dashboard-body .card,
[data-theme="light"] body.dashboard-body .widget {
  background: #FFFFFF !important;
  border-color: rgba(0,0,0,0.08) !important;
  color: #1A1A1A !important;
}
[data-theme="light"] body.dashboard-body .panel h2,
[data-theme="light"] body.dashboard-body .panel h3,
[data-theme="light"] body.dashboard-body .card h2,
[data-theme="light"] body.dashboard-body .card h3 { color: #1A1A1A !important; }
[data-theme="light"] body.dashboard-body .panel p,
[data-theme="light"] body.dashboard-body .card p { color: #4A4A4A !important; }

/* Pipeline em light */
[data-theme="light"] body.dashboard-body [class*="pipeline"] .step,
[data-theme="light"] body.dashboard-body [class*="phase"] {
  background: #FFFFFF !important;
  border: 1px solid rgba(0,0,0,0.08) !important;
  color: #1A1A1A !important;
}

/* Filter select em light */
[data-theme="light"] body.dashboard-body select,
[data-theme="light"] body.dashboard-body input,
[data-theme="light"] body.dashboard-body textarea,
[data-theme="light"] body.dashboard-body .filter-select {
  background: #FFFFFF !important;
  border: 1px solid rgba(0,0,0,0.12) !important;
  color: #1A1A1A !important;
}

/* Override: btn-primary não precisa ter min-width 240px (estava ficando gigante em headers) */
body.dashboard-body .btn-primary,
body.dashboard-body .btn-secondary,
body.dashboard-body .btn-danger {
  min-width: 0 !important;
  height: auto !important;
  padding: 10px 18px !important;
  border-radius: 100px !important;
  font-size: 13px !important;
  white-space: nowrap !important;
  width: auto !important;
  flex: 0 0 auto !important;
}

/* Fix "+ Novo projeto" — texto e fundo precisam contrastar */
body.dashboard-body .page > .topbar .quick-new {
  background: var(--accent);
  color: var(--bg) !important;
  border: 1px solid var(--accent);
  font-weight: 600;
}
body.dashboard-body .page > .topbar .quick-new:hover {
  background: var(--accent-tint);
  border-color: var(--accent-tint);
  color: var(--bg) !important;
}
body.dashboard-body .page > .topbar .quick-new .qn-label,
body.dashboard-body .page > .topbar .quick-new > span {
  color: var(--bg) !important;
}

/* Topbar do painel */
.page > .topbar {
  background: rgba(12,15,21,0.94) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--rule-soft) !important;
  box-shadow: none !important;
}
.page > .topbar .brand-logo {
  max-height: 32px; /* logo já é branca, não precisa filter */
}
.page > .topbar .nav-link {
  font-family: 'Space Grotesk', sans-serif !important;
  color: var(--ink-soft) !important;
  background: transparent !important;
  transition: color var(--transition);
}
.page > .topbar .nav-link:hover,
.page > .topbar .nav-link.active {
  color: var(--accent) !important;
  background: transparent !important;
}
.page > .topbar .quick-new {
  font-family: var(--font-mono) !important;
  color: var(--accent) !important;
}

/* Hover dos nav-links no painel volta ao behavior original */
body.dashboard-body .page > .topbar .nav-link:hover,
body.dashboard-body .page > .topbar .nav-link.active {
  color: var(--accent) !important;
}

/* "+ Novo projeto" mantém o dourado original */
body.dashboard-body .page > .topbar .quick-new {
  background: var(--accent);
  color: var(--bg);
  border: 1px solid var(--accent);
}
body.dashboard-body .page > .topbar .quick-new:hover {
  background: var(--accent-tint);
  border-color: var(--accent-tint);
}

/* User chip volta ao default do dashboard.css (sem override agressivo) */
/* hero-card, KPI rows, cards, btn — todos voltam ao default do dashboard.css */
/* (removidas regras que forçavam tokens do site público dentro do painel)   */

/* Tabs do painel: só ajusta underline accent dourado, sem mudar dimensions */
body.dashboard-body .tab-list .tab.active,
body.dashboard-body .tabs .tab-button.active {
  border-bottom-color: var(--accent);
}

/* Status badges: cores corretas em accent dourado */
body.dashboard-body .status.in-progress,
body.dashboard-body .badge.in-progress {
  background: var(--accent);
  color: var(--bg);
  border-color: var(--accent);
}

/* ============================================================
   CASE STUDY — Página /projeto/<slug> (F5)
   ============================================================ */

.cs-hero {
  position: relative;
  width: 100%;
  height: 80vh;
  min-height: 540px;
  overflow: hidden;
  background: var(--bg-dark);
}
.cs-hero img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.cs-hero::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.15) 0%, rgba(0,0,0,0.55) 100%);
}
.cs-hero__title-block {
  position: absolute;
  bottom: var(--space-xl);
  left: var(--gutter);
  right: var(--gutter);
  z-index: 2;
  max-width: var(--container-wide);
  margin: 0 auto;
  color: var(--invert);
}
.cs-hero__category {
  font-family: var(--font-mono);
  font-size: var(--fs-meta);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--accent-tint);
  margin-bottom: var(--space-sm);
  display: inline-block;
}
.cs-hero__title {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(40px, 6vw, 88px);
  line-height: 1.05;
  letter-spacing: -0.015em;
  color: var(--invert);
  margin: 0;
  max-width: 18ch;
}

.cs-meta {
  background: var(--bg);
  padding: var(--space-lg) 0;
  border-bottom: 1px solid var(--rule);
}
.cs-meta-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-md);
}
@media (max-width: 720px) { .cs-meta-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-sm); } }
.cs-meta-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.cs-meta-item__label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.cs-meta-item__value {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 18px;
  color: var(--ink);
}

.cs-section { padding: var(--space-section) 0; background: var(--bg); }
.cs-section--dark { background: var(--bg-2); }

.cs-narrative {
  display: grid;
  grid-template-columns: 4fr 8fr;
  gap: var(--space-xl);
  max-width: var(--container-wide);
  margin: 0 auto;
  padding: 0 var(--gutter);
}
@media (max-width: 980px) { .cs-narrative { grid-template-columns: 1fr; gap: var(--space-lg); } }

.cs-narrative__label {
  font-family: var(--font-mono);
  font-size: var(--fs-meta);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
}
.cs-narrative__heading {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-h2);
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: var(--space-sm) 0 var(--space-md);
}
.cs-narrative__heading em { font-style: italic; color: var(--accent); font-weight: 300; }
.cs-narrative__body p {
  font-family: var(--font-body);
  font-size: var(--fs-lead);
  line-height: 1.65;
  color: var(--ink-soft);
  margin-bottom: var(--space-md);
}

.cs-gallery {
  display: grid;
  gap: 12px;
  max-width: var(--container-wide);
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.cs-gallery--full {
  grid-template-columns: 1fr;
}
.cs-gallery--duo {
  grid-template-columns: 1fr 1fr;
}
.cs-gallery--asym {
  grid-template-columns: 2fr 1fr;
}
@media (max-width: 720px) {
  .cs-gallery--duo,
  .cs-gallery--asym { grid-template-columns: 1fr; }
}
.cs-gallery img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 16 / 10;
  object-fit: cover;
}
.cs-gallery--asym img:first-child { aspect-ratio: 16 / 10; }
.cs-gallery--asym img:last-child  { aspect-ratio: 4 / 5; }

.cs-pull {
  background: var(--bg-dark);
  color: var(--invert);
  padding: var(--space-section) 0;
  text-align: center;
}
.cs-pull__quote {
  font-family: var(--font-display);
  font-weight: 300;
  font-style: italic;
  font-size: clamp(28px, 4vw, 48px);
  line-height: 1.25;
  letter-spacing: -0.01em;
  color: var(--invert);
  max-width: 920px;
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.cs-nav {
  background: var(--bg);
  padding: var(--space-lg) 0;
  border-top: 1px solid var(--rule);
}
.cs-nav-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
  max-width: var(--container-wide);
  margin: 0 auto;
  padding: 0 var(--gutter);
}
@media (max-width: 720px) { .cs-nav-grid { grid-template-columns: 1fr; } }
.cs-nav-card {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  padding: var(--space-md) 0;
  transition: opacity var(--transition);
}
.cs-nav-card:hover { opacity: 0.7; }
.cs-nav-card--prev { text-align: left; }
.cs-nav-card--next { text-align: right; }
.cs-nav-card__label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 8px;
}
.cs-nav-card__title {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: 28px;
  letter-spacing: -0.005em;
  color: var(--ink);
}

/* Smooth scroll */
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .ds-hero__media img { animation: none; }
  .ds-hero__scroll::after { animation: none; }
}

/* ============================================================
   DARK MODE — Contraste em seções com fundo escuro forçado
   ------------------------------------------------------------
   Algumas seções têm fundo dark constante (testimonials, footer,
   manifesto opcional, auth media, sidebar). No dark mode, --invert
   vira #131313 e --ink vira claro, causando texto preto em fundo
   preto. Este bloco força tokens "on-dark" claros nessas seções.
   ============================================================ */

[data-theme="dark"] .ds-testimonials,
[data-theme="dark"] .ds-footer,
[data-theme="dark"] .ds-auth__media,
[data-theme="dark"] .ds-app__sidebar,
[data-theme="dark"] .cs-hero,
[data-theme="dark"] .ds-cs__hero,
[data-theme="dark"] .cs-pull,
[data-theme="dark"] .cs-meta,
[data-theme="dark"] #ds-mobile-menu,
[data-theme="dark"] .ds-services,
[data-theme="dark"] .ds-process,
[data-theme="dark"] .ds-press,
[data-theme="dark"] .ds-stats,
[data-theme="dark"] .ds-about,
[data-theme="dark"] .ds-team,
[data-theme="dark"] .ds-projects,
[data-theme="dark"] .ds-manifesto,
[data-theme="dark"] .ds-cta {
  --invert: #F0EDE6;
  --ink: #F0EDE6;
  --ink-soft: #C8C4BB;
  --ink-mute: rgba(240,237,230,0.55);
}

/* Garante section titles claras no dark mode em todas as seções */
[data-theme="dark"] .ds-section-title,
[data-theme="dark"] .ds-services .ds-section-title,
[data-theme="dark"] .ds-services h3,
[data-theme="dark"] .ds-service-row__name,
[data-theme="dark"] .ds-service-row__desc {
  color: #F0EDE6 !important;
}

/* Botões CTA que precisam ser visíveis em dark mode (text branco em qualquer fundo) */
[data-theme="dark"] .ds-btn--invert {
  background: rgba(247,245,242,0.08);
  color: #F0EDE6;
  border-color: rgba(247,245,242,0.4);
}
[data-theme="dark"] .ds-btn--invert:hover {
  background: #F0EDE6;
  color: #1A1A1A;
  border-color: #F0EDE6;
}

/* Botões legados do template Bootstrap (.btn-half / .site-button) — span interno
   tem cor #fff hardcoded mas fundo do botão é claro: texto fica invisível */
[data-theme="dark"] .btn-half span,
[data-theme="dark"] .site-button span {
  color: inherit;
}
[data-theme="dark"] .btn-half {
  background: var(--accent);
  color: #1A1A1A;
  border-color: var(--accent);
}
[data-theme="dark"] .btn-half:hover {
  background: var(--accent-tint);
  color: #1A1A1A;
}

/* Menu mobile fullscreen — texto sempre claro (fundo é dark blur) */
#ds-mobile-menu {
  background: rgba(15,15,15,0.96);
}
.ds-mobile-menu__nav a { color: #F0EDE6; }
.ds-mobile-menu__close { color: #F0EDE6; }
.ds-mobile-menu__footer { color: rgba(240,237,230,0.55); }

/* Pull quote em case study (project-detail) — força cor clara */
[data-theme="dark"] .cs-pull__quote {
  color: #F0EDE6;
}

/* Garantia extra: textos de citação/autor nas testimonials no dark */
[data-theme="dark"] .ds-testimonial__quote,
[data-theme="dark"] .ds-testimonial__name,
[data-theme="dark"] .ds-testimonials .ds-section-title {
  color: #F0EDE6;
}
[data-theme="dark"] .ds-testimonial__role {
  color: rgba(240,237,230,0.6);
}
[data-theme="dark"] .ds-testimonial-dot {
  background: rgba(240,237,230,0.25);
}
[data-theme="dark"] .ds-testimonial-dot:hover {
  background: rgba(240,237,230,0.5);
}

/* Footer dark: tagline + links com mais contraste */
[data-theme="dark"] .ds-footer {
  color: rgba(240,237,230,0.7);
}
[data-theme="dark"] .ds-footer__brand h2,
[data-theme="dark"] .ds-footer h4 {
  color: #F0EDE6;
}
[data-theme="dark"] .ds-footer a {
  color: rgba(240,237,230,0.75);
}
[data-theme="dark"] .ds-footer a:hover {
  color: #F0EDE6;
}

/* Auth media (login) */
[data-theme="dark"] .ds-auth__media-quote p,
[data-theme="dark"] .ds-auth__media-quote span {
  color: #F0EDE6;
}

/* Sidebar dashboard (apenas no site público — painel autenticado já tem seu próprio escopo) */
[data-theme="dark"] .ds-app__sidebar-brand {
  color: #F0EDE6;
}
[data-theme="dark"] .ds-app__sidebar-nav a {
  color: rgba(240,237,230,0.7);
}
[data-theme="dark"] .ds-app__sidebar-nav a:hover,
[data-theme="dark"] .ds-app__sidebar-nav a.is-active {
  color: #F0EDE6;
}

/* Press (Casa Vogue, ArchDaily, etc.) — opacity menor demais no dark */
[data-theme="dark"] .ds-press__logo {
  opacity: 0.92;
  color: #D8D4CB;
}
[data-theme="dark"] .ds-press__logo:hover {
  opacity: 1;
  color: #F0EDE6;
}
[data-theme="dark"] .ds-press__label {
  color: rgba(240,237,230,0.6);
}

/* Footer bottom (copyright + CNPJ + cidade) — mais legível no dark */
[data-theme="dark"] .ds-footer__bottom {
  color: rgba(240,237,230,0.55);
  border-top-color: rgba(240,237,230,0.12);
}

/* Manifesto: no dark fica em --bg-2 (#1C1C1B) com --ink-mute pra autor —
   precisa de mais contraste no nome/autor */
[data-theme="dark"] .ds-manifesto__attr {
  color: rgba(240,237,230,0.7);
}
