/**
 * FC DME Solver — PlayStation Design Override
 * Enfileirar DEPOIS de style.css (depende de fc-dme-style)
 * Não editar style.css original.
 */

/* ============================================
   IMPORT — Barlow (body) + Barlow Condensed (display)
   ============================================ */
@import url('https://fonts.googleapis.com/css2?family=Barlow:wght@400;500;600;700&family=Barlow+Condensed:wght@600;700;800&display=swap');

/* ============================================
   VARIÁVEIS PS — Define uma vez, herda em tudo
   ============================================ */
:root {
  /* Fundos */
  --fc-ps-bg-root:        #050C15;
  --fc-ps-bg-secondary:   #080F1C;
  --fc-ps-surface:        #0D1A2A;
  --fc-ps-surface-raised: #122135;
  --fc-ps-overlay:        rgba(5, 12, 21, 0.92);

  /* Bordas */
  --fc-ps-border:         #192D44;
  --fc-ps-border-focus:   #0070D1;
  --fc-ps-border-strong:  #1E3D58;

  /* Texto */
  --fc-ps-text-primary:   #FFFFFF;
  --fc-ps-text-secondary: #8599B2;
  --fc-ps-text-muted:     #3D5470;

  /* CTA / Botões */
  --fc-ps-cta:            #0070D1;
  --fc-ps-cta-hover:      #0058A8;
  --fc-ps-cta-active:     #004486;

  /* Accent / Neon */
  --fc-ps-accent:         #00A8E8;
  --fc-ps-accent-glow:    rgba(0, 168, 232, 0.22);
  --fc-ps-accent-glow-strong: rgba(0, 168, 232, 0.45);

  /* Semânticas (símbolos do controle) */
  --fc-ps-success:        #00C49A;   /* △ */
  --fc-ps-warning:        #F5A623;   /* ○ */
  --fc-ps-danger:         #E8002A;   /* × */

  /* Sombras */
  --fc-ps-shadow-sm:      0 2px 8px rgba(0,0,0,0.55);
  --fc-ps-shadow-md:      0 4px 20px rgba(0,0,0,0.65);
  --fc-ps-shadow-lg:      0 8px 40px rgba(0,0,0,0.75);
  --fc-ps-shadow-glow:    0 0 16px rgba(0,168,232,0.22);
  --fc-ps-shadow-glow-cta:0 4px 24px rgba(0,112,209,0.40);

  /* Tipografia */
  --fc-ps-font-body:      'Barlow', sans-serif;
  --fc-ps-font-display:   'Barlow Condensed', sans-serif;

  /* Radius — geométrico Sony */
  --fc-ps-radius-xs:      2px;
  --fc-ps-radius-sm:      4px;
  --fc-ps-radius-base:    6px;
  --fc-ps-radius-lg:      10px;
  --fc-ps-radius-full:    9999px;

  /* Transições */
  --fc-ps-transition-fast:   0.12s ease;
  --fc-ps-transition-base:   0.2s ease;
  --fc-ps-transition-spring: 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ============================================
   TIPOGRAFIA GLOBAL — namespace do plugin
   ============================================ */
.fc-dme-wrapper,
.fc-dme-modal,
#fc-dme-basketbar,
.fc-dme-totalbar {
  font-family: var(--fc-ps-font-body);
}

.fc-dme-title,
.fc-dme-modal-title {
  font-family: var(--fc-ps-font-display);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* ============================================
   WRAPPER
   ============================================ */
.fc-dme-wrapper {
  background: transparent;
}

/* ============================================
   HEADER — título com assinatura PS (border-left)
   ============================================ */
.fc-dme-header {
  margin-bottom: 28px;
}

.fc-dme-title {
  font-family: var(--fc-ps-font-display);
  font-size: 30px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--fc-ps-text-primary);

  padding-left: 16px;
  border-left: 3px solid var(--fc-ps-accent);

  /* remove justify-content:center do original para alinhar à esquerda (padrão PS Store) */
  justify-content: flex-start;

  background: none;
}

/* ============================================
   NOME DO CARD — gradient azul animado (PS)
   ============================================ */
.fc-dme-card .fc-dme-card-name {
  font-family: var(--fc-ps-font-body);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;

  border-radius: var(--fc-ps-radius-xs) var(--fc-ps-radius-xs) 0 0;
  border: 1px solid var(--fc-ps-border);
  background: rgba(0, 112, 209, 0.10);
  backdrop-filter: blur(12px) saturate(140%);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
  box-shadow: none;
  margin-bottom: -15px;

  /* Gradient azul PS em vez de laranja */
  background-image: linear-gradient(
    90deg,
    #0070D1,
    #00A8E8,
    #5BC8F5,
    #0070D1,
    #004486
  );
  background-size: 300% 100%;
  animation: fcPsNameGradient 5s linear infinite;

  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

@keyframes fcPsNameGradient {
  0%   { background-position:   0% 50%; }
  100% { background-position: 100% 50%; }
}

/* ============================================
   CARD — fundo, borda, hover PS
   ============================================ */
.fc-dme-card {
  background: var(--fc-ps-surface);
  border: 1px solid var(--fc-ps-border);
  border-top: 2px solid transparent;
  border-radius: var(--fc-ps-radius-base);
  transition:
    border-top-color var(--fc-ps-transition-base),
    box-shadow var(--fc-ps-transition-base),
    transform var(--fc-ps-transition-base);
}

.fc-dme-card:hover {
  transform: translateY(-4px);
  border-top-color: var(--fc-ps-accent);
  border-color: var(--fc-ps-border-strong);
  box-shadow: var(--fc-ps-shadow-glow), var(--fc-ps-shadow-md);
}

/* ============================================
   CARD FOOTER
   ============================================ */
.fc-dme-card-footer {
  background: rgba(5, 12, 21, 0.55);
  border-top: 1px solid var(--fc-ps-border);
  border-radius: 0 0 var(--fc-ps-radius-base) var(--fc-ps-radius-base);
}

/* Preço no card */
.fc-dme-price {
  color: var(--fc-ps-accent);
}

/* ============================================
   BOTÃO — RESOLVER (CTA principal PS)
   ============================================ */
.fc-dme-solve-btn {
  background: var(--fc-ps-cta);
  border: none;
  border-radius: var(--fc-ps-radius-sm);
  font-family: var(--fc-ps-font-body);
  font-weight: 700;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #fff;
  padding:5px;
  transition:
    background var(--fc-ps-transition-fast),
    transform var(--fc-ps-transition-fast),
    box-shadow var(--fc-ps-transition-fast);
}

.fc-dme-solve-btn:hover {
  background: var(--fc-ps-cta-hover);
  transform: translateY(-1px);
  box-shadow: var(--fc-ps-shadow-glow-cta);
}

.fc-dme-solve-btn:active {
  background: var(--fc-ps-cta-active);
  transform: translateY(1px);
  box-shadow: none;
}

/* ============================================
   BOTÃO — EDITAR / REMOVER
   ============================================ */
.fc-dme-edit-btn,
.fc-dme-remove-btn {
  border-radius: var(--fc-ps-radius-sm);
  font-family: var(--fc-ps-font-body);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  background: rgba(13, 26, 42, 0.9);
  border: 1px solid var(--fc-ps-border-strong);
  color: var(--fc-ps-text-secondary);
  transition: all var(--fc-ps-transition-fast);
}

.fc-dme-edit-btn:hover {
  border-color: var(--fc-ps-accent);
  color: var(--fc-ps-accent);
  background: rgba(0, 168, 232, 0.08);
}

button.fc-dme-remove-btn {
  background: rgba(232, 0, 42, 0.07);
  border-color: rgba(232, 0, 42, 0.25);
  color: rgba(232, 0, 42, 0.75);
}

button.fc-dme-remove-btn:hover {
  background: rgba(232, 0, 42, 0.14);
  border-color: rgba(232, 0, 42, 0.50);
  color: #E8002A;
}

/* ============================================
   BOTÃO REFRESH
   ============================================ */
.fc-dme-refresh-btn {
  border-radius: var(--fc-ps-radius-sm);
  font-family: var(--fc-ps-font-body);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  background: rgba(13, 26, 42, 0.9);
  border: 1px solid var(--fc-ps-border-strong);
  color: var(--fc-ps-text-secondary);
  transition: all var(--fc-ps-transition-fast);
}

.fc-dme-refresh-btn:hover {
  background: rgba(0, 112, 209, 0.12);
  border-color: var(--fc-ps-border-focus);
  color: var(--fc-ps-accent);
  transform: translateY(-1px);
}

/* ============================================
   DROPDOWN DE PLATAFORMA
   ============================================ */
.fc-dme-toggle-current {
  background: rgba(13, 26, 42, 0.9);
  border: 1px solid var(--fc-ps-border-strong);
  border-radius: var(--fc-ps-radius-sm);
  transition: all var(--fc-ps-transition-base);
}

.fc-dme-toggle-current:hover {
  background: rgba(0, 112, 209, 0.10);
  border-color: var(--fc-ps-border-focus);
}

.fc-dme-platform-menu {
  background: var(--fc-ps-surface);
  border: 1px solid var(--fc-ps-border-strong);
  border-radius: var(--fc-ps-radius-base);
  box-shadow: var(--fc-ps-shadow-lg);
}

.fc-dme-toggle-option {
  background: rgba(5, 12, 21, 0.60);
  border: 1px solid var(--fc-ps-border);
  border-radius: var(--fc-ps-radius-sm);
  transition: all var(--fc-ps-transition-fast);
}

.fc-dme-toggle-option:hover {
  background: rgba(0, 112, 209, 0.14);
  border-color: var(--fc-ps-border-focus);
  transform: translateX(3px);
}

/* ============================================
   CHECKBOXES — PS Blue
   ============================================ */
.fc-dme-challenge-card input.fc-dme-chk,
.fc-dme-selectall-row input.fc-dme-selectall {
  border: 1.5px solid var(--fc-ps-border-strong);
  background: rgba(5, 12, 21, 0.6);
  border-radius: var(--fc-ps-radius-xs);
  transition: all var(--fc-ps-transition-fast);
}

.fc-dme-challenge-card input.fc-dme-chk:hover,
.fc-dme-selectall-row input.fc-dme-selectall:hover {
  border-color: var(--fc-ps-accent);
  transform: translateY(-1px);
}

.fc-dme-challenge-card input.fc-dme-chk:checked,
.fc-dme-selectall-row input.fc-dme-selectall:checked {
  border-color: var(--fc-ps-cta);
  background: linear-gradient(135deg, var(--fc-ps-cta), var(--fc-ps-cta-active));
  box-shadow: 0 0 8px rgba(0, 112, 209, 0.40);
}

/* ============================================
   CHALLENGE CARD (modal interno)
   ============================================ */
.fc-dme-challenge-card {
  background: var(--fc-ps-surface);
  border: 1px solid var(--fc-ps-border);
  border-top: 2px solid transparent;
  border-radius: var(--fc-ps-radius-base);
  transition:
    border-top-color var(--fc-ps-transition-base),
    box-shadow var(--fc-ps-transition-base),
    transform var(--fc-ps-transition-base);
}

.fc-dme-challenge-card:hover {
  border-top-color: var(--fc-ps-accent);
  border-color: var(--fc-ps-border-strong);
  box-shadow: var(--fc-ps-shadow-glow);
  transform: translateY(-3px);
}

/* Linha do checkbox dentro do challenge card */
.fc-dme-challenge-card .fc-dme-chk-row {
  background: rgba(5, 12, 21, 0.55);
  border-bottom: 1px solid var(--fc-ps-border);
  border-radius: var(--fc-ps-radius-base) var(--fc-ps-radius-base) 0 0;
}

.fc-dme-challenge-name-inline {
  font-family: var(--fc-ps-font-body);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--fc-ps-text-secondary);
}

/* Footer do challenge card */
.fc-dme-challenge-footer {
  background: rgba(5, 12, 21, 0.50);
  border-top: 1px solid var(--fc-ps-border);
}

.fc-dme-challenge-price-row {
  border-top: 1px solid var(--fc-ps-border);
}

.fc-dme-challenge-coins {
  font-family: var(--fc-ps-font-body);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--fc-ps-text-muted);
}

/* Preço destacado — azul neon */
.fc-dme-challenge-price-value {
  color: var(--fc-ps-accent);
  font-family: var(--fc-ps-font-display);
  font-weight: 800;
  font-size: 16px;
  letter-spacing: 0.02em;
}

/* Badge de moedas */
.fc-dme-coins-badge {
  background: rgba(5, 12, 21, 0.80);
  border: 1px solid var(--fc-ps-border-strong);
  border-radius: var(--fc-ps-radius-sm);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: var(--fc-ps-shadow-md);
}

.fc-dme-coins-badge-text {
  font-family: var(--fc-ps-font-body);
  font-weight: 700;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fc-ps-text-primary);
}

/* ============================================
   MODAL
   ============================================ */
.fc-dme-modal-overlay {
  background: rgba(5, 12, 21, 0.90);
  backdrop-filter: blur(6px);
}

.fc-dme-modal-content {
  background: var(--fc-ps-surface);
  border: 1px solid var(--fc-ps-border-strong);
  border-top: 2px solid var(--fc-ps-accent);
  border-radius: var(--fc-ps-radius-lg);
  box-shadow:
    var(--fc-ps-shadow-lg),
    0 0 0 1px var(--fc-ps-border) inset;
}

/* Botão fechar — quadrado estilo PS (sem circular) */
.fc-dme-modal-close {
  background: rgba(13, 26, 42, 0.9);
  border: 1px solid var(--fc-ps-border-strong);
  border-radius: var(--fc-ps-radius-sm);
  color: var(--fc-ps-text-secondary);
  font-size: 20px;
  font-weight: 700;
  transition: all var(--fc-ps-transition-fast);
}

.fc-dme-modal-close:hover {
  background: rgba(232, 0, 42, 0.12);
  border-color: rgba(232, 0, 42, 0.40);
  color: #E8002A;
  transform: rotate(90deg);
}

/* Header do modal */
.fc-dme-modal-header {
  border-bottom: 1px solid var(--fc-ps-border);
}

.fc-dme-modal-title {
  color: var(--fc-ps-text-primary);
  font-family: var(--fc-ps-font-display);
  font-weight: 800;
  font-size: 20px;
  text-transform: uppercase;
  letter-spacing: 0.06em;

  padding-left: 12px;
  border-left: 3px solid var(--fc-ps-accent);
}

.fc-dme-modal-count {
  font-family: var(--fc-ps-font-body);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--fc-ps-text-muted);
}

.fc-dme-modal-total {
  color: var(--fc-ps-accent);
  font-family: var(--fc-ps-font-display);
  font-weight: 800;
  font-size: 18px;
  letter-spacing: 0.03em;
}

/* Select all row */
.fc-dme-selectall-row {
  background: rgba(5, 12, 21, 0.70);
  border: 1px solid var(--fc-ps-border);
  border-radius: var(--fc-ps-radius-sm);
}

.fc-dme-selectall-row span {
  font-family: var(--fc-ps-font-body);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--fc-ps-text-secondary);
}

/* ============================================
   TOTALBAR — glassmorphism azul-escuro PS
   ============================================ */
.fc-dme-totalbar {
  background: rgba(5, 12, 21, 0.88) !important;
  border: 1px solid var(--fc-ps-border-strong) !important;
  border-top: 1px solid rgba(0, 168, 232, 0.20) !important;
  border-radius: var(--fc-ps-radius-lg);
  backdrop-filter: blur(16px) saturate(150%);
  -webkit-backdrop-filter: blur(16px) saturate(150%);
  box-shadow:
    0 16px 50px rgba(0,0,0,0.65),
    0 0 0 1px rgba(0, 168, 232, 0.08) inset;
}

/* Linha neon sutil no topo da totalbar */
.fc-dme-totalbar::before {
  content: "";
  position: absolute;
  left: 0; right: 0; top: 0;
  height: 1px;
  border-radius: var(--fc-ps-radius-lg) var(--fc-ps-radius-lg) 0 0;
  background: linear-gradient(
    90deg,
    rgba(0,168,232,0),
    rgba(0,168,232,0.45),
    rgba(0,168,232,0)
  );
  pointer-events: none;
}

.fc-dme-totalbar-left > div {
  color: var(--fc-ps-text-secondary);
  font-family: var(--fc-ps-font-body);
  font-size: 13px;
}

.fc-dme-totalbar strong {
  color: var(--fc-ps-accent);
  font-family: var(--fc-ps-font-display);
  font-weight: 800;
  letter-spacing: 0.02em;
}

.fc-dme-totalbar-coins {
  color: var(--fc-ps-text-secondary);
}

.fc-dme-totalbar-brl {
  color: var(--fc-ps-accent);
}

/* ============================================
   BOTÃO CONCLUIR — PS Blue
   ============================================ */
.fc-dme-conclude-btn {
  background: var(--fc-ps-cta);
  border-radius: var(--fc-ps-radius-sm);
  font-family: var(--fc-ps-font-body);
  font-weight: 700;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: #fff;
  transition:
    transform var(--fc-ps-transition-fast),
    filter var(--fc-ps-transition-fast),
    box-shadow var(--fc-ps-transition-fast);
}

.fc-dme-conclude-btn:hover {
  filter: brightness(1.08);
  box-shadow: var(--fc-ps-shadow-glow-cta);
  transform: translateY(-1px);
}

.fc-dme-conclude-btn:active {
  background: var(--fc-ps-cta-active);
  transform: translateY(1px) scale(0.99);
  filter: brightness(0.97);
  box-shadow: none;
}

.fc-dme-conclude-btn:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 3px rgba(0, 168, 232, 0.30),
    var(--fc-ps-shadow-glow-cta);
}

.fc-dme-conclude-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

/* ============================================
   BASKET BAR — glassmorphism azul PS
   ============================================ */
#fc-dme-basketbar {
  background: rgba(5, 12, 21, 0.88) !important;
  border-top: 1px solid var(--fc-ps-border-strong) !important;
  backdrop-filter: blur(18px) saturate(150%) !important;
  -webkit-backdrop-filter: blur(18px) saturate(150%) !important;
  box-shadow:
    0 -18px 60px rgba(0,0,0,0.65),
    0 0 0 1px rgba(0,168,232,0.07) inset !important;
  border-radius: 10px 10px 0 0;
}

/* Linha neon no topo da basket bar */
#fc-dme-basketbar::before {
  background: linear-gradient(
    90deg,
    rgba(0,168,232,0),
    rgba(0,168,232,0.40),
    rgba(0,168,232,0)
  ) !important;
}

/* Botão comprar — PS Blue com shine */
#fc-dme-basketbar .fc-dme-basket-buy {
  background: var(--fc-ps-cta) !important;
  border-radius: var(--fc-ps-radius-sm) !important;
  font-family: var(--fc-ps-font-body);
  font-weight: 700;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  box-shadow:
    0 16px 40px rgba(0, 112, 209, 0.38),
    0 0 0 1px rgba(255,255,255,0.10) inset !important;
}

#fc-dme-basketbar .fc-dme-basket-buy:hover {
  filter: brightness(1.08);
  transform: translateY(-1px);
  box-shadow:
    0 18px 46px rgba(0, 112, 209, 0.48),
    0 0 0 1px rgba(255,255,255,0.12) inset !important;
}

/* Shine (after) — mantém animação, cor neutra (funciona em azul também) */
#fc-dme-basketbar .fc-dme-basket-buy::after {
  background: linear-gradient(
    90deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,0.50) 50%,
    rgba(255,255,255,0) 100%
  );
}

/* Moedas e BRL na basket bar */
strong.fc-dme-basket-brl,
strong.fc-dme-basket-count {
  color: var(--fc-ps-accent);
}

/* ============================================
   WARNING / ERROR — cores PS
   ============================================ */
.fc-dme-warning {
  background: rgba(245, 166, 35, 0.08);
  border: 1px solid rgba(245, 166, 35, 0.28);
  color: #F5A623;
  border-radius: var(--fc-ps-radius-sm);
  font-family: var(--fc-ps-font-body);
  font-size: 13px;
  font-weight: 600;
}

.fc-dme-error {
  background: rgba(232, 0, 42, 0.08);
  border: 1px solid rgba(232, 0, 42, 0.28);
  color: #E8002A;
  border-radius: var(--fc-ps-radius-sm);
}

/* ============================================
   EMPTY STATE
   ============================================ */
.fc-dme-empty p,
.fc-dme-empty-challenges p {
  font-family: var(--fc-ps-font-body);
  font-size: 14px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fc-ps-text-muted);
}

/* ============================================
   MOBILE OVERRIDES
   ============================================ */
@media (max-width: 640px) {
  .fc-dme-totalbar {
    border-radius: 10px;
  }
  #fc-dme-modal .fc-dme-totalbar--modal{bottom: 30px !important;}
  .fc-dme-card-content{padding:10px;}
.fc-dme-wrapper{margin:10px;}
  .fc-dme-title {
    font-size: 22px;
  }
}

@media (max-width: 480px) {
  .fc-dme-modal-close {
    border-radius: var(--fc-ps-radius-xs);
  }
}