/* ============================================================
   EXPO ABRA — Visual Cyber-Brutalist 2026
   Paleta: preto profundo + neon ciano/magenta + amarelo elétrico
   ============================================================ */

:root{
  --bg:#07070a;
  --bg-2:#0d0d14;
  --ink:#f5f5f7;
  --muted:#9aa0aa;
  --line:#1a1a24;
  --neon-c:#00ffd1;     /* ciano neon */
  --neon-m:#ff2bd6;     /* magenta neon */
  --neon-y:#f5ff3d;     /* amarelo elétrico */
  --neon-v:#7a5cff;     /* violeta */
  --grad: conic-gradient(from 200deg at 50% 50%, #00ffd1, #7a5cff, #ff2bd6, #f5ff3d, #00ffd1);
  --shadow-neon: 0 0 0 1px rgba(0,255,209,.4), 0 0 24px rgba(0,255,209,.25);
  --shadow-mag:  0 0 0 1px rgba(255,43,214,.4), 0 0 24px rgba(255,43,214,.25);
  --r: 18px;
  --mono: ui-monospace, "JetBrains Mono", "SF Mono", Menlo, Consolas, monospace;
  --sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Inter, Roboto, system-ui, sans-serif;
  --display: "Arial Black", "Helvetica Neue", Impact, sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--sans);
  font-size:17px;
  line-height:1.6;
  color:var(--ink);
  background:var(--bg);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* Fundo animado em grade + ruído sutil */
body::before{
  content:"";
  position:fixed;inset:0;
  background:
    radial-gradient(900px 600px at 12% -10%, rgba(122,92,255,.18), transparent 60%),
    radial-gradient(700px 500px at 110% 20%, rgba(255,43,214,.15), transparent 60%),
    radial-gradient(800px 600px at 50% 120%, rgba(0,255,209,.12), transparent 60%),
    linear-gradient(var(--bg),var(--bg));
  z-index:-2;
}
body::after{
  content:"";
  position:fixed;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image: radial-gradient(ellipse at center, #000 30%, transparent 80%);
  z-index:-1;
  pointer-events:none;
  animation: drift 60s linear infinite;
}
@keyframes drift{ to{ background-position: 480px 480px } }

/* ============== TIPOGRAFIA BRUTAL ============== */
h1,h2,h3,h4{font-family:var(--display);letter-spacing:-.02em;line-height:1.02;margin:0 0 .4em}
h1{font-size:clamp(2.6rem, 7vw, 6rem); text-transform:uppercase}
h2{font-size:clamp(1.9rem, 4vw, 3.4rem); text-transform:uppercase}
h3{font-size:clamp(1.2rem, 2vw, 1.6rem)}
p{margin:0 0 1em;color:#d3d6dc}
a{color:var(--neon-c);text-decoration:none;transition:.2s}
a:hover{color:var(--neon-m)}
/* Links inline (em parágrafos e textos corridos) ganham sublinhado para acessibilidade */
p a, .body a, li a, blockquote a, .lead a{text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:2px}
p a:hover, .body a:hover, li a:hover, blockquote a:hover, .lead a:hover{text-decoration-thickness:2px}
strong{color:#fff}
code,kbd{font-family:var(--mono);background:#11111a;padding:2px 7px;border-radius:6px;border:1px solid var(--line);font-size:.92em;color:var(--neon-c)}

.glitch{position:relative;display:inline-block}
.glitch::before,.glitch::after{
  content:attr(data-text);position:absolute;left:0;top:0;width:100%;
  mix-blend-mode:screen;pointer-events:none
}
.glitch::before{color:var(--neon-c);transform:translate(-2px,0);clip-path:polygon(0 0,100% 0,100% 45%,0 45%)}
.glitch::after{color:var(--neon-m);transform:translate(2px,0);clip-path:polygon(0 55%,100% 55%,100% 100%,0 100%)}

.gradient-text{
  background:linear-gradient(95deg,var(--neon-c),var(--neon-v),var(--neon-m));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ============== LAYOUT ============== */
.wrap{width:min(1200px, 92%);margin:0 auto}

/* Barra topo */
.top-tape{
  background:var(--neon-y);
  color:#0a0a0f;
  font-family:var(--mono);
  font-weight:700;
  font-size:.8rem;
  text-transform:uppercase;
  letter-spacing:.18em;
  padding:9px 0;
  overflow:hidden;
  white-space:nowrap;
  position:relative;
  border-bottom:2px solid #000;
}
.top-tape span{display:inline-block;padding-right:48px;animation:tape 28s linear infinite}
@keyframes tape{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* Header */
header.site{
  position:sticky;top:0;z-index:50;
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  background: rgba(7,7,10,.65);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:18px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--display);font-size:1.25rem;text-transform:uppercase;color:#fff}
.brand .dot{width:14px;height:14px;border-radius:50%;background:var(--grad);box-shadow:0 0 18px var(--neon-c);animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{50%{transform:scale(1.18);filter:hue-rotate(40deg)}}
.menu{display:flex;gap:6px;flex-wrap:wrap}
.menu a{
  font-family:var(--mono);font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;
  color:#cfd2d8;padding:9px 14px;border-radius:999px;border:1px solid transparent;transition:.2s;
}
.menu a:hover{border-color:var(--neon-c);color:#fff;background:rgba(0,255,209,.06)}
.menu a.active{background:var(--neon-c);color:#06060a;border-color:var(--neon-c)}

/* Botão CTA neon */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--display);text-transform:uppercase;letter-spacing:.04em;
  padding:14px 22px;border-radius:14px;font-size:1rem;font-weight:900;
  border:2px solid #000;cursor:pointer;transition:.2s;
  position:relative;
}
.btn-primary{
  background:#00d9b1;color:#000 !important;
  box-shadow: 6px 6px 0 #000;
  font-weight:900;
}
.btn-primary:hover,.btn-primary:focus{
  background:#00d9b1;color:#000 !important;
  transform:translate(-2px,-2px);box-shadow:8px 8px 0 #000;
}
.btn-mag{
  background:#ff2bd6;color:#000 !important;
  box-shadow: 6px 6px 0 #000;
  font-weight:900;
}
.btn-mag:hover,.btn-mag:focus{
  background:#ff2bd6;color:#000 !important;
  transform:translate(-2px,-2px);box-shadow:8px 8px 0 #000;
}
.btn-ghost{
  background:transparent;color:#fff;border-color:#fff;
  box-shadow: 6px 6px 0 var(--neon-v);
}
.btn-ghost:hover{background:#fff;color:#06060a;transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--neon-v)}

/* ============== HERO ============== */
.hero{padding:80px 0 60px;position:relative}
.hero .grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:48px;
  align-items:center;
}
@media (max-width: 900px){.hero .grid{grid-template-columns:1fr}}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--neon-c);
  border:1px solid var(--neon-c);padding:7px 14px;border-radius:999px;background:rgba(0,255,209,.05);
}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--neon-c);box-shadow:0 0 12px var(--neon-c);animation:pulse 1.6s infinite}

.hero h1{margin-top:18px}
.hero p.lead{font-size:clamp(1.05rem,1.6vw,1.25rem);color:#dcdfe5;max-width:54ch}

.cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}

/* Visual lateral — TV de pixels */
.tv-art{
  aspect-ratio: 1/1;
  border-radius:24px;
  background:
    radial-gradient(circle at 30% 30%, rgba(0,255,209,.4), transparent 60%),
    radial-gradient(circle at 70% 70%, rgba(255,43,214,.45), transparent 60%),
    linear-gradient(135deg,#0d0d18,#181828);
  border:2px solid #000;
  box-shadow: 10px 10px 0 #000, 0 0 60px rgba(122,92,255,.35);
  position:relative;overflow:hidden;
}
.tv-art::before{
  content:"";position:absolute;inset:14px;border-radius:18px;
  background:
    repeating-linear-gradient(0deg, rgba(0,0,0,.18) 0 2px, transparent 2px 4px),
    conic-gradient(from 0deg, #00ffd1, #7a5cff, #ff2bd6, #f5ff3d, #00ffd1);
  filter: blur(.5px) saturate(140%);
  animation: spin 14s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.tv-art::after{
  content:"4K · 8K · HDR";
  position:absolute;left:50%;bottom:22px;transform:translateX(-50%);
  font-family:var(--mono);font-weight:700;letter-spacing:.4em;font-size:.78rem;
  background:#000;color:var(--neon-c);padding:8px 14px;border-radius:999px;
  border:1px solid var(--neon-c);box-shadow:0 0 16px rgba(0,255,209,.4)
}

/* ============== STATS / TIRA NEON ============== */
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border:2px solid #000;border-radius:20px;overflow:hidden;
  background:#0a0a12;margin:30px 0;
  box-shadow: 8px 8px 0 var(--neon-v);
}
.stats div{padding:22px;border-right:1px solid var(--line)}
.stats div:last-child{border-right:none}
.stats b{display:block;font-family:var(--display);font-size:clamp(1.6rem,3vw,2.4rem);color:var(--neon-c)}
.stats span{font-family:var(--mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.16em;color:var(--muted)}
@media(max-width:780px){.stats{grid-template-columns:repeat(2,1fr)} .stats div:nth-child(2){border-right:none}}

/* ============== BENTO GRID ============== */
section{padding:70px 0;position:relative}
.section-title{display:flex;align-items:end;justify-content:space-between;gap:20px;margin-bottom:36px;flex-wrap:wrap}
.section-title small{font-family:var(--mono);text-transform:uppercase;letter-spacing:.2em;color:var(--muted);font-size:.78rem;display:block;margin-bottom:8px}

.bento{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:minmax(140px,auto);gap:18px}
.card{
  position:relative;border-radius:var(--r);
  background:linear-gradient(180deg,#0e0e18,#0a0a12);
  border:1px solid var(--line);padding:28px;
  overflow:hidden;transition:.25s;
}
.card:hover{transform:translateY(-4px);border-color:var(--neon-c)}
.card .ico{
  width:48px;height:48px;border-radius:12px;
  display:grid;place-items:center;font-family:var(--mono);font-weight:900;font-size:1.2rem;color:#06060a;
  margin-bottom:14px;
}
.card.span-3{grid-column:span 3}
.card.span-2{grid-column:span 2}
.card.span-4{grid-column:span 4}
.card.span-6{grid-column:span 6}
.card.tall{grid-row:span 2}
@media(max-width:980px){.bento{grid-template-columns:repeat(2,1fr)} .card.span-3,.card.span-4,.card.span-2{grid-column:span 2}.card.span-6{grid-column:span 2}}

.card.feat-cyan{background:linear-gradient(140deg, rgba(0,255,209,.14), #0a0a12 60%);border-color:rgba(0,255,209,.35)}
.card.feat-cyan .ico{background:var(--neon-c)}
.card.feat-mag{background:linear-gradient(140deg, rgba(255,43,214,.14), #0a0a12 60%);border-color:rgba(255,43,214,.35)}
.card.feat-mag .ico{background:var(--neon-m)}
.card.feat-yel{background:linear-gradient(140deg, rgba(245,255,61,.14), #0a0a12 60%);border-color:rgba(245,255,61,.35)}
.card.feat-yel .ico{background:var(--neon-y)}
.card.feat-vio{background:linear-gradient(140deg, rgba(122,92,255,.14), #0a0a12 60%);border-color:rgba(122,92,255,.35)}
.card.feat-vio .ico{background:var(--neon-v);color:#fff}

.card h3{margin-bottom:8px;color:#fff}
.card p{margin:0;color:#c4c8cf}
.card ul{margin:10px 0 0;padding-left:18px;color:#c4c8cf}
.card ul li{margin:6px 0}
.card ul li::marker{color:var(--neon-c)}

/* ============== PLANOS ============== */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:880px){.plans{grid-template-columns:1fr}}
.plan{
  border:2px solid #000;border-radius:20px;padding:30px;
  background:linear-gradient(180deg,#0e0e18,#07070d);
  box-shadow: 6px 6px 0 #000;position:relative;overflow:hidden;
  transition:.25s;
}
.plan:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 #000}
.plan h3{font-size:1.4rem;color:#fff}
.plan .price{font-family:var(--display);font-size:3rem;color:var(--neon-c);margin:6px 0}
.plan .price small{font-size:1rem;color:var(--muted);font-family:var(--mono)}
.plan ul{padding:0;list-style:none;margin:18px 0}
.plan ul li{padding:9px 0;border-top:1px dashed var(--line);font-size:.95rem;color:#d2d6dc}
.plan ul li::before{content:"▸ ";color:var(--neon-c);margin-right:6px}
.plan.featured{
  background:linear-gradient(180deg,#1a0a24,#0a0a12);
  border-color:var(--neon-m);
  box-shadow: 6px 6px 0 var(--neon-m);
}
.plan.featured .price{color:var(--neon-m)}
.plan .tag{
  position:absolute;top:14px;right:14px;
  background:var(--neon-y);color:#000;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;
  padding:5px 10px;border-radius:6px;font-weight:900;
}

/* ============== FAQ ============== */
.faq details{
  border:1px solid var(--line);border-radius:14px;
  background:#0c0c14;margin-bottom:10px;padding:0;overflow:hidden;
  transition:.2s;
}
.faq details[open]{border-color:var(--neon-c);background:#0e1418}
.faq summary{
  cursor:pointer;padding:18px 22px;font-weight:700;color:#fff;
  list-style:none;display:flex;align-items:center;justify-content:space-between;gap:14px;
  font-size:1.02rem;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";font-family:var(--mono);font-size:1.6rem;color:var(--neon-c);transition:.2s
}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .body{padding:0 22px 22px;color:#cdd1d8}

/* ============== STEPS ============== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:880px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}
.step{
  background:#0c0c14;border:1px solid var(--line);border-radius:16px;padding:24px;
  position:relative;
}
.step b.num{
  font-family:var(--display);font-size:2.4rem;
  background:linear-gradient(180deg,var(--neon-c),var(--neon-v));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  display:block;line-height:1;margin-bottom:10px;
}
.step h3,.step h4{font-size:1.05rem;margin:0 0 6px;color:#fff;font-family:var(--display);text-transform:uppercase;font-weight:900;letter-spacing:-.01em;line-height:1.2}
.step p{margin:0;font-size:.94rem;color:#bfc3ca}

/* ============== DEPOIMENTOS ============== */
.testis{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:880px){.testis{grid-template-columns:1fr}}
.testi{
  border:1px solid var(--line);border-radius:18px;padding:26px;background:#0c0c14;
  position:relative;
}
.testi::before{
  content:"“";font-family:var(--display);font-size:5rem;color:var(--neon-m);
  position:absolute;top:-14px;left:14px;line-height:1
}
.testi p{font-style:italic;color:#dde0e6}
.testi .who{display:flex;align-items:center;gap:10px;margin-top:14px}
.testi .av{
  width:38px;height:38px;border-radius:50%;
  background:conic-gradient(from 30deg, var(--neon-c), var(--neon-m), var(--neon-y), var(--neon-c));
  border:2px solid #000
}
.testi .who b{color:#fff;font-size:.95rem;display:block}
.testi .who span{font-family:var(--mono);font-size:.78rem;color:var(--muted);letter-spacing:.1em}

/* ============== CTA FAIXA ============== */
.cta-bar{
  margin:60px 0;padding:46px;border-radius:24px;
  background:linear-gradient(120deg,#1a0a24,#0a0a12 60%, #001a18);
  border:2px solid #000;box-shadow:10px 10px 0 var(--neon-c);
  display:grid;grid-template-columns:1.4fr .6fr;gap:24px;align-items:center;
}
@media(max-width:780px){.cta-bar{grid-template-columns:1fr;text-align:center}}
.cta-bar h2{margin:0}
.cta-bar p{margin:8px 0 0;color:#d6d9df}

/* ============== FOOTER ============== */
footer.site{
  border-top:1px solid var(--line);
  padding:56px 0 30px;
  background:#06060a;
  margin-top:60px;
}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px}
@media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr}}
.foot-grid h2,.foot-grid h3,.foot-grid h4,.foot-grid h5{font-family:var(--display);text-transform:uppercase;letter-spacing:.04em;color:#fff;margin:0 0 14px;font-size:1rem;line-height:1.2;font-weight:900}
.foot-grid a{display:block;color:#aab0bb;font-size:.92rem;padding:5px 0}
.foot-grid a:hover{color:var(--neon-c)}
.legal{margin-top:36px;padding-top:20px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  color:var(--muted);font-family:var(--mono);font-size:.78rem;letter-spacing:.1em}

/* ============== EXTRAS PÁGINA TESTE ============== */
.warn{
  background:linear-gradient(135deg, rgba(245,255,61,.1), transparent);
  border:1px dashed var(--neon-y);border-radius:14px;
  padding:18px 22px;color:#f0f1f4;font-size:.96rem;
}
.warn b{color:var(--neon-y)}

.compat{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
@media(max-width:780px){.compat{grid-template-columns:repeat(3,1fr)}}
@media(max-width:480px){.compat{grid-template-columns:repeat(2,1fr)}}
.compat .chip{
  border:1px solid var(--line);border-radius:14px;padding:18px 10px;text-align:center;
  background:#0c0c14;font-family:var(--mono);font-size:.84rem;letter-spacing:.08em;text-transform:uppercase;
  color:#cfd3da;transition:.2s;
}
.compat .chip:hover{border-color:var(--neon-c);color:#fff}
.compat .chip b{display:block;font-family:var(--display);font-size:1.1rem;color:#fff;margin-bottom:4px}

/* ============== UTILIDADES ============== */
.mt-0{margin-top:0!important}
.center{text-align:center}
hr.hard{border:none;height:2px;background:#000;margin:48px 0;box-shadow:0 2px 0 var(--neon-v)}

/* Acessibilidade */
:focus-visible{outline:3px solid var(--neon-c);outline-offset:3px;border-radius:6px}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
}

/* ============== TABELA COMPARATIVA ============== */
.cmp{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#0c0c14;font-size:.95rem}
.cmp th,.cmp td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--line)}
.cmp thead th{background:#11111a;color:#fff;font-family:var(--display);text-transform:uppercase;letter-spacing:.04em;font-size:.86rem}
.cmp tbody tr:last-child td{border-bottom:none}
.cmp .yes{color:var(--neon-c);font-weight:700}
.cmp .no{color:#ff5874;font-weight:700}
.cmp tbody tr:hover{background:#0e0e18}
.cmp .col-feat{background:linear-gradient(180deg, rgba(255,43,214,.08), transparent);color:var(--neon-m)}
@media(max-width:720px){.cmp{font-size:.82rem}.cmp th,.cmp td{padding:10px 8px}}

/* ============== BLOG ============== */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:980px){.posts{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.posts{grid-template-columns:1fr}}
.post{
  border:1px solid var(--line);border-radius:18px;padding:24px;background:#0c0c14;
  display:flex;flex-direction:column;gap:10px;transition:.2s;text-decoration:none;color:inherit;
}
.post:hover{transform:translateY(-3px);border-color:var(--neon-c)}
.post .tag{display:inline-flex;font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--neon-c);align-self:flex-start;border:1px solid var(--neon-c);padding:4px 10px;border-radius:999px}
.post h3{margin:0;color:#fff;font-size:1.18rem;line-height:1.25}
.post p{margin:0;color:#bbc0c8;font-size:.94rem}
.post .meta{margin-top:auto;font-family:var(--mono);font-size:.78rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}

/* Conteúdo de artigo (prose) */
.prose{max-width:780px;margin:0 auto;color:#dde1e7;font-size:1.05rem;line-height:1.75}
.prose h2{margin-top:48px;margin-bottom:14px;font-size:1.8rem}
.prose h3{margin-top:30px;margin-bottom:10px;color:#fff;font-size:1.25rem}
.prose p{margin:0 0 1.1em}
.prose ul,.prose ol{padding-left:22px;margin:0 0 1.1em}
.prose li{margin:6px 0}
.prose blockquote{
  border-left:3px solid var(--neon-c);padding:10px 18px;margin:1.4em 0;
  background:rgba(0,255,209,.05);color:#e3e6ec;border-radius:0 12px 12px 0;font-style:italic;
}
.prose code{font-family:var(--mono);background:#11111a;padding:2px 7px;border-radius:6px;border:1px solid var(--line);font-size:.92em;color:var(--neon-c)}
.prose hr{border:none;height:1px;background:var(--line);margin:34px 0}
.prose .meta-bar{display:flex;gap:14px;align-items:center;font-family:var(--mono);font-size:.78rem;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin-bottom:20px}
.prose .meta-bar .dot-sep{width:5px;height:5px;border-radius:50%;background:var(--neon-c)}

/* Formulário contato */
.form{display:grid;gap:16px;max-width:560px}
.form label{display:flex;flex-direction:column;gap:8px;font-family:var(--mono);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.form input,.form textarea,.form select{
  font-family:var(--sans);font-size:1rem;color:#fff;
  background:#0c0c14;border:1px solid var(--line);border-radius:12px;padding:14px 16px;
  transition:.15s;
}
.form input:focus,.form textarea:focus,.form select:focus{
  outline:none;border-color:var(--neon-c);box-shadow:0 0 0 3px rgba(0,255,209,.15)
}
.form textarea{min-height:140px;resize:vertical}

/* Lista grande de canais (categoria) */
.tags{display:flex;flex-wrap:wrap;gap:8px}
.tags span{
  font-family:var(--mono);font-size:.78rem;letter-spacing:.06em;
  background:#11111a;border:1px solid var(--line);color:#cfd3da;padding:7px 12px;border-radius:999px;
}

/* Footer link list extras */
.foot-grid a.btn{display:inline-flex;margin-top:8px}

/* ============== BOTÃO WHATSAPP FLUTUANTE (somente ícone) ============== */
.wa-float{
  position:fixed;
  right:22px;bottom:22px;
  z-index:90;
  display:inline-grid;place-items:center;
  width:62px;height:62px;
  background:#25D366;
  color:#fff;
  text-decoration:none;
  border-radius:50%;
  border:2px solid #0a0a0a;
  box-shadow: 0 10px 30px rgba(37,211,102,.45), 0 0 0 4px rgba(37,211,102,.18);
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.wa-float:hover{
  background:#128C7E;color:#fff;
  transform: translateY(-3px) scale(1.05);
  box-shadow: 0 14px 40px rgba(37,211,102,.6), 0 0 0 6px rgba(37,211,102,.25);
}
.wa-float svg{width:34px;height:34px;display:block}
.wa-float .lbl{display:none}
.wa-float::before{
  content:"";position:absolute;inset:-6px;border-radius:50%;
  border:2px solid #25D366;
  animation: waPulse 2.2s ease-out infinite;
  z-index:-1;
  pointer-events:none;
}
@keyframes waPulse{
  0%{transform:scale(.95);opacity:.7}
  100%{transform:scale(1.25);opacity:0}
}
@media(max-width:520px){
  .wa-float{width:56px;height:56px;right:16px;bottom:16px}
  .wa-float svg{width:30px;height:30px}
}
@media (prefers-reduced-motion: reduce){
  .wa-float::before{animation:none}
}
