/* ============================================================
   GERENTE DAS TELAS - Tema visual global (dark / neon / gamer)
   Paleta: preto, laranja neon, vermelho fogo, branco metalico,
   azul e roxo. Alto contraste, bordas luminosas, visual premium.
   ============================================================ */

:root{
  /* ===== Design System — Paleta Premium 2026 ===== */
  --gt-preto:        #050505;   /* fundo principal */
  --gt-preto-2:      #0d0d0d;   /* fundo secundario */
  --gt-card:         #121214;   /* superficie */
  --gt-card-2:       #171717;   /* superficie 2 */
  --gt-borda:        #232327;   /* bordas sutis */

  /* Acentos: azul + roxo premium. Os nomes antigos (laranja/fogo/
     vermelho) foram REMAPEADOS para a nova paleta, entao todo o site
     adota o novo visual automaticamente. */
  --gt-azul:         #00afff;
  --gt-azul-neon:    #00afff;
  --gt-roxo:         #8b3dff;
  --gt-roxo-2:       #a875ff;
  --gt-laranja:      #00afff;   /* primario  -> azul premium */
  --gt-laranja-2:    #008fe0;
  --gt-vermelho:     #8b3dff;   /* secundario -> roxo premium */
  --gt-fogo:         #8b3dff;

  --gt-azul-eletrico:#0066ff;
  --gt-ciano:        #00d4ff;
  --gt-branco:       #ffffff;
  --gt-cinza:        #aab3c5;   /* texto secundario (um pouco mais claro) */

  /* sombras/realces premium (discretos, sem exagero) */
  --gt-sombra-neon:  0 0 0 1px rgba(0,175,255,.22), 0 18px 48px rgba(0,102,255,.18);
  --gt-grad:         linear-gradient(135deg, #00afff, #8b3dff);
  --gt-grad-txt:     linear-gradient(135deg, #ffffff, #00d4ff 60%, #a875ff);
  --gt-radius:       16px;

  /* tipografia premium */
  --gt-font:    'Inter', system-ui, -apple-system, Segoe UI, Arial, sans-serif;
  --gt-display: 'Sora', 'Inter', system-ui, sans-serif;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top:84px; }

/* ===== Arredondamento premium global =====
   Pega o que estava quadrado por padrao (inputs/botoes/cards/etc.) sem
   sobrepor o que ja e redondo ou circular — esses usam classes (.gt-fab,
   .uh-avatar, etc.) que tem especificidade maior e continuam vencendo. */
input:not([type=checkbox]):not([type=radio]):not([type=range]),
textarea, select, button,
table, pre, fieldset, blockquote,
.card, .box, .panel, .modal, .popup{
  border-radius: 12px;
}
code, kbd, input[type=checkbox], input[type=radio]{ border-radius: 6px; }
img{ border-radius: 8px; }
/* Nao arredondar imagens que devem ficar inteiras/encostadas */
img.gt-banner-img, .gt-hero img, img.no-round, .gt-logo img, .logo img{ border-radius: 0; }

/* ===== Container centralizado global (evita conteudo colado na borda) ===== */
.gt-container{ max-width:1180px; margin:24px auto; padding:0 18px; width:100%; box-sizing:border-box; }
@media(max-width:680px){ .gt-container{ padding:0 14px; } }

body{
  margin:0;
  font-family:var(--gt-font);
  letter-spacing:.1px;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  color:var(--gt-branco) !important;
  background:
    radial-gradient(1200px 600px at 15% -10%, rgba(139,61,255,.18), transparent 60%),
    radial-gradient(1000px 500px at 95% 0%, rgba(0,194,255,.14), transparent 55%),
    radial-gradient(900px 700px at 50% 120%, rgba(0,175,255,.16), transparent 60%),
    var(--gt-preto) !important;
  background-attachment:fixed !important;
  min-height:100vh;
}

/* textura tecnologica sutil sobre o fundo */
body::before{
  content:"";
  position:fixed; inset:0;
  background-image:
    linear-gradient(rgba(0,175,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(139,61,255,.05) 1px, transparent 1px);
  background-size:46px 46px;
  pointer-events:none;
  z-index:0;
  -webkit-mask-image:radial-gradient(circle at 50% 25%, #000 25%, transparent 78%);
  mask-image:radial-gradient(circle at 50% 25%, #000 25%, transparent 78%);
  animation:gtGridMove 32s linear infinite;
}
@keyframes gtGridMove{ from{ background-position:0 0, 0 0; } to{ background-position:46px 46px, 46px 46px; } }
body > *{ position:relative; z-index:1; }

a{ color:var(--gt-azul-neon); }

/* ---------- TITULOS NEON / 3D METALICO ---------- */
.gt-titulo-neon{
  font-weight:900;
  letter-spacing:1px;
  text-transform:uppercase;
  background:linear-gradient(180deg,#fff,#9fb4d6 55%,#5b6680);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
  filter:drop-shadow(0 2px 0 #000) drop-shadow(0 0 14px rgba(0,194,255,.45));
}

/* ---------- NAV / MENU ---------- */
.gt-nav{
  display:flex; align-items:center; justify-content:center; gap:6px;
  flex-wrap:wrap;
  padding:12px 14px;
  background:linear-gradient(90deg, rgba(0,175,255,.16), rgba(139,61,255,.16));
  border-top:1px solid rgba(0,175,255,.35);
  border-bottom:1px solid rgba(0,194,255,.25);
  backdrop-filter:blur(6px);
}
.gt-nav a{
  color:var(--gt-branco); text-decoration:none; font-weight:700;
  padding:9px 16px; border-radius:999px;
  border:1px solid transparent;
  transition:.25s; display:inline-flex; align-items:center; gap:8px;
}
.gt-nav a:hover{
  border-color:var(--gt-laranja);
  box-shadow:var(--gt-sombra-neon);
  color:#fff;
  transform:translateY(-1px);
}
.gt-nav-cart{ position:relative; }
.gt-cart-count{
  display:flex; align-items:center; justify-content:center;
  min-width:20px; height:20px; padding:0 5px; margin-left:2px;
  background:linear-gradient(135deg,var(--gt-laranja),var(--gt-fogo));
  color:#fff; font-size:12px; font-weight:800; border-radius:999px;
  box-shadow:0 0 10px rgba(0,175,255,.7);
}

/* ---------- BOTOES ---------- */
.gt-btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  border:none; cursor:pointer; font-weight:800;
  padding:12px 18px; border-radius:14px;
  color:#fff; text-decoration:none; transition:.25s;
  text-transform:uppercase; letter-spacing:.4px;
}
.gt-btn-comprar{
  background:linear-gradient(135deg,var(--gt-laranja),var(--gt-fogo));
  box-shadow:0 6px 18px rgba(0,175,255,.35);
}
.gt-btn-comprar:hover{ transform:translateY(-2px); box-shadow:0 0 22px rgba(0,175,255,.7); }
.gt-btn-info{
  background:linear-gradient(135deg,var(--gt-azul),var(--gt-roxo-2));
  box-shadow:0 6px 18px rgba(47,155,255,.3);
}
.gt-btn-info:hover{ transform:translateY(-2px); box-shadow:0 0 22px rgba(0,194,255,.65); }
.gt-btn-cart{ background:linear-gradient(135deg,var(--gt-roxo),var(--gt-roxo-2)); box-shadow:0 6px 18px rgba(139,61,255,.3); }
.gt-btn-cart:hover{ transform:translateY(-2px); box-shadow:0 0 20px rgba(139,61,255,.6); }
.gt-btn-ghost{ background:transparent; border:1px solid var(--gt-borda); color:var(--gt-cinza); }
.gt-btn-ghost:hover{ border-color:var(--gt-azul); color:#fff; box-shadow:0 0 14px rgba(0,175,255,.25); }

/* ---------- CARDS BASE ---------- */
.gt-card{
  background:linear-gradient(160deg,var(--gt-card),var(--gt-card-2));
  border:1px solid var(--gt-borda);
  border-radius:18px;
  box-shadow:0 10px 30px rgba(0,0,0,.5);
}

/* ============================================================
   OVERRIDES GLOBAIS - aplica o tema dark nas paginas legadas
   (login, conta, detalhes, categorias, como-comprar, etc.)
   sem precisar reescrever o CSS de cada uma.
   ============================================================ */

/* tira o fundo claro do <main> das paginas internas (poupa a vitrine .gt-grid) */
main:not(.gt-grid){
  background:transparent !important;
  box-shadow:none !important;
}

/* superficies em "card" viram escuras */
/* Garante que os popups (SweetAlert) sempre apareçam como overlay fixo
   centralizado — evita o modal cair no fluxo da página (ex.: no rodapé). */
.swal2-container{ position:fixed !important; inset:0 !important; z-index:100000 !important; }

.card, .card-form, .login-box, .legal-card,
.download-item, .payment-item, .related-card,
.categoria-item, .info-card, .select-card{
  background:linear-gradient(160deg,var(--gt-card),var(--gt-card-2)) !important;
  border:1px solid var(--gt-borda) !important;
  border-radius:16px !important;
  box-shadow:0 8px 26px rgba(0,0,0,.45) !important;
}
/* hover sutil nas superficies de conteudo */
.gt-termos .card{ transition:transform .2s, border-color .2s, box-shadow .2s; }
.gt-termos .card:hover{ transform:translateY(-2px); border-color:var(--gt-azul) !important; box-shadow:0 12px 30px rgba(0,102,255,.16) !important; }

/* textos legiveis no escuro */
main:not(.gt-grid) h1, main:not(.gt-grid) h2, main:not(.gt-grid) h3,
main:not(.gt-grid) h4, main:not(.gt-grid) p, main:not(.gt-grid) li,
main:not(.gt-grid) strong, main:not(.gt-grid) small, main:not(.gt-grid) label,
.card-form label, .legal-card *, .login-box h2,
.download-info strong, .download-info small{
  color:var(--gt-branco) !important;
}
.legal-card{ color:var(--gt-branco) !important; }

/* campos de formulario escuros */
input:not([type=color]):not([type=range]), select, textarea{
  background:#0f1018 !important;
  color:var(--gt-branco) !important;
  border:1px solid var(--gt-borda) !important;
}
input::placeholder, textarea::placeholder{ color:#8b93a7 !important; }
select option{ background:var(--gt-preto-2); color:var(--gt-branco); }

/* abas (login / conta) */
.tabs button{ background:var(--gt-card-2) !important; color:var(--gt-branco) !important; }
.tabs button.active{ background:linear-gradient(135deg,var(--gt-laranja),var(--gt-fogo)) !important; color:#fff !important; }

/* links de voltar / secundarios -> pilula animada */
.back-btn{
  display:inline-flex !important; align-items:center; gap:8px;
  color:var(--gt-azul-neon) !important; text-decoration:none !important; font-weight:700;
  padding:9px 18px !important; border:1px solid rgba(0,194,255,.35); border-radius:999px;
  background:rgba(0,194,255,.06); transition:.25s; width:auto !important; margin-top:14px;
}
.back-btn:hover{
  border-color:var(--gt-azul-neon); background:rgba(0,194,255,.14);
  box-shadow:0 0 16px rgba(0,194,255,.35); transform:translateY(-1px);
}
.back-btn i{ transition:transform .25s; }
.back-btn:hover i{ transform:translateX(-5px); }

/* Seção "Você também pode gostar" (detalhes) -> CARROSSEL */
.gt-rec-carousel{ position:relative; }
.gt-rec-track{
  display:flex; gap:14px; overflow-x:auto; scroll-snap-type:x mandatory; scroll-behavior:smooth;
  padding:4px 2px 10px; -ms-overflow-style:none; scrollbar-width:none;
}
.gt-rec-track::-webkit-scrollbar{ display:none; }
.gt-rec-track .related-card{ flex:0 0 220px; min-width:220px; max-width:220px; scroll-snap-align:start; }
.gt-rec-arrow{
  position:absolute; top:40%; transform:translateY(-50%); width:42px; height:42px; border-radius:50%;
  border:1px solid rgba(255,255,255,.28); background:rgba(10,10,15,.7); color:#fff; cursor:pointer; z-index:3;
  display:flex; align-items:center; justify-content:center; transition:.2s;
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
}
.gt-rec-arrow:hover{ background:linear-gradient(135deg,var(--gt-laranja),var(--gt-fogo)); border-color:transparent; box-shadow:0 0 16px rgba(0,175,255,.6); }
.gt-rec-prev{ left:-6px; } .gt-rec-next{ right:-6px; }

.rel-link{ text-decoration:none; color:var(--gt-branco) !important; display:block; }
.rel-link h3{ font-size:.95em; margin:8px 0 0; }
.rel-acoes{ display:flex; gap:6px; margin-top:10px; }
.rel-acoes .btn{ min-width:0 !important; flex:1; padding:10px !important; font-size:13px !important; border-radius:10px !important; display:flex; align-items:center; justify-content:center; gap:6px; }
.rel-acoes .btn.carrinho{ flex:0 0 46px; }
@media(max-width:680px){ .gt-rec-track .related-card{ flex-basis:165px; min-width:165px; max-width:165px; } }

/* ===== Avaliacoes ===== */
.produto-rating{ display:flex; align-items:center; gap:8px; }
.produto-rating .stars{ font-size:1.15em; letter-spacing:2px; color:var(--gt-laranja); }
.produto-rating .rating-num{ color:var(--gt-cinza); font-size:.85em; font-weight:600; }

.av-resumo-box{ display:flex; gap:28px; align-items:center; position:relative;
  background:radial-gradient(120% 140% at 0% 0%, rgba(0,175,255,.10), transparent 50%), linear-gradient(160deg,var(--gt-card),var(--gt-card-2));
  border:1px solid var(--gt-borda); border-radius:20px; padding:24px; margin-bottom:20px; flex-wrap:wrap;
  box-shadow:0 18px 48px rgba(0,0,0,.45); }
.av-media-grande{ text-align:center; min-width:130px; padding-right:24px; border-right:1px solid var(--gt-borda); }
.av-media-grande .av-num{ font-size:3.6em; font-weight:900; line-height:1; font-family:var(--gt-display);
  background:var(--gt-grad-txt); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
  filter:drop-shadow(0 4px 20px rgba(0,175,255,.35)); }
.av-media-grande .av-stars-grandes{ color:var(--gt-laranja); font-size:1.3em; letter-spacing:2px; margin:6px 0; }
.av-media-grande .av-total{ color:var(--gt-cinza); font-size:.85em; }
.av-barras{ flex:1; min-width:220px; display:flex; flex-direction:column; gap:6px; }
.av-barra-linha{ display:flex; align-items:center; gap:10px; }
.av-barra-lbl{ color:var(--gt-cinza); font-size:.85em; width:32px; }
.av-barra{ flex:1; height:9px; background:var(--gt-card-2); border-radius:999px; overflow:hidden; }
.av-barra-fill{ height:100%; background:linear-gradient(90deg,var(--gt-laranja),var(--gt-fogo)); border-radius:999px; transition:width .6s ease; }
.av-barra-qtd{ color:var(--gt-cinza); font-size:.82em; width:24px; text-align:right; }

.av-form{ display:flex; flex-direction:column; gap:10px; background:rgba(255,255,255,.03); border:1px solid var(--gt-borda); border-radius:14px; padding:16px; margin-bottom:18px; }
.av-form label{ color:var(--gt-branco) !important; font-weight:700; display:flex; align-items:center; gap:8px; }
.av-stars-input{ display:flex; align-items:center; gap:6px; font-size:1.9em; color:var(--gt-laranja); cursor:pointer; }
.av-stars-input i{ transition:transform .1s; }
.av-stars-input i:hover{ transform:scale(1.18); }
.av-stars-hint{ font-size:.5em; color:var(--gt-cinza); margin-left:6px; }
.av-form textarea{ min-height:84px; resize:vertical; width:100%; }
.av-form .gt-btn{ align-self:flex-start; }
.av-aviso{ color:var(--gt-cinza); background:rgba(255,255,255,.03); border:1px dashed var(--gt-borda); border-radius:12px; padding:14px; margin-bottom:18px; }
.av-aviso.ok{ border-style:solid; border-color:rgba(35,209,139,.4); color:#23d18b; }
.av-aviso a{ color:var(--gt-azul-neon) !important; }

.av-lista{ display:flex; flex-direction:column; gap:12px; }
.av-item{ display:flex; gap:14px; position:relative; overflow:hidden;
  background:linear-gradient(160deg,var(--gt-card),var(--gt-card-2)); border:1px solid var(--gt-borda);
  border-radius:14px; padding:16px 18px; transition:transform .2s, border-color .2s, box-shadow .2s; }
.av-item::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--gt-grad); opacity:.7; }
.av-item:hover{ transform:translateY(-3px); border-color:rgba(0,175,255,.4); box-shadow:0 14px 36px rgba(0,0,0,.45); }
.av-avatar{ flex:0 0 46px; width:46px; height:46px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-weight:900; color:#fff; font-family:var(--gt-display); font-size:1.15em;
  background:linear-gradient(135deg,var(--gt-roxo),var(--gt-azul)); box-shadow:0 0 0 2px rgba(0,175,255,.25), 0 6px 16px rgba(139,61,255,.4); }
.av-corpo{ flex:1; min-width:0; }
.av-item-top{ display:flex; justify-content:space-between; align-items:center; gap:10px; flex-wrap:wrap; }
.av-nome{ font-weight:700; color:#fff; display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.av-verificado{ font-size:.72em; font-weight:700; color:#23d18b; display:inline-flex; align-items:center; gap:4px; background:rgba(35,209,139,.12); border:1px solid rgba(35,209,139,.3); padding:2px 8px; border-radius:999px; }
.av-data{ color:var(--gt-cinza); font-size:.8em; }
.av-estrelas{ color:var(--gt-laranja); letter-spacing:2px; display:block; margin:4px 0; }
.av-coment{ color:var(--gt-cinza); margin:4px 0 0; line-height:1.5; }
.av-vazio{ text-align:center; color:var(--gt-cinza); padding:30px; }
.av-vazio i{ font-size:42px; color:var(--gt-borda); display:block; margin-bottom:10px; }

/* avaliacoes em carrossel (cards) */
.gt-rec-track .av-card{ flex:0 0 290px; min-width:290px; max-width:290px; scroll-snap-align:start; }
.av-card{ background:linear-gradient(160deg,var(--gt-card),var(--gt-card-2)); border:1px solid var(--gt-borda); border-radius:14px; padding:16px; display:flex; flex-direction:column; gap:9px; transition:.2s; }
.av-card:hover{ border-color:var(--gt-azul); box-shadow:0 12px 30px rgba(0,102,255,.18); }
.av-card-top{ display:flex; align-items:center; justify-content:space-between; }
.av-card-top .av-avatar{ width:40px; height:40px; font-size:1.3em; }
.av-card-label{ color:#fff; font-weight:700; font-size:.9em; }
.av-card .av-coment{ color:var(--gt-cinza); font-size:.9em; line-height:1.5; margin:0; min-height:38px;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.av-card .av-estrelas{ display:inline; margin:0; }
.av-card-foot{ display:flex; align-items:center; justify-content:space-between; margin-top:2px; padding-top:10px; border-top:1px solid var(--gt-borda); }
.av-card .av-data{ color:var(--gt-cinza); font-size:.76em; }
@media(max-width:560px){ .av-resumo-box{ flex-direction:column; } }

/* ============================================================
   POLISH / ANIMACOES DE LINKS SOLTOS E TITULOS (checkup geral)
   ============================================================ */

/* transicao suave em qualquer link */
a{ transition:color .2s ease, opacity .2s ease, transform .2s ease; }

/* "Continuar comprando" e links secundarios -> seta desliza */
.gt-continuar{ display:inline-flex !important; align-items:center; gap:7px; transition:.25s; }
.gt-continuar i{ transition:transform .25s; }
.gt-continuar:hover{ filter:drop-shadow(0 0 8px rgba(0,194,255,.4)); }
.gt-continuar:hover i{ transform:translateX(-5px); }

/* Titulos de secao -> entrada suave + sublinhado neon que cresce */
.gt-titulo-secao{
  position:relative; display:inline-flex; padding-bottom:8px;
  animation:gtFadeUp .5s ease both;
}
.gt-titulo-secao::after{
  content:""; position:absolute; left:0; bottom:0; height:3px; width:46px; border-radius:3px;
  background:linear-gradient(90deg,var(--gt-laranja),var(--gt-fogo));
  box-shadow:0 0 10px rgba(0,175,255,.6);
  transition:width .35s ease;
}
.gt-titulo-secao:hover::after{ width:100%; }

/* "OFERTAS SUJEITAS A ALTERACAO" -> brilho pulsando discreto */
.gt-ofertas{ animation:gtPulse 3.2s ease-in-out infinite; }

/* Entrada dos cards: agora controlada pela revelacao global (.gt-js / .gt-in) */

/* Icones de "check" das caracteristicas pulsam de leve ao passar o mouse no card */
.gt-prod:hover .gt-detalhes li i{ animation:gtBeat .6s ease; }

/* ============================================================
   POLISH PREMIUM - animacoes e detalhes no site inteiro
   ============================================================ */

/* brilho varrendo nos botoes primarios */
.gt-btn-comprar, .btn.comprar, .gt-btn-info{ position:relative; overflow:hidden; }
.gt-btn-comprar::after, .btn.comprar::after, .gt-btn-info::after{
  content:""; position:absolute; top:0; left:-130%; width:60%; height:100%;
  background:linear-gradient(120deg, transparent, rgba(255,255,255,.35), transparent);
  transform:skewX(-20deg); transition:left .6s ease; pointer-events:none;
}
.gt-btn-comprar:hover::after, .btn.comprar:hover::after, .gt-btn-info:hover::after{ left:140%; }

/* zoom suave na imagem do produto ao passar o mouse */
.gt-prod .gt-img img, .gt-catp .img img, .related-img-container img, .gt-cat-destaque-bg{ transition:transform .45s ease; }
.gt-prod:hover .gt-img img.active, .gt-catp:hover .img img, .related-card:hover .related-img-container img{ transform:scale(1.07); }

/* transicoes suaves nos cards */
.gt-card, .card, .gt-prod, .gt-catp, .related-card{ transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease; }

/* menu: sublinhado animado */
.gt-nav a{ position:relative; }
.gt-nav a::after{
  content:""; position:absolute; left:16px; right:16px; bottom:4px; height:2px; border-radius:2px;
  background:linear-gradient(90deg,var(--gt-laranja),var(--gt-fogo));
  transform:scaleX(0); transform-origin:left; transition:transform .25s ease;
}
.gt-nav a:hover::after{ transform:scaleX(1); }

/* badge "Destaque" pulsando */
.gt-badge{ animation:gtPulse 2.6s ease-in-out infinite; }

/* icones dos botoes saltam de leve no hover */
.gt-btn i{ transition:transform .25s ease; }
.gt-btn:hover i{ transform:scale(1.18); }

/* carrossel: moldura com gradiente animado */
.gt-car-viewport{ position:relative; }
.gt-car-viewport::before{
  content:""; position:absolute; inset:0; border-radius:18px; padding:1.5px; pointer-events:none; z-index:4;
  background:linear-gradient(120deg, rgba(0,175,255,.55), rgba(0,194,255,.45), rgba(139,61,255,.55));
  background-size:220% 220%;
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude;
  opacity:.65; animation:gtBorder 7s linear infinite;
}

/* entrada suave ao entrar na tela (scroll reveal) — sem estado escondido,
   entao se o JS falhar o conteudo continua visivel */
.gt-in{ animation:gtFadeUp .55s ease both; }

/* foco acessivel discreto */
a:focus-visible, button:focus-visible{ outline:2px solid var(--gt-azul-neon); outline-offset:2px; }

/* ============================================================
   CONSISTENCIA PREMIUM GLOBAL — mesmo padrao do hero em todo lugar
   ============================================================ */
/* titulos grandes de pagina herdam a identidade do hero (degrade) */
main h1, .page-title, .gt-hero2-title{
  font-family:var(--gt-display) !important; font-weight:800; text-transform:uppercase; letter-spacing:.5px;
  background:var(--gt-grad-txt); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
}
/* mantem o icone do titulo colorido (o degrade acima deixaria transparente) */
main h1 i, .page-title i{ -webkit-text-fill-color:var(--gt-azul); color:var(--gt-azul); }
/* botoes primarios legados adotam o gradiente premium */
.submit-btn, .btn-submit, .copy-btn, .btn.comprar, .chat-start{
  background:var(--gt-grad) !important; color:#fff !important; border:none !important;
  font-family:var(--gt-display); text-transform:uppercase; letter-spacing:.4px; border-radius:12px !important; transition:.2s;
}
.submit-btn:hover, .btn-submit:hover, .copy-btn:hover, .btn.comprar:hover, .chat-start:hover{
  box-shadow:0 0 22px rgba(0,175,255,.6) !important; transform:translateY(-1px);
}
/* abas ativas no padrao azul->roxo */
.tabs button.active{ background:var(--gt-grad) !important; color:#fff !important; }
/* inputs com foco azul em qualquer pagina */
input:focus, select:focus, textarea:focus{ outline:none; border-color:var(--gt-azul) !important; box-shadow:0 0 0 3px rgba(0,175,255,.15) !important; }

/* ===== Tipografia premium: CAIXA ALTA + NEGRITO nos destaques ===== */
.gt-titulo-secao{ text-transform:uppercase; font-weight:900; letter-spacing:.6px; }
.gt-prod-body h3, .gt-catp h4, .related-card h3, .rel-link h3, .gt-rec-card h4{
  text-transform:uppercase; font-weight:800; letter-spacing:.3px;
}
.gt-preco, .gt-car-preco, .produto-info .preco, .gt-catp .preco, .av-media-grande .av-num{ font-weight:900; }
.gt-car-texto h3, .produto-info h1{ text-transform:uppercase; letter-spacing:.5px; }
.gt-titulo-neon{ text-transform:uppercase; }

/* fonte de DISPLAY (Sora) nos titulos e destaques */
h1, h2, h3, h4, .gt-titulo-secao, .gt-titulo-neon, .gt-preco, .gt-car-preco,
.produto-info .preco, .gt-catp .preco, .av-media-grande .av-num, .gt-prod-body h3,
.gt-catp h4, .related-card h3, .rel-link h3, .gt-car-texto h3{
  font-family:var(--gt-display);
}
/* menu e botoes em caixa alta com tracking */
.gt-nav a{ text-transform:uppercase; letter-spacing:.6px; font-size:.82em; }
.gt-btn{ text-transform:uppercase; letter-spacing:.6px; font-family:var(--gt-display); }
.gt-marquee span{ text-transform:uppercase; letter-spacing:.5px; }

/* ===== MAIS BRILHO (glow premium) ===== */
.gt-titulo-secao{ text-shadow:0 0 24px rgba(0,175,255,.30); }
.gt-titulo-secao i{ filter:drop-shadow(0 0 8px rgba(0,175,255,.6)); }
.gt-btn-comprar{ box-shadow:0 6px 20px rgba(0,102,255,.40); }
.gt-btn-comprar:hover{ box-shadow:0 0 28px rgba(0,175,255,.75); transform:translateY(-2px); }
.gt-prod:hover, .gt-catp:hover, .related-card:hover, .gt-cat-destaque:hover{
  box-shadow:0 0 0 1px rgba(0,175,255,.40), 0 20px 54px rgba(0,102,255,.24) !important;
}
.gt-badge{ box-shadow:0 0 16px rgba(0,175,255,.75); }
.gt-preco, .gt-car-preco, .produto-info .preco, .gt-catp .preco{ filter:drop-shadow(0 0 14px rgba(0,175,255,.35)); }
.gt-cart-fab, .gt-tg-fab{ animation:gtFabPulse 2.8s ease-in-out infinite; }
@keyframes gtFabPulse{ 0%,100%{ box-shadow:0 8px 24px rgba(0,175,255,.45); } 50%{ box-shadow:0 8px 30px rgba(0,175,255,.8); } }

/* preco "salta" quando passa o mouse no card */
.gt-prod .gt-preco, .gt-catp .preco{ transition:transform .25s ease; transform-origin:center; }
.gt-prod:hover .gt-preco, .gt-catp:hover .preco{ transform:scale(1.06); }

/* titulos de secao entram deslizando */
.gt-titulo-secao{ animation:gtSlideIn .5s ease both; }
@keyframes gtSlideIn{ from{ opacity:0; transform:translateX(-14px); } to{ opacity:1; transform:translateX(0); } }

@keyframes gtBorder{ 0%{ background-position:0% 50%; } 100%{ background-position:220% 50%; } }

/* ---------- ANIMACOES ---------- */
@keyframes gtFloat{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-10px); } }
@keyframes gtFadeUp{ from{ opacity:0; transform:translateY(22px); } to{ opacity:1; transform:translateY(0); } }
@keyframes gtGlow{ 0%,100%{ filter:drop-shadow(0 0 8px rgba(0,175,255,.5)); } 50%{ filter:drop-shadow(0 0 20px rgba(0,194,255,.7)); } }
@keyframes gtPulse{ 0%,100%{ opacity:.55; } 50%{ opacity:1; text-shadow:0 0 10px rgba(0,175,255,.5); } }
@keyframes gtBeat{ 0%,100%{ transform:scale(1); } 40%{ transform:scale(1.35); } }

/* ---------- REVELACAO AO ABRIR/ROLAR (global) ----------
   So liga quando html tem .gt-js (JS ok + sem reduced-motion).
   Sem JS / reduced-motion: cards ficam visiveis normalmente. */
.gt-js .gt-prod, .gt-js .gt-card, .gt-js .gt-depo-card, .gt-js .gt-catp{
  opacity:0; transform:translateY(28px) scale(.985); will-change:opacity,transform;
  animation:none !important;
  transition:opacity .55s ease, transform .6s cubic-bezier(.22,.61,.36,1);
}
.gt-js .gt-prod.gt-in, .gt-js .gt-card.gt-in, .gt-js .gt-depo-card.gt-in, .gt-js .gt-catp.gt-in{
  opacity:1; transform:none;
}

/* ============================================================
   EFEITOS PREMIUM / URGÊNCIA (azul + roxo, sem vermelho)
   Ligados por classes no <html>: .gt-fx-glow / .gt-fx-borda
   ============================================================ */

/* Glow neon azul/roxo ao passar o mouse nos cards */
.gt-fx-glow .gt-prod{ transition:transform .25s, box-shadow .3s, border-color .3s; }
.gt-fx-glow .gt-prod:hover{
  border-color:rgba(0,175,255,.55);
  box-shadow:0 0 0 1px rgba(0,175,255,.35), 0 10px 34px rgba(0,175,255,.28), 0 6px 30px rgba(139,61,255,.28);
}

/* Borda animada (gradiente girando) nos MAIS VENDIDOS */
.gt-fx-borda .gt-prod.mais-vendido{ position:relative; border-color:transparent; }
.gt-fx-borda .gt-prod.mais-vendido::before{
  content:""; position:absolute; inset:-2px; z-index:0; border-radius:20px; padding:2px;
  background:linear-gradient(120deg,#00afff,#8b3dff,#00d4ff,#8b3dff,#00afff);
  background-size:300% 100%;
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude;
  animation:gtBorder 4s linear infinite; pointer-events:none;
}
.gt-fx-borda .gt-prod.mais-vendido > *{ position:relative; z-index:1; }

/* Selos de escassez/urgência */
.gt-escassez{ display:inline-flex; align-items:center; gap:6px; font-size:.72rem; font-weight:800;
  padding:4px 10px; border-radius:999px; letter-spacing:.2px; margin:2px 0 0;
  background:linear-gradient(135deg,rgba(0,175,255,.16),rgba(139,61,255,.16));
  color:#bfe6ff; border:1px solid rgba(0,175,255,.35); }
.gt-escassez i{ animation:gtPulse 2.2s ease-in-out infinite; }
.gt-vendo{ display:inline-flex; align-items:center; gap:7px; font-size:.8rem; font-weight:700; color:#9fe0ff; margin-top:8px; }
.gt-vendo .pt{ width:8px; height:8px; border-radius:50%; background:#00d4ff; box-shadow:0 0 0 0 rgba(0,212,255,.6); animation:gtPing 1.6s ease-out infinite; }
@keyframes gtPing{ 0%{ box-shadow:0 0 0 0 rgba(0,212,255,.55);} 70%{ box-shadow:0 0 0 10px rgba(0,212,255,0);} 100%{ box-shadow:0 0 0 0 rgba(0,212,255,0);} }

/* Faixa de benefícios trocando */
.gt-beneficios{ display:flex; align-items:center; justify-content:center; gap:10px; min-height:30px;
  margin:14px auto 0; padding:8px 16px; max-width:520px; border-radius:999px; text-align:center;
  background:linear-gradient(135deg,rgba(0,175,255,.12),rgba(139,61,255,.12));
  border:1px solid rgba(0,175,255,.28); color:#dff3ff; font-weight:700; font-size:.92rem; }
.gt-beneficios .ic{ color:#00d4ff; }
.gt-benef-item{ display:inline-flex; align-items:center; gap:8px; opacity:0; transform:translateY(8px);
  transition:opacity .4s ease, transform .4s ease; }
.gt-benef-item.on{ opacity:1; transform:none; }

/* Contador "X pessoas online" (faixa topo / flutuante) */
.gt-online{ display:inline-flex; align-items:center; gap:7px; font-size:.82rem; font-weight:700; color:#bfe6ff; }
.gt-online .pt{ width:8px; height:8px; border-radius:50%; background:#00d4ff; box-shadow:0 0 8px #00d4ff; animation:gtPulse 2s ease-in-out infinite; }

/* Barra de meta de vendas */
.gt-meta{ max-width:680px; margin:26px auto 0; padding:16px 18px; border-radius:16px;
  background:linear-gradient(160deg,var(--gt-card),var(--gt-card-2)); border:1px solid var(--gt-borda); }
.gt-meta-top{ display:flex; justify-content:space-between; align-items:center; font-weight:800; color:#eaf6ff; margin-bottom:10px; font-size:.95rem; }
.gt-meta-top .q{ color:#9fe0ff; font-weight:800; }
.gt-meta-bar{ height:14px; border-radius:999px; background:rgba(255,255,255,.07); overflow:hidden; }
.gt-meta-fill{ height:100%; border-radius:999px; width:0; background:linear-gradient(90deg,#00afff,#8b3dff,#00d4ff);
  background-size:200% 100%; animation:gtBorder 3s linear infinite; transition:width 1.2s cubic-bezier(.22,.61,.36,1); }

/* Botões rápidos do hero (Promoções / Mais Vendidos / Suporte / Cashback) */
.gt-quick-chips{ display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin:2px 0 6px; }
.gt-chip{ display:inline-flex; align-items:center; gap:8px; padding:9px 16px; border-radius:999px;
  font-weight:700; font-size:.86rem; text-decoration:none; color:#dff3ff;
  background:rgba(255,255,255,.04); border:1px solid rgba(0,175,255,.28); transition:.2s; }
.gt-chip:hover{ color:#fff; border-color:rgba(0,175,255,.6);
  box-shadow:0 6px 20px rgba(0,175,255,.25), 0 4px 16px rgba(139,61,255,.22); transform:translateY(-2px); }
.gt-chip i{ color:#00d4ff; }
