/* ─── Arcade Wallet Card UI ─────────────────────────────────── */

.wallet-card-slot-area {
  flex: 1;
  max-width: 240px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  min-height: 0;
  overflow: hidden;
  transition: min-height .4s ease;
  padding: 8px 4px;
  border-radius: 10px;
  background: rgba(56,189,248,.04);
  border: 1px solid rgba(56,189,248,.12);
}

.wallet-card-slot-area.active {
  min-height: 160px;
}

/* Reader slot */
.wcard-reader {
  position: relative;
  width: 180px;
  height: 10px;
  background: linear-gradient(180deg, #0a1020, #1a2040);
  border: 2px solid #3a5a9a;
  border-radius: 4px;
  box-shadow: inset 0 2px 6px rgba(0,0,0,.8), 0 0 8px rgba(56,189,248,.15);
  overflow: visible;
  z-index: 5;
}

.wcard-reader::before {
  content: '';
  position: absolute;
  top: 2px; left: 50%;
  transform: translateX(-50%);
  width: 140px; height: 3px;
  background: #000;
  border-radius: 2px;
  border: 1px solid #4a6aaa;
}

.wcard-reader-led {
  position: absolute;
  top: -6px; right: 8px;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #333;
  box-shadow: 0 0 3px rgba(0,0,0,.5);
  transition: all .3s;
}

.wcard-reader-led.ready {
  background: #38bdf8;
  box-shadow: 0 0 6px rgba(56,189,248,.6);
}

.wcard-reader-led.active {
  background: #38bdf8;
  box-shadow: 0 0 6px rgba(56,189,248,.6);
  animation: wcardLedBlink 1.5s ease-in-out infinite;
}

@keyframes wcardLedBlink {
  0%, 100% { opacity: 1; }
  50% { opacity: .4; }
}

/* Card tray */
.wcard-tray {
  width: 180px;
  height: 110px;
  overflow: hidden;
  margin-top: -10px;
  position: relative;
}

/* ─── The Wallet Card (blue theme) ─── */
.wcard {
  position: relative;
  width: 165px;
  height: 104px;
  margin: 2px auto 0;
  border-radius: 10px;
  background: linear-gradient(135deg, #0a1a40 0%, #102860 30%, #0a1a40 60%, #102860 100%);
  border: 2px solid;
  border-image: linear-gradient(135deg, #38bdf8, #7dd3fc, #38bdf8, #0ea5e9) 1;
  box-shadow:
    0 4px 20px rgba(0,0,0,.6),
    0 0 30px rgba(56,189,248,.15),
    inset 0 1px 0 rgba(255,255,255,.08);
  overflow: hidden;
  transform: translateY(115px);
  transition: none;
}

.wcard.showing {
  transform: translateY(0);
  transition: transform .5s ease-out;
}

.wcard.inserted {
  transform: translateY(-115px);
  transition: transform 3s cubic-bezier(.4,.0,.2,1);
}

.wcard.ejecting {
  transform: translateY(0);
  transition: transform .8s ease-out;
}

/* Shimmer */
.wcard::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    115deg,
    transparent 20%,
    rgba(56,189,248,.08) 30%,
    rgba(255,255,255,.06) 35%,
    transparent 40%,
    transparent 60%,
    rgba(56,189,248,.05) 65%,
    rgba(100,200,255,.08) 70%,
    transparent 80%
  );
  animation: wcardShimmer 4s ease-in-out infinite;
  pointer-events: none;
}

@keyframes wcardShimmer {
  0%, 100% { transform: translateX(-100%); }
  50% { transform: translateX(100%); }
}

/* Chip (blue tint) */
.wcard-chip {
  position: absolute;
  top: 28px; left: 16px;
  width: 38px; height: 28px;
  background: linear-gradient(135deg, #2a6aaa, #4a9adc, #2a6aaa, #3a8acc);
  border-radius: 4px;
  box-shadow:
    0 1px 4px rgba(0,0,0,.4),
    inset 0 0 0 1px rgba(255,255,255,.2);
}

.wcard-chip::before {
  content: '';
  position: absolute;
  top: 4px; left: 4px; right: 4px; bottom: 4px;
  border: 1px solid rgba(56,120,200,.5);
  border-radius: 2px;
}

.wcard-chip::after {
  content: '';
  position: absolute;
  top: 50%; left: 4px; right: 4px;
  height: 1px;
  background: rgba(56,120,200,.5);
  box-shadow:
    0 -6px 0 rgba(56,120,200,.4),
    0 6px 0 rgba(56,120,200,.4);
}

/* Branding */
.wcard-brand {
  position: absolute;
  top: 8px; left: 16px;
  font-size: .5rem;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(56,189,248,.6);
}

.wcard-type-badge {
  position: absolute;
  top: 6px; right: 12px;
  font-size: .55rem;
  font-weight: 800;
  letter-spacing: 1px;
  color: rgba(56,189,248,.8);
  text-shadow: 0 0 8px rgba(56,189,248,.3);
}

/* Card info */
.wcard-info {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 6px 14px 8px;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,.3));
}

.wcard-name {
  font-size: .65rem;
  font-weight: 700;
  color: rgba(255,255,255,.75);
  letter-spacing: 1px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 120px;
}

.wcard-number {
  font-size: .55rem;
  font-family: 'Courier New', monospace;
  color: rgba(56,189,248,.5);
  letter-spacing: 2px;
  margin-top: 1px;
}

/* Credits display */
.wcard-credits {
  position: absolute;
  bottom: 8px; right: 12px;
  text-align: right;
}

.wcard-credits-label {
  font-size: .45rem;
  color: rgba(255,255,255,.35);
  text-transform: uppercase;
  letter-spacing: 1px;
}

.wcard-credits-value {
  font-size: 1.1rem;
  font-weight: 900;
  color: #38bdf8;
  text-shadow: 0 0 10px rgba(56,189,248,.4);
  line-height: 1;
}

.wcard-credits-value.low {
  color: #ff8866;
  text-shadow: 0 0 10px rgba(255,100,80,.4);
}

.wcard-credits-value.empty {
  color: #ff4466;
  text-shadow: 0 0 10px rgba(255,60,100,.4);
}

/* Buttons */
.wcard-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}

.wcard-insert-btn,
.wcard-eject-btn {
  padding: 5px 10px;
  border-radius: 8px;
  font-weight: 700;
  font-size: .65rem;
  letter-spacing: .5px;
  cursor: pointer;
  transition: all .2s;
  text-transform: uppercase;
  border: none;
}

.wcard-insert-btn {
  background: linear-gradient(180deg, rgba(56,189,248,.2), rgba(56,189,248,.08));
  border: 2px solid rgba(56,189,248,.5);
  color: #7dd3fc;
}

.wcard-insert-btn:hover {
  background: linear-gradient(180deg, rgba(56,189,248,.35), rgba(56,189,248,.18));
  box-shadow: 0 0 20px rgba(56,189,248,.25);
  transform: scale(1.03);
}

.wcard-eject-btn {
  background: linear-gradient(180deg, rgba(255,100,80,.12), rgba(255,100,80,.05));
  border: 2px solid rgba(255,100,80,.3);
  color: #ff8866;
  font-size: .65rem;
  padding: 4px 12px;
}

.wcard-eject-btn:hover {
  background: linear-gradient(180deg, rgba(255,100,80,.25), rgba(255,100,80,.12));
  box-shadow: 0 0 15px rgba(255,100,80,.2);
}

/* Status text */
.wcard-status-text {
  font-size: .7rem;
  color: rgba(56,189,248,.6);
  text-align: center;
  min-height: 1em;
}

.wcard-status-text.error {
  color: #ff4466;
}

/* Quota display */
.wcard-quota-display {
  display: flex;
  align-items: baseline;
  gap: 6px;
  padding: 4px 0;
}

.wcard-quota-value {
  font-size: 1.3rem;
  font-weight: 900;
  color: #38bdf8;
  text-shadow: 0 0 10px rgba(56,189,248,.3);
  line-height: 1;
}

.wcard-quota-value.low {
  color: #ff8866;
  text-shadow: 0 0 10px rgba(255,100,80,.3);
}

.wcard-quota-value.empty {
  color: #ff4466;
  text-shadow: 0 0 10px rgba(255,60,100,.3);
}

.wcard-quota-label {
  font-size: .6rem;
  color: rgba(56,189,248,.5);
  letter-spacing: .5px;
  text-transform: uppercase;
}

/* Loading */
.wcard-loading {
  font-size: .65rem;
  color: rgba(255,255,255,.3);
  letter-spacing: 1px;
}

.wcard-loading::after {
  content: '...';
  animation: cardPulse 1.5s ease-in-out infinite;
}
