/* ============================================================
   AFTER CHAOS — style.css
   Estrutura: variáveis → reset → utilitários → componentes
   ============================================================ */

/* ── VARIÁVEIS ─────────────────────────────────────────────── */
:root {
  --ink:   #050505;
  --ink2:  #0a0a0a;
  --ink3:  #121212;
  --blood:  #e61919;
  --blood2: #ff2b2b;
  --gold:   #d4af37;
  --gold2:  #f4cf6a;
  --cream:  #f8f4f0;
  --cream2: #e0d8cc;
  --smoke:  #a09b96;
  --line:   rgba(212, 175, 55, 0.15);
  --glass:  rgba(255, 255, 255, 0.03);
  --glass-border: rgba(255, 255, 255, 0.08);
  --ff-d: 'Bebas Neue', sans-serif;
  --ff-s: 'DM Serif Display', serif;
  --ff-b: 'DM Sans', sans-serif;
  --transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

/* ── RESET ──────────────────────────────────────────────────── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html  { scroll-behavior: smooth; overflow-x: hidden; }
body  {
  font-family: var(--ff-b);
  background: var(--ink);
  color: var(--cream);
  overflow-x: hidden;
  cursor: none;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

/* Em touch, restaura cursor normal */
@media (pointer: coarse) {
  body { cursor: auto; }
  button, a, [role="button"] { cursor: pointer; }
}

/* Safe area para iPhone com notch */
.nav {
  padding-left: max(60px, env(safe-area-inset-left));
  padding-right: max(60px, env(safe-area-inset-right));
}
@media (max-width: 768px) {
  .nav {
    padding-left: max(20px, env(safe-area-inset-left));
    padding-right: max(20px, env(safe-area-inset-right));
  }
  .hero, .sec, .testis, .cta-band, .footer {
    padding-left: max(20px, env(safe-area-inset-left));
    padding-right: max(20px, env(safe-area-inset-right));
  }
  .footer {
    padding-bottom: max(48px, env(safe-area-inset-bottom));
  }
}

::-webkit-scrollbar       { width: 4px; }
::-webkit-scrollbar-track { background: var(--ink); }
::-webkit-scrollbar-thumb { background: var(--blood); border-radius: 10px; }

/* ── UTILITÁRIOS ────────────────────────────────────────────── */
/* Reveal System */
.rev { opacity: 0; transform: translateY(40px); transition: all 1s cubic-bezier(0.16, 1, 0.3, 1); }
.rev.vis { opacity: 1; transform: translateY(0); }
.rev.fr  { transform: translateX(40px); }
.rev.fl  { transform: translateX(-40px); }
.rev.vis.fr, .rev.vis.fl { transform: translateX(0); }

/* Section tag */
.sec-tag {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  font-size: 11px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 24px;
}
.sec-tag::before { content: ''; width: 40px; height: 1px; background: var(--gold); }

/* Section heading */
.sec-h {
  font-family: var(--ff-s);
  font-size: clamp(48px, 6vw, 90px);
  line-height: 1.1;
  font-weight: 400;
  color: var(--cream);
  margin-bottom: 60px;
}
.sec-h em {
  font-style: italic;
  color: var(--gold2);
  text-decoration: underline;
  text-decoration-color: var(--blood);
  text-underline-offset: 8px;
}

/* Section base */
.sec { padding: 160px 60px; position: relative; }

/* Buttons */
.btn-cta {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 20px 48px;
  background: var(--blood);
  color: var(--cream);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  transition: var(--transition);
  border-radius: 4px;
}
.btn-cta::before {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 100%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.2), transparent);
  transition: .6s;
}
.btn-cta:hover { background: var(--blood2); transform: translateY(-4px); box-shadow: 0 10px 30px rgba(230,25,25,.3); }
.btn-cta:hover::before { left: 100%; }

.btn-gh {
  font-size: 12px;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--smoke);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 12px;
  transition: var(--transition);
  font-weight: 600;
}
.btn-gh::after { content: ''; width: 32px; height: 1px; background: currentColor; transition: var(--transition); }
.btn-gh:hover { color: var(--cream); gap: 20px; }
.btn-gh:hover::after { width: 56px; background: var(--gold); }

/* ── CURSOR ─────────────────────────────────────────────────── */
#cur {
  position: fixed;
  width: 8px; height: 8px;
  background: var(--blood2);
  border-radius: 50%;
  pointer-events: none;
  z-index: 10000;
  transform: translate(-50%, -50%);
  transition: width .3s, height .3s, background .3s;
}
#cur-r {
  position: fixed;
  width: 40px; height: 40px;
  border: 1px solid rgba(212,175,55,.4);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%);
  transition: width .4s, height .4s, border-color .4s, background .4s;
}
body:has(a:hover, button:hover, .p-item:hover) #cur { width: 4px; height: 4px; background: var(--gold2); }
body:has(a:hover, button:hover, .p-item:hover) #cur-r {
  width: 60px; height: 60px;
  border-color: var(--gold);
  background: rgba(212,175,55,.05);
}

/* ── NAV ────────────────────────────────────────────────────── */
.nav {
  position: fixed;
  top: 0; left: 0;
  width: 100%;
  z-index: 1000;
  padding: 32px 60px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: var(--transition);
  border-bottom: 1px solid transparent;
}
.nav.stuck {
  padding: 16px 60px;
  background: rgba(5,5,5,.85);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--glass-border);
}

.nav-logo {
  font-family: var(--ff-d);
  font-size: 28px;
  letter-spacing: .15em;
  color: var(--cream);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 12px;
}
.nav-mark {
  width: 24px; height: 24px;
  background: var(--blood);
  clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
  flex-shrink: 0;
  animation: pulse 2s infinite ease-in-out;
}

@keyframes pulse {
  0%   { transform: scale(1);    box-shadow: 0 0 0 0   rgba(230,25,25,.4); }
  70%  { transform: scale(1.05); box-shadow: 0 0 0 10px rgba(230,25,25,0); }
  100% { transform: scale(1); }
}

.nav-links { display: flex; gap: 40px; list-style: none; }
.nav-links a {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--smoke);
  text-decoration: none;
  transition: var(--transition);
  position: relative;
}
.nav-links a::after {
  content: '';
  position: absolute;
  bottom: -4px; left: 0;
  width: 0; height: 1px;
  background: var(--blood);
  transition: var(--transition);
}
.nav-links a:hover { color: var(--cream); }
.nav-links a:hover::after { width: 100%; }

.nav-btn {
  font-family: var(--ff-b);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .25em;
  text-transform: uppercase;
  padding: 14px 32px;
  background: transparent;
  border: 1px solid var(--gold);
  color: var(--gold);
  cursor: none;
  transition: var(--transition);
  border-radius: 2px;
}
.nav-btn:hover { background: var(--gold); color: var(--ink); box-shadow: 0 0 20px rgba(212,175,55,.3); }

/* Mobile menu */
.mob-btn {
  display: none;
  background: none; border: none;
  cursor: none;
  flex-direction: column;
  gap: 6px;
  padding: 10px;
  z-index: 1001;
}
.mob-btn span { display: block; width: 28px; height: 2px; background: var(--cream); transition: var(--transition); }

.mob-ov {
  position: fixed; inset: 0;
  background: var(--ink);
  z-index: 2000;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 40px;
  opacity: 0;
  pointer-events: none;
  transition: var(--transition);
}
.mob-ov.open { opacity: 1; pointer-events: all; }
.mob-ov a {
  font-family: var(--ff-d);
  font-size: 50px;
  color: var(--cream);
  text-decoration: none;
  letter-spacing: .1em;
  transition: var(--transition);
}
.mob-ov a:hover { color: var(--blood); transform: scale(1.1); }
.mob-cls {
  position: absolute; top: 40px; right: 40px;
  font-size: 30px; color: var(--cream);
  background: none; border: none; cursor: none;
}

/* ── HERO ───────────────────────────────────────────────────── */
.hero {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  overflow: hidden;
  padding: 0 60px;
}
.hero-bg {
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(circle at 70% 30%, rgba(230,25,25,.15) 0%, transparent 50%),
    radial-gradient(circle at 20% 70%, rgba(212,175,55,.10) 0%, transparent 50%),
    var(--ink);
  animation: bg-shift 20s infinite alternate ease-in-out;
}
@keyframes bg-shift { 0% { transform: scale(1); } 100% { transform: scale(1.1); } }

.hero-bg-txt {
  position: absolute; bottom: -5%; left: -2%; z-index: 0;
  font-family: var(--ff-d);
  font-size: clamp(200px, 25vw, 400px);
  letter-spacing: -.03em;
  color: transparent;
  -webkit-text-stroke: 1px rgba(255,255,255,.03);
  line-height: .8;
  user-select: none;
  white-space: nowrap;
  animation: bgdrift 40s linear infinite;
}
@keyframes bgdrift { from { transform: translateX(0); } to { transform: translateX(-15%); } }

.hero-inner {
  position: relative; z-index: 2;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  align-items: center;
  gap: 80px;
  padding-top: 120px;
  padding-bottom: 100px;
}

.hero-eye { display: flex; align-items: center; gap: 16px; margin-bottom: 32px; opacity: 0; animation: fade-in 1s .2s forwards; }
.hero-dot { width: 8px; height: 8px; background: var(--blood2); border-radius: 50%; animation: blink 2s infinite; }
.hero-eye-txt { font-size: 11px; letter-spacing: .35em; text-transform: uppercase; color: var(--smoke); font-weight: 500; }
@keyframes blink { 0%, 100% { opacity:1; transform:scale(1); } 50% { opacity:.4; transform:scale(.8); } }

.hero-h {
  font-family: var(--ff-d);
  font-size: clamp(60px, 8vw, 120px);
  line-height: 1.2;
  letter-spacing: .02em;
  margin-bottom: 40px;
}
.hero-h .ln { display: block; overflow: hidden; padding-top: 8px; margin-top: -8px; }
.hero-h .ln span { display: block; transform: translateY(100%); animation: slide-up 1s cubic-bezier(.16,1,.3,1) forwards; }
.hero-h .ln:nth-child(1) span { animation-delay: .3s; }
.hero-h .ln:nth-child(2) span { animation-delay: .45s; }
.hero-h .ln:nth-child(3) span { animation-delay: .6s; }
@keyframes slide-up { to { transform: translateY(0); } }
@keyframes fade-in  { to { opacity: 1; transform: translateY(0); } }

.hero-h .ac { color: transparent; -webkit-text-stroke: 2px var(--blood); position: relative; }
.hero-h .ac::after {
  content: '';
  position: absolute;
  bottom: 10%; left: 0;
  width: 100%; height: 8px;
  background: var(--blood);
  opacity: .2; z-index: -1;
  transform: skewX(-15deg);
}

.hero-p {
  font-size: 17px; line-height: 1.8;
  color: var(--smoke);
  max-width: 500px;
  margin-bottom: 56px;
  opacity: 0; transform: translateY(20px);
  animation: fade-in 1s .8s forwards;
}
.hero-acts { display: flex; align-items: center; gap: 32px; }

/* Stats */
.hero-right {
  display: flex; flex-direction: column; gap: 20px;
  opacity: 0; transform: translateX(40px);
  animation: fade-in 1s 1.2s forwards;
}
.h-stat {
  padding: 40px;
  background: var(--glass);
  border: 1px solid var(--glass-border);
  backdrop-filter: blur(10px);
  transition: var(--transition);
  border-radius: 4px;
  position: relative; overflow: hidden;
}
.h-stat::before {
  content: '';
  position: absolute; top: 0; left: 0;
  width: 3px; height: 0;
  background: var(--gold);
  transition: var(--transition);
}
.h-stat:hover { transform: translateX(-10px); background: rgba(255,255,255,.06); }
.h-stat:hover::before { height: 100%; }
.h-stat-n { font-family: var(--ff-d); font-size: 64px; line-height: 1; color: var(--cream); display: flex; align-items: flex-start; }
.h-stat-n sup { font-size: 24px; color: var(--gold); margin-left: 4px; margin-top: 10px; }
.h-stat-l { font-size: 11px; letter-spacing: .3em; text-transform: uppercase; color: var(--smoke); margin-top: 12px; font-weight: 500; }

/* Bottom bar */
.hero-bar {
  position: relative; z-index: 2;
  display: flex; align-items: center; justify-content: space-between;
  padding: 40px 0;
  border-top: 1px solid var(--line);
  margin-top: auto;
  opacity: 0; animation: fade-in 1s 1.4s forwards;
}
.hbar-tags { display: flex; gap: 16px; flex-wrap: wrap; }
.hbar-tag {
  font-size: 10px; letter-spacing: .25em; text-transform: uppercase;
  color: var(--smoke);
  padding: 10px 24px;
  border: 1px solid var(--glass-border);
  background: var(--glass);
  border-radius: 20px;
  transition: var(--transition);
}
.hbar-tag:hover { border-color: var(--gold); color: var(--gold2); transform: translateY(-2px); }
.hbar-scroll { display: flex; align-items: center; gap: 16px; font-size: 10px; letter-spacing: .3em; text-transform: uppercase; color: var(--smoke); }
.hbar-line { width: 60px; height: 1px; background: var(--glass-border); position: relative; overflow: hidden; }
.hbar-line::after {
  content: '';
  position: absolute; top: 0; left: -100%;
  width: 100%; height: 100%;
  background: var(--blood);
  animation: spulse 3s infinite;
}
@keyframes spulse { 0%{left:-100%} 50%{left:0} 100%{left:100%} }

/* ── MARQUEE ────────────────────────────────────────────────── */
.mq-wrap {
  overflow: hidden;
  background: var(--blood);
  padding: 24px 0;
  border-top: 1px solid rgba(255,255,255,.1);
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.mq-track { display: flex; animation: mq 30s linear infinite; white-space: nowrap; }
.mq-track:hover { animation-play-state: paused; }
@keyframes mq { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.mq-i {
  display: inline-flex; align-items: center; gap: 40px;
  padding: 0 40px;
  font-family: var(--ff-d); font-size: 24px; letter-spacing: .15em;
  color: var(--cream); text-transform: uppercase;
}
.mq-dot { width: 8px; height: 8px; background: rgba(255,255,255,.5); border-radius: 50%; flex-shrink: 0; }

/* ── ABOUT ──────────────────────────────────────────────────── */
.about { background: var(--ink2); }
.about-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 100px; align-items: center; }

.about-frame { position: relative; aspect-ratio: 3/4; border-radius: 4px; overflow: hidden; box-shadow: 0 30px 60px rgba(0,0,0,.5); }
.about-frame img { width: 100%; height: 100%; object-fit: cover; transition: transform 1s cubic-bezier(.16,1,.3,1); filter: grayscale(20%); }
.about-frame:hover img { transform: scale(1.05); filter: grayscale(0); }

.about-badge {
  position: absolute; bottom: 40px; right: -20px;
  width: 140px; height: 140px;
  background: var(--blood);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  z-index: 2;
  box-shadow: 0 20px 40px rgba(230,25,25,.4);
  animation: float 4s infinite alternate ease-in-out;
}
@keyframes float { from{transform:translateY(0)} to{transform:translateY(-15px)} }
.about-badge .n { font-family: var(--ff-d); font-size: 60px; line-height: 1; color: var(--cream); }
.about-badge .l { font-size: 11px; letter-spacing: .3em; text-transform: uppercase; color: rgba(255,255,255,.8); margin-top: 4px; }

.about-r p { font-size: 18px; line-height: 1.8; color: var(--smoke); margin-bottom: 28px; font-weight: 300; }
.about-r p strong { color: var(--cream); font-weight: 600; }

.about-tools { display: flex; flex-wrap: wrap; gap: 12px; margin: 48px 0; }
.t-tag {
  font-size: 11px; letter-spacing: .25em; text-transform: uppercase;
  padding: 12px 28px;
  border: 1px solid var(--line); color: var(--smoke);
  transition: var(--transition); background: var(--glass); border-radius: 2px;
}
.t-tag:hover { border-color: var(--gold); color: var(--gold2); transform: translateY(-4px); background: rgba(255,255,255,.05); }

.about-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; margin-top: 60px; }
.a-stat { padding: 32px; background: var(--glass); border: 1px solid var(--glass-border); transition: var(--transition); border-radius: 4px; }
.a-stat:hover { transform: translateY(-8px); background: rgba(255,255,255,.06); border-color: var(--gold); }
.a-stat-n { font-family: var(--ff-d); font-size: 56px; line-height: 1; color: var(--cream); }
.a-stat-n span { color: var(--blood); font-size: 32px; margin-left: 2px; }
.a-stat-l { font-size: 11px; letter-spacing: .3em; text-transform: uppercase; color: var(--smoke); margin-top: 10px; font-weight: 600; }

/* ── PORTFOLIO ──────────────────────────────────────────────── */
.port-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 80px; flex-wrap: wrap; gap: 40px; }
.port-filters { display: flex; gap: 12px; background: var(--glass); padding: 6px; border-radius: 40px; border: 1px solid var(--glass-border); }
.f-btn {
  font-size: 11px; letter-spacing: .3em; text-transform: uppercase;
  padding: 14px 32px;
  background: transparent; border: none;
  color: var(--smoke); cursor: none;
  transition: var(--transition); border-radius: 30px; font-weight: 600;
}
.f-btn:hover { color: var(--cream); }
.f-btn.on { background: var(--blood); color: var(--cream); box-shadow: 0 10px 20px rgba(230,25,25,.3); }

.port-grid { display: grid; grid-template-columns: repeat(12,1fr); gap: 16px; }
.p-item { grid-column: span 4; }
.p-item {
  position: relative; overflow: hidden;
  background: var(--ink3); text-decoration: none;
  border-radius: 4px; aspect-ratio: 16/9;
}
.p-item img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center top;
  display: block;
  transition: transform 1.2s cubic-bezier(.16,1,.3,1), filter .8s;
  filter: brightness(.85) grayscale(20%);
}
.p-item:hover img { transform: scale(1.06); filter: brightness(1) grayscale(0); }
.p-over {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.9) 0%, transparent 60%);
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 40px; opacity: 0; transition: opacity .5s;
}
.p-item:hover .p-over { opacity: 1; }
.p-cat { font-size:11px; letter-spacing:.4em; text-transform:uppercase; color:var(--blood); margin-bottom:12px; font-weight:700; transform:translateY(20px); transition:var(--transition); }
.p-name { font-family:var(--ff-s); font-size:28px; color:var(--cream); font-weight:400; margin-bottom:8px; transform:translateY(20px); transition:var(--transition); transition-delay:.05s; }
.p-handle { font-size:13px; color:var(--smoke); transform:translateY(20px); transition:var(--transition); transition-delay:.1s; }
.p-item:hover .p-cat,.p-item:hover .p-name,.p-item:hover .p-handle { transform:translateY(0); }
.p-play {
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%) scale(.8);
  width:80px; height:80px;
  background:rgba(230,25,25,.9); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:var(--transition);
  box-shadow:0 0 40px rgba(230,25,25,.5);
}
.p-item:hover .p-play { transform:translate(-50%,-50%) scale(1); opacity:1; }
.p-play svg { width:24px; height:24px; fill:var(--cream); margin-left:4px; }

/* ── SERVICES ───────────────────────────────────────────────── */
.services { background: var(--ink2); }
.svc-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 24px; margin-top: 80px; }
.svc {
  padding: 60px; background: var(--glass);
  border: 1px solid var(--glass-border);
  position: relative; overflow: hidden;
  transition: var(--transition); border-radius: 4px;
}
.svc::before {
  content: '';
  position: absolute; top:0; left:0;
  width:100%; height:4px;
  background: linear-gradient(90deg,var(--blood),var(--gold));
  transform:scaleX(0); transform-origin:left;
  transition: transform .6s cubic-bezier(.16,1,.3,1);
}
.svc:hover { background:rgba(255,255,255,.05); transform:translateY(-10px); }
.svc:hover::before { transform:scaleX(1); }
.svc-n { font-family:var(--ff-d); font-size:120px; line-height:1; color:rgba(255,255,255,.03); position:absolute; top:10px; right:20px; letter-spacing:-.05em; transition:var(--transition); }
.svc:hover .svc-n { color:rgba(230,25,25,.08); transform:translateY(-10px); }
.svc-ico { width:64px; height:64px; display:flex; align-items:center; justify-content:center; background:rgba(230,25,25,.1); border-radius:12px; margin-bottom:40px; transition:var(--transition); }
.svc:hover .svc-ico { background:var(--blood); transform:rotate(10deg); }
.svc:hover .svc-ico svg { stroke:var(--cream); }
.svc-ico svg { width:28px; height:28px; stroke:var(--blood); fill:none; stroke-width:2; transition:var(--transition); }
.svc-title { font-family:var(--ff-s); font-size:32px; font-weight:400; color:var(--cream); margin-bottom:12px; }
.svc-sub { font-size:11px; letter-spacing:.35em; text-transform:uppercase; color:var(--gold); margin-bottom:24px; font-weight:700; }
.svc-desc { font-size:16px; line-height:1.8; color:var(--smoke); font-weight:300; }

/* ── PRICING ────────────────────────────────────────────────── */
.pricing { background:var(--ink); border-top:1px solid var(--line); position:relative; }
.plans-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:80px; }
.plan-card {
  padding:60px 40px; background:var(--glass);
  border:1px solid var(--glass-border); border-radius:4px;
  transition:var(--transition); position:relative; overflow:hidden;
  display:flex; flex-direction:column;
}
.plan-card:hover { transform:translateY(-12px); background:rgba(255,255,255,.05); border-color:var(--accent); }
.plan-card::after {
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at top right,rgba(255,255,255,.05) 0%,transparent 70%);
  opacity:0; transition:var(--transition);
}
.plan-card:hover::after { opacity:1; }
.plan-n { font-family:var(--ff-d); font-size:140px; line-height:1; color:rgba(255,255,255,.02); position:absolute; bottom:-20px; right:-10px; letter-spacing:-.05em; z-index:0; transition:var(--transition); }
.plan-card:hover .plan-n { color:rgba(255,255,255,.05); transform:scale(1.1); }
.plan-card > * { position:relative; z-index:2; }
.p-starter { --accent:#2ecc71; }
.p-pro     { --accent:#3498db; }
.p-premium { --accent:var(--blood); }
.p-long    { --accent:var(--gold); }
.plan-ico { width:56px; height:56px; display:flex; align-items:center; justify-content:center; background:rgba(255,255,255,.03); border-radius:12px; margin-bottom:32px; border:1px solid var(--glass-border); transition:var(--transition); }
.plan-card:hover .plan-ico { background:var(--accent); transform:rotate(8deg); border-color:transparent; }
.plan-ico svg { width:24px; height:24px; stroke:var(--accent); fill:none; stroke-width:2; transition:var(--transition); }
.plan-card:hover .plan-ico svg { stroke:var(--ink); }
.plan-badge { font-size:10px; letter-spacing:.3em; text-transform:uppercase; color:var(--accent); margin-bottom:12px; font-weight:700; }
.plan-title { font-family:var(--ff-s); font-size:34px; color:var(--cream); margin-bottom:12px; font-weight:400; }
.plan-sub { font-size:14px; color:var(--smoke); margin-bottom:32px; line-height:1.6; font-weight:300; }
.plan-price { font-family:var(--ff-d); font-size:52px; color:var(--cream); margin-bottom:40px; display:flex; align-items:baseline; gap:8px; line-height:1; }
.plan-price span { font-size:13px; font-family:var(--ff-b); color:var(--smoke); letter-spacing:.1em; text-transform:uppercase; }
.plan-features { list-style:none; margin-bottom:48px; flex-grow:1; border-top:1px solid var(--glass-border); padding-top:32px; }
.plan-features li { font-size:14px; color:var(--smoke); margin-bottom:18px; display:flex; align-items:flex-start; gap:12px; line-height:1.4; }
.plan-features li::before { content:'✓'; color:var(--accent); font-size:14px; font-weight:700; flex-shrink:0; }
.plan-btn {
  width:100%; padding:18px;
  background:transparent; border:1px solid var(--glass-border);
  color:var(--cream); font-size:11px; letter-spacing:.25em; text-transform:uppercase;
  font-weight:700; border-radius:4px; transition:var(--transition);
  text-align:center; text-decoration:none; backdrop-filter:blur(5px);
}
.plan-card:hover .plan-btn { background:var(--accent); color:var(--ink); border-color:var(--accent); box-shadow:0 10px 30px rgba(0,0,0,.3); }

/* ── PROCESS ────────────────────────────────────────────────── */
.process { background:var(--ink); border-top:1px solid var(--line); }
.proc-row { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:80px; }
.proc { padding:48px 40px; background:var(--glass); border:1px solid var(--glass-border); border-radius:4px; transition:var(--transition); }
.proc:hover { transform:translateY(-8px); border-color:var(--gold); background:rgba(255,255,255,.05); }
.proc-n { font-family:var(--ff-d); font-size:48px; color:var(--blood); margin-bottom:24px; opacity:.5; }
.proc-t { font-family:var(--ff-s); font-size:24px; color:var(--cream); margin-bottom:16px; }
.proc-d { font-size:14px; line-height:1.7; color:var(--smoke); font-weight:300; }

/* ── TESTIMONIALS ───────────────────────────────────────────── */
.testis { padding:160px 60px; background:var(--ink2); }
.testi-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:32px; margin-top:80px; }
.tcard {
  padding:60px; background:var(--glass);
  border:1px solid var(--glass-border); border-radius:8px;
  transition:var(--transition); position:relative;
}
.tcard::after {
  content:'"'; position:absolute; top:20px; right:40px;
  font-family:var(--ff-s); font-size:100px;
  color:rgba(230,25,25,.1); line-height:1;
}
.tcard:hover { transform:translateY(-10px); border-color:var(--blood); background:rgba(255,255,255,.05); }
.tcard-txt { font-size:20px; line-height:1.7; color:var(--cream2); margin-bottom:40px; font-style:italic; position:relative; z-index:1; }
.tcard-auth { display:flex; align-items:center; gap:20px; }
.tcard-av { width:64px; height:64px; border-radius:50%; object-fit:cover; border:2px solid var(--blood); }
.tcard-name { font-size:18px; font-weight:600; color:var(--cream); margin-bottom:4px; }
.tcard-role { font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--smoke); }

/* ── CTA BAND ───────────────────────────────────────────────── */
.cta-band {
  padding:120px 60px;
  background:linear-gradient(135deg,var(--blood),#900);
  display:flex; justify-content:space-between; align-items:center; gap:80px;
  margin:80px 60px; border-radius:8px;
  position:relative; overflow:hidden;
}
.cta-band::before {
  content:''; position:absolute; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100' viewBox='0 0 100 100'%3E%3Cg fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M96 95h4v1h-4v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4H0v-1h15v-9H0v-1h15v-9H0v-1h15v-9H0v-1h15v-9H0v-1h15v-9H0v-1h15v-9H0v-1h15v-9H0v-1h15v-9H0v-1h15V0h1v15h9V0h1v15h9V0h1v15h9V0h1v15h9V0h1v15h9V0h1v15h9V0h1v15h9V0h1v15h9V0h1v15h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  opacity:.1;
}
.cta-t { font-family:var(--ff-d); font-size:clamp(60px,8vw,100px); color:var(--cream); line-height:.9; }
.cta-t .red { color:var(--ink); }
.cta-desc { font-size:20px; color:rgba(255,255,255,.9); max-width:440px; margin-bottom:40px; }
.cta-band .btn-cta { background:var(--ink); color:var(--blood); border-radius:4px; }
.cta-band .btn-cta:hover { background:var(--cream); color:var(--ink); box-shadow:0 10px 40px rgba(0,0,0,.3); }

/* ── CONTACT ────────────────────────────────────────────────── */
.quick-channels { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-bottom:48px; }
.qc-card {
  display:flex; align-items:center; gap:20px;
  padding:28px 32px; border-radius:8px;
  text-decoration:none;
  border:1px solid var(--glass-border); background:var(--glass);
  transition:var(--transition); position:relative; overflow:hidden;
}
.qc-card::before { content:''; position:absolute; inset:0; opacity:0; transition:opacity .4s; }
.qc-card:hover { transform:translateY(-6px); }
.qc-card:hover::before { opacity:1; }
.whatsapp::before  { background:rgba(37,211,102,.08); }
.whatsapp:hover    { border-color:#25d366; box-shadow:0 10px 30px rgba(37,211,102,.15); }
.whatsapp .qc-ico  { color:#25d366; }
.instagram::before { background:rgba(225,48,108,.08); }
.instagram:hover   { border-color:#e1306c; box-shadow:0 10px 30px rgba(225,48,108,.15); }
.instagram .qc-ico { color:#e1306c; }
.discord::before   { background:rgba(88,101,242,.08); }
.discord:hover     { border-color:#5865f2; box-shadow:0 10px 30px rgba(88,101,242,.15); }
.discord .qc-ico   { color:#5865f2; }
.qc-ico { width:52px; height:52px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.qc-ico svg { width:32px; height:32px; }
.qc-label { font-size:10px; letter-spacing:.25em; text-transform:uppercase; color:var(--smoke); margin-bottom:4px; }
.qc-name { font-size:20px; font-weight:700; color:var(--cream); }
.qc-arrow { margin-left:auto; font-size:20px; color:var(--smoke); transition:var(--transition); }
.qc-card:hover .qc-arrow { transform:translateX(6px); color:var(--cream); }

.contact-divider { display:flex; align-items:center; gap:20px; margin:48px 0; color:var(--smoke); font-size:12px; letter-spacing:.2em; text-transform:uppercase; }
.cd-line { flex:1; height:1px; background:var(--line); }

.cf-wrap {
  padding:60px;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));
  border:1px solid var(--glass-border); border-radius:12px;
  position:relative; overflow:hidden; backdrop-filter:blur(10px);
}
.cf-wrap::before {
  content:''; position:absolute; top:0; left:0;
  width:100%; height:4px;
  background:linear-gradient(90deg,var(--blood),var(--gold));
  transform:scaleX(0); transform-origin:left;
  transition:transform .8s cubic-bezier(.16,1,.3,1);
}
.cf-wrap:hover::before { transform:scaleX(1); }
.cf-title { font-family:var(--ff-s); font-size:36px; color:var(--cream); margin-bottom:48px; position:relative; z-index:1; }
.f-row { display:grid; grid-template-columns:1fr 1fr; gap:28px; margin-bottom:28px; }
.f-row.full { grid-template-columns:1fr; }
.f-g { display:flex; flex-direction:column; gap:12px; position:relative; }
.f-g label { font-size:11px; letter-spacing:.25em; text-transform:uppercase; color:var(--gold); font-weight:700; transition:var(--transition); }
.f-g input,.f-g select,.f-g textarea {
  padding:18px 20px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.1);
  color:var(--cream); font-family:var(--ff-b); font-size:15px;
  border-radius:8px; transition:all .3s cubic-bezier(.16,1,.3,1);
  box-shadow:0 4px 20px rgba(0,0,0,.2) inset;
}
.f-g input::placeholder,.f-g textarea::placeholder { color:rgba(255,255,255,.4); font-weight:400; }
.f-g input:focus,.f-g select:focus,.f-g textarea:focus {
  outline:none; border-color:var(--blood);
  background:rgba(230,25,25,.05);
  box-shadow:0 0 25px rgba(230,25,25,.15),0 4px 20px rgba(0,0,0,.3) inset;
  transform:translateY(-2px);
}
.f-g textarea { height:160px; resize:vertical; min-height:120px; }
.f-g select {
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 16px center; background-size:12px;
  color:var(--cream); background-color:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.1);
}
.f-g select option { background:var(--ink2); color:var(--cream); }
.f-g select option:checked { background:var(--blood); }
.f-sub {
  width:100%; padding:22px 32px;
  background:linear-gradient(180deg,var(--blood),#b31313);
  color:var(--cream); border:none; font-family:var(--ff-b);
  font-size:13px; font-weight:800; letter-spacing:.35em; text-transform:uppercase;
  cursor:none; transition:all .3s cubic-bezier(.16,1,.3,1);
  border-radius:8px; margin-top:8px; position:relative; overflow:hidden;
}
.f-sub::before {
  content:''; position:absolute; top:0; left:-100%;
  width:100%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
  transition:left .8s;
}
.f-sub:hover { background:linear-gradient(180deg,var(--blood2),#c51616); transform:translateY(-4px); box-shadow:0 15px 40px rgba(230,25,25,.4),0 0 0 1px rgba(255,255,255,.1) inset; }
.f-sub:hover::before { left:100%; }
.f-sub:active { transform:translateY(-2px) scale(.98); }

/* ── FOOTER ─────────────────────────────────────────────────── */
.footer { padding:80px 60px; border-top:1px solid var(--line); display:flex; justify-content:space-between; align-items:center; background:var(--ink); }
.f-logo { font-family:var(--ff-d); font-size:24px; color:var(--cream); text-decoration:none; display:flex; align-items:center; gap:12px; letter-spacing:.1em; }
.f-mark { width:18px; height:18px; background:var(--blood); clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%); }
.f-copy { font-size:12px; color:var(--smoke); letter-spacing:.05em; }
.f-socs { display:flex; gap:24px; }
.f-soc { color:var(--smoke); transition:var(--transition); }
.f-soc:hover { color:var(--blood); transform:translateY(-4px); }
.f-soc svg { width:22px; height:22px; fill:currentColor; }

/* ── RESPONSIVE ─────────────────────────────────────────────── */

/* Tablet */
@media (max-width: 1100px) {
  .nav { padding:24px 30px; }
  .sec { padding:100px 30px; }
  .testis { padding:100px 30px; }

  .hero { padding:0 30px; }
  .hero-inner { grid-template-columns:1fr; gap:48px; text-align:center; padding-top:100px; padding-bottom:60px; }
  .hero-p { margin-left:auto; margin-right:auto; }
  .hero-acts { justify-content:center; flex-wrap:wrap; gap:20px; }
  .hero-right { transform:none; animation:fade-in 1s 1.2s forwards; flex-direction:row; flex-wrap:wrap; justify-content:center; gap:12px; }
  .h-stat { flex:1; min-width:140px; padding:28px 20px; }
  .h-stat-n { font-size:48px; }

  .hero-bar { flex-direction:column; align-items:flex-start; gap:20px; }

  .about-grid { grid-template-columns:1fr; gap:60px; }
  .about-frame { max-width:500px; margin:0 auto; }
  .about-badge { right:0; }
  .about-stats { grid-template-columns:repeat(3,1fr); }

  .port-head { flex-direction:column; align-items:flex-start; gap:24px; }

  .svc-grid { grid-template-columns:1fr; }
  .plans-grid { grid-template-columns:repeat(2,1fr); }
  .proc-row { grid-template-columns:repeat(2,1fr); }
  .testi-grid { grid-template-columns:1fr; }

  .cta-band { margin:40px 30px; flex-direction:column; text-align:center; padding:80px 30px; gap:40px; }
  .cta-r { display:flex; flex-direction:column; align-items:center; }

  .quick-channels { grid-template-columns:1fr; }
  .f-row { grid-template-columns:1fr; }

  .footer { padding:60px 30px; }
}

/* Mobile */
@media (max-width: 768px) {
  /* Cursor: desliga no touch */
  #cur, #cur-r { display:none; }
  body { cursor:auto; }
  button, a { cursor:pointer; }

  /* Nav */
  .nav { padding:20px 20px; }
  .nav.stuck { padding:14px 20px; }
  .nav-links, .nav-btn { display:none; }
  .mob-btn { display:flex; }
  .nav-logo { font-size:22px; }

  /* Mobile overlay — botões clicáveis */
  .mob-btn, .mob-cls { cursor:pointer; }
  .mob-ov a { cursor:pointer; font-size:40px; }

  /* Hero */
  .hero { padding:0 20px; min-height:100svh; }
  .hero-inner { padding-top:90px; padding-bottom:40px; gap:36px; }
  .hero-h { font-size:clamp(44px, 13vw, 64px); }
  .hero-eye { justify-content:center; }
  .hero-p { font-size:15px; max-width:100%; }
  .hero-acts { flex-direction:column; align-items:center; gap:16px; width:100%; }
  .btn-cta { width:100%; justify-content:center; padding:18px 32px; }
  .btn-gh { justify-content:center; }

  .hero-right { flex-direction:row; flex-wrap:wrap; gap:10px; }
  .h-stat { flex:1; min-width:calc(50% - 5px); padding:20px 16px; }
  .h-stat-n { font-size:40px; }
  .h-stat-n sup { font-size:18px; }
  .h-stat-l { font-size:10px; margin-top:8px; }

  .hero-bar { padding:28px 0; flex-direction:column; gap:16px; align-items:flex-start; }
  .hbar-tags { gap:8px; }
  .hbar-tag { font-size:9px; padding:8px 14px; }
  .hbar-scroll { display:none; }

  /* Sections */
  .sec { padding:80px 20px; }
  .testis { padding:80px 20px; }
  .sec-h { font-size:clamp(36px, 10vw, 52px); margin-bottom:40px; }

  /* About */
  .about-grid { gap:40px; }
  .about-frame { max-width:100%; }
  .about-badge { width:100px; height:100px; right:-10px; bottom:20px; }
  .about-badge .n { font-size:42px; }
  .about-badge .l { font-size:9px; }
  .about-r p { font-size:16px; }
  .about-tools { gap:8px; }
  .t-tag { font-size:10px; padding:10px 16px; }
  .about-stats { grid-template-columns:repeat(3,1fr); gap:12px; }
  .a-stat { padding:20px 14px; }
  .a-stat-n { font-size:36px; }
  .a-stat-n span { font-size:20px; }
  .a-stat-l { font-size:9px; margin-top:6px; }

  /* Portfolio */
  .port-head { margin-bottom:40px; }
  .port-filters { flex-wrap:wrap; gap:6px; }
  .f-btn { padding:10px 18px; font-size:10px; }
  .port-grid { gap:10px; }
  .p-item { grid-column:span 12 !important; aspect-ratio:16/10 !important; }
  .p-over { opacity:1; padding:24px; }
  .p-cat { transform:none; font-size:10px; }
  .p-name { transform:none; font-size:20px; }
  .p-handle { transform:none; }
  .p-play { display:none; }

  /* Services */
  .svc { padding:40px 28px; }
  .svc-title { font-size:26px; }
  .svc-grid { gap:16px; margin-top:48px; }

  /* Pricing */
  .plans-grid { grid-template-columns:1fr; gap:16px; margin-top:48px; }
  .plan-card { padding:40px 28px; }
  .plan-title { font-size:26px; }
  .plan-price { font-size:40px; }

  /* Process */
  .proc-row { grid-template-columns:1fr; gap:16px; margin-top:48px; }
  .proc { padding:32px 24px; }

  /* Testimonials */
  .testi-grid { gap:16px; margin-top:48px; }
  .tcard { padding:36px 24px; }
  .tcard-txt { font-size:16px; }
  .tcard::after { font-size:70px; top:10px; right:20px; }

  /* CTA Band */
  .cta-band { margin:40px 20px; padding:60px 24px; gap:32px; border-radius:8px; }
  .cta-t { font-size:clamp(48px, 14vw, 72px); }
  .cta-desc { font-size:16px; }
  .cta-band .btn-cta { width:100%; justify-content:center; }

  /* Contact */
  .quick-channels { grid-template-columns:1fr; gap:12px; margin-bottom:32px; }
  .qc-card { padding:20px 24px; }
  .qc-name { font-size:16px; }
  .cf-wrap { padding:32px 20px; }
  .f-row { grid-template-columns:1fr; gap:20px; margin-bottom:20px; }
  .f-row.full { margin-bottom:20px; }
  .f-g input, .f-g select, .f-g textarea { font-size:16px; /* evita zoom no iOS */ padding:16px; }
  .f-g textarea { height:130px; }
  .f-sub { padding:18px; font-size:12px; }
  .contact-divider { font-size:10px; }

  /* Footer */
  .footer { padding:48px 20px; flex-direction:column; gap:28px; text-align:center; }
  .f-socs { justify-content:center; }

  /* Marquee */
  .mq-i { font-size:18px; padding:0 24px; gap:24px; }
}

/* Mobile pequeno (iPhone SE, etc.) */
@media (max-width: 390px) {
  .hero-h { font-size:40px; }
  .h-stat { min-width:100%; }
  .about-stats { grid-template-columns:repeat(3,1fr); gap:8px; }
  .a-stat { padding:16px 8px; }
  .a-stat-n { font-size:28px; }
}

/* ── LANGUAGE SWITCHER ─────────────────────────────────────── */
.lang-switcher {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 20px;
}
.lang-btn {
  background: none;
  border: none;
  font-family: var(--ff-b);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  color: var(--smoke);
  cursor: pointer;
  padding: 4px 8px;
  transition: var(--transition);
  border-radius: 4px;
}
.lang-btn:hover {
  color: var(--cream);
}
.lang-btn.active {
  color: var(--gold);
  background: rgba(212, 175, 55, 0.1);
}
.lang-sep {
  color: var(--line);
  font-size: 10px;
  user-select: none;
}
.mob-lang {
  margin: 0 0 20px 0;
  justify-content: center;
}
.mob-lang .lang-btn {
  font-size: 16px;
  padding: 8px 16px;
}

@media (max-width: 1024px) {
  .nav .lang-switcher { display: none; }
}
