
/* ========================================================
   COPA 2026 BANNER (link interno topo)
   ======================================================== */
.copa-banner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  width: 100%;
  padding: 10px 20px;
  background: linear-gradient(90deg, #009c3b 0%, #00b85e 50%, #009c3b 100%);
  color: #0a1410;
  font-family: "Space Mono", monospace;
  font-size: 0.82rem;
  text-decoration: none;
  text-align: center;
  border-bottom: 2px solid #ffd700;
  transition: filter 0.25s ease;
  position: relative;
  z-index: 9001;
}
.copa-banner:hover {
  filter: brightness(1.08);
}
.copa-banner strong {
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.02em;
}
.copa-banner-icon {
  font-size: 1.2rem;
  filter: drop-shadow(0 0 6px rgba(255, 215, 0, 0.8));
}
.copa-banner-text {
  color: rgba(10, 20, 16, 0.92);
}
.copa-banner-arrow {
  font-family: "Bebas Neue", monospace;
  font-size: 1rem;
  font-weight: 700;
  color: #ffd700;
  text-shadow: 0 0 8px rgba(255, 215, 0, 0.6);
  transition: transform 0.25s ease;
}
.copa-banner:hover .copa-banner-arrow {
  transform: translateX(4px);
}
@media (max-width: 600px) {
  .copa-banner {
    font-size: 0.72rem;
    padding: 8px 14px;
  }
  .copa-banner-icon {
    font-size: 1rem;
  }
}

/* ========================================================
   FLOATING CTA BUTTONS
   ======================================================== */
.float-cta-wrap {
  position: fixed;
  bottom: 28px;
  right: 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  z-index: 9000;
}
.float-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 13px 20px;
  border-radius: 100px;
  font-family: "Bebas Neue", sans-serif;
  font-size: 1rem;
  letter-spacing: 0.12em;
  text-decoration: none;
  transition: transform 0.2s, box-shadow 0.2s;
  white-space: nowrap;
  box-shadow: 0 4px 24px rgba(0,0,0,0.5);
}
.float-btn i { font-size: 1.2rem; }
.float-btn:hover { transform: translateY(-3px) scale(1.04); }
.float-wpp { background: #25d366; color: #fff; }
.float-wpp:hover { box-shadow: 0 8px 32px rgba(37,211,102,0.5); }
.float-shop { background: var(--neon-magenta); color: #fff; }
.float-shop:hover { box-shadow: 0 8px 32px rgba(var(--neon-magenta-rgb), 0.5); }
.float-btn-label { display: inline-block; }
@media (max-width: 480px) {
  .float-cta-wrap { bottom: 16px; right: 12px; gap: 10px; }
  .float-btn { padding: 12px 16px; font-size: 0.9rem; }
  .float-btn-label { display: none; }
}

/* ========================================================
   BRANDS SECTION
   ======================================================== */
.brands-section {
  padding: 80px 40px;
  background: var(--dark);
  overflow: hidden;
}
.brands-eyebrow {
  font-family: "Space Mono", monospace;
  font-size: 0.72rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: rgba(255,248,240,0.45);
  margin-bottom: 12px;
}
.brands-ticker-wrap {
  overflow: hidden;
  padding: 24px 0;
  border-top: 1px solid rgba(var(--neon-cyan-rgb), 0.08);
  border-bottom: 1px solid rgba(var(--neon-cyan-rgb), 0.08);
  margin: 32px 0;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, black 8%, black 92%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0%, black 8%, black 92%, transparent 100%);
}
.brands-ticker-inner {
  display: inline-flex;
  align-items: center;
  gap: 48px;
  animation: brandsTicker 28s linear infinite;
  white-space: nowrap;
}
@keyframes brandsTicker {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.brand-logo-item {
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.1rem;
  letter-spacing: 0.2em;
  color: rgba(255,248,240,0.3);
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.brand-logo-item i { color: rgba(var(--neon-cyan-rgb), 0.35); font-size: 0.9rem; }
.brands-stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  max-width: 800px;
  margin: 0 auto;
}
.brands-stat {
  text-align: center;
  padding: 24px 12px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(var(--neon-cyan-rgb), 0.08);
  border-radius: 12px;
}
.bs-num {
  font-family: "Bebas Neue", sans-serif;
  font-size: 2.4rem;
  line-height: 1;
  margin-bottom: 4px;
}
.bs-num.cyan { color: var(--neon-cyan); text-shadow: 0 0 20px rgba(var(--neon-cyan-rgb), 0.4); }
.bs-num.magenta { color: var(--neon-magenta); text-shadow: 0 0 20px rgba(var(--neon-magenta-rgb), 0.4); }
.bs-num span { font-size: 1.5rem; }
.bs-lbl {
  font-size: 0.58rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,248,240,0.4);
}
@media (max-width: 768px) {
  .brands-stats-row { grid-template-columns: repeat(2, 1fr); }
  .brands-section { padding: 60px 20px; }
}

/* ========================================================
   PORTFOLIO SECTION
   ======================================================== */
.portfolio-section {
  padding: 80px 40px;
  background: var(--dark-card);
}
.portfolio-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 16px;
  max-width: 1200px;
  margin: 0 auto;
}
.portfolio-card {
  position: relative;
  border-radius: 20px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  overflow: hidden;
  padding: 28px;
  min-height: 220px;
  transition: transform 0.3s, border-color 0.3s;
}
.portfolio-card:hover { transform: translateY(-4px); }
.port-lg { grid-row: span 1; }
.port-glow {
  position: absolute;
  width: 200px; height: 200px;
  border-radius: 50%;
  pointer-events: none;
  top: -60px; right: -60px;
  transition: width 0.3s, height 0.3s;
}
.port-glow-cyan { background: radial-gradient(circle, rgba(var(--neon-cyan-rgb), 0.15), transparent 70%); }
.port-glow-magenta { background: radial-gradient(circle, rgba(var(--neon-magenta-rgb), 0.15), transparent 70%); }
.port-glow-rainbow { background: radial-gradient(circle, rgba(124,58,237,0.15), transparent 70%); }
.port-glow-green { background: radial-gradient(circle, rgba(57,255,20,0.15), transparent 70%); }
.port-glow-fire { background: radial-gradient(circle, rgba(255,106,0,0.15), transparent 70%); }
.portfolio-card:hover .port-glow { width: 280px; height: 280px; }
.port-content {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; gap: 16px; height: 100%;
}
.port-visual { display: flex; justify-content: center; margin-bottom: 4px; }
.port-band {
  height: 48px; border-radius: 24px;
  padding: 0 16px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; width: 100%; max-width: 240px;
}
.pb-cyan { background: linear-gradient(135deg,#0d1f2d,#0a2d2d); border: 1px solid rgba(var(--neon-cyan-rgb), 0.3); }
.pb-magenta { background: linear-gradient(135deg,#1f0d1a,#2d0a1a); border: 1px solid rgba(var(--neon-magenta-rgb), 0.3); }
.pb-rainbow { background: linear-gradient(135deg,#1a0d2d,#0d1a2d); border: 1px solid rgba(124,58,237,0.3); }
.pb-green { background: linear-gradient(135deg,#0d1f0d,#0a2d0a); border: 1px solid rgba(57,255,20,0.3); }
.pb-fire { background: linear-gradient(135deg,#1f0d00,#2d1a00); border: 1px solid rgba(255,106,0,0.3); }
.port-leds { display: flex; gap: 6px; align-items: center; }
.port-led {
  width: 8px; height: 8px; border-radius: 50%;
  animation: ledBlink 0.8s ease-in-out infinite alternate;
}
.port-led:nth-child(2) { animation-delay: 0.15s; }
.port-led:nth-child(3) { animation-delay: 0.3s; }
.port-led:nth-child(4) { animation-delay: 0.45s; }
.port-led:nth-child(5) { animation-delay: 0.6s; }
.port-led:nth-child(6) { animation-delay: 0.75s; }
@keyframes ledBlink { 0% { opacity: 0.4; transform: scale(0.7); } 100% { opacity: 1; transform: scale(1); } }
.plc { background: var(--neon-cyan); box-shadow: 0 0 6px var(--neon-cyan); }
.plm { background: var(--neon-magenta); box-shadow: 0 0 6px var(--neon-magenta); }
.plg { background: var(--neon-green); box-shadow: 0 0 6px var(--neon-green); }
.plr { width: 7px; height: 7px; border-radius: 50%; }
.plr.r1 { background: #ff0000; box-shadow: 0 0 6px #ff0000; }
.plr.r2 { background: #ff8c00; box-shadow: 0 0 6px #ff8c00; }
.plr.r3 { background: #ffe600; box-shadow: 0 0 6px #ffe600; }
.plr.r4 { background: var(--neon-green); box-shadow: 0 0 6px var(--neon-green); }
.plr.r5 { background: var(--neon-cyan); box-shadow: 0 0 6px var(--neon-cyan); }
.plf { border-radius: 50%; }
.plf.f1 { background: #ff6a00; box-shadow: 0 0 6px #ff6a00; }
.plf.f2 { background: #ff4500; box-shadow: 0 0 6px #ff4500; }
.plf.f3 { background: #ff2000; box-shadow: 0 0 6px #ff2000; }
.plf.f4 { background: #ff4500; box-shadow: 0 0 6px #ff4500; }
.plf.f5 { background: #ff6a00; box-shadow: 0 0 6px #ff6a00; }
.port-band-text {
  font-family: "Bebas Neue", sans-serif;
  font-size: 0.65rem; letter-spacing: 0.15em;
  color: rgba(255,248,240,0.4);
}
.port-info { flex: 1; }
.port-tag {
  display: inline-block;
  font-size: 0.58rem; letter-spacing: 0.15em; text-transform: uppercase;
  padding: 3px 10px; border-radius: 100px;
  border: 1px solid rgba(var(--neon-cyan-rgb), 0.25);
  color: var(--neon-cyan); margin-bottom: 8px;
}
.port-title {
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.15rem; letter-spacing: 0.08em;
  color: var(--cream); margin-bottom: 6px;
}
.port-desc { font-size: 0.65rem; color: rgba(255,248,240,0.45); line-height: 1.65; }
.port-cta-card {
  display: flex; align-items: center; justify-content: center;
  background: rgba(var(--neon-cyan-rgb), 0.03);
  border: 1px dashed rgba(var(--neon-cyan-rgb), 0.2);
}
.port-cta-inner { text-align: center; padding: 8px; }
.port-cta-btn {
  display: inline-block; padding: 10px 22px;
  background: var(--neon-cyan); color: var(--dark);
  font-family: "Bebas Neue", sans-serif;
  font-size: 1rem; letter-spacing: 0.12em;
  border-radius: 100px; text-decoration: none;
  transition: transform 0.2s, box-shadow 0.2s;
}
.port-cta-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 24px rgba(var(--neon-cyan-rgb), 0.4);
}
@media (max-width: 900px) {
  .portfolio-grid { grid-template-columns: 1fr 1fr; }
  .port-lg { grid-column: span 2; }
  .port-cta-card { grid-column: span 2; }
}
@media (max-width: 560px) {
  .portfolio-grid { grid-template-columns: 1fr; }
  .port-lg, .port-cta-card { grid-column: span 1; }
  .portfolio-section { padding: 60px 20px; }
}

/* ========================================================
   FAQ SECTION
   ======================================================== */
.faq-section {
  padding: 80px 40px;
  background: var(--dark);
  max-width: 860px;
  margin: 0 auto;
}
.faq-list { display: flex; flex-direction: column; gap: 8px; margin-top: 8px; }
.faq-item {
  border: 1px solid rgba(var(--neon-cyan-rgb), 0.1);
  border-radius: 12px; overflow: hidden;
  background: rgba(255,255,255,0.02);
  transition: border-color 0.2s;
}
.faq-item:hover, .faq-item.open { border-color: rgba(var(--neon-cyan-rgb), 0.3); }
.faq-question {
  width: 100%; background: none; border: none;
  padding: 20px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  cursor: pointer; text-align: left;
  color: var(--cream);
  font-family: "Space Mono", monospace; font-size: 0.82rem; line-height: 1.5;
  transition: color 0.2s;
}
.faq-question:hover, .faq-item.open .faq-question { color: var(--neon-cyan); }
.faq-icon { flex-shrink: 0; font-size: 0.9rem; color: var(--neon-cyan); transition: transform 0.3s; }
.faq-item.open .faq-icon { transform: rotate(45deg); }
.faq-answer { max-height: 0; overflow: hidden; transition: max-height 0.35s ease, padding 0.35s ease; padding: 0 24px; }
.faq-item.open .faq-answer { max-height: 300px; padding: 0 24px 20px; }
.faq-answer p { font-size: 0.75rem; color: rgba(255,248,240,0.55); line-height: 1.75; }
.faq-cta {
  text-align: center; margin-top: 40px; padding-top: 32px;
  border-top: 1px solid rgba(var(--neon-cyan-rgb), 0.08);
  display: flex; align-items: center; justify-content: center; gap: 20px; flex-wrap: wrap;
}
.faq-cta p { font-size: 0.75rem; color: rgba(255,248,240,0.45); }
.faq-cta-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 11px 24px; background: #25d366; color: #fff;
  font-family: "Bebas Neue", sans-serif; font-size: 1rem; letter-spacing: 0.1em;
  border-radius: 100px; text-decoration: none;
  transition: transform 0.2s, box-shadow 0.2s;
}
.faq-cta-btn:hover { transform: translateY(-2px); box-shadow: 0 6px 24px rgba(37,211,102,0.4); }
@media (max-width: 768px) {
  .faq-section { padding: 60px 20px; }
  .faq-question { font-size: 0.75rem; padding: 16px 18px; }
  .faq-answer { padding: 0 18px; }
  .faq-item.open .faq-answer { padding: 0 18px 16px; }
}

/* ========================================================
   CONTACT SECTION
   ======================================================== */
.contact-section { padding: 80px 40px; background: var(--dark-card); }
.contact-inner {
  display: grid; grid-template-columns: 1fr 1.4fr;
  gap: 60px; max-width: 1100px; margin: 0 auto; align-items: start;
}
.contact-eyebrow {
  font-family: "Space Mono", monospace; font-size: 0.7rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--neon-cyan); margin-bottom: 16px;
}
.contact-title {
  font-family: "Bebas Neue", sans-serif;
  font-size: clamp(2.5rem, 5vw, 4.5rem); line-height: 0.9;
  color: var(--cream); margin-bottom: 20px;
}
.contact-copy { font-size: 0.78rem; color: rgba(255,248,240,0.5); line-height: 1.75; margin-bottom: 32px; }
.contact-channels { display: flex; flex-direction: column; gap: 12px; }
.contact-channel {
  display: flex; align-items: center; gap: 16px;
  padding: 14px 18px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(var(--neon-cyan-rgb), 0.1);
  border-radius: 12px; text-decoration: none;
  transition: border-color 0.2s, background 0.2s;
}
.contact-channel:hover { border-color: rgba(var(--neon-cyan-rgb), 0.3); background: rgba(var(--neon-cyan-rgb), 0.05); }
.contact-channel i { font-size: 1.3rem; color: var(--neon-cyan); width: 28px; text-align: center; }
.cc-label { font-size: 0.6rem; letter-spacing: 0.15em; text-transform: uppercase; color: rgba(255,248,240,0.35); margin-bottom: 2px; }
.cc-val { font-size: 0.78rem; color: var(--cream); }
.contact-form-wrap {
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(var(--neon-cyan-rgb), 0.1);
  border-radius: 20px; padding: 36px;
}
.contact-form { display: flex; flex-direction: column; gap: 16px; }
.cf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.cf-field { display: flex; flex-direction: column; gap: 6px; }
.cf-field label { font-size: 0.62rem; letter-spacing: 0.15em; text-transform: uppercase; color: rgba(255,248,240,0.45); }
.cf-field input, .cf-field select, .cf-field textarea {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(var(--neon-cyan-rgb), 0.15);
  border-radius: 10px; padding: 12px 16px;
  color: var(--cream);
  font-family: "Space Mono", monospace; font-size: 0.75rem;
  outline: none; transition: border-color 0.2s, background 0.2s;
  -webkit-appearance: none; appearance: none;
}
.cf-field select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='%2300f5ff'%3E%3Cpath d='M0 0l6 8 6-8z'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 14px center; cursor: pointer;
}
/* Opcoes do dropdown - estilizadas no tema escuro (corrige branco-no-branco) */
.cf-field select option {
  background-color: #14141d;
  color: #fff8f0;
  padding: 8px;
}
.cf-field select option:checked,
.cf-field select option:hover {
  background-color: #1a1a2e;
  color: var(--neon-cyan, var(--neon-cyan));
}
.cf-field input:focus, .cf-field select:focus, .cf-field textarea:focus {
  border-color: var(--neon-cyan); background: rgba(var(--neon-cyan-rgb), 0.05);
}
.cf-field textarea { resize: vertical; min-height: 100px; }
.cf-field input::placeholder, .cf-field textarea::placeholder { color: rgba(255,248,240,0.2); }
.cf-submit-row { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.cf-submit-btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 28px; background: var(--neon-magenta); color: #fff;
  font-family: "Bebas Neue", sans-serif; font-size: 1.1rem; letter-spacing: 0.12em;
  border: none; border-radius: 100px; cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s;
}
.cf-submit-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(var(--neon-magenta-rgb), 0.4); }
.cf-submit-btn:disabled { opacity: 0.6; cursor: not-allowed; transform: none; }
.cf-privacy { font-size: 0.6rem; color: rgba(255,248,240,0.3); line-height: 1.5; flex: 1; }
.cf-success {
  padding: 14px 18px;
  background: rgba(57,255,20,0.1); border: 1px solid rgba(57,255,20,0.3);
  border-radius: 10px; color: var(--neon-green); font-size: 0.75rem;
  display: flex; align-items: center; gap: 10px;
}
@media (max-width: 900px) { .contact-inner { grid-template-columns: 1fr; gap: 40px; } }
@media (max-width: 600px) {
  .contact-section { padding: 60px 20px; }
  .contact-form-wrap { padding: 24px 20px; }
  .cf-row { grid-template-columns: 1fr; }
}

/* ========================================================
   HERO BRACELET - IMAGEM REAL + HALO COLORIDO DINAMICO
   ======================================================== */
.hero-bracelet-img {
  display: block;
  width: 360px;
  height: auto;
  max-width: 80%;
  object-fit: contain;
  filter:
    drop-shadow(0 0 18px var(--halo-color, var(--neon-cyan)))
    drop-shadow(0 0 38px var(--halo-color, var(--neon-cyan)))
    drop-shadow(0 0 70px var(--halo-color-soft, var(--halo-color, var(--neon-cyan))));
  transition: filter 0.8s ease, opacity 0.5s ease;
  will-change: filter, transform;
}

/* Halo anel - respeita a cor atual da pulseira */
.hero .hero-img-ring {
  background:
    radial-gradient(circle at 50% 50%,
      color-mix(in srgb, var(--halo-color, var(--neon-cyan)) 32%, transparent) 0%,
      color-mix(in srgb, var(--halo-color, var(--neon-cyan)) 10%, transparent) 45%,
      transparent 72%);
  border: 1px dashed color-mix(in srgb, var(--halo-color, var(--neon-cyan)) 45%, transparent);
  box-shadow:
    0 0 60px color-mix(in srgb, var(--halo-color, var(--neon-cyan)) 30%, transparent),
    inset 0 0 40px color-mix(in srgb, var(--halo-color, var(--neon-cyan)) 12%, transparent);
  transition: background 0.8s ease, border-color 0.8s ease, box-shadow 0.8s ease;
}

/* Blobs de fundo do hero seguem a cor */
.hero .hero-blob {
  background: radial-gradient(circle,
    color-mix(in srgb, var(--halo-color, var(--neon-cyan)) 28%, transparent) 0%,
    transparent 70%);
  transition: background 0.8s ease;
}
.hero .hero-blob2 {
  background: radial-gradient(circle,
    color-mix(in srgb, var(--halo-color-soft, var(--halo-color, var(--neon-magenta))) 22%, transparent) 0%,
    transparent 70%);
  transition: background 0.8s ease;
}

@media (max-width: 900px) {
  .hero-bracelet-img { width: 240px; }
}
@media (max-width: 600px) {
  .hero-bracelet-img { width: 200px; }
}

@media (prefers-reduced-motion: reduce) {
  .hero-bracelet-img { transition: none; }
}

/* ========================================================
   HERO - AJUSTES DE LAYOUT (padding texto + pulseira maior)
   ======================================================== */
.hero .hero-text {
  padding-left: 40px;
}
.hero .hero-img-ring {
  width: 520px;
  height: 520px;
}
.hero .hero-bracelet-img {
  width: 460px;
}

@media (max-width: 1100px) {
  .hero .hero-text { padding-left: 20px; }
  .hero .hero-img-ring { width: 440px; height: 440px; }
  .hero .hero-bracelet-img { width: 380px; }
}
@media (max-width: 900px) {
  .hero .hero-text { padding-left: 0; }
  .hero .hero-img-ring { width: 320px; height: 320px; }
  .hero .hero-bracelet-img { width: 280px; }
}
@media (max-width: 600px) {
  .hero .hero-img-ring { width: 260px; height: 260px; }
  .hero .hero-bracelet-img { width: 220px; }
}

/* ========================================================
   HERO PILLS - SWATCHES COLORIDOS DAS CORES REAIS
   ======================================================== */
.hero-pill.pill-swatch {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  font-family: inherit;
  font-size: 0.62rem;
  letter-spacing: 0.08em;
  padding: 6px 14px 6px 8px;
  border-radius: 100px;
  border: 1px solid rgba(255, 248, 240, 0.18);
  color: rgba(255, 248, 240, 0.55);
  text-transform: uppercase;
  cursor: none;
  transition: border-color 0.25s, color 0.25s, background 0.25s, box-shadow 0.25s, transform 0.25s;
}
.hero-pill.pill-swatch .sw-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--sw, var(--neon-cyan));
  box-shadow:
    0 0 6px var(--sw, var(--neon-cyan)),
    0 0 12px color-mix(in srgb, var(--sw, var(--neon-cyan)) 55%, transparent);
  flex-shrink: 0;
}
.hero-pill.pill-swatch:hover {
  border-color: var(--sw, var(--neon-cyan));
  color: #fff;
  transform: translateY(-1px);
}
.hero-pill.pill-swatch.active {
  background: color-mix(in srgb, var(--sw, var(--neon-cyan)) 14%, transparent);
  border-color: var(--sw, var(--neon-cyan));
  color: #fff;
  box-shadow: 0 0 18px color-mix(in srgb, var(--sw, var(--neon-cyan)) 40%, transparent);
}

/* ========================================================
   MODELOS - CARDS COM IMAGEM REAL DA PULSEIRA
   ======================================================== */
.shake-card.card-photo {
  background: linear-gradient(160deg,
    color-mix(in srgb, var(--card-color, var(--neon-cyan)) 14%, #0a0a0f) 0%,
    #0a0a0f 85%);
  border: 1px solid color-mix(in srgb, var(--card-color, var(--neon-cyan)) 35%, transparent);
  overflow: hidden;
}
.shake-card.card-photo::before {
  content: "";
  position: absolute;
  inset: -2px -2px auto -2px;
  height: 60%;
  background: radial-gradient(ellipse at 50% 40%,
    color-mix(in srgb, var(--card-soft, var(--card-color, var(--neon-cyan))) 40%, transparent) 0%,
    transparent 70%);
  pointer-events: none;
  z-index: 0;
}
.shake-card.card-photo .card-chip {
  color: var(--card-color, var(--neon-cyan));
  border-color: color-mix(in srgb, var(--card-color, var(--neon-cyan)) 60%, transparent);
  background: color-mix(in srgb, var(--card-color, var(--neon-cyan)) 10%, transparent);
  backdrop-filter: blur(4px);
}
.card-photo-wrap {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 220px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 6px;
  margin-bottom: 10px;
}
.card-photo-wrap img {
  max-width: 86%;
  max-height: 100%;
  object-fit: contain;
  filter:
    drop-shadow(0 0 14px var(--card-color, var(--neon-cyan)))
    drop-shadow(0 0 30px color-mix(in srgb, var(--card-soft, var(--card-color, var(--neon-cyan))) 55%, transparent));
  transition: transform 0.5s ease;
}
.shake-card.card-photo:hover .card-photo-wrap img {
  transform: scale(1.06) rotate(-3deg);
}
.shake-card.card-photo .card-bottom { z-index: 2; }

@media (max-width: 600px) {
  .card-photo-wrap { height: 180px; }
}

/* ========================================================
   CARD PRICE - SUBTEXTO "/un"
   ======================================================== */
.card-price-unit {
  font-size: 0.62em;
  opacity: 0.55;
  font-weight: 500;
  letter-spacing: 0.02em;
  margin-left: 2px;
}

/* ========================================================
   MODELOS SEM FOTO - PULSEIRA RENDERIZADA EM CSS
   ======================================================== */
.card-css-wrap {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 220px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 6px;
  margin-bottom: 10px;
}
.css-bracelet {
  position: relative;
  width: 200px;
  height: 78px;
  border-radius: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  transform: rotate(-8deg);
  transition: transform 0.5s ease;
}
.shake-card.card-css:hover .css-bracelet {
  transform: rotate(-8deg) scale(1.06);
}
.cb-window {
  position: relative;
  width: 96px;
  height: 38px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: rgba(0,0,0,0.55);
  border: 1px solid rgba(255,255,255,0.25);
  box-shadow: inset 0 0 12px rgba(0,0,0,0.6);
}
.cb-led {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--led, var(--neon-cyan));
  box-shadow: 0 0 8px var(--led, var(--neon-cyan)), 0 0 16px var(--led, var(--neon-cyan));
  animation: ledPulse 1.2s ease-in-out infinite;
}
.cb-led.l1 { animation-delay: 0s; }
.cb-led.l2 { animation-delay: 0.15s; }
.cb-led.l3 { animation-delay: 0.3s; }
.cb-led.l4 { animation-delay: 0.45s; }

/* ---- Preto silicone, visor transparente ---- */
.bracelet-black {
  background: linear-gradient(160deg, #1a1d22 0%, #0a0c10 60%, #1a1d22 100%);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 8px 22px rgba(0,0,0,0.55),
    inset 0 1px 0 rgba(255,255,255,0.08),
    inset 0 -2px 6px rgba(0,0,0,0.5);
}
.bracelet-black .cb-window {
  background: rgba(20,22,28,0.4);
  border: 1px solid rgba(255,255,255,0.18);
  backdrop-filter: blur(2px);
}
.bracelet-black .cb-led { --led: var(--neon-cyan); }

/* ---- Branco leitoso (translucido difuso) ---- */
.bracelet-milky {
  background:
    radial-gradient(ellipse at 30% 20%, rgba(255,255,255,0.95) 0%, rgba(232,238,242,0.85) 60%, rgba(210,218,225,0.75) 100%);
  border: 1px solid rgba(255,255,255,0.7);
  box-shadow:
    0 8px 22px rgba(0,0,0,0.35),
    0 0 30px rgba(255,255,255,0.25),
    inset 0 1px 0 rgba(255,255,255,0.9),
    inset 0 -3px 8px rgba(180,190,200,0.4);
}
.bracelet-milky .cb-window {
  background: rgba(255,255,255,0.35);
  border: 1px solid rgba(255,255,255,0.6);
  box-shadow: inset 0 0 10px rgba(255,255,255,0.5);
}
.bracelet-milky .cb-led { --led: #ffffff; box-shadow: 0 0 10px #fff, 0 0 22px rgba(255,255,255,0.7); }

/* ---- Verde bandeira ---- */
.bracelet-flaggreen {
  background: linear-gradient(160deg, #00b347 0%, #008a36 50%, #006b29 100%);
  border: 1px solid rgba(255,255,255,0.18);
  box-shadow:
    0 8px 22px rgba(0,80,30,0.45),
    0 0 24px rgba(0,156,59,0.35),
    inset 0 1px 0 rgba(255,255,255,0.25),
    inset 0 -2px 6px rgba(0,0,0,0.3);
}
.bracelet-flaggreen .cb-led { --led: #ffe600; }

/* ---- Branco leitoso RGB (cicla cores) ---- */
.bracelet-rgb {
  background:
    radial-gradient(ellipse at 30% 20%, rgba(255,255,255,0.95) 0%, rgba(245,240,250,0.85) 60%, rgba(220,215,230,0.75) 100%);
  border: 1px solid rgba(255,255,255,0.6);
  animation: rgbAura 4s linear infinite;
  box-shadow:
    0 8px 22px rgba(0,0,0,0.4),
    0 0 30px var(--rgb-now, var(--neon-magenta)),
    inset 0 1px 0 rgba(255,255,255,0.9),
    inset 0 -3px 8px rgba(180,180,200,0.4);
}
.bracelet-rgb .cb-window {
  background: rgba(255,255,255,0.3);
  border: 1px solid rgba(255,255,255,0.6);
}
.bracelet-rgb .cb-led {
  animation: ledPulse 1.2s ease-in-out infinite, rgbCycle 4s linear infinite;
}
.bracelet-rgb .cb-led.l2 { animation-delay: 0.15s, -1s; }
.bracelet-rgb .cb-led.l3 { animation-delay: 0.3s, -2s; }
.bracelet-rgb .cb-led.l4 { animation-delay: 0.45s, -3s; }

@keyframes rgbCycle {
  0%   { background: var(--neon-magenta); box-shadow: 0 0 10px var(--neon-magenta), 0 0 20px var(--neon-magenta); }
  25%  { background: #ffd700; box-shadow: 0 0 10px #ffd700, 0 0 20px #ffd700; }
  50%  { background: var(--neon-cyan); box-shadow: 0 0 10px var(--neon-cyan), 0 0 20px var(--neon-cyan); }
  75%  { background: #9b4dff; box-shadow: 0 0 10px #9b4dff, 0 0 20px #9b4dff; }
  100% { background: var(--neon-magenta); box-shadow: 0 0 10px var(--neon-magenta), 0 0 20px var(--neon-magenta); }
}
@keyframes rgbAura {
  0%   { box-shadow: 0 8px 22px rgba(0,0,0,0.4), 0 0 30px var(--neon-magenta), inset 0 1px 0 rgba(255,255,255,0.9), inset 0 -3px 8px rgba(180,180,200,0.4); }
  25%  { box-shadow: 0 8px 22px rgba(0,0,0,0.4), 0 0 30px #ffd700, inset 0 1px 0 rgba(255,255,255,0.9), inset 0 -3px 8px rgba(180,180,200,0.4); }
  50%  { box-shadow: 0 8px 22px rgba(0,0,0,0.4), 0 0 30px var(--neon-cyan), inset 0 1px 0 rgba(255,255,255,0.9), inset 0 -3px 8px rgba(180,180,200,0.4); }
  75%  { box-shadow: 0 8px 22px rgba(0,0,0,0.4), 0 0 30px #9b4dff, inset 0 1px 0 rgba(255,255,255,0.9), inset 0 -3px 8px rgba(180,180,200,0.4); }
  100% { box-shadow: 0 8px 22px rgba(0,0,0,0.4), 0 0 30px var(--neon-magenta), inset 0 1px 0 rgba(255,255,255,0.9), inset 0 -3px 8px rgba(180,180,200,0.4); }
}

@media (max-width: 600px) {
  .card-css-wrap { height: 180px; }
  .css-bracelet { width: 170px; height: 66px; }
  .cb-window { width: 82px; height: 32px; }
}

@media (prefers-reduced-motion: reduce) {
  .bracelet-rgb { animation: none; }
  .bracelet-rgb .cb-led { animation: ledPulse 1.2s ease-in-out infinite; }
}

/* ========================================================
   LGPD CONSENT BANNER
   ======================================================== */
#hutz-consent {
  position: fixed;
  inset: 0;
  z-index: 99999;
  pointer-events: none;
  font-family: "Space Mono", ui-monospace, monospace;
}
#hutz-consent.is-open { pointer-events: auto; }

#hutz-consent .hc-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0);
  transition: background 0.35s ease;
}
#hutz-consent.is-open .hc-overlay { background: rgba(0,0,0,0.45); }

#hutz-consent .hc-card {
  position: absolute;
  left: 50%;
  bottom: 24px;
  transform: translate(-50%, 30px);
  width: min(720px, calc(100vw - 32px));
  background: linear-gradient(160deg, #0e0e15 0%, #14141d 100%);
  border: 1px solid rgba(var(--neon-cyan-rgb), 0.25);
  border-radius: 18px;
  padding: 22px 24px 20px;
  box-shadow: 0 18px 60px rgba(0,0,0,0.55), 0 0 32px rgba(var(--neon-cyan-rgb), 0.12);
  color: #fff8f0;
  opacity: 0;
  transition: transform 0.35s ease, opacity 0.35s ease;
}
#hutz-consent.is-open .hc-card { transform: translate(-50%, 0); opacity: 1; }

#hutz-consent .hc-main {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 18px;
}
#hutz-consent .hc-icon {
  font-size: 1.8rem;
  line-height: 1;
  flex-shrink: 0;
  margin-top: 2px;
}
#hutz-consent .hc-text h3 {
  margin: 0 0 8px;
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.4rem;
  letter-spacing: 0.04em;
  color: var(--neon-cyan, var(--neon-cyan));
}
#hutz-consent .hc-text p {
  margin: 0;
  font-size: 0.82rem;
  line-height: 1.6;
  color: rgba(255, 248, 240, 0.78);
}
#hutz-consent .hc-text a {
  color: var(--neon-cyan, var(--neon-cyan));
  text-decoration: underline;
  text-underline-offset: 3px;
}

#hutz-consent .hc-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
#hutz-consent .hc-actions .hc-btn { flex: 1 1 auto; min-width: 120px; }

#hutz-consent .hc-btn {
  font-family: "Space Mono", monospace;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 12px 18px;
  border-radius: 100px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform 0.2s, background 0.25s, border-color 0.25s, color 0.25s, box-shadow 0.25s;
}
#hutz-consent .hc-btn:hover { transform: translateY(-1px); }

#hutz-consent .hc-btn-primary {
  background: var(--neon-cyan, var(--neon-cyan));
  color: #0a0a0f;
  font-weight: 700;
  box-shadow: 0 0 20px rgba(var(--neon-cyan-rgb), 0.35);
}
#hutz-consent .hc-btn-primary:hover {
  box-shadow: 0 0 28px rgba(var(--neon-cyan-rgb), 0.55);
}
#hutz-consent .hc-btn-outline {
  background: transparent;
  border-color: rgba(255, 248, 240, 0.35);
  color: #fff8f0;
}
#hutz-consent .hc-btn-outline:hover { border-color: var(--neon-cyan, var(--neon-cyan)); color: var(--neon-cyan, var(--neon-cyan)); }
#hutz-consent .hc-btn-ghost {
  background: transparent;
  border-color: transparent;
  color: rgba(255, 248, 240, 0.55);
}
#hutz-consent .hc-btn-ghost:hover { color: #fff8f0; text-decoration: underline; }

/* Detail view (Personalizar) */
#hutz-consent .hc-row {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 14px 0;
  border-top: 1px solid rgba(255, 248, 240, 0.08);
}
#hutz-consent .hc-row:first-child { border-top: none; }
#hutz-consent .hc-row-info { flex: 1; }
#hutz-consent .hc-row-info strong {
  display: block;
  font-size: 0.85rem;
  color: var(--neon-cyan, var(--neon-cyan));
  letter-spacing: 0.04em;
  margin-bottom: 2px;
}
#hutz-consent .hc-row-info span {
  display: block;
  font-size: 0.74rem;
  color: rgba(255, 248, 240, 0.65);
  line-height: 1.55;
}

#hutz-consent .hc-toggle {
  position: relative;
  display: inline-block;
  width: 44px;
  height: 24px;
  flex-shrink: 0;
  cursor: pointer;
}
#hutz-consent .hc-toggle input { opacity: 0; width: 0; height: 0; position: absolute; }
#hutz-consent .hc-toggle span {
  position: absolute;
  inset: 0;
  background: rgba(255, 248, 240, 0.15);
  border-radius: 100px;
  transition: background 0.25s;
}
#hutz-consent .hc-toggle span::before {
  content: "";
  position: absolute;
  top: 3px; left: 3px;
  width: 18px; height: 18px;
  background: #fff;
  border-radius: 50%;
  transition: transform 0.25s;
}
#hutz-consent .hc-toggle input:checked + span {
  background: var(--neon-cyan, var(--neon-cyan));
  box-shadow: 0 0 10px rgba(var(--neon-cyan-rgb), 0.4);
}
#hutz-consent .hc-toggle input:checked + span::before { transform: translateX(20px); background: #0a0a0f; }
#hutz-consent .hc-toggle.hc-toggle-locked { opacity: 0.6; cursor: not-allowed; }

#hutz-consent .hc-detail-actions {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid rgba(255, 248, 240, 0.08);
}

@media (max-width: 600px) {
  #hutz-consent .hc-card {
    bottom: 12px;
    width: calc(100vw - 24px);
    padding: 18px 18px 16px;
  }
  #hutz-consent .hc-text h3 { font-size: 1.2rem; }
  #hutz-consent .hc-text p { font-size: 0.78rem; }
  #hutz-consent .hc-actions { flex-direction: column; }
  #hutz-consent .hc-actions .hc-btn { width: 100%; }
  #hutz-consent .hc-detail-actions { flex-direction: column-reverse; }
  #hutz-consent .hc-detail-actions .hc-btn { width: 100%; }
}

/* Link de reabrir consent no rodape */
.hc-reopen-link {
  background: none;
  border: none;
  color: inherit;
  font: inherit;
  cursor: pointer;
  padding: 0;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.hc-reopen-link:hover { color: var(--neon-cyan, var(--neon-cyan)); }

/* ========================================================
   ICONES INLINE (substitui Font Awesome)
   ======================================================== */
.hutz-icon {
  display: inline-block;
  width: 1em;
  height: 1em;
  vertical-align: -0.15em;
  fill: currentColor;
  flex-shrink: 0;
}

/* ========================================================
   DESCONTO PRIMEIRA COMPRA - CTA WHATSAPP
   ======================================================== */
.nl-cta-wrap {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 6px;
}
.nl-cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 16px 28px;
  background: #25d366;
  color: #fff;
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.15rem;
  letter-spacing: 0.12em;
  border-radius: 100px;
  text-transform: uppercase;
  text-decoration: none;
  border: 2px solid rgba(255,255,255,0.2);
  box-shadow: 0 8px 24px rgba(37, 211, 102, 0.35), 0 0 0 0 rgba(37, 211, 102, 0.4);
  transition: transform 0.2s ease, box-shadow 0.3s ease, background 0.2s;
  cursor: none;
  animation: nlPulse 2.4s ease-in-out infinite;
}
.nl-cta-btn:hover {
  background: #20bd5a;
  transform: translateY(-2px);
  box-shadow: 0 12px 30px rgba(37, 211, 102, 0.55), 0 0 0 8px rgba(37, 211, 102, 0.15);
}
.nl-cta-btn .hutz-icon {
  width: 1.2em;
  height: 1.2em;
}
.nl-cta-note {
  margin: 0;
  font-size: 0.72rem;
  letter-spacing: 0.05em;
  color: rgba(255, 248, 240, 0.55);
  text-align: center;
}
@keyframes nlPulse {
  0%, 100% { box-shadow: 0 8px 24px rgba(37, 211, 102, 0.35), 0 0 0 0 rgba(37, 211, 102, 0.4); }
  50%      { box-shadow: 0 8px 24px rgba(37, 211, 102, 0.45), 0 0 0 12px rgba(37, 211, 102, 0); }
}
@media (prefers-reduced-motion: reduce) {
  .nl-cta-btn { animation: none; }
}
@media (max-width: 600px) {
  .nl-cta-btn { font-size: 1rem; padding: 14px 22px; }
}

/* FAQ - aumenta max-height para respostas mais longas (personalizacao, pagamento) */
.faq-item.open .faq-answer {
  max-height: 600px;
}

/* Logo Hutz SVG - override do estilo de texto */
.nav-logo {
  display: inline-flex;
  align-items: center;
  padding: 0;
}
.nav-logo img {
  display: block;
  width: 44px;
  height: 44px;
  filter: drop-shadow(0 0 12px rgba(222, 46, 99, 0.4));
  transition: transform 0.25s ease, filter 0.25s ease;
}
.nav-logo:hover img {
  transform: scale(1.06);
  filter: drop-shadow(0 0 18px rgba(222, 46, 99, 0.7));
}
.footer-logo-text {
  display: inline-flex;
  align-items: center;
}
.footer-logo-text img {
  display: block;
  width: 56px;
  height: 56px;
  transition: transform 0.25s ease;
}
.footer-logo-text:hover img {
  transform: scale(1.05);
}

/* Feedback do form de contato (sucesso / erro / loading) */
.cf-feedback { margin-top: 8px; font-size: 0.78rem; padding: 0; min-height: 1.5em; }
.cf-feedback.cf-fb-loading { color: rgba(255,248,240,0.6); }
.cf-feedback.cf-fb-success {
  color: var(--neon-cyan, var(--neon-cyan));
  padding: 12px 16px;
  background: rgba(var(--neon-cyan-rgb), 0.08);
  border: 1px solid rgba(var(--neon-cyan-rgb), 0.3);
  border-radius: 10px;
}
.cf-feedback.cf-fb-error {
  color: #ff6f6f;
  padding: 12px 16px;
  background: rgba(255,80,80,0.08);
  border: 1px solid rgba(255,80,80,0.3);
  border-radius: 10px;
}

/* ========================================================
   PORTFOLIO - CARDS COM FOTO REAL
   ======================================================== */
.portfolio-card.port-photo {
  padding: 0;
  overflow: hidden;
  background: #0a0a0f;
}
.portfolio-card.port-photo .port-content {
  display: flex;
  flex-direction: column;
  height: 100%;
  gap: 0;
}
.portfolio-card.port-photo .port-visual-photo {
  margin: 0;
  width: 100%;
  height: 220px;
  overflow: hidden;
  position: relative;
}
.portfolio-card.port-photo .port-visual-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 50%, rgba(10,10,15,0.65) 100%);
  pointer-events: none;
}
.portfolio-card.port-photo .port-visual-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}
.portfolio-card.port-photo:hover .port-visual-photo img {
  transform: scale(1.06);
}
.portfolio-card.port-photo.port-lg .port-visual-photo {
  height: 320px;
}
.portfolio-card.port-photo .port-info {
  padding: 22px 24px 26px;
  flex: 1;
}
@media (max-width: 768px) {
  .portfolio-card.port-photo .port-visual-photo { height: 180px; }
  .portfolio-card.port-photo.port-lg .port-visual-photo { height: 220px; }
}

/* ========================================================
   PERSONALIZACAO - FOTO REAL NO HERO DA SECAO
   ======================================================== */
.ls-photo-frame {
  padding: 0;
  background: transparent;
  border: none;
  overflow: visible;
  position: relative;
}
.ls-photo-frame::before {
  content: "";
  position: absolute;
  inset: -8px;
  background: radial-gradient(circle at 40% 40%, rgba(var(--neon-cyan-rgb), 0.25), rgba(var(--neon-magenta-rgb), 0.2) 40%, transparent 70%);
  filter: blur(40px);
  z-index: -1;
}
.ls-photo {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 28px;
  box-shadow:
    0 30px 80px rgba(0,0,0,0.55),
    0 0 0 1px rgba(var(--neon-cyan-rgb), 0.12);
  transform: rotate(-2deg);
  transition: transform 0.5s ease;
}
.ls-photo:hover {
  transform: rotate(0deg) scale(1.02);
}
@media (max-width: 900px) {
  .ls-photo { transform: rotate(0deg); }
}

/* ========================================================
   CARD RGB - HALO CICLICO DE CORES
   Cicla --card-color e --card-soft entre 4 cores do espectro
   pra simular o efeito RGB que a propria pulseira faz
   ======================================================== */
.shake-card.card-rgb-cycle {
  --card-color: var(--neon-magenta);
  --card-soft:  #9b4dff;
  animation: rgbCardCycle 6s linear infinite;
}
.shake-card.card-rgb-cycle::before {
  animation: rgbCardGlow 6s linear infinite;
}
.shake-card.card-rgb-cycle .card-photo-wrap img {
  animation: rgbCardDropShadow 6s linear infinite;
}
.shake-card.card-rgb-cycle .card-chip {
  animation: rgbCardChip 6s linear infinite;
}

@keyframes rgbCardCycle {
  0%   { --card-color: var(--neon-magenta); --card-soft: #ff6fa8; border-color: rgba(var(--neon-magenta-rgb), 0.45); background: linear-gradient(160deg, rgba(var(--neon-magenta-rgb), 0.18) 0%, #0a0a0f 85%); }
  25%  { --card-color: #ffd700; --card-soft: #fff27a; border-color: rgba(255,215,0,0.45); background: linear-gradient(160deg, rgba(255,215,0,0.18) 0%, #0a0a0f 85%); }
  50%  { --card-color: var(--neon-cyan); --card-soft: #7cffff; border-color: rgba(var(--neon-cyan-rgb), 0.45); background: linear-gradient(160deg, rgba(var(--neon-cyan-rgb), 0.18) 0%, #0a0a0f 85%); }
  75%  { --card-color: #9b4dff; --card-soft: #c77dff; border-color: rgba(155,77,255,0.45); background: linear-gradient(160deg, rgba(155,77,255,0.18) 0%, #0a0a0f 85%); }
  100% { --card-color: var(--neon-magenta); --card-soft: #ff6fa8; border-color: rgba(var(--neon-magenta-rgb), 0.45); background: linear-gradient(160deg, rgba(var(--neon-magenta-rgb), 0.18) 0%, #0a0a0f 85%); }
}

@keyframes rgbCardGlow {
  0%   { background: radial-gradient(ellipse at 50% 40%, rgba(var(--neon-magenta-rgb), 0.55) 0%, transparent 70%); }
  25%  { background: radial-gradient(ellipse at 50% 40%, rgba(255,215,0,0.55) 0%, transparent 70%); }
  50%  { background: radial-gradient(ellipse at 50% 40%, rgba(var(--neon-cyan-rgb), 0.55) 0%, transparent 70%); }
  75%  { background: radial-gradient(ellipse at 50% 40%, rgba(155,77,255,0.55) 0%, transparent 70%); }
  100% { background: radial-gradient(ellipse at 50% 40%, rgba(var(--neon-magenta-rgb), 0.55) 0%, transparent 70%); }
}

@keyframes rgbCardDropShadow {
  0%   { filter: drop-shadow(0 0 18px var(--neon-magenta)) drop-shadow(0 0 36px rgba(255,111,168,0.55)); }
  25%  { filter: drop-shadow(0 0 18px #ffd700) drop-shadow(0 0 36px rgba(255,242,122,0.55)); }
  50%  { filter: drop-shadow(0 0 18px var(--neon-cyan)) drop-shadow(0 0 36px rgba(124,255,255,0.55)); }
  75%  { filter: drop-shadow(0 0 18px #9b4dff) drop-shadow(0 0 36px rgba(199,125,255,0.55)); }
  100% { filter: drop-shadow(0 0 18px var(--neon-magenta)) drop-shadow(0 0 36px rgba(255,111,168,0.55)); }
}

@keyframes rgbCardChip {
  0%   { color: var(--neon-magenta); border-color: rgba(var(--neon-magenta-rgb), 0.7); background: rgba(var(--neon-magenta-rgb), 0.15); }
  25%  { color: #ffd700; border-color: rgba(255,215,0,0.7);  background: rgba(255,215,0,0.15); }
  50%  { color: var(--neon-cyan); border-color: rgba(var(--neon-cyan-rgb), 0.7);  background: rgba(var(--neon-cyan-rgb), 0.15); }
  75%  { color: #9b4dff; border-color: rgba(155,77,255,0.7); background: rgba(155,77,255,0.15); }
  100% { color: var(--neon-magenta); border-color: rgba(var(--neon-magenta-rgb), 0.7); background: rgba(var(--neon-magenta-rgb), 0.15); }
}

@media (prefers-reduced-motion: reduce) {
  .shake-card.card-rgb-cycle,
  .shake-card.card-rgb-cycle::before,
  .shake-card.card-rgb-cycle .card-photo-wrap img,
  .shake-card.card-rgb-cycle .card-chip {
    animation: none;
  }
}

/* ========================================================
   SHAKE-CARDS - LARGURA FIXA E TEXTO QUEBRA AUTOMATICO
   Corrige cards expandindo horizontalmente quando descricao
   eh mais longa (ex: card Preto).
   ======================================================== */
.shake-card {
  width: 280px !important;
  max-width: 280px !important;
  box-sizing: border-box;
}
.shake-card .card-bottom,
.shake-card .card-name,
.shake-card .card-desc {
  width: 100%;
  max-width: 100%;
  word-wrap: break-word;
  overflow-wrap: break-word;
  hyphens: auto;
  white-space: normal;
}
.shake-card .card-desc {
  min-height: 4.5em;   /* ~3 linhas, mantem altura uniforme entre cards */
}

@media (max-width: 768px) {
  .shake-card {
    width: 240px !important;
    max-width: 240px !important;
  }
}
