/* =========================================================
   Zemploo Site - App Styles (Top nav layout)
   ========================================================= */

* { box-sizing: border-box; }

html, body, #root {
  margin: 0;
  padding: 0;
  height: 100%;
  width: 100%;
}

body {
  background: var(--bg-page);
  color: var(--fg-2);
  font-family: var(--font-body);
  overflow: hidden;
}

/* ---------- Theme: light ---------- */
body.theme-light {
  --bg-page: #EDE9DC;
  --bg-card: #F7F4EA;
  --bg-card-hover: #E6E1D1;
  --fg-1: #14161B;
  --fg-2: #2A2E36;
  --fg-3: #4F5560;
  --fg-4: #8A8F99;
  --hairline: rgba(20, 22, 27, 0.10);
  --hairline-strong: rgba(20, 22, 27, 0.22);
  --border-default: var(--hairline);
  --border-strong: var(--hairline-strong);
  /* Amber em light vira amarelo escuro (legível em cream); textos de destaque ficam pretos */
  --amber-500: #A8841C;    /* decorativo: dots, barras, hover, borders */
  --amber-400: #C5A03C;
  --amber-600: #8B6F1A;
  --amber-100: rgba(168, 132, 28, 0.16);
}
body.theme-light .zemploo-bg { opacity: 0.55; }
body.theme-light .zemploo-bg__vignette {
  background: radial-gradient(120% 90% at 50% 50%, transparent 30%, rgba(237, 233, 220, 0.95) 95%);
}
body.theme-light .zemploo-bg__grain { mix-blend-mode: multiply; opacity: 0.06; }

/* TEXTOS de destaque amber no light → ficam PRETO (statement) */
body.theme-light .hl-amber                              { color: #14161B; }
body.theme-light .svc--amber .svc__head-text .eyebrow   { color: #14161B; }
body.theme-light .why-card__kicker--amber               { color: #14161B; }
body.theme-light .proj__tag--amber                      { color: #14161B; border-color: rgba(20, 22, 27, 0.35); }

/* NÚMEROS GRANDES amber (01/02/03) → ouro com contorno preto = "shiny gold" */
body.theme-light .what-card__num--amber {
  color: #D4A92B;
  -webkit-text-stroke: 1.5px #14161B;
  text-stroke: 1.5px #14161B;
  paint-order: stroke fill;
}

/* ---------- Background canvas ---------- */
.zemploo-bg {
  position: fixed; inset: 0;
  z-index: 0;
  pointer-events: none;
  transition: opacity 600ms var(--ease-out);
}
.zemploo-bg canvas {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  filter: contrast(1.08) brightness(0.96);
}
.zemploo-bg__grain {
  position: absolute; inset: 0;
  background-image: radial-gradient(rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 3px 3px;
  mix-blend-mode: overlay;
  opacity: 0.4;
}
.zemploo-bg__vignette {
  position: absolute; inset: 0;
  background: radial-gradient(140% 100% at 50% 60%, transparent 35%, rgba(14,16,20,0.55) 95%);
}

/* =========================================================
   APP SHELL - top nav + main
   ========================================================= */
.app {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: auto 1fr;
  height: 100vh;
  width: 100vw;
}

/* =========================================================
   TOP NAV
   ========================================================= */
.topnav {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--sp-6);
  /* Traçado vai borda-a-borda; conteúdo se ancora no max-width 1280 do site. */
  padding: 14px max(var(--sp-6), calc((100vw - 1280px) / 2));
  background: rgba(14, 16, 20, 0.18);
  backdrop-filter: blur(14px) saturate(1.15);
  -webkit-backdrop-filter: blur(14px) saturate(1.15);
  border-bottom: 1px solid rgba(255,255,255,0.04);
  z-index: 10;
  transition: background 240ms var(--ease-out), border-color 240ms var(--ease-out), backdrop-filter 240ms var(--ease-out);
}
.topnav--scrolled {
  background: rgba(14, 16, 20, 0.55);
  border-bottom-color: var(--hairline);
}
body.theme-light .topnav {
  background: rgba(255,255,255,0.28);
  border-bottom: 1px solid rgba(20,22,27,0.04);
}
body.theme-light .topnav--scrolled {
  background: rgba(255,255,255,0.78);
  border-bottom-color: rgba(20,22,27,0.08);
}

.topnav__brand {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: 4px;
  margin: -4px;
  border-radius: 12px;
  color: var(--fg-1);
}
.topnav__brand:hover { color: var(--accent-primary); }

.topnav__brand-mark {
  width: 56px; height: 56px;
  display: grid; place-items: center;
  flex-shrink: 0;
}
.topnav__brand-mark img { width: 100%; height: 100%; object-fit: contain; }

.topnav__brand-word {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 28px;
  letter-spacing: -0.02em;
}

.topnav__nav {
  display: flex;
  justify-content: center;
  gap: 4px;
}
.topnav__item {
  position: relative;
  background: transparent;
  border: 0;
  color: var(--fg-2);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  padding: 10px 18px;
  border-radius: 999px;
  transition: all 160ms var(--ease-out);
}
.topnav__item:hover { color: var(--fg-1); background: rgba(255,255,255,0.04); }
body.theme-light .topnav__item:hover { background: rgba(20,22,27,0.05); }
.topnav__item--active { color: var(--fg-1); }
.topnav__item-bar {
  position: absolute;
  left: 50%;
  bottom: 2px;
  transform: translateX(-50%);
  width: 16px;
  height: 2px;
  border-radius: 999px;
  background: var(--accent-primary);
  box-shadow: 0 0 12px var(--accent-primary);
}

.topnav__right {
  display: flex;
  align-items: center;
  gap: 8px;
}

.topnav__theme {
  display: inline-flex;
  padding: 3px;
  gap: 2px;
  border: 1px solid var(--hairline);
  border-radius: 999px;
  background: rgba(14,16,20,0.45);
}
body.theme-light .topnav__theme { background: rgba(244,244,242,0.6); }
.topnav__theme-btn {
  width: 30px; height: 30px;
  background: transparent;
  border: 0;
  color: var(--fg-3);
  border-radius: 50%;
  cursor: pointer;
  display: grid; place-items: center;
  transition: all 160ms var(--ease-out);
}
.topnav__theme-btn:hover { color: var(--fg-1); }
.topnav__theme-btn.is-on {
  background: var(--bg-card);
  color: var(--fg-1);
  box-shadow: 0 1px 0 var(--hairline-strong);
}
.topnav__theme-btn svg { width: 16px; height: 16px; }

.topnav__social {
  width: 36px; height: 36px;
  display: grid; place-items: center;
  border: 1px solid var(--hairline);
  border-radius: 50%;
  color: var(--fg-2);
  text-decoration: none;
  transition: all 160ms var(--ease-out);
}
.topnav__social:hover { color: var(--fg-1); border-color: var(--hairline-strong); }
.topnav__social--wa:hover { color: #25D366; border-color: #25D366; }
.topnav__social--ig:hover {
  color: #E1306C;
  border-color: #E1306C;
}

.topnav__cta { margin-left: 4px; }

@media (max-width: 920px) {
  .topnav { grid-template-columns: auto 1fr auto; padding: 12px var(--sp-4); gap: var(--sp-4); }
  .topnav__nav { gap: 0; }
  .topnav__item { padding: 8px 12px; font-size: 13px; }
  .topnav__cta, .topnav__social { display: none; }
}
@media (max-width: 640px) {
  .topnav__brand-word { display: none; }
  .topnav__item { padding: 8px 10px; font-size: 12.5px; }
}

/* =========================================================
   MAIN
   ========================================================= */
.main {
  overflow-y: auto;
  overflow-x: hidden;
  padding: var(--sp-7) var(--sp-8);
  scroll-behavior: smooth;
}
.main > * {
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
}
/* Footer escapa do padding lateral do .main pra ir borda-a-borda;
   o conteúdo interno (top/cols/bottom) é centralizado em 1280px. */
.main > .footer {
  max-width: none;
  margin-left: calc(-1 * var(--sp-8));
  margin-right: calc(-1 * var(--sp-8));
  padding-left: var(--sp-8);
  padding-right: var(--sp-8);
}
@media (max-width: 1100px) {
  .main > .footer {
    margin-left: calc(-1 * var(--sp-5));
    margin-right: calc(-1 * var(--sp-5));
    padding-left: var(--sp-5);
    padding-right: var(--sp-5);
  }
}
.main::-webkit-scrollbar { width: 10px; }
.main::-webkit-scrollbar-track { background: transparent; }
.main::-webkit-scrollbar-thumb {
  background: var(--hairline-strong);
  border-radius: 999px;
}

@media (max-width: 1100px) {
  .main { padding: var(--sp-5) var(--sp-5); }
}

/* Page header (services / carta / faq / inner home sections) */
.page__header,
.section-head {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  max-width: 760px;
  margin-bottom: var(--sp-6);
}
.page__header h2,
.section-head h2 {
  font-size: var(--text-display-m);
  text-wrap: balance;
  color: var(--fg-1);
}
.page__lead {
  color: var(--fg-2);
  font-size: var(--text-body-l);
  max-width: 640px;
  line-height: var(--lh-loose);
}

.section-head--row {
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-end;
  max-width: 100%;
  gap: var(--sp-6);
}
.section-head--row > div { max-width: 760px; }
.section-head__lede {
  color: var(--fg-2);
  font-size: 14px;
  line-height: 1.55;
  max-width: 320px;
}
@media (max-width: 900px) {
  .section-head--row { flex-direction: column; align-items: flex-start; }
}

.eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--fg-3);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.eyebrow svg { width: 14px; height: 14px; }

/* Eyebrow mais forte usado nas seções de Serviços (01/02/03 · ...) */
.svc__head-text .eyebrow {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--fg-1);
  letter-spacing: 0.16em;
}
.svc--magenta .svc__head-text .eyebrow { color: var(--magenta-500); }
.svc--blue    .svc__head-text .eyebrow { color: var(--blue-500); }
.svc--amber   .svc__head-text .eyebrow { color: var(--amber-500); }

/* Highlights */
.hl-magenta { color: var(--magenta-500); }
.hl-blue    { color: var(--blue-500); }
.hl-amber   { color: var(--amber-500); }

/* =========================================================
   HOME - long scrolling page
   ========================================================= */
.page--home {
  display: flex;
  flex-direction: column;
  gap: var(--sp-9);
  max-width: 1280px;
  margin: 0 auto;
  padding-bottom: var(--sp-8);
}

/* HERO */
.hero {
  position: relative;
  display: flex; flex-direction: column;
  gap: var(--sp-5);
  padding-top: var(--sp-6);
  min-height: calc(100vh - 96px - var(--sp-7));
  justify-content: center;
  max-width: 900px;
}
.hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--fg-2);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  padding: 8px 14px;
  border: 1px solid var(--hairline-strong);
  border-radius: 999px;
  background: rgba(14,16,20,0.4);
  width: fit-content;
}
body.theme-light .hero__eyebrow { background: rgba(255,255,255,0.7); }
.dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
.dot--magenta {
  background: var(--accent-primary);
  box-shadow: 0 0 12px var(--accent-primary);
  animation: pulse 2.2s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.45; transform: scale(0.85); }
}

.hero__title {
  font-family: var(--font-display);
  font-size: clamp(48px, 6.2vw, 96px);
  font-weight: 700;
  line-height: 0.98;
  letter-spacing: -0.03em;
  color: var(--fg-1);
  margin: 0;
}
.hero__title .line {
  display: block;
  opacity: 0;
  transform: translateY(20px);
  animation: heroIn 600ms var(--ease-out) forwards;
}
.hero__title .line:nth-child(1) { animation-delay: 80ms; }
.hero__title .line:nth-child(2) { animation-delay: 160ms; }
.hero__title .line:nth-child(3) { animation-delay: 240ms; }
.hero__title .line:nth-child(4) { animation-delay: 320ms; }
@keyframes heroIn {
  to { opacity: 1; transform: translateY(0); }
}
@media print, (prefers-reduced-motion: reduce) {
  .hero__title .line { opacity: 1; transform: none; animation: none; }
}

.hero__sub {
  max-width: 600px;
  font-size: var(--text-body-l);
  color: var(--fg-2);
  line-height: var(--lh-loose);
}

.hero__cta {
  display: flex;
  gap: var(--sp-3);
  flex-wrap: wrap;
  margin-top: var(--sp-2);
}

.hero__meta {
  display: flex;
  align-items: stretch;
  justify-content: center;
  gap: var(--sp-5);
  margin-top: var(--sp-7);
  padding: var(--sp-5) var(--sp-5);
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
}
.hero__meta-item {
  display: flex; align-items: center; gap: var(--sp-3);
  min-width: 200px;
  flex: 1;
  justify-content: center;
}
.hero__meta-num {
  font-family: var(--font-display);
  font-size: 48px;
  font-weight: 700;
  letter-spacing: -0.04em;
  color: var(--accent-tertiary);
  line-height: 1;
}
.hero__meta-label {
  font-family: var(--font-mono);
  font-size: 13px;
  text-transform: uppercase;
  color: var(--fg-1);
  letter-spacing: 0.08em;
  line-height: 1.45;
  font-weight: 500;
}
.hero__meta-divider {
  width: 1px;
  background: var(--hairline);
  align-self: stretch;
}
@media (max-width: 720px) {
  .hero__meta { flex-wrap: wrap; gap: var(--sp-3); padding: var(--sp-4); }
  .hero__meta-divider { display: none; }
  .hero__meta-item { min-width: 100%; justify-content: flex-start; }
  .hero__meta-num { font-size: 40px; }
}

.hero__scroll-wrap {
  margin-top: var(--sp-5);
  display: flex;
  justify-content: flex-start;
}
.hero__scroll {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: transparent;
  border: 1px solid var(--hairline);
  border-radius: 999px;
  color: var(--fg-3);
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  cursor: pointer;
}
.hero__scroll:hover { color: var(--fg-1); border-color: var(--hairline-strong); }
.hero__scroll svg {
  width: 14px; height: 14px;
  animation: scrollBob 2.4s ease-in-out infinite;
}
@keyframes scrollBob {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(3px); }
}

/* =========================================================
   HOME - O QUE FAZEMOS - number-led editorial cards
   ========================================================= */
.what-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
}
@media (max-width: 1000px) { .what-grid { grid-template-columns: 1fr; } }

.what-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: var(--sp-6) var(--sp-5);
  background: var(--bg-card);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-card);
  transition: all 240ms var(--ease-out);
}
body.theme-light .what-card { background: rgba(255,255,255,0.82); backdrop-filter: blur(6px); }
.what-card:hover { transform: translateY(-3px); border-color: var(--hairline-strong); }

.what-card__top {
  display: flex;
  align-items: center;
  gap: 14px;
}
.what-card__num {
  font-family: var(--font-display);
  font-size: 48px;
  font-weight: 700;
  letter-spacing: -0.05em;
  line-height: 1;
  color: var(--fg-1);
}
.what-card__num--magenta { color: var(--magenta-500); }
.what-card__num--blue    { color: var(--blue-500); }
.what-card__num--amber   { color: var(--amber-500); }

.what-card__rule {
  flex: 1;
  height: 1px;
  background: var(--hairline-strong);
  display: block;
}
.what-card__rule--magenta { background: linear-gradient(90deg, var(--magenta-500), transparent); }
.what-card__rule--blue    { background: linear-gradient(90deg, var(--blue-500), transparent); }
.what-card__rule--amber   { background: linear-gradient(90deg, var(--amber-500), transparent); }

.what-card h3 {
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--fg-1);
  line-height: 1.15;
  max-width: 16ch;
}
.what-card > p {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--fg-2);
}

.what-card ul {
  list-style: none;
  margin: auto 0 0; padding: var(--sp-3) 0 0;
  border-top: 1px solid var(--hairline);
  display: flex; flex-direction: column; gap: 6px;
  font-size: 13px;
}
.what-card ul li {
  display: flex; align-items: center; gap: 10px;
  color: var(--fg-1);
}
.what-card__dot {
  width: 5px; height: 5px; border-radius: 50%;
  flex-shrink: 0;
}
.what-card__dot--magenta { background: var(--magenta-500); }
.what-card__dot--blue    { background: var(--blue-500); }
.what-card__dot--amber   { background: var(--amber-500); }

.what-card__more {
  background: transparent;
  border: 0;
  padding: 0;
  color: var(--fg-1);
  font-size: 13px;
  font-weight: 500;
  display: inline-flex; align-items: center; gap: 6px;
  cursor: pointer;
  margin-top: 4px;
  width: fit-content;
}
.what-card__more svg { width: 14px; height: 14px; transition: transform 200ms var(--ease-out); }
.what-card__more:hover svg { transform: translateX(3px); }

/* =========================================================
   HOME - PARA QUEM (editorial typographic statement)
   ========================================================= */
.home-focus {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  padding: var(--sp-7) 0;
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
}
.home-focus__statement {
  font-family: var(--font-display);
  font-size: clamp(28px, 3.6vw, 52px);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.1;
  color: var(--fg-1);
  text-wrap: balance;
  max-width: 22ch;
}
.home-focus__lead { color: var(--fg-1); }
.home-focus__sub {
  font-size: 15px;
  color: var(--fg-2);
  line-height: 1.65;
  max-width: 60ch;
}

/* =========================================================
   HOME - MISSÃO & VISÃO
   ========================================================= */
.mission-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-4);
}
@media (max-width: 900px) { .mission-grid { grid-template-columns: 1fr; } }

.mission-card {
  position: relative;
  padding: var(--sp-6);
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  min-height: 280px;
  overflow: hidden;
}
.mission-card--mission {
  background:
    radial-gradient(800px 380px at 100% 0%, rgba(233,30,120,0.25), transparent 60%),
    var(--bg-card);
}
.mission-card--vision {
  background:
    radial-gradient(800px 380px at 0% 100%, rgba(45,125,255,0.25), transparent 60%),
    var(--bg-card);
}
body.theme-light .mission-card--mission {
  background:
    radial-gradient(800px 380px at 100% 0%, rgba(233,30,120,0.18), transparent 60%),
    rgba(255,255,255,0.85);
}
body.theme-light .mission-card--vision {
  background:
    radial-gradient(800px 380px at 0% 100%, rgba(45,125,255,0.18), transparent 60%),
    rgba(255,255,255,0.85);
}

.mission-card__tag {
  align-self: flex-start;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--fg-1);
  padding: 6px 12px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--hairline-strong);
  border-radius: 999px;
}
.mission-card--mission .mission-card__tag {
  color: var(--magenta-500);
  border-color: rgba(233,30,120,0.4);
  background: rgba(233,30,120,0.10);
}
.mission-card--vision .mission-card__tag {
  color: var(--blue-500);
  border-color: rgba(45,125,255,0.4);
  background: rgba(45,125,255,0.10);
}

.mission-card p {
  font-family: var(--font-display);
  font-size: clamp(18px, 1.6vw, 22px);
  font-weight: 400;
  letter-spacing: -0.01em;
  line-height: 1.4;
  color: var(--fg-1);
  text-wrap: pretty;
}
.mission-card p strong {
  font-weight: 600;
}
.mission-card--mission p strong { color: var(--magenta-500); }
.mission-card--vision p strong  { color: var(--blue-500); }

/* =========================================================
   HOME - COMO ATUAMOS (4 steps, numerals only)
   ========================================================= */
.how-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--sp-3);
}
@media (max-width: 1200px) { .how-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 800px)  { .how-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px)  { .how-grid { grid-template-columns: 1fr; } }

.how-step {
  position: relative;
  display: flex; flex-direction: column;
  gap: 12px;
  padding: var(--sp-5);
  background: var(--bg-card);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-card);
  transition: all 240ms var(--ease-out);
}
body.theme-light .how-step { background: rgba(255,255,255,0.82); }
.how-step:hover { transform: translateY(-2px); border-color: var(--hairline-strong); }

.how-step__num {
  font-family: var(--font-display);
  font-size: 56px;
  font-weight: 700;
  letter-spacing: -0.05em;
  color: var(--accent-tertiary);
  line-height: 0.9;
  margin-bottom: 4px;
}

.how-step h4 {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--fg-1);
}
.how-step p {
  font-size: 13.5px;
  color: var(--fg-2);
  line-height: 1.55;
}

/* =========================================================
   HOME - POR QUE ZEMPLOO (numbered kicker, no icons)
   ========================================================= */
.why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
}
@media (max-width: 900px) { .why-grid { grid-template-columns: 1fr; } }

.why-card {
  padding: var(--sp-5);
  background: var(--bg-card);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-card);
  display: flex; flex-direction: column;
  gap: 10px;
  transition: all 240ms var(--ease-out);
}
body.theme-light .why-card { background: rgba(255,255,255,0.82); }
.why-card:hover { transform: translateY(-2px); border-color: var(--hairline-strong); }

.why-card__kicker {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-3);
  display: inline-flex; align-items: center; gap: 8px;
}
.why-card__kicker::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
  display: inline-block;
}
.why-card__kicker--magenta { color: var(--magenta-500); }
.why-card__kicker--blue    { color: var(--blue-500); }
.why-card__kicker--amber   { color: var(--amber-500); }

.why-card h4 {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--fg-1);
}
.why-card p {
  font-size: 13px;
  color: var(--fg-2);
  line-height: 1.55;
}

/* =========================================================
   HOME - OUTRO CTA
   ========================================================= */
.home-outro {
  position: relative;
  text-align: center;
  padding: var(--sp-9) var(--sp-6);
  border-radius: var(--radius-lg);
  border: 1px solid var(--hairline-strong);
  background:
    radial-gradient(800px 400px at 30% 30%, rgba(233,30,120,0.20), transparent 60%),
    radial-gradient(800px 400px at 70% 80%, rgba(45,125,255,0.20), transparent 60%),
    rgba(20,22,27,0.6);
  overflow: hidden;
  display: flex; flex-direction: column; align-items: center;
  gap: var(--sp-4);
}
body.theme-light .home-outro {
  background:
    radial-gradient(800px 400px at 30% 30%, rgba(233,30,120,0.18), transparent 60%),
    radial-gradient(800px 400px at 70% 80%, rgba(45,125,255,0.16), transparent 60%),
    rgba(255,255,255,0.75);
}
.home-outro h2 {
  max-width: 22ch;
  font-size: clamp(28px, 3vw, 44px);
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--fg-1);
  text-wrap: balance;
  margin: 0;
  line-height: 1.1;
}
.home-outro p {
  max-width: 56ch;
  color: var(--fg-2);
  font-size: 15px;
  line-height: 1.6;
}
.home-outro__cta {
  display: flex; gap: var(--sp-3); flex-wrap: wrap; justify-content: center;
  margin-top: var(--sp-2);
}

/* =========================================================
   SERVICES
   ========================================================= */
.page--services { max-width: 1280px; margin: 0 auto; }

.services-stack {
  display: flex; flex-direction: column;
  gap: var(--sp-8);
}

.svc {
  position: relative;
  padding-top: var(--sp-6);
  border-top: 1px solid var(--hairline);
}
.svc:first-child { border-top: 0; padding-top: 0; }

.svc__head {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: var(--sp-6);
  align-items: start;
  margin-bottom: var(--sp-4);
}
@media (max-width: 1000px) {
  .svc__head { grid-template-columns: 1fr; gap: var(--sp-3); margin-bottom: var(--sp-3); }
}

.svc__head-text h3 {
  font-family: var(--font-display);
  font-size: clamp(28px, 2.8vw, 40px);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.1;
  color: var(--fg-1);
  margin: 8px 0 12px;
  text-wrap: balance;
  max-width: 22ch;
}
.svc__head-text p {
  color: var(--fg-2);
  font-size: 15px;
  line-height: 1.65;
  max-width: 60ch;
}
.svc__head-text p + p {
  margin-top: 14px;
}

.svc__bullets {
  list-style: none;
  margin: 0;
  padding: var(--sp-4);
  background: var(--bg-card);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-card);
  display: flex; flex-direction: column; gap: 8px;
  font-size: 13px;
  color: var(--fg-1);
}
body.theme-light .svc__bullets { background: rgba(255,255,255,0.75); }
.svc__bullets li { display: flex; align-items: center; gap: 10px; }
@media (max-width: 1000px) {
  .svc__bullets {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px 16px;
    padding: var(--sp-3) var(--sp-4);
  }
}
@media (max-width: 540px) {
  .svc__bullets { grid-template-columns: 1fr; }
}
.svc__bullet-dot {
  width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0;
}
.svc__bullet-dot--magenta { background: var(--magenta-500); }
.svc__bullet-dot--blue    { background: var(--blue-500); }
.svc__bullet-dot--amber   { background: var(--amber-500); }

/* Carousel */
.carousel {
  position: relative;
  margin: 0 calc(var(--sp-8) * -1);
  padding: 0 var(--sp-8);
}
@media (max-width: 1100px) {
  .carousel { margin: 0 calc(var(--sp-5) * -1); padding: 0 var(--sp-5); }
}
.carousel__track {
  display: flex;
  gap: var(--sp-4);
  overflow-x: auto;
  padding-bottom: var(--sp-3);
  scrollbar-width: none;
  scroll-behavior: auto;
}
.carousel__track::-webkit-scrollbar { display: none; }

.proj {
  flex: 0 0 360px;
  display: flex; flex-direction: column;
  border-radius: var(--radius-card);
  background: var(--bg-card);
  border: 1px solid var(--hairline);
  overflow: hidden;
  transition: all 240ms var(--ease-out);
}
body.theme-light .proj { background: rgba(255,255,255,0.85); }
.proj:hover { border-color: var(--hairline-strong); transform: translateY(-2px); }
.proj--magenta:hover { border-color: rgba(233,30,120,0.4); }
.proj--blue:hover    { border-color: rgba(45,125,255,0.4); }
.proj--amber:hover   { border-color: rgba(242,193,78,0.4); }

.proj__cover {
  position: relative;
  height: 280px;
  overflow: hidden;
  display: grid; place-items: center;
}
.proj__cover--img {
  background-size: 100% auto;
  background-position: center top;
  background-repeat: no-repeat;
}
.proj__cover-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.06) 1px, transparent 1px);
  background-size: 28px 28px;
  mix-blend-mode: overlay;
}
.proj__cover-mark {
  font-family: var(--font-display);
  font-size: 48px;
  font-weight: 700;
  color: rgba(255,255,255,0.92);
  letter-spacing: -0.02em;
  text-shadow: 0 4px 24px rgba(0,0,0,0.35);
}

.proj__body {
  padding: var(--sp-4);
  display: flex; flex-direction: column;
  gap: 8px;
  flex: 1;
}
.proj__tag {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-3);
  width: fit-content;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid var(--hairline-strong);
}
.proj__tag--magenta { color: var(--magenta-500); border-color: rgba(233,30,120,0.35); }
.proj__tag--blue    { color: var(--blue-500);    border-color: rgba(45,125,255,0.35); }
.proj__tag--amber   { color: var(--amber-500);   border-color: rgba(242,193,78,0.4); }

.proj__body h4 {
  font-family: var(--font-display);
  font-size: 19px;
  color: var(--fg-1);
  font-weight: 600;
  letter-spacing: -0.01em;
}
.proj__body p {
  font-size: 13px;
  color: var(--fg-2);
  line-height: 1.45;
  flex: 1;
}
.proj__more {
  margin-top: 8px;
  background: transparent;
  border: 0;
  color: var(--fg-1);
  font-size: 13px;
  font-weight: 500;
  display: inline-flex; align-items: center; gap: 4px;
  padding: 0;
  cursor: pointer;
  width: fit-content;
  border-bottom: 1px solid var(--hairline-strong);
  padding-bottom: 2px;
  transition: all 160ms var(--ease-out);
}
.proj__more:hover { border-color: var(--accent-primary); }
.proj__more svg { width: 14px; height: 14px; }

.proj--ghost {
  background: transparent;
  border-style: dashed;
  border-color: var(--hairline-strong);
}
.proj--ghost .proj__ghost-body {
  height: 100%;
  display: flex; flex-direction: column; justify-content: center;
  gap: 12px; padding: var(--sp-5);
}
.proj--ghost h4 {
  font-family: var(--font-display);
  font-size: 22px;
  color: var(--fg-1);
  font-weight: 600;
  letter-spacing: -0.02em;
}

.carousel__controls {
  position: absolute;
  top: -56px; right: var(--sp-8);
  display: flex; gap: 6px;
}
@media (max-width: 1100px) { .carousel__controls { right: var(--sp-5); } }
.carousel__controls button {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--bg-card);
  border: 1px solid var(--hairline-strong);
  color: var(--fg-1);
  cursor: pointer;
  display: grid; place-items: center;
  transition: all 160ms var(--ease-out);
}
.carousel__controls button:hover {
  background: var(--accent-primary);
  border-color: var(--accent-primary);
  color: #fff;
}

/* =========================================================
   CARTA
   ========================================================= */
.page--carta { max-width: 1280px; margin: 0 auto; }

.carta-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--sp-7);
  align-items: start;
}
@media (max-width: 1000px) { .carta-grid { grid-template-columns: 1fr; } }

.carta-preview {
  display: flex; flex-direction: column;
  gap: var(--sp-3);
}
.carta-preview__frame {
  aspect-ratio: 1 / 1.414;
  background: #0E1014;
  border-radius: var(--radius-card);
  border: 1px solid var(--hairline-strong);
  padding: 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 30px 60px -30px rgba(0,0,0,0.6);
}
.carta-preview__page {
  position: relative;
  height: 100%;
  display: flex; flex-direction: column;
}
.carta-preview__brand {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: -0.02em;
  color: #F4F4F2;
}
.carta-preview__num {
  position: absolute;
  bottom: 0; right: 0;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--mist);
  letter-spacing: 0.1em;
}
.carta-preview__head {
  margin-top: auto;
  display: flex; flex-direction: column; gap: 12px;
  z-index: 2;
}
.carta-preview__head h3 {
  font-family: var(--font-display);
  font-size: clamp(20px, 2vw, 26px);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.1;
  color: #F4F4F2;
  margin: 0;
}
.carta-preview__head p {
  font-size: 12.5px;
  color: var(--mist);
  line-height: 1.5;
  max-width: 36ch;
}
.carta-preview__head .eyebrow {
  font-size: 10px;
  color: var(--mist);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 500;
}
.carta-preview__halo {
  position: absolute;
  inset: -40%;
  background: radial-gradient(circle at 80% 20%, rgba(233,30,120,0.4), transparent 50%),
              radial-gradient(circle at 10% 100%, rgba(45,125,255,0.32), transparent 55%);
  z-index: 0;
}
.carta-preview__caption {
  text-align: center;
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--fg-3);
}

.carta-summary { display: flex; flex-direction: column; gap: var(--sp-5); }

.carta-toc {
  list-style: none;
  padding: var(--sp-4);
  margin: 0;
  background: var(--bg-card);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-card);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px 24px;
}
body.theme-light .carta-toc { background: rgba(255,255,255,0.75); }
.carta-toc li {
  font-family: var(--font-body);
  font-size: 13.5px;
  color: var(--fg-1);
  padding: 10px 0;
  border-bottom: 1px solid var(--hairline);
  display: flex; gap: 12px;
}
.carta-toc li:nth-last-child(-n+2) { border-bottom: 0; }
.carta-toc li span {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--accent-tertiary);
  width: 24px;
}

.carta-actions {
  display: flex; gap: var(--sp-3); flex-wrap: wrap;
}

.carta-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-3);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--hairline);
}
.carta-stats > div {
  display: flex; flex-direction: column; gap: 4px;
}
.carta-stats strong {
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--fg-1);
}
.carta-stats > div:nth-child(1) strong { color: var(--magenta-500); }
.carta-stats > div:nth-child(2) strong { color: var(--blue-500); }
.carta-stats > div:nth-child(3) strong { color: var(--amber-500); }
.carta-stats span {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--fg-3);
}

/* =========================================================
   FAQ - high contrast cards, readable in dark theme
   ========================================================= */
.page--faq { max-width: 1100px; margin: 0 auto; }

.faq-list {
  display: flex; flex-direction: column;
  gap: 10px;
  margin-bottom: var(--sp-7);
}
.faq-list details {
  background: rgba(255,255,255,0.96);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius-card);
  overflow: hidden;
  transition: all 240ms var(--ease-out);
  color: #14161B;
}
body.theme-light .faq-list details {
  background: #FFFFFF;
  border-color: rgba(20,22,27,0.10);
}
.faq-list details:hover {
  border-color: rgba(233,30,120,0.32);
}
.faq-list details[open] {
  border-color: rgba(233,30,120,0.45);
  box-shadow: 0 12px 36px -16px rgba(233,30,120,0.35);
}

.faq-list summary {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  padding: 20px var(--sp-5);
  cursor: pointer;
  list-style: none;
  user-select: none;
}
.faq-list summary::-webkit-details-marker { display: none; }
.faq-list__num {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--magenta-500);
  letter-spacing: 0.08em;
  width: 32px;
  flex-shrink: 0;
}
.faq-list__q {
  flex: 1;
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 600;
  color: #14161B;
  letter-spacing: -0.01em;
  line-height: 1.3;
}
.faq-list__chev {
  width: 32px; height: 32px;
  display: grid; place-items: center;
  border-radius: 50%;
  border: 1px solid rgba(20,22,27,0.12);
  background: rgba(20,22,27,0.04);
  color: #14161B;
  flex-shrink: 0;
  transition: all 240ms var(--ease-out);
}
.faq-list__chev.is-open {
  transform: rotate(180deg);
  background: var(--magenta-500);
  color: #fff;
  border-color: var(--magenta-500);
}
.faq-list__a {
  padding: 0 var(--sp-5) 22px calc(var(--sp-5) + 32px + var(--sp-4));
  font-size: 15px;
  line-height: 1.65;
  color: #3D424C;
  max-width: 720px;
}

.faq-cta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-5);
  padding: var(--sp-6);
  background: linear-gradient(120deg, rgba(233,30,120,0.18), rgba(45,125,255,0.12) 60%, transparent);
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-lg);
}
.faq-cta h3 {
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--fg-1);
  margin-top: 6px;
}
.faq-cta__buttons {
  display: flex; gap: var(--sp-3); flex-wrap: wrap;
}

@media (max-width: 720px) {
  .faq-cta { flex-direction: column; align-items: flex-start; }
}

/* =========================================================
   BUTTONS (shared)
   ========================================================= */
.btn {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 14px;
  padding: 12px 20px;
  border-radius: var(--radius-pill);
  border: 1px solid transparent;
  cursor: pointer;
  transition: all 200ms var(--ease-out);
  letter-spacing: 0;
  text-decoration: none;
}
.btn svg { width: 16px; height: 16px; }
.btn--primary {
  background: var(--accent-primary);
  color: #fff;
  box-shadow: var(--glow-magenta);
}
.btn--primary:hover {
  filter: brightness(1.08);
  transform: translateY(-1px);
}
.btn--secondary {
  background: transparent;
  border-color: var(--hairline-strong);
  color: var(--fg-1);
}
.btn--secondary:hover {
  background: rgba(255,255,255,0.04);
  border-color: var(--fg-1);
}
body.theme-light .btn--secondary:hover { background: rgba(20,22,27,0.04); }
.btn:active { transform: scale(0.98); }
.btn--sm { padding: 9px 14px; font-size: 13px; }
.btn--sm svg { width: 14px; height: 14px; }

/* =========================================================
   FOOTER
   ========================================================= */
.footer {
  margin-top: var(--sp-9);
  padding-top: var(--sp-7);
  border-top: 1px solid var(--hairline-strong);
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
}

.footer__top {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: var(--sp-6);
  flex-wrap: wrap;
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}
.footer__bottom {
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}
.footer__brand {
  display: inline-flex;
  align-items: center;
  gap: 14px;
}
.footer__brand-mark {
  width: 60px; height: 60px;
  display: grid; place-items: center;
  flex-shrink: 0;
}
.footer__brand-mark img { width: 100%; height: 100%; object-fit: contain; }
.footer__brand-word {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 32px;
  letter-spacing: -0.02em;
  color: var(--fg-1);
}

.footer__tagline {
  font-family: var(--font-display);
  font-size: 16px;
  color: var(--fg-2);
  line-height: 1.4;
  text-align: right;
  max-width: 360px;
}
@media (max-width: 720px) {
  .footer__tagline { text-align: left; }
}

.footer__cols {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--sp-6) var(--sp-7);
  padding: var(--sp-5) 0;
  border-bottom: 1px solid var(--hairline);
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}
.footer__col { min-width: 0; }
@media (max-width: 720px) {
  .footer__cols { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
  .footer__cols { grid-template-columns: 1fr; gap: var(--sp-5); }
}

.footer__col {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.footer__col .eyebrow { margin-bottom: 2px; }
.footer__col a {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--fg-1);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  border-bottom: 1px solid transparent;
  transition: border-color 160ms var(--ease-out);
}
.footer__col a:hover { border-bottom-color: currentColor; }
.footer__col a svg { width: 16px; height: 16px; opacity: 0.72; }
.footer__col p {
  font-size: 14px;
  color: var(--fg-1);
  line-height: 1.55;
}
.footer__col-sub {
  font-size: 13px !important;
  color: var(--fg-3) !important;
}

.footer__bottom {
  display: flex;
  justify-content: space-between;
  gap: var(--sp-3);
  flex-wrap: wrap;
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--fg-3);
  letter-spacing: 0.04em;
  padding-bottom: var(--sp-3);
}

/* =========================================================
   FORMULÁRIO (página oculta /#formulario)
   ========================================================= */
.page--form { max-width: 760px; }

.form-grid {
  display: flex;
  flex-direction: column;
  gap: var(--sp-7);
  margin-top: var(--sp-7);
}

.form-section { display: flex; flex-direction: column; gap: var(--sp-4); }
.form-section__head {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--hairline);
}
.form-section__rule {
  display: inline-block;
  width: 24px; height: 1.5px;
  background: var(--accent-primary);
  border-radius: 2px;
}
.form-section__head .eyebrow { margin: 0; }
.form-section__body {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}

.field { display: flex; flex-direction: column; gap: 7px; }
.field__label {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--fg-2);
  font-weight: 500;
}
.field__input {
  font-family: var(--font-body);
  font-size: 14.5px;
  color: var(--fg-1);
  /* Fundo amarelo bem clarinho - derivado do --amber-500 da logo */
  background: rgba(242, 193, 78, 0.08);
  border: 1px solid var(--hairline-strong);
  border-radius: 10px;
  padding: 11px 13px;
  outline: 0;
  width: 100%;
  transition: border-color 160ms var(--ease-out), background 160ms var(--ease-out);
}
body.theme-light .field__input {
  background: rgba(242, 193, 78, 0.32);
  border-color: rgba(212, 158, 46, 0.45);
}
.field__input:focus {
  border-color: var(--accent-primary);
  background: rgba(242, 193, 78, 0.14);
}
body.theme-light .field__input:focus {
  background: rgba(242, 193, 78, 0.48);
  border-color: var(--accent-primary);
}
.field__input::placeholder { color: var(--fg-4); }
.field__input:disabled { opacity: 0.45; cursor: not-allowed; }

.field__input--area {
  resize: vertical;
  min-height: 120px;
  line-height: 1.55;
  font-family: var(--font-body);
}

/* Linha com 2 campos lado a lado (vira 1 col no mobile) */
.field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-4);
}
@media (max-width: 640px) {
  .field-row { grid-template-columns: 1fr; }
}

/* Telefone(s) com botão de adicionar */
.field__multi { display: flex; flex-direction: column; gap: 8px; }
.field__multi-row { display: flex; gap: 8px; align-items: stretch; }
.field__multi-row .field__input { flex: 1; }
.field__multi-btn {
  width: 40px;
  border: 1px solid var(--hairline-strong);
  border-radius: 10px;
  background: transparent;
  color: var(--fg-3);
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
  transition: all 160ms var(--ease-out);
}
.field__multi-btn:hover {
  color: var(--fg-1);
  border-color: var(--fg-2);
}
.field__multi-btn--remove:hover { color: #ff5d6f; border-color: #ff5d6f; }
.field__multi-add {
  align-self: flex-start;
  border: 1px dashed var(--hairline-strong);
  background: transparent;
  color: var(--fg-3);
  font-family: var(--font-body);
  font-size: 13px;
  padding: 8px 14px;
  border-radius: 999px;
  cursor: pointer;
  transition: all 160ms var(--ease-out);
}
.field__multi-add:hover {
  color: var(--fg-1);
  border-color: var(--accent-primary);
  border-style: solid;
}

/* Checkbox plain */
.field__check {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 13.5px;
  color: var(--fg-2);
  cursor: pointer;
  user-select: none;
  margin-top: -2px;
}
.field__check input {
  width: 16px; height: 16px;
  accent-color: var(--accent-primary);
  cursor: pointer;
}
.field__check:hover { color: var(--fg-1); }

.form-actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding-top: var(--sp-5);
  border-top: 1px solid var(--hairline);
  text-align: center;
}
.form-actions .btn { padding-left: var(--sp-6); padding-right: var(--sp-6); }
.form-actions__hint {
  font-size: 12.5px;
  color: var(--fg-3);
  max-width: 44ch;
  line-height: 1.5;
}
