*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  --dark:   #080d14;
  --slate:  #eef1f6;
  --cyan:   #00c8ff;
  --muted:  #6b7a8d;
  --white:  #f8fafc;
}

html { scroll-behavior: smooth; }

body {
  font-family: 'DM Sans', sans-serif;
  background: var(--white);
  color: #1a2332;
  overflow-x: hidden;
}

a { text-decoration: none; color: inherit; }

@font-face {
  font-family: 'logo';
  src: url(./font/hyperspace-race-extended-bold.otf);
}

    #splash,
    #uncover {
      position: fixed;
      inset: 0;
      z-index: 9999;
      overflow: hidden;
    }

    #splash  { background: #080d14; }
    #uncover { pointer-events: none; }

    #splash canvas,
    #uncover canvas {
      position: absolute;
      inset: 0;
      display: block;
    }

    /* Scan lines decorativas */
    #splash::after {
      content: '';
      position: absolute;
      inset: 0;
      background: repeating-linear-gradient(
        0deg,
        transparent,
        transparent 2px,
        rgba(0,0,0,.07) 2px,
        rgba(0,0,0,.07) 4px
      );
      pointer-events: none;
      z-index: 1;
    }

    /* UI central */
    #splash-ui {
      position: absolute;
      inset: 0;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      z-index: 2;
      transition: opacity .35s ease;
    }

    #splash-ui.hide { opacity: 0; pointer-events: none; }

    .splash-logo {
      font-family: 'DM Serif Display', serif;
      font-size: clamp(20px, 3.5vw, 40px);
      letter-spacing: 7px;
      color: #fff;
      text-transform: uppercase;
      opacity: 0;
      animation: sUp .7s .4s forwards;
    }

    .splash-divider {
      width: 44px;
      height: 1px;
      background: #00c8ff;
      margin: 18px 0 12px;
      opacity: 0;
      animation: sUp .7s .55s forwards;
    }

    .splash-sub {
      font-size: 10px;
      letter-spacing: 4px;
      text-transform: uppercase;
      color: #00c8ff;
      margin-bottom: 52px;
      opacity: 0;
      animation: sUp .7s .65s forwards;
    }

    .splash-prompt {
      font-size: 10px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: rgb(255, 255, 255);
      margin-bottom: 22px;
      opacity: 0;
      animation: sUp .7s .78s forwards;
    }

    .splash-btns {
      display: flex;
      gap: 16px;
      opacity: 0;
      animation: sUp .7s .92s forwards;
    }

    .splash-btn {
      font-family: 'DM Sans', sans-serif;
      font-size: 11px;
      font-weight: 500;
      letter-spacing: 3px;
      text-transform: uppercase;
      padding: 14px 38px;
      border: 1px solid rgba(0,200,255,.35);
      background: transparent;
      color: rgba(255,255,255,.7);
      cursor: pointer;
      position: relative;
      overflow: hidden;
      transition: color .3s, border-color .3s;
    }

    .splash-btn::before {
      content: '';
      position: absolute;
      inset: 0;
      background: #00c8ff;
      transform: translateY(100%);
      transition: transform .35s cubic-bezier(.4,0,.2,1);
    }

    .splash-btn:hover::before { transform: translateY(0); }
    .splash-btn:hover         { color: #080d14; border-color: #00c8ff; }
    .splash-btn span          { position: relative; z-index: 1; }

    @keyframes sUp {
      from { opacity:0; transform:translateY(14px); }
      to   { opacity:1; transform:translateY(0); }
    }

    /* ── Lang btn no nav ── */
    .lang-btn {
      font-size: 11px;
      font-weight: 500;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: rgba(255,255,255,.75);
      border: 1px solid rgba(255,255,255,.25);
      padding: 7px 14px;
      transition: color .3s, border-color .3s;
      white-space: nowrap;
    }
    .lang-btn:hover { color: #00c8ff; border-color: #00c8ff; }

    @media (max-width: 860px) { .lang-btn { display: none; } }

/* ── Language switcher ── */

.lang-btn {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(255, 255, 255, .75);
  border: 1px solid rgba(255, 255, 255, .25);
  padding: 7px 14px;
  transition: color .3s, border-color .3s;
  white-space: nowrap;
}

.lang-btn:hover {
  color: var(--cyan);
  border-color: var(--cyan);
}

/* ── Nav ── */
nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 clamp(20px, 5vw, 70px);
  height: 72px;
  transition: background .4s, box-shadow .4s;
}

nav.scrolled {
  background: var(--dark);
  box-shadow: 0 2px 24px rgba(0,0,0,.4);
}

.logo {
  font-family: 'DM Serif Display', serif;
  color: #fff;
}

.logo span {
  display: block;
  font-size: clamp(15px, 1.8vw, 20px);
  font-family: logo;
  letter-spacing: 2px;
}

.logo small {
  font-size: 10px;
  letter-spacing: 3px;
  color: var(--cyan);
  text-transform: uppercase;
}

.nav-links {
  display: flex;
  gap: clamp(18px, 2.5vw, 36px);
}

.nav-links a {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(255,255,255,.75);
  transition: color .3s;
}

.nav-links a:hover { color: var(--cyan); }

.nav-cta {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--dark);
  background: var(--cyan);
  border: none;
  padding: 10px 22px;
  cursor: pointer;
  transition: opacity .3s;
}

.nav-cta:hover { opacity: .85; }

.burger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
}

.burger span {
  width: 22px;
  height: 1.5px;
  background: #fff;
  display: block;
}

#mmenu {
  display: none;
  position: fixed;
  inset: 0;
  background: var(--dark);
  z-index: 101;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 28px;
}

#mmenu.open { display: flex; }

#mmenu a {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(26px, 5vw, 40px);
  color: #fff;
  font-weight: 400;
  letter-spacing: 2px;
  transition: color .3s;
}

#mmenu a:hover { color: var(--cyan); }

.mclose {
  position: absolute;
  top: 24px;
  right: clamp(20px, 5vw, 70px);
  font-size: 28px;
  color: #fff;
  cursor: pointer;
  font-weight: 300;
}


/* ── Hero ── */
#hero {
  height: 100svh;
  min-height: 580px;
  position: relative;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}

.hero-bg {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(rgba(8,13,20,.85), rgba(8, 13, 20, 0.588)),
    url('./img/ChatGPT\ Image\ 6\ de\ abr.\ de\ 2026\,\ 14_05_45.png') center / cover no-repeat,
    var(--dark);
  animation: zoom 8s ease-out forwards;
}

.hero-bg::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 60% at 60% 40%, rgba(0,200,255,.12) 0%, transparent 70%);
}

.hero-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(8,13,20,.95) 0%, rgba(8,13,20,.3) 60%, transparent 100%);
}

@keyframes zoom {
  from { transform: scale(1.04); }
  to   { transform: scale(1); }
}

.hero-text {
  position: relative;
  z-index: 2;
  padding: clamp(36px, 6vw, 90px);
  padding-bottom: clamp(56px, 8vw, 110px);
}

.hero-text p {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--cyan);
  margin-bottom: 14px;
  opacity: 0;
  animation: up .8s .3s forwards;
}

.hero-text h1 {
  font-family: 'DM Serif Display', serif;
  font-weight: 400;
  font-size: clamp(38px, 6vw, 80px);
  color: #fff;
  line-height: 1.08;
  margin-bottom: 28px;
  opacity: 0;
  animation: up .8s .5s forwards;
}

.hero-text h1 em {
  font-style: italic;
  color: var(--cyan);
}

.hero-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  opacity: 0;
  animation: up .8s .7s forwards;
}

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

/* ── Botões ── */
.btn {
  display: inline-block;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  padding: 14px 30px;
  border: 1px solid;
  cursor: pointer;
  transition: .3s;
}

.btn-cyan {
  color: var(--dark);
  background: var(--cyan);
  border-color: var(--cyan);
}

.btn-cyan:hover {
  background: transparent;
  color: var(--cyan);
}

.btn-outline-light {
  color: rgba(255,255,255,.7);
  border-color: rgba(255,255,255,.25);
}

.btn-outline-light:hover {
  background: #fff;
  color: var(--dark);
  border-color: #fff;
}

.btn-white {
  color: #fff;
  border-color: rgba(255,255,255,.5);
}

.btn-white:hover {
  background: #fff;
  color: var(--dark);
  border-color: #fff;
}


/* ── Sobre ── */
#sobre {
  padding: clamp(60px, 9vw, 120px) clamp(20px, 5vw, 70px);
}

.sobre-wrap {
  max-width: 1300px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 90px);
  align-items: center;
}

.sobre-img {
  aspect-ratio: 4/5;
  overflow: hidden;
  background: var(--dark);
  position: relative;
}

.sobre-img-inner {
  width: 100%; height: 100%;
  background: var(--dark);
  background-image:
    linear-gradient(rgba(0,200,255,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,200,255,.08) 1px, transparent 1px);
  background-size: 36px 36px;
  transition: transform .6s ease;
  position: relative;
}

.sobre-img-inner::after {
  content: '</>';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  font-family: 'DM Serif Display', serif;
  font-size: clamp(60px, 10vw, 110px);
  color: rgba(0,200,255,.15);
  letter-spacing: -4px;
  pointer-events: none;
}

.sobre-img:hover .sobre-img-inner { transform: scale(1.03); }

.eyebrow {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--cyan);
  margin-bottom: 12px;
}

h2 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(28px, 3.5vw, 48px);
  font-weight: 400;
  line-height: 1.15;
  margin-bottom: 20px;
}

h2 em { font-style: italic; color: var(--cyan); }

.line {
  width: 40px; height: 1px;
  background: var(--cyan);
  margin: 20px 0 24px;
}

p.body-text, #sobre p, #processo .split-text p {
  font-size: clamp(13px, 1.4vw, 15px);
  font-weight: 300;
  color: var(--muted);
  line-height: 1.9;
  margin-bottom: 14px;
}

.stats {
  display: flex;
  gap: 30px;
  margin-top: 30px;
  padding-top: 28px;
  border-top: 1px solid #dde4ef;
  flex-wrap: wrap;
}

.stat-num {
  font-family: 'DM Serif Display', serif;
  font-size: 36px;
  font-weight: 400;
  color: var(--dark);
  line-height: 1;
}

.stat-lbl {
  font-size: 9px;
  font-weight: 500;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--cyan);
  margin-top: 4px;
}


/* ── Serviços ── */
#servicos {
  background: var(--dark);
  padding: clamp(60px, 9vw, 120px) clamp(20px, 5vw, 70px);
}

.servicos-wrap { max-width: 1300px; margin: 0 auto; }

.cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-top: clamp(36px, 5vw, 52px);
}

.card {
  border: 1px solid #dde4ef;
  overflow: hidden;
  transition: border-color .3s, box-shadow .3s;
}

.card:hover {
  border-color: var(--cyan);
  box-shadow: 0 8px 32px rgba(0,200,255,.1);
}

.card-icon {
  font-size: 2.2rem;
  padding: 2rem 1.5rem 0;
}

.card-body { padding: 1.2rem 1.5rem 1.5rem; }

.card-tipo {
  font-size: 9px;
  font-weight: 500;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--cyan);
  margin-bottom: 5px;
}

.card-nome {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(18px, 2vw, 24px);
  font-weight: 400;
  color: white;
  margin-bottom: 8px;
}

.card-desc {
  font-size: 13px;
  font-weight: 300;
  color: var(--muted);
  line-height: 1.7;
  margin-bottom: 14px;
}

.card-foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 12px;
  border-top: 1px solid #e8eef6;
}

.card-preco {
  font-family: 'DM Serif Display', serif;
  font-size: 13px;
  color: var(--muted);
}

.card-preco strong {
  font-size: 20px;
  font-weight: 400;
  color: white;
}

.card-area {
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 1px;
}


/* ── Processo ── */
#processo {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.split-visual {
  min-height: 420px;
  background: var(--dark);
  background-image:
    linear-gradient(rgba(0,200,255,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,200,255,.07) 1px, transparent 1px);
  background-size: 44px 44px;
  position: relative;
}

.split-visual::after {
  content: '{ }';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  font-family: 'DM Serif Display', serif;
  font-size: clamp(60px, 10vw, 120px);
  color: rgba(0,200,255,.1);
  letter-spacing: -6px;
  white-space: nowrap;
}

.split-text {
  background: var(--slate);
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(48px, 7vw, 90px);
}

.split-text h2 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(26px, 3vw, 44px);
  font-weight: 400;
  line-height: 1.15;
}

.split-text p {
  font-size: clamp(13px, 1.3vw, 15px);
  font-weight: 300;
  color: var(--muted);
  line-height: 1.9;
  margin-bottom: 12px;
}

.list {
  margin: 18px 0 28px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  list-style: none;
}

.list li {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 13px;
  font-weight: 300;
  color: #1a2332;
}

.list li::before {
  content: '';
  width: 22px; height: 1px;
  background: var(--cyan);
  flex-shrink: 0;
}


/* ── Stack ── */
#stack {
  background: var(--dark);
  padding: clamp(60px, 9vw, 110px) clamp(20px, 5vw, 70px);
}

#stack .section-head h2 { color: #fff; }

.amenities {
  max-width: 1300px;
  margin: clamp(36px, 5vw, 52px) auto 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
}

.am {
  border: 1px solid rgba(0,200,255,.1);
  padding: clamp(24px, 3vw, 38px) clamp(18px, 2vw, 28px);
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: background .3s;
}

.am:hover { background: rgba(0,200,255,.05); }

.am-icon { font-size: 22px; }

.am h4 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(16px, 1.6vw, 20px);
  font-weight: 400;
  color: #fff;
}

.am p {
  font-size: 12px;
  font-weight: 300;
  color: rgba(255,255,255,.4);
  line-height: 1.7;
}


/* ── Depoimentos ── */
#depoimentos {
  padding: clamp(60px, 8vw, 100px) 0;
  overflow: hidden;
}

.dep-track {
  display: flex;
  gap: 20px;
  width: max-content;
  animation: slide 30s linear infinite;
}

.dep-track:hover { animation-play-state: paused; }

@keyframes slide {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

.dep {
  width: clamp(270px, 28vw, 360px);
  flex-shrink: 0;
  padding: 28px 24px;
  background: var(--slate);
  border-left: 2px solid var(--cyan);
}

.dep-stars {
  color: var(--cyan);
  font-size: 13px;
  margin-bottom: 14px;
}

.dep blockquote {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(14px, 1.5vw, 17px);
  font-weight: 400;
  font-style: italic;
  line-height: 1.7;
  color: var(--dark);
  margin-bottom: 16px;
}

.dep cite {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--cyan);
  font-style: normal;
}


/* ── Contato ── */

.loc-text {
  max-width: 860px;
  margin: 0 auto;
  padding: clamp(60px, 9vw, 110px) clamp(20px, 5vw, 70px);
  color: black;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.loc-text h2 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(26px, 3vw, 42px);
  font-weight: 400;
  color: black;
}

.loc-text h2 em { font-style: italic; color: var(--cyan); }

.loc-text .line { background: var(--cyan); }

.loc-text p {
  font-size: 13px;
  font-weight: 300;
  color: black;
  line-height: 1.9;
  margin-bottom: 24px;
  max-width: 520px;
}

.loc-items {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 40px;
  margin-bottom: 32px;
  color: black;
  width: 100%;
}

.loc-item {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}

.loc-icon {
  width: 32px; height: 32px;
  border: 1px solid rgba(0,200,255,.25);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  flex-shrink: 0;
  margin-top: 2px;
}

.loc-item strong {
  display: block;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--cyan);
  margin-bottom: 3px;
}

.loc-item span {
  font-size: 12px;
  font-weight: 300;
  color: black;
}


/* ── CTA Orçamento ── */
#orcamento {
  position: relative;
  padding: clamp(80px, 11vw, 140px) 20px;
  text-align: center;
  overflow: hidden;
}

.orcamento-bg {
  position: absolute;
  inset: 0;
  background: var(--dark);
  background-image:
    linear-gradient(rgba(0,200,255,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,200,255,.07) 1px, transparent 1px);
  background-size: 52px 52px;
}

.orcamento-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 60% at 50% 50%, rgba(0,200,255,.1) 0%, transparent 70%);
}

#orcamento .inner {
  position: relative;
  z-index: 2;
}

#orcamento h2 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(32px, 5vw, 62px);
  font-weight: 400;
  color: #fff;
  line-height: 1.1;
  margin-bottom: 14px;
}

#orcamento h2 em { font-style: italic; color: var(--cyan); }

#orcamento p {
  font-size: clamp(13px, 1.4vw, 16px);
  font-weight: 300;
  color: rgba(255,255,255,.6);
  max-width: 480px;
  margin: 0 auto 32px;
  line-height: 1.8;
}

.tel {
  margin-top: 20px;
  font-size: 12px;
  font-weight: 300;
  color: rgba(255,255,255,.4);
  letter-spacing: 1px;
}

.tel a { color: var(--cyan); transition: color .3s; }
.tel a:hover { color: #7ee8ff; }


/* ── Footer ── */
footer {
  background: var(--dark);
  padding: clamp(44px, 6vw, 70px) clamp(20px, 5vw, 70px) 28px;
  border-top: 1px solid rgba(0,200,255,.1);
}

.ft {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: clamp(24px, 4vw, 56px);
  padding-bottom: 40px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  margin-bottom: 24px;
}

.ft-brand span {
  font-family: 'DM Serif Display', serif;
  font-size: 20px;
  letter-spacing: 1px;
  color: #fff;
  display: block;
}

.ft-brand small {
  font-size: 9px;
  letter-spacing: 3px;
  color: var(--cyan);
  text-transform: uppercase;
  display: block;
  margin-bottom: 16px;
}

.ft-brand p {
  font-size: 12px;
  font-weight: 300;
  color: rgba(255,255,255,.35);
  line-height: 1.8;
  max-width: 260px;
}

.ft-col h5 {
  font-size: 9px;
  font-weight: 500;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--cyan);
  margin-bottom: 16px;
}

.ft-col ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 9px;
}

.ft-col ul a {
  font-size: 12px;
  font-weight: 300;
  color: rgba(255,255,255,.35);
  transition: color .3s;
}

.ft-col ul a:hover { color: #fff; }

.ft-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}

.ft-bottom p {
  font-size: 10px;
  font-weight: 300;
  color: rgba(255,255,255,.2);
}

.socials { display: flex; gap: 12px; }

.socials a {
  width: 32px; height: 32px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  color: rgba(255,255,255,.35);
  transition: .3s;
}

.socials a:hover {
  border-color: var(--cyan);
  color: var(--cyan);
}


/* ── Reveal ── */
.reveal {
  opacity: 0;
  transform: translateY(26px);
  transition: opacity .65s ease, transform .65s ease;
}

.reveal.on { opacity: 1; transform: none; }

.d1 { transition-delay: .1s; }
.d2 { transition-delay: .2s; }
.d3 { transition-delay: .3s; }


/* ── Responsivo ── */
@media (max-width: 1100px) {
  .amenities { grid-template-columns: repeat(2, 1fr); }
  .ft { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 860px) {
  .sobre-wrap, #processo { grid-template-columns: 1fr; }

  .sobre-img { aspect-ratio: 16/9; max-height: 320px; }

  .split-visual { min-height: 280px; }

  .cards { grid-template-columns: 1fr; max-width: 400px; margin-left: auto; margin-right: auto; }

  .loc-items { grid-template-columns: 1fr; }

  .nav-links, .nav-cta { display: none; }
  .burger { display: flex; }
}

@media (max-width: 600px) {
  .amenities { grid-template-columns: 1fr 1fr; }
  .ft { grid-template-columns: 1fr; }
  .stats { flex-wrap: wrap; }
}