/*
 * CENTRYA — Sistema de identidade visual
 *
 * Direção: premium consulting tech. Canvas creme quente, ink quase-preto,
 * cobalt elétrico como cor de marca, coral quente como acento.
 * Tipografia: Sora (display + UI) + JetBrains Mono (acentos técnicos).
 * Voz: direta, focada em resultado, sem ruído.
 */

/* ============ TOKENS ============ */
:root{
  /* Surfaces */
  --bone:        #F2EDE4;      /* canvas principal — creme quente */
  --paper:       #FBF8F2;      /* cards / superfícies elevadas */
  --paper-2:     #EAE3D6;      /* superfície sutilmente recuada */
  --ink:         #0E1014;      /* texto principal — quase-preto frio */
  --ink-2:       #3D404A;      /* texto secundário */
  --ink-3:       #7A7C84;      /* meta / placeholder */
  --line:        rgba(14,16,20,.10);
  --line-soft:   rgba(14,16,20,.06);

  /* Brand */
  --brand:       #1E3FE0;      /* cobalt elétrico */
  --brand-deep:  #0F2599;      /* hover / pressionado */
  --brand-soft:  #DDE3FA;      /* halo / fundo de chip */

  /* Accent (usar com parcimônia) */
  --accent:      #FF6B4A;      /* coral quente — só para destaques pontuais */
  --accent-soft: #FFE3DA;

  /* Dark slab (footer / seções de contraste) */
  --dark:        #0E1014;
  --dark-2:      #15171C;
  --dark-ink:    #ECEAE3;
  --dark-ink-2:  #A3A4AA;
  --dark-line:   rgba(236,234,227,.12);

  /* Status */
  --ok:          #15803D;
  --warn:        #B91C1C;

  /* Type */
  --display: "Sora", ui-sans-serif, system-ui, sans-serif;
  --sans:    "Sora", ui-sans-serif, system-ui, sans-serif;
  --mono:    "JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;

  /* Layout */
  --maxw:    1280px;
  --gutter:  clamp(20px, 4vw, 56px);
  --radius:  14px;
  --radius-sm: 8px;

  /* Shadow / elevation */
  --shadow-1: 0 1px 0 rgba(14,16,20,.04), 0 2px 6px rgba(14,16,20,.04);
  --shadow-2: 0 10px 30px -12px rgba(14,16,20,.18), 0 2px 8px rgba(14,16,20,.06);
  --shadow-brand: 0 12px 30px -10px rgba(30,63,224,.45);
}

/* ============ RESET / BASE ============ */
*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
html{ scroll-behavior:smooth; }
noscript{ display:none; }
body{
  background:var(--bone);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.55;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; }
::selection{ background:var(--brand); color:#fff; }

h1,h2,h3,h4,h5,h6{ margin:0; font-family:var(--display); font-weight:600; letter-spacing:-.02em; line-height:1.05; }
p{ margin:0 0 1em; }

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--mono);
  font-size:12px;
  font-weight:500;
  letter-spacing:.04em;
  color:var(--brand);
  text-transform:uppercase;
}
.eyebrow::before{
  content:""; width:6px; height:6px; background:var(--brand); border-radius:50%;
}
.eyebrow.is-light{ color:var(--dark-ink-2); }
.eyebrow.is-light::before{ background:var(--accent); }

.mono{ font-family:var(--mono); }

/* ============ LAYOUT ============ */
.shell{
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 var(--gutter);
}
.section{
  padding:clamp(72px, 11vh, 128px) 0;
  position:relative;
}
.section.is-tight{ padding:clamp(56px, 9vh, 96px) 0; }
.section + .section{ border-top:1px solid var(--line); }
.section-head{
  display:grid;
  grid-template-columns:1fr;
  gap:24px;
  margin-bottom:56px;
}
@media (min-width: 900px){
  .section-head{ grid-template-columns: 1fr 1fr; gap:48px; align-items:end; }
}
.section-head h2{
  font-size:clamp(36px, 4.6vw, 56px);
  max-width:18ch;
}
.section-head .lede{
  color:var(--ink-2);
  font-size:18px;
  max-width:44ch;
  line-height:1.55;
  margin:0;
}

/* ============ LOGO ============ */
.logo{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--display);
  font-weight:600;
  font-size:21px;
  letter-spacing:-.025em;
  color:var(--ink);
  line-height:1;
}
.logo-mark{
  width:26px; height:26px;
  flex:0 0 auto;
  color:var(--brand);
}
.logo-mark circle{ vector-effect:non-scaling-stroke; }
.logo:hover .logo-mark{ animation: spin 1.4s cubic-bezier(.4,0,.2,1); }
@keyframes spin{ to{ transform: rotate(360deg); } }
.logo .word{ color:var(--ink); }
.logo.is-light .word{ color:var(--dark-ink); }

/* ============ NAV ============ */
.nav{
  position:fixed;
  top:0; left:0; right:0;
  z-index:50;
  padding:16px var(--gutter);
  display:flex;
  align-items:center;
  justify-content:space-between;
  transition: background .3s ease, backdrop-filter .3s ease, border-color .3s ease, padding .3s ease, box-shadow .3s ease;
  border-bottom:1px solid transparent;
}
.nav.is-stuck{
  background:rgba(242,237,228,.86);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom-color:var(--line);
  padding-top:12px;
  padding-bottom:12px;
}
.nav-links{
  display:flex;
  gap:32px;
  list-style:none;
  margin:0; padding:0;
}
.nav-links a{
  font-size:15px;
  font-weight:500;
  color:var(--ink-2);
  padding:6px 0;
  position:relative;
  transition:color .2s ease;
}
.nav-links a:hover{ color:var(--ink); }
.nav-links a::after{
  content:"";
  position:absolute;
  left:0; bottom:0;
  width:0; height:1.5px;
  background:var(--brand);
  transition: width .3s cubic-bezier(.4,0,.2,1);
}
.nav-links a:hover::after{ width:100%; }
.nav-cta{
  display:none;
  align-items:center;
  gap:8px;
  padding:10px 16px;
  background:var(--ink);
  color:var(--bone);
  border-radius:999px;
  font-size:14px;
  font-weight:500;
  transition: background .2s ease, transform .2s ease;
}
.nav-cta:hover{ background:var(--brand); transform:translateY(-1px); }
.nav-cta .arrow{ transition: transform .25s ease; }
.nav-cta:hover .arrow{ transform: translateX(3px); }
@media (min-width: 900px){ .nav-cta{ display:inline-flex; } }
.nav-toggle{
  display:none;
  width:32px; height:24px;
  position:relative;
}
.nav-toggle span{
  position:absolute; left:4px; right:4px; height:1.5px;
  background:var(--ink); transition: transform .25s ease, opacity .25s ease;
}
.nav-toggle span:nth-child(1){ top:6px; }
.nav-toggle span:nth-child(2){ top:11px; }
.nav-toggle span:nth-child(3){ top:16px; }
@media (max-width: 760px){
  .nav-links{ display:none; }
  .nav-toggle{ display:block; }
  .nav.is-open .nav-links{
    position:absolute;
    top:100%; left:0; right:0;
    display:flex;
    flex-direction:column;
    gap:0;
    padding:24px var(--gutter) 32px;
    background:var(--bone);
    border-bottom:1px solid var(--line);
  }
  .nav.is-open .nav-links a{
    padding:14px 0;
    font-size:18px;
    border-bottom:1px solid var(--line-soft);
  }
  .nav.is-open .nav-toggle span:nth-child(1){ transform:translateY(5px) rotate(45deg); }
  .nav.is-open .nav-toggle span:nth-child(2){ opacity:0; }
  .nav.is-open .nav-toggle span:nth-child(3){ transform:translateY(-5px) rotate(-45deg); }
}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 22px;
  border-radius:999px;
  font-size:15px;
  font-weight:500;
  font-family:var(--sans);
  cursor:pointer;
  transition: background .2s ease, color .2s ease, transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  border:1px solid transparent;
  white-space:nowrap;
}
.btn .arrow{ transition: transform .25s cubic-bezier(.4,0,.2,1); display:inline-flex; }
.btn:hover .arrow{ transform: translateX(4px); }
.btn-primary{
  background:var(--ink);
  color:var(--bone);
  border-color:var(--ink);
}
.btn-primary:hover{ background:var(--brand); border-color:var(--brand); box-shadow:var(--shadow-brand); transform:translateY(-1px); }
.btn-brand{
  background:var(--brand);
  color:#fff;
  border-color:var(--brand);
}
.btn-brand:hover{ background:var(--brand-deep); border-color:var(--brand-deep); box-shadow:var(--shadow-brand); transform:translateY(-1px); }
.btn-ghost{
  background:transparent;
  color:var(--ink);
  border-color:var(--line);
}
.btn-ghost:hover{ border-color:var(--ink); background:var(--paper); }
.btn-light{
  background:var(--bone);
  color:var(--ink);
  border-color:var(--bone);
}
.btn-light:hover{ background:#fff; transform:translateY(-1px); }
.btn-lg{ padding:18px 28px; font-size:16px; }

/* ============ HERO ============ */
.hero{
  position:relative;
  padding: 148px var(--gutter) 80px;
  overflow:hidden;
}
.hero-bg{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:0;
  background-image:
    radial-gradient(circle at 85% 12%, rgba(30,63,224,.10), transparent 50%),
    radial-gradient(circle at 5% 85%, rgba(255,107,74,.07), transparent 45%);
}
.hero-grid-overlay{
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background-image:
    linear-gradient(var(--line-soft) 1px, transparent 1px),
    linear-gradient(90deg, var(--line-soft) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse at 50% 30%, #000 30%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at 50% 30%, #000 30%, transparent 75%);
  opacity:.7;
}
.hero .shell{ position:relative; z-index:1; }
.hero-inner{
  display:grid;
  grid-template-columns:1fr;
  gap:64px;
  max-width:var(--maxw);
  margin:0 auto;
}
@media (min-width: 1000px){
  .hero-inner{ grid-template-columns: 1.25fr 1fr; gap:80px; align-items:center; }
}
.hero h1{
  font-size:clamp(44px, 6.5vw, 84px);
  letter-spacing:-.035em;
  line-height:1.02;
  margin:24px 0 28px;
  max-width:14ch;
}
.hero h1 .brand-word{ color:var(--brand); }
.hero h1 .underline{
  position:relative;
  display:inline-block;
  white-space:nowrap;
}
.hero h1 .underline::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:-2px;
  height:8px;
  background:var(--accent);
  z-index:-1;
  transform-origin:left;
  animation: drawLine 1s cubic-bezier(.4,0,.2,1) .6s both;
}
@keyframes drawLine{ from{ transform:scaleX(0); } to{ transform:scaleX(1); } }
.hero-lede{
  font-size:19px;
  color:var(--ink-2);
  max-width:48ch;
  line-height:1.55;
  margin-bottom:36px;
}
.hero-ctas{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  align-items:center;
}
.hero-ctas .micro{
  font-size:13px;
  color:var(--ink-3);
  font-family:var(--mono);
  margin-left:6px;
}

/* Trust strip */
.trust-strip{
  margin-top:64px;
  padding-top:32px;
  border-top:1px solid var(--line);
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:24px;
}
@media (min-width: 700px){ .trust-strip{ grid-template-columns: repeat(4, 1fr); } }
.trust-item .k{
  font-family:var(--display);
  font-weight:600;
  font-size:36px;
  letter-spacing:-.03em;
  color:var(--ink);
  line-height:1;
  display:flex;
  align-items:baseline;
  gap:2px;
}
.trust-item .k .unit{ color:var(--brand); font-size:.7em; }
.trust-item .l{
  font-size:13px;
  color:var(--ink-3);
  margin-top:10px;
  line-height:1.4;
  max-width:22ch;
}

/* Hero visual card */
.hero-card{
  position:relative;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:24px;
  box-shadow: var(--shadow-2);
  font-family:var(--mono);
  font-size:13px;
  display:flex;
  flex-direction:column;
  gap:14px;
  transform: rotate(-1deg);
}
.hero-card .head{
  display:flex; align-items:center; gap:8px;
  padding-bottom:14px;
  border-bottom:1px solid var(--line);
  color:var(--ink-3);
  font-size:11px;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.hero-card .head i{
  width:8px; height:8px; border-radius:50%;
  background:#ddd;
}
.hero-card .head i:nth-child(1){ background:#ff6b4a; }
.hero-card .head i:nth-child(2){ background:#ffc24a; }
.hero-card .head i:nth-child(3){ background:#48c774; }
.hero-card .head .name{ margin-left:8px; }
.hero-kpis{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
}
.hero-kpi{
  background:var(--bone);
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:14px;
}
.hero-kpi .label{ font-size:10px; color:var(--ink-3); letter-spacing:.04em; text-transform:uppercase; }
.hero-kpi .value{
  font-family:var(--display);
  font-weight:600;
  font-size:24px;
  color:var(--ink);
  margin-top:6px;
  letter-spacing:-.02em;
  display:flex; align-items:baseline; gap:4px;
}
.hero-kpi .value .up{
  font-family:var(--mono);
  font-weight:500;
  font-size:11px;
  color:var(--ok);
  background:rgba(21,128,61,.12);
  padding:2px 6px;
  border-radius:4px;
  letter-spacing:0;
}
.hero-chart{
  background:var(--bone);
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:14px;
}
.hero-chart .label{ font-size:10px; color:var(--ink-3); letter-spacing:.04em; text-transform:uppercase; margin-bottom:10px; }
.hero-chart .bars{ display:flex; align-items:flex-end; gap:6px; height:60px; }
.hero-chart .bars i{
  flex:1;
  background:var(--brand);
  opacity:.18;
  border-radius:2px 2px 0 0;
  display:block;
}
.hero-chart .bars i.on{ opacity:1; }

/* Floating badge on hero card */
.hero-card-badge{
  position:absolute;
  top:-14px; right:-14px;
  background:var(--accent);
  color:#fff;
  font-family:var(--display);
  font-size:13px;
  font-weight:600;
  letter-spacing:-.01em;
  padding:8px 14px;
  border-radius:999px;
  box-shadow: 0 8px 20px -8px rgba(255,107,74,.6);
  transform: rotate(6deg);
}

/* ============ LOGOS / Social proof strip ============ */
.proof{
  background:var(--paper);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:32px var(--gutter);
}
.proof-inner{
  max-width:var(--maxw);
  margin:0 auto;
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:24px 48px;
  justify-content:space-between;
}
.proof-label{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.06em;
  color:var(--ink-3);
  text-transform:uppercase;
}
.proof-marks{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:32px;
  color:var(--ink-2);
  font-family:var(--display);
  font-weight:500;
  font-size:18px;
  letter-spacing:-.015em;
  opacity:.7;
}
.proof-marks .mark{ display:inline-flex; align-items:center; gap:6px; }
.proof-marks .mark .dot{ width:7px; height:7px; border-radius:50%; background:var(--ink-3); display:inline-block; }
.proof-marks .mark-client{ color:var(--ink); font-weight:500; opacity:1; }
.proof-marks .mark-client .dot-brand{ background:var(--brand); }
.proof-divider{ color:var(--line); font-size:20px; line-height:1; }

/* ============ SERVICES ============ */
.services{
  display:grid;
  grid-template-columns:1fr;
  gap:16px;
}
@media (min-width: 720px){ .services{ grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px){ .services{ grid-template-columns: repeat(3, 1fr); } }
.service{
  position:relative;
  padding:28px;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  display:flex;
  flex-direction:column;
  gap:18px;
  min-height:300px;
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.service:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-2);
  border-color:var(--ink);
}
.service-icon{
  width:48px; height:48px;
  background:var(--brand-soft);
  color:var(--brand);
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  transition: background .3s ease, color .3s ease;
}
.service-icon svg{ width:22px; height:22px; stroke:currentColor; stroke-width:1.6; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.service:hover .service-icon{ background:var(--ink); color:var(--bone); }
.service h3{
  font-size:22px;
  font-weight:600;
  letter-spacing:-.02em;
}
.service p{
  color:var(--ink-2);
  font-size:15px;
  line-height:1.55;
  margin:0;
}
.service-outcome{
  margin-top:auto;
  padding-top:16px;
  border-top:1px solid var(--line-soft);
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--ink-3);
  display:flex;
  align-items:center;
  gap:8px;
}
.service-outcome::before{
  content:""; width:6px; height:6px; background:var(--ok); border-radius:50%;
}
.service.is-featured{
  background:var(--ink);
  color:var(--dark-ink);
  border-color:var(--ink);
}
.service.is-featured h3{ color:var(--bone); }
.service.is-featured p{ color:var(--dark-ink-2); }
.service.is-featured .service-icon{ background:var(--brand); color:#fff; }
.service.is-featured .service-outcome{ color:var(--dark-ink-2); border-color:var(--dark-line); }
.service.is-featured:hover .service-icon{ background:var(--accent); color:#fff; }

/* ============ PROCESS ============ */
.process-wrap{
  position:relative;
}
.process{
  display:grid;
  grid-template-columns:1fr;
  gap:24px;
  counter-reset: step;
}
@media (min-width: 720px){ .process{ grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px){ .process{ grid-template-columns: repeat(4, 1fr); gap:0; } }
.process-step{
  padding:28px 24px;
  position:relative;
  counter-increment: step;
}
@media (min-width: 1080px){
  .process-step{ padding:32px 28px; }
  .process-step + .process-step{ border-left:1px solid var(--line); }
}
.process-step::before{
  content: "0" counter(step);
  display:block;
  font-family:var(--mono);
  font-size:12px;
  color:var(--brand);
  letter-spacing:.06em;
  margin-bottom:16px;
}
.process-step h3{
  font-size:20px;
  margin-bottom:10px;
  letter-spacing:-.02em;
}
.process-step p{
  color:var(--ink-2);
  font-size:14.5px;
  line-height:1.55;
  margin:0;
}
.process-step .timing{
  margin-top:14px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.06em;
  color:var(--ink-3);
  text-transform:uppercase;
}

/* ============ CASES ============ */
.cases{
  display:grid;
  grid-template-columns:1fr;
  gap:20px;
}
@media (min-width: 900px){
  .cases{
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: auto;
  }
  .case.is-wide{ grid-column: span 2; }
}
.case{
  position:relative;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px;
  display:grid;
  gap:24px;
  overflow:hidden;
  transition: transform .3s ease, box-shadow .3s ease;
  min-height:340px;
}
.case:hover{ transform:translateY(-4px); box-shadow: var(--shadow-2); }
.case.is-wide{
  grid-template-columns: 1.05fr 1fr;
  align-items:center;
}
@media (max-width: 720px){
  .case.is-wide{ grid-template-columns: 1fr; }
}
.case-meta{ display:flex; justify-content:space-between; align-items:center; gap:12px; }
.case-cat{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.06em;
  color:var(--brand);
  text-transform:uppercase;
  background:var(--brand-soft);
  padding:5px 10px;
  border-radius:999px;
}
.case-id{ font-family:var(--mono); font-size:11px; color:var(--ink-3); letter-spacing:.04em; }
.case h3{
  font-size:28px;
  font-weight:600;
  letter-spacing:-.025em;
  line-height:1.05;
}
.case p{ color:var(--ink-2); font-size:15px; line-height:1.55; margin:0; max-width:48ch; }
.case-results{
  display:flex;
  gap:18px;
  margin-top:auto;
  padding-top:18px;
  border-top:1px solid var(--line-soft);
  flex-wrap:wrap;
}
.case-result .v{
  font-family:var(--display);
  font-weight:600;
  font-size:24px;
  letter-spacing:-.025em;
  color:var(--brand);
  line-height:1;
}
.case-result .l{
  font-size:11px;
  font-family:var(--mono);
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--ink-3);
  margin-top:4px;
  display:block;
}
.case-visual{
  background:var(--bone);
  border:1px solid var(--line);
  border-radius:10px;
  position:relative;
  overflow:hidden;
  min-height:200px;
}
.case .case-body{
  display:flex; flex-direction:column; gap:16px;
}

/* Case visuals (CSS art) */
.cv-bars{ display:flex; align-items:flex-end; gap:6px; padding:20px; height:100%; min-height:200px; }
.cv-bars i{
  flex:1;
  background: linear-gradient(180deg, var(--brand), rgba(30,63,224,.3));
  border-radius:3px 3px 0 0;
  height:var(--h, 40%);
}
.cv-bars i.alt{ background: linear-gradient(180deg, var(--accent), rgba(255,107,74,.3)); }

.cv-rings{ position:absolute; inset:0; display:grid; place-items:center; }
.cv-rings i{
  position:absolute;
  aspect-ratio:1;
  border:1.5px solid var(--line);
  border-radius:50%;
  width:var(--s, 60%);
}
.cv-rings i:nth-child(1){ --s:88%; border-style:dashed; }
.cv-rings i:nth-child(2){ --s:60%; border-color: var(--brand); }
.cv-rings i:nth-child(3){ --s:35%; border-color: var(--brand); background: rgba(30,63,224,.06); }
.cv-rings i:nth-child(4){ --s:14%; background: var(--brand); border-color: var(--brand); }
.cv-rings .pct{
  position:relative;
  font-family:var(--display);
  font-weight:600;
  font-size:32px;
  color:var(--ink);
  letter-spacing:-.03em;
  z-index:1;
}

.cv-flow{
  position:absolute; inset:0;
  padding:20px;
  display:flex;
  flex-direction:column;
  gap:8px;
  font-family:var(--mono);
  font-size:12px;
  color:var(--ink-2);
  justify-content:center;
}
.cv-flow .row{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:#fff;
  padding:8px 12px;
  border:1px solid var(--line);
  border-radius:6px;
  width:fit-content;
}
.cv-flow .row::before{ content:""; width:6px; height:6px; background:var(--brand); border-radius:50%; }
.cv-flow .row.done::before{ background:var(--ok); }
.cv-flow .row.in-1{ margin-left:18px; }
.cv-flow .row.in-2{ margin-left:36px; }
.cv-flow .row.in-3{ margin-left:54px; }

.cv-dash{
  position:absolute; inset:0;
  padding:18px;
  display:grid;
  grid-template-columns: 90px 1fr;
  gap:10px;
}
.cv-dash .side{
  background:#fff;
  border:1px solid var(--line);
  border-radius:8px;
  padding:10px;
  display:flex; flex-direction:column; gap:6px;
}
.cv-dash .side i{ height:8px; background:var(--line); border-radius:2px; display:block; }
.cv-dash .side i.on{ background:var(--brand); }
.cv-dash .main{
  background:#fff;
  border:1px solid var(--line);
  border-radius:8px;
  padding:14px;
  display:flex; flex-direction:column; gap:8px;
  overflow:hidden;
  position:relative;
}
.cv-dash .main .row{ display:flex; align-items:center; gap:6px; }
.cv-dash .main .row .pill{ font-family:var(--mono); font-size:9px; padding:2px 6px; background:var(--brand-soft); color:var(--brand); border-radius:4px; }
.cv-dash .main svg.spark{ width:100%; height:50px; margin-top:auto; }
.cv-dash .main svg.spark path{ stroke:var(--brand); stroke-width:2; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.cv-dash .main svg.spark .area{ fill:rgba(30,63,224,.12); stroke:none; }

/* ============ ABOUT ============ */
.about{
  display:grid;
  grid-template-columns:1fr;
  gap:48px;
}
@media (min-width: 900px){ .about{ grid-template-columns: 0.85fr 1fr; gap:80px; align-items:center; } }
.about-portrait{
  position:relative;
  aspect-ratio: 4/5;
  border-radius:var(--radius);
  background:
    linear-gradient(135deg, var(--paper-2), var(--paper)),
    repeating-linear-gradient(45deg, transparent 0 12px, var(--line-soft) 12px 24px);
  border:1px solid var(--line);
  overflow:hidden;
}
.about-portrait::before{
  content:"";
  position:absolute; inset:0;
  background-image: repeating-linear-gradient(45deg, transparent 0 14px, rgba(14,16,20,.04) 14px 28px);
}
.about-portrait .tag{
  position:absolute;
  top:16px; left:16px;
  background:var(--ink);
  color:var(--bone);
  font-family:var(--mono);
  font-size:10px;
  padding:6px 10px;
  border-radius:999px;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.about-portrait .signature{
  position:absolute;
  bottom:20px; left:20px; right:20px;
}
.about-portrait .signature .name{
  font-family:var(--display);
  font-weight:600;
  font-size:28px;
  letter-spacing:-.02em;
  color:var(--ink);
}
.about-portrait .signature .meta{
  font-family:var(--mono);
  font-size:11px;
  color:var(--ink-3);
  margin-top:6px;
  letter-spacing:.04em;
}
.about-portrait .ph-label{
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%,-50%);
  font-family:var(--mono);
  font-size:11px;
  color:var(--ink-3);
  letter-spacing:.1em;
  text-transform:uppercase;
  background:rgba(251,248,242,.92);
  border:1px dashed var(--line);
  padding:8px 14px;
  border-radius:999px;
}
.about h2{ font-size:clamp(34px, 4.2vw, 48px); margin-bottom:24px; max-width:18ch; }
.about p{
  font-size:17px;
  color:var(--ink-2);
  line-height:1.65;
  max-width:54ch;
}
.about p .hl{ color:var(--ink); font-weight:500; }
.about-points{
  margin-top:32px;
  display:grid;
  gap:16px;
}
.about-point{
  display:grid;
  grid-template-columns: 38px 1fr;
  gap:14px;
  align-items:start;
}
.about-point svg{
  width:20px; height:20px;
  color:var(--brand);
  margin-top:2px;
}
.about-point .t{
  font-weight:500;
  color:var(--ink);
  font-size:15px;
}
.about-point .d{
  color:var(--ink-3);
  font-size:14px;
  margin-top:2px;
}

/* ============ TECH STACK ============ */
.tech-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:12px;
}
@media (min-width: 600px){ .tech-grid{ grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 900px){ .tech-grid{ grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 1080px){ .tech-grid{ grid-template-columns: repeat(6, 1fr); } }
.tech{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:16px;
  display:flex;
  flex-direction:column;
  gap:8px;
  transition: border-color .25s ease, background .25s ease, transform .25s ease;
}
.tech:hover{ border-color:var(--brand); background:#fff; transform:translateY(-2px); }
.tech .n{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.06em;
  color:var(--ink-3);
  text-transform:uppercase;
}
.tech .name{ font-weight:500; font-size:15px; letter-spacing:-.01em; }
.tech .kind{ font-size:11px; color:var(--ink-3); font-family:var(--mono); }

/* ============ FAQ ============ */
.faq{
  display:grid;
  grid-template-columns:1fr;
  gap:0;
  border-top:1px solid var(--line);
}
.faq-item{
  border-bottom:1px solid var(--line);
}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:24px 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  font-family:var(--display);
  font-weight:500;
  font-size:19px;
  letter-spacing:-.015em;
  color:var(--ink);
  transition: color .2s ease;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary:hover{ color:var(--brand); }
.faq-item summary .toggle{
  flex:0 0 auto;
  width:32px; height:32px;
  border-radius:50%;
  background:var(--paper);
  border:1px solid var(--line);
  display:grid;
  place-items:center;
  transition: background .25s ease, transform .25s ease, border-color .25s ease;
}
.faq-item summary .toggle::before{
  content:""; width:10px; height:1.5px; background:var(--ink); position:absolute;
}
.faq-item summary .toggle::after{
  content:""; width:1.5px; height:10px; background:var(--ink); position:absolute;
  transition: transform .25s ease, opacity .25s ease;
}
.faq-item summary .toggle{ position:relative; }
.faq-item[open] summary .toggle{ background:var(--brand); border-color:var(--brand); transform: rotate(180deg); }
.faq-item[open] summary .toggle::before,
.faq-item[open] summary .toggle::after{ background:#fff; }
.faq-item[open] summary .toggle::after{ transform: scaleY(0); }
.faq-answer{
  padding:0 0 28px 0;
  color:var(--ink-2);
  font-size:16px;
  line-height:1.65;
  max-width:72ch;
}

/* ============ CTA / CONTACT ============ */
.cta-section{
  background:var(--ink);
  color:var(--dark-ink);
  padding:clamp(72px, 11vh, 120px) var(--gutter);
  position:relative;
  overflow:hidden;
}
.cta-section::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    radial-gradient(circle at 90% 10%, rgba(30,63,224,.25), transparent 40%),
    radial-gradient(circle at 5% 90%, rgba(255,107,74,.12), transparent 40%);
  pointer-events:none;
}
.cta-section .shell{ position:relative; z-index:1; }
.cta-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:56px;
}
@media (min-width: 900px){ .cta-grid{ grid-template-columns: 1fr 1fr; gap:80px; } }
.cta-copy h2{
  font-size:clamp(38px, 5vw, 64px);
  color:var(--bone);
  letter-spacing:-.03em;
  max-width:14ch;
  margin-bottom:24px;
}
.cta-copy h2 em{ font-style:normal; color:var(--brand); }
.cta-copy h2 em.warm{ color:var(--accent); }
.cta-copy .lede{
  font-size:18px;
  color:var(--dark-ink-2);
  max-width:42ch;
  line-height:1.55;
  margin-bottom:32px;
}
.cta-links{ display:grid; gap:14px; }
.cta-link{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:18px 20px;
  border:1px solid var(--dark-line);
  border-radius:var(--radius-sm);
  color:var(--dark-ink);
  transition: background .25s ease, border-color .25s ease, transform .25s ease;
}
.cta-link:hover{ background:var(--dark-2); border-color:var(--brand); transform:translateX(4px); }
.cta-link .l{ display:flex; align-items:center; gap:14px; }
.cta-link .icon{
  width:36px; height:36px; border-radius:50%;
  background:var(--dark-2);
  display:grid; place-items:center;
  color:var(--brand);
}
.cta-link .icon svg{ width:16px; height:16px; stroke:currentColor; stroke-width:1.6; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.cta-link .lbl{ font-size:11px; font-family:var(--mono); color:var(--dark-ink-2); letter-spacing:.06em; text-transform:uppercase; margin-bottom:2px; }
.cta-link .val{ font-size:15px; color:var(--dark-ink); font-weight:500; }
.cta-link .arrow{ color:var(--dark-ink-2); transition: transform .25s ease, color .25s ease; }
.cta-link:hover .arrow{ color:var(--brand); transform:translateX(3px); }

.form{
  background:var(--dark-2);
  border:1px solid var(--dark-line);
  border-radius:var(--radius);
  padding:32px;
  position:relative;
}
.form-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:24px;
  padding-bottom:18px;
  border-bottom:1px solid var(--dark-line);
}
.form-header .ttl{
  font-family:var(--display);
  font-weight:600;
  font-size:18px;
  color:var(--bone);
  letter-spacing:-.015em;
}
.form-header .badge{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.06em;
  color:var(--ok);
  text-transform:uppercase;
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.form-header .badge::before{
  content:""; width:7px; height:7px; background:var(--ok); border-radius:50%;
  animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse{ 0%,100%{ opacity:1; transform:scale(1); } 50%{ opacity:.6; transform:scale(1.3); } }
.field{
  margin-bottom:18px;
}
.field label{
  display:flex; justify-content:space-between;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.06em;
  color:var(--dark-ink-2);
  text-transform:uppercase;
  margin-bottom:8px;
}
.field label .req{ color:var(--accent); }
.field input,
.field textarea,
.field select{
  width:100%;
  background:var(--dark);
  border:1px solid var(--dark-line);
  color:var(--dark-ink);
  font-family:var(--sans);
  font-size:15px;
  padding:14px 16px;
  border-radius:var(--radius-sm);
  outline:none;
  transition: border-color .2s ease, background .2s ease;
}
.field input::placeholder,
.field textarea::placeholder{ color:#5d6068; }
.field input:focus,
.field textarea:focus,
.field select:focus{ border-color:var(--brand); background:#0a0c10; }
.field textarea{ resize:vertical; min-height:120px; line-height:1.5; }
.form-submit{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  width:100%;
  padding:16px 24px;
  background:var(--brand);
  color:#fff;
  font-family:var(--sans);
  font-weight:500;
  font-size:15px;
  border-radius:999px;
  cursor:pointer;
  border:1px solid var(--brand);
  transition: background .25s ease, transform .2s ease, box-shadow .25s ease;
  margin-top:8px;
}
.form-submit:hover{ background:var(--brand-deep); transform:translateY(-1px); box-shadow: 0 12px 30px -8px rgba(30,63,224,.6); }
.form-submit:disabled{ opacity:.6; cursor:wait; }
.form-status{
  margin-top:14px;
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.04em;
  min-height:1.6em;
  color:var(--dark-ink-2);
}
.form-status.ok{ color:var(--ok); }
.form-status.err{ color:var(--warn); }
.form-note{
  margin-top:16px;
  font-size:12px;
  color:var(--dark-ink-2);
  text-align:center;
  line-height:1.5;
}

/* ============ FOOTER ============ */
.footer{
  background:var(--ink);
  color:var(--dark-ink);
  padding:48px var(--gutter) 24px;
  border-top:1px solid var(--dark-line);
}
.footer-grid{
  max-width:var(--maxw);
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr;
  gap:48px;
  padding-bottom:36px;
  border-bottom:1px solid var(--dark-line);
}
@media (min-width: 900px){ .footer-grid{ grid-template-columns: 1.4fr 1fr 1fr 1fr; } }
.footer-brand p{
  color:var(--dark-ink-2);
  font-size:14px;
  line-height:1.6;
  margin-top:16px;
  max-width:34ch;
}
.footer-col h4{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--dark-ink-2);
  margin-bottom:16px;
  font-weight:500;
}
.footer-col ul{ list-style:none; padding:0; margin:0; display:grid; gap:10px; }
.footer-col a{ color:var(--dark-ink); font-size:14px; transition: color .2s ease; }
.footer-col a:hover{ color:var(--brand); }
.footer-bottom{
  max-width:var(--maxw);
  margin:24px auto 0;
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:12px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.04em;
  color:var(--dark-ink-2);
  text-transform:uppercase;
}

/* ============ REVEAL ============ */
.reveal{
  opacity:0;
  transform:translateY(20px);
  transition: opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1);
}
.reveal.in{ opacity:1; transform:none; }
.reveal[data-delay="1"]{ transition-delay:.05s; }
.reveal[data-delay="2"]{ transition-delay:.10s; }
.reveal[data-delay="3"]{ transition-delay:.15s; }
.reveal[data-delay="4"]{ transition-delay:.20s; }
.reveal[data-delay="5"]{ transition-delay:.25s; }

/* Hero staggered intro */
.hero .stagger > *{
  opacity:0;
  transform:translateY(16px);
  animation: rise .9s cubic-bezier(.4,0,.2,1) forwards;
}
.hero .stagger > *:nth-child(1){ animation-delay:.05s; }
.hero .stagger > *:nth-child(2){ animation-delay:.18s; }
.hero .stagger > *:nth-child(3){ animation-delay:.30s; }
.hero .stagger > *:nth-child(4){ animation-delay:.42s; }
.hero .stagger > *:nth-child(5){ animation-delay:.54s; }
@keyframes rise{ to{ opacity:1; transform:none; } }

/* ============ CASE DASHBOARD VISUAL ============ */
.cv-dashboard{
  position:absolute; inset:0;
  padding:18px;
  display:flex; flex-direction:column; gap:10px;
  font-family:var(--mono);
  background:var(--bone);
}
.cvd-header{
  display:flex; align-items:center; justify-content:space-between;
  padding-bottom:10px;
  border-bottom:1px solid var(--line);
}
.cvd-title{ font-size:10px; color:var(--ink-3); letter-spacing:.04em; }
.cvd-live{ font-size:10px; color:var(--ok); letter-spacing:.04em; }
.cvd-kpis{
  display:grid; grid-template-columns:repeat(3,1fr); gap:8px;
}
.cvd-kpi{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:6px;
  padding:10px 12px;
}
.cvd-lbl{ font-size:9px; color:var(--ink-3); letter-spacing:.06em; text-transform:uppercase; }
.cvd-val{
  font-family:var(--display);
  font-weight:600; font-size:17px;
  color:var(--ink); letter-spacing:-.02em;
  margin-top:4px;
}
.cvd-trend{ font-size:10px; color:var(--ok); margin-top:3px; }
.cvd-chart{
  flex:1;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:6px;
  padding:12px;
  display:flex; flex-direction:column;
  overflow:hidden;
}
.cvd-chart-lbl{ font-size:9px; color:var(--ink-3); letter-spacing:.06em; text-transform:uppercase; margin-bottom:8px; }
.cvd-bars{
  flex:1; display:flex; align-items:flex-end; gap:5px;
}
.cvd-bars i{
  flex:1; background:var(--brand); opacity:.15;
  border-radius:2px 2px 0 0; height:var(--h,40%); display:block;
}
.cvd-bars i.on{ opacity:1; }

/* ============ PROJ TEASER ============ */
.proj-tags{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  margin-bottom:40px;
}
.proj-more{
  font-family:var(--mono);
  font-size:11px;
  color:var(--brand);
  letter-spacing:.06em;
  text-transform:uppercase;
}
.proj-cta-row{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  align-items:center;
  padding-top:40px;
  border-top:1px solid var(--line);
}

/* ============ HERO CARD FLOAT ============ */
@keyframes heroFloat{
  0%,100%{ transform: rotate(-1deg) translateY(0); }
  50%     { transform: rotate(-.4deg) translateY(-8px); }
}
.hero-card{ animation: heroFloat 7s ease-in-out infinite; }

/* ============ PROOF MARKS ENTRY ============ */
@keyframes markIn{
  from{ opacity:0; transform:translateY(6px); }
  to  { opacity:1; transform:none; }
}
.proof-marks .mark{
  opacity:0;
  animation: markIn .5s cubic-bezier(.4,0,.2,1) forwards;
}
.proof-marks .mark:nth-child(1){ animation-delay:.70s; }
.proof-marks .mark:nth-child(2){ animation-delay:.85s; }
.proof-marks .mark:nth-child(3){ animation-delay:1.0s; }
.proof-marks .mark:nth-child(4){ animation-delay:1.15s; }
.proof-marks .mark:nth-child(5){ animation-delay:1.3s; }

/* ============ ABOUT CAPS ============ */
.about-caps{
  margin-top:0;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
@media (min-width:900px){ .about-caps{ grid-template-columns:repeat(4,1fr); } }

.about-cap{
  opacity:0;
  padding:16px 18px;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  background:var(--paper);
  display:grid;
  grid-template-columns:32px 1fr;
  gap:10px;
  align-items:start;
  transition: opacity .5s cubic-bezier(.2,.7,.2,1),
              border-color .25s ease,
              transform .25s ease;
}
.about-cap:hover{
  border-color:var(--brand);
  transform:translateY(-2px);
  transition-delay:0s;
}
.about-cap .n{
  font-family:var(--mono);
  font-size:11px;
  color:var(--brand);
  letter-spacing:.06em;
  text-transform:uppercase;
  padding-top:2px;
}
.about-cap .t{
  font-weight:500;
  font-size:14px;
  color:var(--ink);
  margin-bottom:4px;
}
.about-cap .d{
  font-size:13px;
  color:var(--ink-3);
  line-height:1.5;
}

/* Stagger: about-caps when parent reveals */
.reveal.in .about-cap:nth-child(1){ opacity:1; transition-delay:.20s; }
.reveal.in .about-cap:nth-child(2){ opacity:1; transition-delay:.30s; }
.reveal.in .about-cap:nth-child(3){ opacity:1; transition-delay:.40s; }
.reveal.in .about-cap:nth-child(4){ opacity:1; transition-delay:.50s; }

/* Stagger: about-points when parent reveals */
.about-points .about-point{
  opacity:0;
  transition: opacity .55s cubic-bezier(.2,.7,.2,1);
}
.reveal.in .about-points .about-point:nth-child(1){ opacity:1; transition-delay:.55s; }
.reveal.in .about-points .about-point:nth-child(2){ opacity:1; transition-delay:.65s; }
.reveal.in .about-points .about-point:nth-child(3){ opacity:1; transition-delay:.75s; }
.reveal.in .about-points .about-point:nth-child(4){ opacity:1; transition-delay:.85s; }

/* ============ RESPONSIVE ENHANCEMENTS ============ */

/* iOS Safari: previne auto-zoom em inputs com font-size < 16px */
@media (max-width: 767px) {
  .field input,
  .field textarea,
  .field select,
  .form-submit { font-size: 16px; }
}

/* Espaçamento de section-head mais compacto em mobile */
@media (max-width: 899px) {
  .section-head { margin-bottom: 40px; }
  .cta-grid { gap: 40px; }
}

/* Nav tablet: mostra CTA entre o toggle mobile e o desktop full */
@media (min-width: 761px) and (max-width: 899px) {
  .nav-cta { display: inline-flex; }
  .nav-links { gap: 18px; }
  .nav-links a { font-size: 14px; }
}

/* Hero: constrains o card em tablet/meio-termo */
@media (max-width: 999px) {
  .hero { padding-top: 112px; }
  .hero-card-outer { width: 100%; max-width: 440px; margin: 0 auto; }
}
@media (min-width: 640px) and (max-width: 999px) {
  .hero h1 { font-size: clamp(44px, 7vw, 68px); }
}

/* Hero: mobile pequeno (< 640px) */
@media (max-width: 639px) {
  .hero { padding: 92px var(--gutter) 56px; }
  .hero h1 { font-size: clamp(34px, 9.5vw, 44px); max-width: 100%; }
  .hero-lede { font-size: 17px; margin-bottom: 24px; }
  .hero-ctas { flex-direction: column; align-items: stretch; }
  .hero-ctas > .btn { width: 100%; justify-content: center; }
  .hero-ctas .micro { margin-left: 0; text-align: center; }
  .hero-card-outer { display: none; }
  .trust-strip { margin-top: 40px; padding-top: 20px; gap: 16px 20px; }
  .trust-item .k { font-size: 28px; }
}

/* Telas muito pequenas (< 360px) */
@media (max-width: 359px) {
  :root { --gutter: 14px; }
  .hero h1 { font-size: 30px; }
  .hero h1 .underline { white-space: normal; }
  .btn { padding: 12px 16px; font-size: 14px; }
  .btn-lg { padding: 14px 18px; }
}

/* Proof strip empilhado em mobile */
@media (max-width: 639px) {
  .proof-inner { flex-direction: column; gap: 12px; justify-content: flex-start; }
  .proof-divider { display: none; }
  .proof-marks { flex-wrap: wrap; gap: 10px 18px; }
}

/* About portrait: altura limitada em mobile (aspecto 4/5 ficaria muito alto) */
@media (max-width: 639px) {
  .about-portrait { max-height: 280px; }
}

/* Services: padding e min-height reduzidos em mobile */
@media (max-width: 479px) {
  .service { padding: 20px; min-height: auto; gap: 14px; }
  .service h3 { font-size: 20px; }
}

/* Process: padding compacto em mobile */
@media (max-width: 719px) {
  .process-step { padding: 20px 16px; }
  .process-step h3 { font-size: 18px; }
}

/* Cases: compacto em mobile */
@media (max-width: 479px) {
  .case { padding: 20px; min-height: auto; }
  .case h3 { font-size: 22px; }
}

/* FAQ: fonte e padding menores em mobile */
@media (max-width: 639px) {
  .faq-item summary { font-size: 16px; padding: 18px 0; gap: 12px; }
  .faq-answer { font-size: 15px; padding-bottom: 20px; }
}

/* CTA/contato: form e links adaptados para mobile */
@media (max-width: 639px) {
  .form { padding: 20px; }
  .cta-copy h2 { font-size: clamp(30px, 9.5vw, 46px); }
  .cta-link { padding: 14px 16px; }
  .cta-link .val { word-break: break-all; font-size: 14px; }
}

/* Footer: espaçamento compacto em mobile */
@media (max-width: 479px) {
  .footer { padding: 40px var(--gutter) 20px; }
  .footer-grid { gap: 32px; padding-bottom: 24px; }
  .footer-bottom { flex-direction: column; gap: 8px; align-items: flex-start; }
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; transition-duration:.001ms !important; }
}
