    :root {
      /* Modern color palette based on Revolut/N26 style */
      --primary: #1a1f71;
      --primary-dark: #0c1045;
      --primary-light: #3244b6;
      --secondary: #00579f;
      --accent: #f7b600;
      --success: #00d34d;
      --danger: #ff4d4d;
      --warning: #ffad33;
      --info: #0095ff;
      --neutral-100: #ffffff;
      --neutral-200: #f5f7fa;
      --neutral-300: #eaecf0;
      --neutral-400: #d0d5dd;
      --neutral-500: #9da4b4;
      --neutral-600: #6e7891;
      --neutral-700: #4f5d75;
      --neutral-800: #293249;
      --neutral-900: #1a1f37;

      /* Shadows & Effects */
      --shadow-sm: 0 1px 3px rgba(16, 24, 40, 0.1);
      --shadow-md: 0 4px 8px -2px rgba(16, 24, 40, 0.1), 0 2px 4px -2px rgba(16, 24, 40, 0.06);
      --shadow-lg: 0 12px 16px -4px rgba(16, 24, 40, 0.08), 0 4px 6px -2px rgba(16, 24, 40, 0.03);
      --shadow-xl: 0 20px 24px -4px rgba(16, 24, 40, 0.08), 0 8px 8px -4px rgba(16, 24, 40, 0.03);
      --shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, 0.06);
      
      /* Border radius */
      --radius-sm: 6px;
      --radius-md: 12px;
      --radius-lg: 16px;
      --radius-xl: 24px;
      --radius-full: 9999px;
      
      /* Transitions */
      --transition-fast: all 0.2s ease;
      --transition-base: all 0.3s ease;
      --transition-slow: all 0.5s ease;
      
      /* Card gradients */
      --card-gradient: linear-gradient(135deg, #1a1f71 0%, #0c1045 100%);
      --success-gradient: linear-gradient(135deg, #00c057 0%, #00a346 100%);
      
      /* Animations */
      --animation-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);

      /* Visa color helpers */
      --visa-blue: var(--primary);
      --visa-yellow: var(--accent);
      --success-green: var(--success);
      --danger-red: var(--danger);
      --warning-orange: var(--warning);
      --visa-gold: #F7B600;
      --visa-gold-light: #FFD233;
      --visa-gold-dark: #E5A800;
    }
    
    * {
      margin: 0;
      padding: 0;
      box-sizing: border-box;
    }

    html.is-loading body > :not(.loading-overlay):not(#tawkto-loader):not(#tawkto-container) {
      display: none;
    }
    
    body {
      font-family: 'Inter', 'Roboto', system-ui, sans-serif;
      font-size: 1.21rem; /* 15% increase from previous */
      color: #1f2937;
      background: var(--neutral-200);
      line-height: 1.5;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      overflow-x: hidden;
      height: 100vh;
      margin: 0;
      position: relative;
    }

    .rate-impact-modal {
      text-align: left;
      color: var(--neutral-800);
    }

    .rate-impact-description {
      margin-bottom: 1rem;
      font-size: 0.95rem;
      color: var(--neutral-600);
    }

    .rate-impact-cards {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
      gap: 1rem;
      margin: 1.25rem 0;
    }

    .rate-impact-card {
      background: var(--neutral-100);
      border: 1px solid var(--neutral-300);
      border-radius: var(--radius-lg);
      box-shadow: 0 10px 24px rgba(26, 31, 113, 0.08);
      padding: 1rem 1.25rem;
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
    }

    .rate-impact-card--highlight {
      border-color: var(--primary-light);
      box-shadow: 0 14px 30px rgba(26, 31, 113, 0.12);
    }

    .rate-impact-card-title {
      margin: 0;
      font-size: 1.05rem;
      font-weight: 600;
      color: var(--primary-dark);
    }

    .rate-impact-rate {
      margin: 0;
      font-size: 0.85rem;
      color: var(--neutral-600);
    }

    .rate-impact-amount {
      display: flex;
      justify-content: space-between;
      align-items: baseline;
      gap: 0.75rem;
      padding-top: 0.25rem;
      border-top: 1px solid rgba(234, 236, 240, 0.8);
    }

    .rate-impact-amount:first-of-type {
      border-top: none;
      padding-top: 0;
    }

    .rate-impact-label {
      font-size: 0.75rem;
      letter-spacing: 0.05em;
      text-transform: uppercase;
      color: var(--neutral-500);
    }

    .rate-impact-value {
      font-size: 1.2rem;
      font-weight: 700;
      color: var(--primary);
    }

    .rate-impact-card--highlight .rate-impact-value {
      color: var(--primary-dark);
    }

    .rate-impact-warning {
      margin-top: 1rem;
      font-size: 0.9rem;
      color: var(--neutral-700);
    }

    @media (max-width: 480px) {
      .rate-impact-cards {
        grid-template-columns: 1fr;
      }

      .rate-impact-card {
        padding: 1rem;
      }
    }

    /* Scrollbars */
    ::-webkit-scrollbar {
      width: 6px;
      height: 6px;
    }
    
    ::-webkit-scrollbar-track {
      background: var(--neutral-200);
    }
    
    ::-webkit-scrollbar-thumb {
      background: var(--neutral-500);
      border-radius: var(--radius-full);
    }
    
    /* Header */
    .app-header {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 0.6rem 1rem;
      background: var(--neutral-100);
      border-bottom: 1px solid var(--neutral-300);
      box-shadow: var(--shadow-sm);
      z-index: 1000;
      height: 60px;
    }
    
    .header-brand {
      display: flex;
      align-items: center;
      gap: 0.5rem;
    }
    
    .header-brand img {
      height: 40px;
      width: auto;
    }
    
    .header-actions {
      display: flex;
      align-items: center;
      gap: 0.25rem;
    }

    .header-action-btn {
      width: 32px;
      height: 32px;
      border-radius: var(--radius-full);
      display: flex;
      align-items: center;
      justify-content: center;
      background: var(--neutral-200);
      color: var(--neutral-700);
      border: none;
      cursor: pointer;
      transition: var(--transition-base);
      position: relative;
    }
    
    .header-action-btn:hover {
      background: var(--neutral-300);
      color: var(--neutral-900);
    }
    
    .notification-badge {
      position: absolute;
      top: -2px;
      right: -2px;
      background: var(--danger);
      color: white;
      border-radius: var(--radius-full);
      font-size: 0.6rem;
      width: 16px;
      height: 16px;
      display: flex;
      align-items: center;
      justify-content: center;
      font-weight: 600;
      border: 2px solid #fff;
    }
    
    /* Connected Users Badge */
    .users-online-badge {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      padding: 0.25rem 0.5rem;
      background: rgba(26, 31, 113, 0.08);
      border-radius: var(--radius-md);
      font-size: 0.7rem;
      color: var(--primary);
      font-weight: 500;
      white-space: nowrap;
    }
    
    .users-online-badge i {
      font-size: 0.7rem;
    }
    
    .pulse-dot {
      width: 6px;
      height: 6px;
      background-color: var(--success);
      border-radius: 50%;
      animation: pulse 1.5s infinite;
    }
    
    @keyframes pulse {
      0% {
        transform: scale(0.95);
        box-shadow: 0 0 0 0 rgba(0, 211, 77, 0.7);
      }
      
      70% {
        transform: scale(1);
        box-shadow: 0 0 0 4px rgba(0, 211, 77, 0);
      }
      
      100% {
        transform: scale(0.95);
        box-shadow: 0 0 0 0 rgba(0, 211, 77, 0);
      }
    }
    
    /* Account Balance Card */
    .balance-card {
      background: var(--card-gradient);
      border-radius: var(--radius-lg);
      padding: 1.25rem;
      color: white;
      box-shadow: var(--shadow-lg);
      position: relative;
      overflow: hidden;
      margin-bottom: 1.25rem;
      transition: transform 0.3s var(--animation-bounce), box-shadow 0.3s ease;
    }

    .balance-card .balance-video-bg {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      z-index: 0;
    }
    
    .balance-card:hover {
      transform: translateY(-5px);
      box-shadow: var(--shadow-xl);
    }
    
    .balance-card::after {
      content: '';
      position: absolute;
      top: 0;
      left: -100%;
      width: 100%;
      height: 100%;
      background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
      animation: shine 3s infinite;
    }

    .balance-card.blurred {
      filter: blur(4px);
      pointer-events: none;
    }
    
    @keyframes shine {
      100% { left: 200%; }
    }

    /* --- Partículas verde-neón sobre la tarjeta de saldo --- */
    .particles-container{
      position:absolute;
      inset:0;
      overflow:hidden;
      z-index:1;
    }
    .particle{
      position:absolute;
      width:6px;height:6px;
      background:radial-gradient(circle,rgba(0,230,118,1) 0%,rgba(0,230,118,.2) 70%);
      border-radius:50%;
      opacity:0;
      pointer-events:none;
      filter:drop-shadow(0 0 3px rgba(0,230,118,.8));
    }
    .particle.diamond{clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);}
    .particle.mini{width:3px;height:3px;}
    .particle.trail::after{
      content:'';
      position:absolute;inset:0;
      background:inherit;
      filter:blur(2px);
      opacity:.7;
      transform:translateX(-5px);
    }
    
    .card-decoration {
      position: absolute;
      right: -50px;
      bottom: -50px;
      width: 200px;
      height: 200px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(255,255,255,0.1) 0%, rgba(255,255,255,0) 70%);
      z-index: 1;
    }
    
    .card-decoration:nth-child(2) {
      left: -30px;
      top: -30px;
      width: 150px;
      height: 150px;
    }
    
  .balance-content {
    position: relative;
    z-index: 2;
  }

  .header-right {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    min-width: 0;
  }

  .balance-controls {
    display: flex;
    gap: 0.25rem;
  }

  .balance-control-btn {
    background: rgba(255,255,255,0.2);
    border: none;
    color: white;
    width: 24px;
    height: 24px;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.65rem;
    cursor: pointer;
    transition: background 0.2s;
  }

  .balance-control-btn:hover {
    background: rgba(255,255,255,0.3);
  }

  .balance-refresh-btn {
    background: rgba(255,255,255,0.2);
    border: none;
    color: white;
    width: 22px;
    height: 22px;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.2s;
    flex-shrink: 0;
    padding: 0;
  }

  #refresh-balance-btn {
    margin-left: 0;
  }

  .balance-refresh-btn:hover {
    background: rgba(255,255,255,0.3);
  }

  .balance-refresh-btn img {
    width: 14px;
    height: 14px;
    filter: brightness(0) invert(1);
  }
    
    .balance-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 0.5rem;
      gap: 0.5rem;
      flex-wrap: nowrap;
      width: 100%;
    }
    
    .header-avatar {
      width: 28px;
      height: 28px;
      border-radius: var(--radius-full);
      background: rgba(255, 255, 255, 0.2);
      color: white;
      display: flex;
      align-items: center;
      justify-content: center;
      font-weight: 600;
      font-size: 0.75rem;
      flex-shrink: 0;
      overflow: hidden;
      background-size: cover;
      background-position: center;
    }

    .user-avatar {
      width: 40px;
      height: 40px;
      border-radius: var(--radius-full);
      background: var(--primary);
      color: white;
      display: flex;
      align-items: center;
      justify-content: center;
      font-weight: 600;
      font-size: 0.9rem;
    }

    .modal-avatar {
      width: 80px;
      height: 80px;
      border-radius: var(--radius-full);
      object-fit: cover;
      border: 2px solid var(--neutral-300);
      margin: 0 auto 1rem;
      display: block;
    }

    .balance-label {
      font-size: 0.8rem;
      opacity: 0.8;
      margin-bottom: 0.25rem;
      display: flex;
      align-items: center;
      gap: 0.5rem;
      flex: 1;
      min-width: 0;
      overflow: hidden;
    }

    .balance-label span {
      white-space: nowrap;
    }
    
    .balance-label i {
      font-size: 0.9rem;
    }
    
    .balance-amount {
      /* Slightly larger to emphasize the main balance */
      font-size: clamp(2.376rem, 7.92vw, 3.432rem);
      font-weight: 700;
      margin: 0.5rem 0 0.75rem;
      display: flex;
      align-items: center;
      justify-content: center;
      text-align: center;
      gap: 0.5rem;
      flex-wrap: wrap;
      white-space: normal;
    }

    @media (min-width: 768px) {
      .balance-header {
        flex-wrap: nowrap;
      }

      .balance-amount {
        justify-content: center;
        text-align: center;
      }

      #refresh-balance-btn {
        margin-left: 0;
      }
    }

    /* Slight increase for the main balance display */
    #dashboard-balance {
      font-size: clamp(2.495rem, 8.316vw, 3.604rem);
    }
    
    .currency-flag {
      width: 20px;
      height: 14px;
      border-radius: 2px;
      object-fit: cover;
      box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
      flex-shrink: 0;
    }
    
    .balance-equivalents {
      display: flex;
      flex-wrap: wrap;
      justify-content: center;
      gap: 0.75rem;
      margin-bottom: 0.75rem;
      width: fit-content;
      margin-left: auto;
      margin-right: auto;
    }
    
    .balance-equivalent {
      background: rgba(255, 255, 255, 0.1);
      border-radius: var(--radius-md);
      padding: 0.4rem 0.6rem;
      font-size: 0.75rem;
      display: flex;
      align-items: center;
      gap: 0.4rem;
      backdrop-filter: blur(5px);
      box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
      white-space: nowrap;
    }

    #usdt-balance {
      cursor: pointer;
    }

    .exchange-rate {
      background: rgba(255, 255, 255, 0.15);
      border-radius: var(--radius-md);
      padding: 0.4rem 0.6rem;
      font-size: 0.71rem;
      margin: 0 auto 0.75rem;
      display: flex;
      justify-content: center;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
      width: fit-content;
      max-width: 100%;
    }
    
    #balance-label-name,
    .balance-date {
      font-size: 0.7rem;
      color: rgba(255, 255, 255, 0.875);
    }

    .balance-date {
      margin-left: 0.25rem;
    }

    #balance-block-msg {
      color: var(--danger);
      font-size: 0.75rem;
      text-align: center;
      margin-top: -0.5rem;
      margin-bottom: 0.75rem;
      display: none;
    }

    .account-level {
      font-size: 0.71rem;
      font-weight: 400;
      margin-top: -0.5rem;
      margin-bottom: 1rem;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 0.25rem;
      cursor: pointer;
      width: fit-content;
      margin-left: auto;
      margin-right: auto;
    }

    .balance-card.uranio-infinite {
      background: linear-gradient(135deg, var(--visa-gold-dark), var(--visa-gold-light));
      box-shadow: 0 0 20px rgba(255, 215, 0, 0.4), 0 0 40px rgba(255, 215, 0, 0.3);
      animation: goldPulse 3s infinite;
    }

    /* Savings label inside balance card */
    .balance-savings .btn-outline {
      color: #fff;
      border-color: rgba(255, 255, 255, 0.85);
    }

    .balance-savings .btn-outline:hover {
      background: rgba(255, 255, 255, 0.2);
    }
    
    .balance-actions {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      grid-auto-rows: 52px;
      gap: 1rem;
      margin-top: 1rem;
    }

    .balance-actions .action-group {
      display: contents;
    }

    .balance-btn {
      border: 1px solid rgba(255, 255, 255, 0.3);
      border-radius: var(--radius-xl);
      padding: 0.549rem 0.729rem;
      height: 100%;
      min-height: 52px;
      display: flex;
      align-items: center;
      justify-content: center;
      font-weight: 600;
      font-size: clamp(0.648rem, 2.25vw, 0.765rem);
      overflow: hidden;
      text-overflow: ellipsis;
      background: rgba(255, 255, 255, 0.1);
      color: #fff;
      backdrop-filter: blur(8px);
      -webkit-backdrop-filter: blur(8px);
      cursor: pointer;
      transition: var(--transition-base);
      box-shadow: var(--shadow-md);
      white-space: nowrap;
      width: 100%;
    }

    .balance-btn:hover {
      background: rgba(255, 255, 255, 0.2);
      box-shadow: var(--shadow-lg);
      transform: translateY(-2px);
    }
    
    .balance-btn:active {
      transform: translateY(0);
    }

    .balance-btn i {
      margin-right: 6px;
      font-size: 0.729rem;
    }

    #send-bank-name {
      display: inline-block;
      max-width: 100%;
      white-space: normal;
    }

    #send-btn {
      grid-column: 2;
      grid-row: 1;
      white-space: normal;
    }

    #send-btn .btn-text {
      display: flex;
      flex-direction: column;
      line-height: 1.1;
      text-align: center;
    }

    .balance-btn:disabled,
    .balance-btn.disabled {
      opacity: 0.6;
      cursor: not-allowed;
      transform: none;
    }

    .balance-btn.disabled:hover {
      background: rgba(255, 255, 255, 0.1);
      box-shadow: var(--shadow-md);
      transform: none;
    }

    #recharge-btn {
      grid-column: 1;
      grid-row: 1;
    }

    #intercambioBtn {
      grid-column: 1;
      grid-row: 2;
      white-space: normal;
    }

    #intercambioBtn .btn-text {
      display: flex;
      flex-direction: column;
      line-height: 1.1;
      text-align: center;
    }

    #cryptoBtn {
      grid-column: 2;
      grid-row: 2;
    }

    @media (min-width: 500px) {
      .balance-actions {
        grid-template-columns: repeat(2, 1fr);
      }
    }
    
    /* Pending transactions badge */
    .pending-transaction-badge {
      background: rgba(255, 255, 255, 0.2);
      border-left: 3px solid var(--accent);
      border-radius: var(--radius-md);
      padding: 0.6rem;
      margin-top: 0.6rem;
      font-size: 0.75rem;
      color: var(--neutral-100);
      display: flex;
      align-items: center;
      gap: 0.5rem;
    }

    .pending-transaction-badge i {
      color: var(--accent);
      font-size: 0.9rem;
      flex-shrink: 0;
    }

    /* Rejected transactions badge */
    .rejected-transaction-badge {
      background: rgba(255, 255, 255, 0.2);
      border-left: 3px solid var(--danger);
      border-radius: var(--radius-md);
      padding: 0.6rem;
      margin-top: 0.6rem;
      font-size: 0.75rem;
      color: var(--neutral-100);
      display: flex;
      align-items: center;
      gap: 0.5rem;
    }

    .rejected-transaction-badge i {
      color: var(--danger);
      font-size: 0.9rem;
      flex-shrink: 0;
    }
    
    /* Dashboard Layout */
    .app-container {
      padding-top: 70px;
      padding-bottom: 130px;
      max-width: 100%;
      margin: 0 auto;
      height: 100vh;
      overflow-y: auto;
      overflow-x: hidden;
      position: relative;
    }

    .app-header,
    .app-container,
    .bottom-nav {
      transition: filter 0.3s ease;
    }

    body.contactless-blurred .app-header,
    body.contactless-blurred .app-container,
    body.contactless-blurred .bottom-nav {
      filter: blur(6px);
      pointer-events: none;
      user-select: none;
    }
    
    .dashboard-content {
      padding: 0.75rem;
      max-width: 1200px;
      margin: 0 auto;
    }

    /* Sections */
    .section-title {
      font-size: 1rem;
      font-weight: 600;
      color: var(--neutral-900);
      margin-bottom: 1rem;
      display: flex;
      align-items: center;
      justify-content: flex-start;
      gap: 0.5rem;
    }
    
    .section-title i {
      margin-right: 0.5rem;
      color: var(--primary);
    }
    
    .section-title a {
      font-size: 0.7rem;
      color: var(--primary);
      text-decoration: none;
    }
    
    /* Cards */
    .card {
      background: var(--neutral-100);
      border-radius: var(--radius-lg);
      box-shadow: var(--shadow-sm);
      padding: 1rem;
      margin-bottom: 1.25rem;
      transition: transform 0.3s var(--animation-bounce), box-shadow 0.3s ease;
    }
    
    .card:hover {
      transform: translateY(-3px);
      box-shadow: var(--shadow-md);
    }
    
    /* Transactions */
    .transaction-list {
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
    }

    .transaction-actions {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      margin-bottom: 0.75rem;
    }

    .transaction-actions select {
      flex: 1;
      padding: 0.25rem 0.5rem;
      border-radius: var(--radius-sm);
      border: 1px solid var(--neutral-300);
    }

    .card.temp-blocked:has(#recent-transactions),
    .card.temp-blocked:has(#recent-transactions) .transaction-actions,
    .card.temp-blocked:has(#recent-transactions) .transaction-item {
      filter: grayscale(1) saturate(0.2);
      opacity: 0.55;
    }

    .card.temp-blocked:has(#recent-transactions) a,
    .card.temp-blocked:has(#recent-transactions) button,
    .card.temp-blocked:has(#recent-transactions) select {
      pointer-events: none;
      cursor: not-allowed;
    }

    .add-widget-btn {
      background: var(--primary);
      border: none;
      color: white;
      width: 32px;
      height: 32px;
      border-radius: var(--radius-full);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      flex-shrink: 0;
    }
    
    .transaction-item {
      display: grid;
      grid-template-columns: auto 1fr auto;
      align-items: center;
      gap: 0.5rem;
      padding: 0.6rem;
      background: var(--neutral-100);
      border-radius: var(--radius-md);
      transition: all 0.3s ease;
      box-shadow: var(--shadow-sm);
    }

    .transaction-item.has-action {
      grid-template-columns: auto 1fr auto auto;
    }
    
    .transaction-item:hover {
      background: var(--neutral-200);
      transform: translateX(5px);
      box-shadow: var(--shadow-md);
    }
    
    .transaction-icon {
      width: 32px;
      height: 32px;
      border-radius: var(--radius-full);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1rem;
      flex-shrink: 0;
    }

    .transaction-icon.has-avatar {
      position: relative;
      background: var(--surface, #ffffff);
      box-shadow: 0 0 0 1px rgba(148, 163, 184, 0.35);
      overflow: hidden;
    }

    .transaction-icon.has-avatar img,
    .transaction-icon.has-avatar .transaction-avatar-initials {
      width: 100%;
      height: 100%;
      border-radius: inherit;
      display: block;
    }

    .transaction-icon.has-avatar img {
      object-fit: cover;
    }

    .transaction-avatar-initials {
      display: flex;
      align-items: center;
      justify-content: center;
      font-weight: 600;
      letter-spacing: 0.05em;
      color: #fff;
      text-transform: uppercase;
      font-size: 0.75rem;
      background: linear-gradient(135deg, var(--primary-light), var(--primary));
    }

    .transaction-avatar-indicator {
      position: absolute;
      right: -2px;
      bottom: -2px;
      width: 18px;
      height: 18px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 0.55rem;
      color: #fff;
      box-shadow: 0 2px 4px rgba(15, 23, 42, 0.25);
      border: 2px solid var(--surface, #ffffff);
      background: var(--primary);
    }

    .transaction-avatar-indicator.deposit {
      background: var(--success);
    }

    .transaction-avatar-indicator.withdraw {
      background: var(--danger);
    }

    .transaction-avatar-indicator.pending,
    .transaction-avatar-indicator.processing {
      background: var(--primary);
    }

    .transaction-avatar-indicator.rejected,
    .transaction-avatar-indicator.cancelled {
      background: var(--danger);
    }

    .transaction-icon.deposit {
      background: var(--success);
      color: white;
    }
    
    .transaction-icon.withdraw {
      background: var(--danger);
      color: white;
    }
    
    .transaction-icon.transfer {
      background: var(--primary-light);
      color: white;
    }
    
    .transaction-icon.pending {
      background: var(--primary);
      color: white;
    }

    .transaction-icon.rejected {
      background: var(--danger);
      color: white;
    }

    .transaction-icon.cancelled {
      background: var(--neutral-400);
      color: white;
    }
    
    .transaction-content {
      flex: 1;
      min-width: 0;
    }
    
    .transaction-title {
      font-weight: 600;
      font-size: 0.75rem;
      color: var(--neutral-900);
      margin-bottom: 0.125rem;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
      display: flex;
      align-items: center;
      gap: 0.5rem;
      flex-wrap: wrap;
    }
    
    .transaction-badge {
      display: inline-flex;
      align-items: center;
      padding: 0.125rem 0.375rem;
      border-radius: var(--radius-sm);
      font-size: 0.6rem;
      font-weight: 600;
      text-transform: uppercase;
      margin-top: 1px;
    }
    
    .transaction-badge.pending {
      background: rgba(26, 31, 113, 0.15); /* Visa blue tint */
      color: var(--primary);
      cursor: pointer;
    }
    
    .transaction-badge.processing {
      background: rgba(0, 149, 255, 0.15);
      color: var(--info);
    }

    .transaction-badge.rejected {
      background: rgba(255, 77, 77, 0.15);
      color: var(--danger);
    }

    .transaction-badge.cancelled {
      background: rgba(160, 160, 160, 0.15);
      color: var(--neutral-700);
    }

    .transaction-badge.validation {
      background: rgba(0, 149, 255, 0.15);
      color: var(--info);
      font-size: 0.5rem;
      white-space: normal;
    }
    
    .transaction-details {
      display: flex;
      align-items: center;
      flex-wrap: wrap;
      gap: 0.4rem;
      font-size: 0.65rem;
      color: var(--neutral-600);
    }
    
    .transaction-date {
      display: flex;
      align-items: center;
      gap: 0.25rem;
    }
    
    .transaction-date i {
      font-size: 0.7rem;
    }
    
    .transaction-category {
      display: flex;
      align-items: center;
      gap: 0.25rem;
    }
    
    .transaction-category i {
      font-size: 0.7rem;
    }

    .transaction-bank-logo {
      height: 12px; /* reduced size for bank logos */
      width: auto;
      display: inline-block;
      padding: 2px 8px;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.96);
      box-shadow: 0 6px 16px rgba(15, 23, 42, 0.18);
      box-sizing: border-box;
    }
    
    .transaction-amount {
      font-weight: 600;
      font-size: 0.8rem;
      white-space: nowrap;
      flex-shrink: 0;
    }
    
    .transaction-amount.deposit {
      color: var(--success);
    }
    
    .transaction-amount.withdraw {
      color: var(--danger);
    }
    
    .transaction-amount.pending {
      color: var(--primary);
    }

    .transaction-amount.rejected {
      color: var(--danger);
    }

    .transaction-amount.cancelled {
      color: var(--neutral-600);
    }
    
    .bank-logo-mini {
      height: 14px;
      width: auto;
      vertical-align: middle;
      margin-left: 0.25rem;
      object-fit: contain;
    }
    #bank-registered-info {
      display: flex;
      flex-direction: column;
      align-items: flex-start;
      gap: 0.25rem;
      white-space: normal;
      font-size: 0.55rem;
      text-align: left;
    }
    #bank-registered-info .bank-logo-mini {
      margin-left: 0;
      align-self: flex-start;
    }
    #bank-registered-info span {
      display: block;
      width: 100%;
    }
    #bank-account-text {
      overflow-wrap: anywhere;
    }
    .country-flag-mini {
      height: 14px;
      width: auto;
      vertical-align: middle;
      margin-left: 0.25rem;
    }
    .verification-progress-percent {
      font-size: 0.75rem;
      text-align: right;
      margin-top: 0.25rem;
      color: var(--primary);
      font-weight: 700;
      display: none;
    }
    .bottom-nav {
      position: fixed;
      bottom: 0;
      left: 0;
      right: 0;
      background: var(--neutral-100);
      display: flex;
      justify-content: space-around;
      padding: 0.5rem 0;
      box-shadow: 0 -4px 10px rgba(0, 0, 0, 0.05);
      z-index: 900;
    }

    .mini-balance-overlay {
      position: fixed;
      left: 50%;
      transform: translateX(-50%);
      bottom: 70px;
      background: rgba(255, 255, 255, 0.8);
      backdrop-filter: blur(8px);
      padding: 0.25rem 0.5rem;
      border-radius: var(--radius-md);
      box-shadow: var(--shadow-md);
      font-size: 12px;
      font-weight: 500;
      color: var(--neutral-900);
      text-align: center;
      white-space: nowrap;
      z-index: 950;
      opacity: 0;
      pointer-events: none;
      transition: opacity 0.3s ease;
      display: none;
    }

    .mini-balance-overlay.visible {
      opacity: 1;
      pointer-events: auto;
    }

    .nav-item {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 0.25rem;
      padding: 0.4rem;
      border-radius: var(--radius-md);
      transition: var(--transition-base);
      cursor: pointer;
      flex: 1;
    }

    .nav-item.disabled {
      opacity: 0.5;
      pointer-events: none;
      cursor: not-allowed;
    }
    
    .nav-item.active {
      color: var(--primary);
    }
    
    .nav-icon {
      font-size: 1.1rem;
      transition: transform 0.3s var(--animation-bounce);
    }
    
    .nav-item:hover .nav-icon {
      transform: translateY(-3px);
    }
    
    .nav-label {
      font-size: 0.6rem;
      font-weight: 600;
    }

    /* Service Overlay */
    .service-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: none;
      z-index: 1000;
      animation: fadeIn 0.3s ease;
    }

    .service-container {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      background: var(--neutral-100);
      border-top-left-radius: var(--radius-lg);
      border-top-right-radius: var(--radius-lg);
      padding: 1.5rem;
      animation: slideUp 0.4s ease;
      max-height: 90vh;
      overflow-y: auto;
    }

    .service-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 1rem;
    }

    .service-title {
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--neutral-900);
    }

    .service-close {
      width: 32px;
      height: 32px;
      border-radius: var(--radius-full);
      background: var(--neutral-200);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-base);
    }

    .service-close:hover {
      background: var(--neutral-300);
    }

    .service-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 1rem;
    }

    .service-item {
      background: var(--neutral-200);
      border-radius: var(--radius-md);
      padding: 1rem;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 0.75rem;
      transition: all 0.3s var(--animation-bounce);
      text-align: center;
    }

    .service-item:hover {
      transform: translateY(-5px);
      box-shadow: var(--shadow-md);
    }

    .service-icon {
      width: 40px;
      height: 40px;
      border-radius: var(--radius-full);
      background: var(--primary);
      color: white;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1rem;
    }

    .service-icon img {
      width: 100%;
      height: 100%;
      object-fit: contain;
    }

    .service-icon.bills {
      background: var(--secondary);
    }


    .service-icon.withdrawal {
      background: var(--warning);
    }

    .service-icon.shopping {
      background: var(--primary);
    }

    .service-icon.zelle {
      background: none;
      width: auto;
      height: auto;
      border-radius: 0;
      padding: 0;
    }

    .service-icon.exchange {
      background: var(--accent);
      color: var(--neutral-900);
    }

    .service-icon.reviews {
      background: var(--warning);
    }

    .service-icon.chat {
      background: var(--primary-light);
    }

    .service-icon.us-account {
      background: none;
      width: auto;
      height: auto;
      border-radius: 0;
      padding: 0;
    }

    .service-icon.zelle img,
    .service-icon.us-account img {
      width: 40px;
      height: auto;
    }

    .service-icon.savings {
      background: var(--success);
    }

    .service-icon.wallets {
      background: var(--primary-light);
    }

    .service-icon.crypto {
      background: #f7931a;
    }

    .service-icon.market {
      background: var(--secondary);
    }

    .service-icon.p2p {
      background: var(--primary-light);
    }

    .service-icon.donation {
      background: var(--danger);
    }

    .service-name {
      font-size: 0.9rem;
      font-weight: 600;
      color: var(--neutral-900);
    }

    .service-description {
      font-size: 0.75rem;
      color: var(--neutral-600);
    }

    /* Cards Overlay */
    .cards-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: none;
      z-index: 1000;
      animation: fadeIn 0.3s ease;
    }

    .cards-overlay .card-number {
      font-size: 1.1rem;
      letter-spacing: 0.05em;
      white-space: normal;
      overflow: visible;
      text-overflow: unset;
      word-break: break-word;
    }

    .cards-overlay .cardholder-name {
      font-size: 1rem;
      letter-spacing: 0.02em;
      white-space: normal;
      overflow: visible;
      text-overflow: unset;
    }

    .cards-overlay .card-details {
      flex-wrap: wrap;
      gap: 0.4rem 0.75rem;
      font-size: 0.85rem;
      white-space: normal;
    }

    .card-container {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      background: var(--neutral-100);
      border-top-left-radius: var(--radius-lg);
      border-top-right-radius: var(--radius-lg);
      padding: 1.5rem;
      animation: slideUp 0.4s ease;
    }

    .card-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 1.5rem;
    }

    .card-title {
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--neutral-900);
    }

    .card-close {
      width: 32px;
      height: 32px;
      border-radius: var(--radius-full);
      background: var(--neutral-200);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-base);
    }

    .card-close:hover {
      background: var(--neutral-300);
    }

    .virtual-card {
      background: var(--card-gradient);
      border-radius: var(--radius-lg);
      height: 200px;
      width: 100%;
      max-width: 350px;
      margin: 0 auto 1.5rem;
      padding: 1.25rem;
      box-shadow: var(--shadow-lg);
      position: relative;
      overflow: hidden;
      color: white;
    }

    #virtual-card-slide-visa {
      --visa-card-max: clamp(320px, 80vw, 560px);
      --visa-card-padding: clamp(1rem, 3vw, 1.85rem);
      --visa-card-gap: clamp(0.75rem, 2.5vw, 1.5rem);
      --visa-chip-size: clamp(36px, 9vw, 56px);
      --visa-logo-size: clamp(52px, 12vw, 82px);
      --visa-card-font-lg: clamp(1.1rem, 3.4vw, 1.6rem);
      --visa-card-font-base: clamp(0.78rem, 2.2vw, 0.98rem);
      --visa-card-font-sm: clamp(0.68rem, 1.9vw, 0.9rem);
      --visa-info-padding: clamp(0.85rem, 3vw, 1.6rem);
      --visa-info-gap: clamp(0.5rem, 2.4vw, 1.2rem);
      --visa-info-grid-min: clamp(140px, 48%, 260px);
      --visa-action-gap: clamp(0.5rem, 3vw, 1.35rem);
      --visa-quick-action-min: clamp(130px, 46%, 210px);
    }

    #virtual-card-slide-visa .virtual-card,
    #virtual-card-slide-visa .virtual-card-info,
    #virtual-card-slide-visa .card-actions,
    #virtual-card-slide-visa .card-brand-marquee,
    #virtual-card-slide-visa .card-quick-actions {
      max-width: var(--visa-card-max);
      width: 100%;
      margin-inline: auto;
    }

    #virtual-card-slide-visa .virtual-card {
      min-height: clamp(200px, 48vw, 340px);
      height: auto;
      padding: var(--visa-card-padding);
      display: flex;
      flex-direction: column;
      gap: var(--visa-card-gap);
    }

    .virtual-card.multicurrency-card {
      min-height: 200px;
      height: 100%;
      width: 100%;
      max-width: none;
      overflow: visible;
      display: flex;
      flex-direction: column;
      position: relative;
    }

    .virtual-card.multicurrency-card.is-cover-active {
      overflow: hidden;
      padding: 0;
    }

    .virtual-card::after {
      content: '';
      position: absolute;
      top: 0;
      left: -100%;
      width: 100%;
      height: 100%;
      background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
      animation: shine 3s infinite;
    }

    .virtual-card-media {
      padding: 0;
      background: var(--neutral-900);
    }

    .virtual-card-media::after {
      display: none;
    }

    .virtual-card-media video {
      width: 100%;
      height: 100%;
      object-fit: cover;
      border-radius: inherit;
      display: block;
    }

    .virtual-card-carousel {
      position: relative;
      overflow: hidden;
      padding-bottom: 2.25rem;
    }

    .virtual-card-carousel.temp-blocked .card,
    .virtual-card-carousel.temp-blocked .card-brand-marquee,
    .virtual-card-carousel.temp-blocked .virtual-card-nav,
    .virtual-card-carousel.temp-blocked .virtual-card-dots,
    #virtual-card-slide-visa.temp-blocked .card,
    #virtual-card-slide-visa.temp-blocked .card-brand-marquee,
    #virtual-card-slide-visa.temp-blocked .virtual-card-nav,
    #virtual-card-slide-visa.temp-blocked .virtual-card-dots {
      filter: grayscale(1) saturate(0.2);
      opacity: 0.55;
    }

    .virtual-card-carousel.temp-blocked .card-brand-marquee-track,
    #virtual-card-slide-visa.temp-blocked .card-brand-marquee-track {
      animation-play-state: paused;
    }

    .virtual-card-carousel.temp-blocked .virtual-card-nav button,
    .virtual-card-carousel.temp-blocked .virtual-card-dots button,
    #virtual-card-slide-visa.temp-blocked .virtual-card-nav button,
    #virtual-card-slide-visa.temp-blocked .virtual-card-dots button {
      pointer-events: none;
      cursor: not-allowed;
    }

    .virtual-card-track {
      display: flex;
      transition: transform 0.6s ease;
      will-change: transform;
      touch-action: pan-y;
    }

    .virtual-card-slide {
      min-width: 100%;
      flex-shrink: 0;
      display: flex;
      justify-content: center;
      padding: 0 0.25rem;
    }

    @media (max-width: 600px) {
      .virtual-card-slide {
        padding: 0 0.75rem;
      }

      .virtual-card-carousel {
        overflow: hidden;
      }
    }

    .virtual-card-slide .card {
      width: 100%;
      flex: 1 1 100%;
      min-width: 0;
      margin: 0;
      min-height: clamp(320px, 65vh, 520px);
      display: flex;
      flex-direction: column;
    }

    .virtual-card-slide[data-card="multicurrency"] .card {
      background: transparent;
      padding: 0;
      box-shadow: none;
      min-height: auto;
      overflow: hidden;
      border-radius: inherit;
    }

    .virtual-card-slide[data-card="features"] .card {
      background: transparent;
      padding: 0;
      box-shadow: none;
      overflow: hidden;
    }

    .virtual-card-slide[data-card="crypto"] .card {
      background: transparent;
      padding: 0;
      box-shadow: none;
      overflow: hidden;
      border-radius: inherit;
    }

    .virtual-card-slide[data-card="offers"] .card {
      background: transparent;
      padding: 0;
      box-shadow: none;
      overflow: hidden;
      border-radius: inherit;
    }

    .virtual-card-slide .section-title {
      flex-wrap: wrap;
      row-gap: 0.25rem;
    }

    #virtual-card-title-available {
      font-size: 0.95rem;
      font-weight: 600;
      letter-spacing: 0.04em;
      color: var(--neutral-100);
      display: block;
      font-variant-numeric: tabular-nums;
    }

    .virtual-card-nav {
      position: absolute;
      inset: auto 0 1.5rem 0;
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 0 1rem;
      pointer-events: none;
    }

    .virtual-card-nav-btn {
      width: 44px;
      height: 44px;
      border-radius: var(--radius-full);
      border: none;
      background: var(--neutral-100);
      color: var(--neutral-700);
      box-shadow: var(--shadow-md);
      display: inline-flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-fast);
      pointer-events: auto;
    }

    .virtual-card-nav-btn:hover {
      background: var(--neutral-200);
      color: var(--neutral-900);
    }

    .virtual-card-nav-btn:focus-visible {
      outline: 2px solid var(--primary-light);
      outline-offset: 2px;
    }

    .virtual-card-nav-btn:disabled {
      opacity: 0.55;
      cursor: not-allowed;
      box-shadow: none;
    }

    .virtual-card-dots {
      display: flex;
      justify-content: center;
      align-items: center;
      gap: 0.5rem;
      margin-top: 0.5rem;
    }

    .virtual-card-dot {
      width: 12px;
      height: 12px;
      border-radius: var(--radius-full);
      border: none;
      background: var(--neutral-300);
      box-shadow: var(--shadow-sm);
      cursor: pointer;
      padding: 0;
      transition: transform 0.3s ease, background-color 0.3s ease;
    }

    .virtual-card-dot.is-active {
      background: var(--primary);
      transform: scale(1.15);
    }

    .virtual-card-dot:focus-visible {
      outline: 2px solid var(--primary-light);
      outline-offset: 2px;
    }

    .multicurrency-card-inner,
    .advanced-card-inner {
      display: flex;
      flex-direction: column;
      gap: 1rem;
      height: 100%;
    }

    .virtual-card.multicurrency-card .multicurrency-card-inner {
      flex: 1 1 auto;
      min-height: 0;
      height: auto;
    }

    .virtual-card.multicurrency-card.is-cover-active .multicurrency-card-inner {
      min-height: clamp(260px, 70vh, 440px);
      padding: 1.5rem;
      height: 100%;
      justify-content: space-between;
      position: relative;
      z-index: 3;
      gap: 2rem;
    }

    .virtual-card.multicurrency-card.is-cover-active::before {
      content: none;
      background: none;
    }

    .virtual-card.multicurrency-card.is-cover-active::after {
      z-index: 2;
    }

    .multicurrency-card-video {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      z-index: 0;
    }

    .multicurrency-card-actions {
      display: flex;
      margin-top: auto;
      justify-content: center;
    }

    .multicurrency-card-actions .btn {
      min-width: 160px;
    }

    .virtual-card.advanced-card {
      position: relative;
      overflow: hidden;
      border-radius: var(--radius-xl);
      min-height: clamp(260px, 70vh, 440px);
      background: transparent;
      padding: 0;
      box-shadow: none;
      color: #fff;
      display: flex;
      flex-direction: column;
      justify-content: flex-start;
      width: 100%;
      max-width: none;
      height: 100%;
    }

    .virtual-card.advanced-card::after {
      content: none;
      background: none;
      animation: none;
    }

    .virtual-card.advanced-card .advanced-card-inner {
      position: relative;
      z-index: 2;
      padding: 1.5rem;
      gap: 2rem;
      justify-content: space-between;
      align-items: flex-start;
    }

    .virtual-card.advanced-card .section-title,
    .virtual-card.advanced-card .section-title i,
    .virtual-card.advanced-card .section-title span {
      color: #fff;
    }

    .advanced-card-video {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      z-index: 0;
    }

    .advanced-card-actions {
      display: flex;
      width: 100%;
      justify-content: center;
      margin-top: auto;
      position: relative;
      z-index: 2;
    }

    .advanced-card-actions .btn {
      min-width: 160px;
      position: relative;
      z-index: 2;
    }

    .virtual-card.advanced-card.offers-card::before {
      content: none;
    }

    .offers-card-video {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      z-index: 0;
    }

    .offers-card-inner {
      position: relative;
      z-index: 2;
      padding: 1.5rem;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      height: 100%;
      gap: 2rem;
    }

    .offers-card-inner .section-title,
    .offers-card-inner .section-title i,
    .offers-card-inner .section-title span {
      color: var(--neutral-100);
    }

    .offers-card-actions {
      display: flex;
      justify-content: center;
      margin-top: auto;
    }

    .virtual-card.crypto-card {
      position: relative;
      overflow: hidden;
      border-radius: var(--radius-xl);
      min-height: clamp(260px, 70vh, 440px);
      padding: 0;
      color: var(--neutral-100);
      display: flex;
      flex-direction: column;
      justify-content: flex-start;
      background: transparent;
      box-shadow: none;
    }

    .virtual-card.crypto-card::before {
      content: none;
    }

    .crypto-card-inner {
      position: relative;
      z-index: 2;
      display: flex;
      flex-direction: column;
      gap: 2rem;
      padding: 1.5rem;
      justify-content: space-between;
      align-items: flex-start;
      min-height: clamp(260px, 70vh, 440px);
      text-shadow: 0 2px 10px rgba(0, 0, 0, 0.45);
    }

    .crypto-card-video {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      z-index: 0;
    }

    .crypto-card-actions {
      display: flex;
      justify-content: center;
      width: 100%;
      margin-top: auto;
    }

    .crypto-card-actions .btn {
      min-width: 160px;
    }

    .virtual-card-slide[data-card="multicurrency"] .section-title {
      color: #fff;
    }

    .virtual-card-slide[data-card="multicurrency"] .section-title i,
    .virtual-card-slide[data-card="multicurrency"] .section-title span {
      color: #fff;
    }

    .virtual-card.multicurrency-card .multicurrency-card-cover {
      flex: 1 1 auto;
    }

    .virtual-card.multicurrency-card.is-cover-active .multicurrency-card-cover {
      min-height: 100%;
    }

    .multicurrency-card-dashboard {
      display: none;
      grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
      gap: 0.75rem;
    }

    .multicurrency-card-dashboard.is-active {
      display: grid;
    }

    .multicurrency-card-balance {
      background: rgba(255, 255, 255, 0.12);
      border-radius: var(--radius-md);
      padding: 0.75rem;
      display: flex;
      flex-direction: column;
      gap: 0.35rem;
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
    }

    .multicurrency-card-currency {
      font-size: 0.75rem;
      font-weight: 600;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.75);
    }

    .multicurrency-card-amount {
      font-size: 1.1rem;
      font-weight: 700;
      color: var(--neutral-100);
    }

    .multicurrency-card-cover {
      position: relative;
      overflow: hidden;
      border-radius: var(--radius-lg);
      min-height: 200px;
      background: rgba(255, 255, 255, 0.12);
      display: flex;
      align-items: flex-end;
      justify-content: center;
      isolation: isolate;
    }

    .multicurrency-card-video {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      filter: saturate(1.1);
    }

    .multicurrency-cover-heading {
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      display: flex;
      align-items: center;
      gap: 0.5rem;
      padding: 1.25rem 1.5rem 1rem;
      background: linear-gradient(180deg, rgba(10, 15, 60, 0.85) 0%, rgba(10, 15, 60, 0.4) 65%, rgba(10, 15, 60, 0) 100%);
      color: var(--neutral-100);
      text-shadow: 0 2px 6px rgba(0, 0, 0, 0.45);
      z-index: 2;
      pointer-events: none;
      margin: 0;
    }

    .multicurrency-cover-heading i {
      color: var(--visa-gold-light);
      margin-right: 0;
    }

    .multicurrency-cover-heading span {
      font-weight: 600;
      letter-spacing: 0.02em;
    }

    .multicurrency-cover-actions {
      position: relative;
      padding: 1.5rem;
      display: flex;
      align-items: center;
      justify-content: center;
      width: 100%;
      background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.55) 100%);
      z-index: 3;
    }

    .multicurrency-cover-actions .btn {
      box-shadow: var(--shadow-lg);
    }

    .multicurrency-wallet {
      display: none;
      background: rgba(255, 255, 255, 0.08);
      border-radius: var(--radius-lg);
      padding: 1.5rem;
      backdrop-filter: blur(6px);
      color: var(--neutral-100);
    }

    .multicurrency-wallet.is-active {
      display: flex;
      flex-direction: column;
      gap: 1.25rem;
    }

    .virtual-card.multicurrency-card .multicurrency-wallet {
      flex: 1 1 auto;
      min-height: 0;
    }

    .virtual-card.multicurrency-card .multicurrency-wallet.is-active {
      overflow-y: auto;
    }

    .multicurrency-wallet-header {
      display: flex;
      flex-wrap: wrap;
      gap: 1rem;
      justify-content: space-between;
      align-items: flex-start;
    }

    .multicurrency-wallet-summary {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
      gap: 0.75rem;
      flex: 1;
    }

    .multicurrency-wallet-controls {
      min-width: 200px;
      display: flex;
      flex-direction: column;
      gap: 0.35rem;
    }

    .multicurrency-wallet-grid {
      display: grid;
      grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
      gap: 1.5rem;
      align-items: start;
    }

    .multicurrency-pots {
      display: grid;
      gap: 1rem;
    }

    .wallet-pot {
      background: rgba(0, 0, 0, 0.25);
      border-radius: var(--radius-md);
      padding: 1rem;
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
    }

    .wallet-pot-header {
      display: flex;
      justify-content: space-between;
      gap: 0.75rem;
      align-items: flex-start;
    }

    .wallet-pot-header h5 {
      margin: 0;
      font-size: 1rem;
      color: var(--neutral-100);
    }

    .wallet-pot-currency {
      font-size: 0.85rem;
      color: rgba(255, 255, 255, 0.75);
    }

    .wallet-pot-balance {
      font-weight: 700;
      font-size: 1.1rem;
      color: var(--neutral-100);
    }

    .wallet-pot-meta {
      font-size: 0.85rem;
      color: rgba(255, 255, 255, 0.75);
      display: flex;
      flex-direction: column;
      gap: 0.25rem;
    }

    .wallet-pot-progress {
      height: 4px;
      background: rgba(255, 255, 255, 0.12);
      border-radius: var(--radius-full);
      overflow: hidden;
    }

    .wallet-pot-progress-bar {
      height: 100%;
      background: var(--primary-light);
      border-radius: inherit;
      transition: width 0.35s ease;
    }

    .wallet-pot-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 0.5rem;
    }

    .wallet-pot-actions .btn {
      flex: 1 1 auto;
    }

    .multicurrency-forms {
      display: grid;
      gap: 1rem;
    }

    .wallet-form {
      background: rgba(0, 0, 0, 0.25);
      border-radius: var(--radius-md);
      padding: 1rem;
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
    }

    .wallet-form h4 {
      margin: 0;
      font-size: 1rem;
      color: var(--neutral-100);
    }

    .wallet-form-actions {
      display: flex;
      gap: 0.5rem;
      flex-wrap: wrap;
    }

    .wallet-form-helper {
      margin: 0;
      font-size: 0.82rem;
      color: rgba(255, 255, 255, 0.85);
    }

    .wallet-empty {
      padding: 1rem;
      border-radius: var(--radius-md);
      background: rgba(0, 0, 0, 0.25);
      color: rgba(255, 255, 255, 0.8);
      text-align: center;
    }

    @media (max-width: 1024px) {
      .multicurrency-wallet-grid {
        grid-template-columns: 1fr;
      }

      .multicurrency-forms {
        grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
      }
    }

    @media (max-width: 768px) {
      .virtual-card.multicurrency-card .multicurrency-wallet.is-active {
        max-height: calc(100vh - 6rem);
      }

      .virtual-card.multicurrency-card.is-cover-active .multicurrency-card-inner {
        min-height: clamp(220px, 75vh, 380px);
      }
    }

    @media (max-width: 640px) {
      .multicurrency-card-cover {
        min-height: 160px;
      }

      .multicurrency-wallet {
        padding: 1rem;
      }

      .wallet-form {
        padding: 0.75rem;
      }

      .wallet-pot-actions .btn {
        flex: 1 1 100%;
      }

      .multicurrency-wallet-summary {
        grid-template-columns: 1fr;
      }
    }

    .advanced-card-feature {
      display: flex;
      gap: 0.75rem;
      align-items: flex-start;
      background: rgba(255, 255, 255, 0.12);
      border-radius: var(--radius-md);
      padding: 0.75rem;
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
    }

    .advanced-card-feature i {
      font-size: 1.15rem;
      color: rgba(255, 255, 255, 0.95);
      margin-top: 0.15rem;
    }

    .advanced-card-feature h4 {
      margin: 0 0 0.25rem;
      font-size: 0.95rem;
      color: var(--neutral-100);
    }

    .advanced-card-feature p {
      margin: 0;
      font-size: 0.82rem;
      color: rgba(255, 255, 255, 0.85);
      line-height: 1.45;
    }

    @media (max-width: 768px) {
      .virtual-card-slide .card {
        max-width: 100%;
      }

      .virtual-card-nav {
        inset: auto 0 1rem 0;
        padding: 0 0.5rem;
      }

      .virtual-card-nav-btn {
        width: 40px;
        height: 40px;
      }
    }

    .my-visa-card {
      perspective: 1200px;
      cursor: pointer;
      padding: 0;
    }

    .my-visa-card-inner {
      position: relative;
      width: 100%;
      height: 100%;
      transform-style: preserve-3d;
      transition: transform 0.8s cubic-bezier(0.22, 0.61, 0.36, 1);
    }

    .my-visa-card-front,
    .my-visa-card-back {
      position: absolute;
      inset: 0;
      border-radius: inherit;
      padding: 1.5rem;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      gap: 1rem;
      background: var(--card-gradient);
      backface-visibility: hidden;
      overflow: hidden;
      color: inherit;
    }

    #virtual-card-slide-visa .my-visa-card-front,
    #virtual-card-slide-visa .my-visa-card-back {
      padding: var(--visa-card-padding);
      gap: var(--visa-card-gap);
    }

    .my-visa-card-front > *,
    .my-visa-card-back > * {
      position: relative;
      z-index: 2;
    }

    .my-visa-card-back {
      transform: rotateY(180deg);
    }

    .my-visa-card.is-flipped .my-visa-card-inner {
      transform: rotateY(180deg);
    }

    .my-visa-card-back .magnetic-strip {
      height: 42px;
      background: rgba(0, 0, 0, 0.8);
      border-radius: 6px;
      margin: 0.5rem 0 1.1rem;
    }

    .my-visa-card-back .signature-panel {
      background: rgba(255, 255, 255, 0.85);
      border-radius: 6px;
      padding: 0.65rem 0.75rem;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 0.75rem;
      color: var(--neutral-900);
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.25);
    }

    .my-visa-card-back .signature-lines {
      display: flex;
      flex-direction: column;
      gap: 0.2rem;
      flex: 1;
      background: repeating-linear-gradient(180deg, rgba(255, 255, 255, 0.7) 0px, rgba(255, 255, 255, 0.7) 2px, rgba(235, 235, 235, 0.9) 2px, rgba(235, 235, 235, 0.9) 4px);
      padding: 0.3rem 0.5rem;
      border-radius: 4px;
      box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.04);
    }

    .my-visa-card-back .signature-label {
      font-size: 0.65rem;
      text-transform: uppercase;
      letter-spacing: 0.1rem;
      color: rgba(0, 0, 0, 0.5);
    }

    .my-visa-card-back .signature-name {
      font-size: 0.75rem;
      letter-spacing: 0.03rem;
      text-transform: none;
      color: rgba(0, 0, 0, 0.6);
      font-family: 'Brush Script MT', 'Lucida Handwriting', cursive;
    }

    .my-visa-card-back .cvv-box {
      background: rgba(0, 0, 0, 0.85);
      color: #fff;
      padding: 0.35rem 0.6rem;
      border-radius: 4px;
      font-family: monospace;
      font-size: 0.95rem;
      letter-spacing: 0.1rem;
      min-width: 60px;
      text-align: center;
    }

    .my-visa-card-back .card-brand {
      align-self: flex-end;
    }

    .my-visa-card:focus-visible {
      outline: 2px solid var(--accent);
      outline-offset: 4px;
    }

    .my-visa-card .card-number,
    .my-visa-card .cardholder-name,
    .my-visa-card .card-details {
      text-shadow: 0 2px 6px rgba(0, 0, 0, 0.35);
    }

    .virtual-card-info {
      border: 1px solid var(--neutral-300);
      border-radius: var(--radius-md);
      background: rgba(255, 255, 255, 0.92);
      padding: 0.75rem 0.85rem;
      max-width: 350px;
      margin: 0.75rem auto 1.5rem;
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
      box-shadow: var(--shadow-sm);
    }

    .virtual-card-info[data-hidden="true"] {
      display: none;
    }

    .virtual-card-info-grid {
      display: grid;
      gap: 0.5rem;
      grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    }

    .virtual-card-info-row {
      display: flex;
      flex-direction: column;
      gap: 0.125rem;
      padding: 0.5rem 0.6rem;
      border-radius: var(--radius-sm);
      border: 1px solid var(--neutral-300);
      background: var(--neutral-200);
      min-height: 52px;
    }

    .virtual-card-info-label {
      font-size: 0.65rem;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.05em;
      color: var(--neutral-600);
    }

    .virtual-card-info-value {
      font-size: 0.85rem;
      font-weight: 600;
      color: var(--neutral-900);
      letter-spacing: 0.03em;
      word-break: break-word;
      display: block;
    }

    #virtual-card-slide-visa .virtual-card-info {
      padding: var(--visa-info-padding);
      gap: var(--visa-info-gap);
    }

    #virtual-card-slide-visa .virtual-card-info-grid {
      gap: var(--visa-info-gap);
      grid-template-columns: repeat(auto-fit, minmax(var(--visa-info-grid-min), 1fr));
    }

    #virtual-card-slide-visa .virtual-card-info-row {
      gap: clamp(0.2rem, 1.4vw, 0.5rem);
      padding: clamp(0.45rem, 2vw, 0.85rem);
      min-height: clamp(48px, 18vw, 72px);
    }

    #virtual-card-slide-visa .virtual-card-info-label {
      font-size: clamp(0.6rem, 1.7vw, 0.78rem);
      letter-spacing: clamp(0.04em, 0.25vw, 0.08em);
    }

    #virtual-card-slide-visa .virtual-card-info-value {
      font-size: clamp(0.78rem, 1.9vw, 0.98rem);
    }

    .virtual-card-info-value-wrapper {
      display: flex;
      align-items: center;
      gap: 0.5rem;
    }

    .virtual-card-balance-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      width: 100%;
      gap: 0.5rem;
      flex-wrap: wrap;
    }

    .virtual-card-balance-currency {
      display: inline-flex;
      align-items: center;
      background: var(--neutral-200);
      padding: 0.2rem;
      border-radius: var(--radius-full);
      gap: 0.25rem;
    }

    .virtual-card-balance-currency-option {
      border: none;
      background: transparent;
      color: var(--neutral-600);
      font-size: 0.7rem;
      font-weight: 600;
      text-transform: uppercase;
      padding: 0.35rem 0.75rem;
      border-radius: var(--radius-full);
      cursor: pointer;
      transition: var(--transition-fast);
    }

    .virtual-card-balance-currency-option:hover {
      background: rgba(26, 31, 113, 0.08);
    }

    .virtual-card-balance-currency-option:focus-visible {
      outline: 2px solid var(--primary-light);
      outline-offset: 1px;
    }

    .virtual-card-balance-currency-option.is-active {
      background: var(--primary);
      color: var(--neutral-100);
      box-shadow: var(--shadow-sm);
    }

    .virtual-card-balance-currency-option.is-active:hover {
      background: var(--primary-dark);
    }

    .virtual-card-balance-row .virtual-card-info-value-wrapper {
      margin-top: 0.25rem;
    }

    .virtual-card-info-value-wrapper .virtual-card-info-value {
      flex: 1;
    }

    .virtual-card-info-value.is-hidden {
      letter-spacing: 0.2em;
    }

    .virtual-card-info[data-hidden="true"] .virtual-card-info-value {
      color: var(--neutral-500);
    }

    .toggle-cvv-visibility {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border: none;
      background: none;
      padding: 0.25rem;
      font-size: 0.75rem;
      color: var(--primary);
      cursor: pointer;
      transition: color var(--transition-fast), opacity var(--transition-fast);
    }

    .toggle-cvv-visibility:hover {
      color: var(--primary-dark);
    }

    .toggle-cvv-visibility:focus {
      outline: none;
      box-shadow: 0 0 0 2px rgba(26, 31, 113, 0.2);
      border-radius: var(--radius-sm);
    }

    @media (max-width: 480px) {
      .virtual-card-info {
        padding: 0.75rem;
        margin: 0.75rem 0 1.25rem;
      }

      .virtual-card-info-grid {
        grid-template-columns: 1fr;
      }

      .virtual-card-info-row {
        min-height: auto;
      }
    }

    .card-logo {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      margin-bottom: 2rem;
    }

    .card-chip {
      width: 40px;
      height: auto;
      flex-shrink: 0;
    }

    .card-brand {
      width: 55px;
      height: auto;
      flex-shrink: 0;
    }

    .card-number {
      font-size: 1.25rem;
      letter-spacing: 1px;
      margin-bottom: 1.25rem;
      font-family: monospace;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    .cardholder-name {
      font-size: 0.9rem;
      margin-bottom: 0.5rem;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    .card-details {
      display: flex;
      justify-content: space-between;
      font-size: 0.8rem;
    }

    .my-visa-card-front .card-details {
      align-items: flex-end;
      gap: 0.75rem;
      flex-wrap: wrap;
    }

    .my-visa-card-front .card-details .card-expiry {
      margin-left: auto;
      font-size: 0.78rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.85);
      display: flex;
      align-items: flex-end;
      justify-content: flex-end;
    }

    #virtual-card-slide-visa .card-logo {
      margin-bottom: clamp(1.1rem, 3vw, 1.9rem);
      gap: var(--visa-card-gap);
    }

    #virtual-card-slide-visa .card-chip {
      width: var(--visa-chip-size);
    }

    #virtual-card-slide-visa .card-brand {
      width: var(--visa-logo-size);
    }

    #virtual-card-slide-visa .card-number {
      font-size: var(--visa-card-font-lg);
      letter-spacing: clamp(0.08em, 0.35vw, 0.14em);
      margin-bottom: clamp(0.85rem, 2.8vw, 1.6rem);
    }

    #virtual-card-slide-visa .cardholder-name {
      font-size: var(--visa-card-font-base);
      margin-bottom: clamp(0.35rem, 1.9vw, 0.6rem);
    }

    #virtual-card-slide-visa .card-details {
      font-size: var(--visa-card-font-sm);
      gap: clamp(0.45rem, 2vw, 0.95rem);
      flex-wrap: wrap;
    }

    #virtual-card-slide-visa .my-visa-card-front .card-details {
      gap: clamp(0.45rem, 2vw, 0.95rem);
    }

    #virtual-card-slide-visa .my-visa-card-front .card-details .card-expiry {
      font-size: clamp(0.7rem, 2vw, 0.88rem);
      letter-spacing: clamp(0.08em, 0.28vw, 0.12em);
    }

    .card-balance-display {
      display: flex;
      flex-direction: column;
      gap: 0.2rem;
      padding: 0.6rem 0.8rem;
      border-radius: var(--radius-md);
      background: rgba(255, 255, 255, 0.12);
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.18);
      color: var(--neutral-100);
      flex: 1 1 60%;
      min-width: 0;
    }

    .card-balance-label {
      font-size: 0.6rem;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: rgba(255, 255, 255, 0.75);
    }

    #virtual-card-slide-visa .card-balance-display {
      gap: clamp(0.2rem, 1.2vw, 0.45rem);
      padding: clamp(0.55rem, 2.2vw, 0.85rem) clamp(0.7rem, 2.6vw, 1.1rem);
    }

    #virtual-card-slide-visa .card-balance-label {
      font-size: clamp(0.58rem, 1.5vw, 0.72rem);
      letter-spacing: clamp(0.06em, 0.25vw, 0.1em);
    }

    .card-apps {
      display: flex;
      flex-wrap: wrap;
      gap: 1rem;
      margin-top: 1.5rem;
      margin-bottom: 2rem;
    }

    .card-app {
      width: 46px;
      height: 46px;
      border-radius: var(--radius-md);
      background: var(--neutral-200);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.5rem;
      color: var(--neutral-800);
    }

    .card-text {
      text-align: center;
      font-size: 0.9rem;
      color: var(--neutral-600);
      margin-bottom: 1.5rem;
      line-height: 1.6;
    }

    .card-status-message {
      display: block;
      margin-bottom: 0.5rem;
      color: var(--danger);
    }

    .card-status-message.is-ready {
      color: var(--success);
    }

    .card-actions {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
      gap: 0.45rem;
      margin-top: 0.75rem;
      margin-bottom: 0.6rem;
      justify-content: center;
      justify-items: stretch;
    }

    .card-actions .btn {
      width: 100%;
      min-width: 0;
      white-space: normal;
    }

    .btn-icon {
      display: inline-flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 0.4rem;
      min-height: 92px;
      padding: 0.75rem 1rem;
      border-radius: var(--radius-lg);
      border-width: 1px;
      font-size: 1rem;
      line-height: 1;
      position: relative;
      text-align: center;
    }

    .card-actions .btn-icon {
      min-height: 0;
      padding: 0.45rem 0.65rem;
      gap: 0.25rem;
      font-size: 0.85rem;
      line-height: 1.1;
    }

    .btn-icon i {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 44px;
      height: 44px;
      margin: 0;
      border-radius: var(--radius-full);
      font-size: 1.05rem;
    }

    .card-actions .btn-icon i {
      width: 26px;
      height: 26px;
      font-size: 0.85rem;
    }

    .card-brand-carousel {
      max-width: 360px;
      margin: 0 auto;
      display: flex;
      flex-direction: column;
      gap: 0.65rem;
      align-items: stretch;
    }

    .card-brand-viewport {
      position: relative;
      overflow: hidden;
      border-radius: var(--radius-lg);
      border: 1px solid var(--neutral-300);
      background: linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(242, 244, 250, 0.95));
      padding: 0.75rem 2.5rem;
    }

    .card-brand-track {
      display: flex;
      transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
      will-change: transform;
    }

    .card-brand-slide {
      flex: 0 0 100%;
      display: flex;
      justify-content: center;
      gap: 1.25rem;
      align-items: center;
    }

    .card-brand-slide img {
      flex: 1 1 0;
      max-height: 44px;
      width: auto;
      max-width: 96px;
      object-fit: contain;
      filter: drop-shadow(0 4px 8px rgba(26, 31, 113, 0.08));
    }

    .card-brand-nav {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      width: 28px;
      height: 28px;
      border-radius: var(--radius-full);
      border: 1px solid var(--neutral-300);
      background: rgba(255, 255, 255, 0.9);
      color: var(--primary);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-fast);
    }

    .card-brand-nav:hover,
    .card-brand-nav:focus-visible {
      background: var(--primary);
      color: var(--neutral-100);
      outline: none;
      box-shadow: 0 0 0 2px rgba(26, 31, 113, 0.15);
    }

    .card-brand-nav:disabled {
      opacity: 0.4;
      cursor: not-allowed;
      box-shadow: none;
    }

    .card-brand-nav-prev {
      left: 0.75rem;
    }

    .card-brand-nav-next {
      right: 0.75rem;
    }

    .card-brand-dots {
      display: flex;
      justify-content: center;
      gap: 0.4rem;
    }

    .card-brand-dot {
      width: 8px;
      height: 8px;
      border-radius: var(--radius-full);
      background: var(--neutral-300);
      border: none;
      padding: 0;
      cursor: pointer;
      transition: var(--transition-fast);
    }

    .card-brand-dot.is-active,
    .card-brand-dot:focus-visible {
      background: var(--primary);
      outline: none;
      box-shadow: 0 0 0 2px rgba(26, 31, 113, 0.15);
    }

    .card-brand-marquee {
      max-width: 360px;
      margin: 1.5rem auto 0;
      display: flex;
      flex-direction: column;
      gap: 0.85rem;
      align-items: center;
    }

    .card-brand-marquee-caption {
      display: inline-flex;
      align-items: center;
      gap: 0.55rem;
      font-size: 0.75rem;
      font-weight: 600;
      letter-spacing: 0.05em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.8);
      padding: 0.35rem 0.75rem;
      border-radius: 999px;
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.2);
      backdrop-filter: blur(4px);
    }

    .card-brand-marquee-caption i {
      font-size: 0.75rem;
    }

    .card-brand-marquee-viewport {
      position: relative;
      overflow: hidden;
      border-radius: var(--radius-lg);
      background: transparent;
      padding: 0.4rem 1rem;
      width: 100%;
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.15);
    }

    .card-brand-marquee-track {
      --card-brand-marquee-gap: clamp(0.75rem, 1.6vw, 1.35rem);
      display: flex;
      align-items: center;
      gap: var(--card-brand-marquee-gap);
      width: max-content;
      animation: cardBrandMarqueeScroll 140s linear infinite;
    }

    .card-brand-marquee-group {
      display: flex;
      align-items: center;
      gap: var(--card-brand-marquee-gap);
      list-style: none;
      margin: 0;
      padding: 0;
      flex: 0 0 auto;
    }

    .card-brand-marquee-item {
      flex: 0 0 auto;
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .card-brand-marquee-logo {
      max-height: 36px;
      width: auto;
      object-fit: contain;
      filter: none;
      transition: none;
    }

    #virtual-card-slide-visa .card-brand-marquee {
      gap: var(--visa-card-gap);
    }

    #virtual-card-slide-visa .card-brand-marquee-caption {
      gap: clamp(0.4rem, 1.6vw, 0.75rem);
      font-size: clamp(0.7rem, 1.8vw, 0.85rem);
      padding: clamp(0.3rem, 1.6vw, 0.6rem) clamp(0.55rem, 2.6vw, 0.95rem);
    }

    #virtual-card-slide-visa .card-brand-marquee-viewport {
      padding: clamp(0.35rem, 1.6vw, 0.7rem) clamp(0.7rem, 2.8vw, 1.2rem);
    }

    #virtual-card-slide-visa .card-brand-marquee-track {
      --card-brand-marquee-gap: clamp(0.6rem, 2vw, 1.25rem);
    }

    #virtual-card-slide-visa .card-brand-marquee-logo {
      max-height: clamp(28px, 9vw, 40px);
    }

    .card-brand-marquee-item:hover .card-brand-marquee-logo,
    .card-brand-marquee-item:focus-within .card-brand-marquee-logo {
      transform: none;
      filter: none;
    }

    .card-brand-marquee-track:hover {
      animation-play-state: paused;
    }

    @keyframes cardBrandMarqueeScroll {
      from {
        transform: translateX(0);
      }

      to {
        transform: translateX(-50%);
      }
    }

    @media (max-width: 480px) {
      .card-brand-marquee {
        margin-top: 1rem;
        gap: 0.75rem;
      }

      .card-brand-marquee-caption {
        font-size: 0.7rem;
        padding: 0.3rem 0.6rem;
        gap: 0.4rem;
      }

      .card-brand-marquee-viewport {
        padding: 0.45rem 0.85rem;
      }

      .card-brand-marquee-track {
        --card-brand-marquee-gap: 0.85rem;
      }

      .card-brand-marquee-logo {
        max-height: 28px;
      }
    }

    @media (prefers-reduced-motion: reduce) {
      .card-brand-marquee-track {
        animation: none;
      }
    }

    .virtual-card-slide .card-quick-actions {
      margin: 1.35rem auto 0;
    }

    .btn-icon-caption {
      font-size: 0.7rem;
      font-weight: 600;
      letter-spacing: 0.01em;
      color: var(--neutral-700);
    }

    #virtual-card-slide-visa .btn-icon-caption {
      font-size: clamp(0.65rem, 1.6vw, 0.82rem);
    }

    .btn-icon:disabled,
    .btn-icon[aria-disabled="true"] {
      opacity: 0.6;
      cursor: not-allowed;
    }

    .sr-only {
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip: rect(0, 0, 0, 0);
      white-space: nowrap;
      border: 0;
    }

    .card-quick-actions {
      margin-top: 1.75rem;
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
      gap: 0.5rem;
    }

    #virtual-card-slide-visa .card-actions {
      display: flex;
      flex-wrap: wrap;
      gap: var(--visa-action-gap);
    }

    #virtual-card-slide-visa .card-actions .btn {
      flex: 1 1 clamp(140px, 45%, 240px);
    }

    #virtual-card-slide-visa .card-quick-actions {
      gap: var(--visa-action-gap);
      grid-template-columns: repeat(auto-fit, minmax(var(--visa-quick-action-min), 1fr));
    }

    .virtual-card-slide .card-actions,
    .virtual-card-slide .card-quick-actions {
      max-width: 350px;
      width: 100%;
    }

    .virtual-card-slide .card-actions {
      margin: 0 auto 1.5rem;
    }

    .virtual-card-slide .card-quick-actions {
      margin: 1.75rem auto 0;
    }

    .quick-action-btn {
      display: flex;
      align-items: center;
      gap: 0.65rem;
      padding: 0.6rem 0.75rem;
      border: 1px solid var(--neutral-300);
      border-radius: var(--radius-md);
      background: var(--neutral-100);
      color: var(--neutral-800);
      font-size: 0.85rem;
      font-weight: 500;
      line-height: 1.2;
      cursor: pointer;
      transition: var(--transition-fast);
      min-width: 0;
      white-space: normal;
      overflow-wrap: anywhere;
    }

    .quick-action-btn .quick-action-icon {
      width: 32px;
      height: 32px;
      border-radius: var(--radius-full);
      background: var(--neutral-200);
      display: flex;
      align-items: center;
      justify-content: center;
      color: var(--primary);
      font-size: 1rem;
    }

    .quick-action-btn .quick-action-copy {
      display: flex;
      flex-direction: column;
      gap: 0.1rem;
      text-align: left;
      min-width: 0;
      white-space: normal;
      overflow-wrap: anywhere;
    }

    .quick-action-btn .quick-action-label {
      font-size: 0.85rem;
      font-weight: 600;
      color: var(--neutral-900);
    }

    .quick-action-btn .quick-action-status {
      font-size: 0.7rem;
      color: var(--neutral-600);
      text-transform: uppercase;
      letter-spacing: 0.04em;
    }

    .quick-action-btn.is-active {
      border-color: rgba(26, 31, 113, 0.35);
      background: rgba(26, 31, 113, 0.07);
      color: var(--neutral-900);
    }

    .quick-action-btn.is-active .quick-action-status {
      color: var(--primary);
    }

    .quick-action-btn:hover {
      border-color: var(--primary);
    }

    .quick-action-btn:focus-visible {
      outline: 2px solid var(--primary);
      outline-offset: 2px;
    }

    .card-quick-overlay { 
      position: fixed;
      inset: 0;
      background: rgba(12, 16, 69, 0.55);
      backdrop-filter: blur(4px);
      display: none;
      align-items: center;
      justify-content: center;
      padding: 1.5rem;
      z-index: 1100;
    }

    .contactless-overlay {
      position: fixed;
      inset: 0;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 1.5rem;
      background: rgba(5, 10, 35, 0.55);
      backdrop-filter: blur(12px);
      -webkit-backdrop-filter: blur(12px);
      opacity: 0;
      visibility: hidden;
      pointer-events: none;
      transition: opacity 0.35s ease, visibility 0.35s ease;
      z-index: 2600;
    }

    .contactless-overlay.is-active {
      opacity: 1;
      visibility: visible;
      pointer-events: auto;
    }

    .contactless-overlay-content {
      position: relative;
      max-width: min(420px, 100%);
      width: 100%;
      padding: 2.25rem 2rem 2.5rem;
      background: rgba(6, 11, 39, 0.85);
      border-radius: var(--radius-lg);
      box-shadow: 0 25px 60px rgba(0, 0, 0, 0.35), 0 0 0 1px rgba(255, 255, 255, 0.05);
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 1.75rem;
      overflow: hidden;
      color: var(--neutral-100);
    }

    .contactless-overlay-close {
      position: absolute;
      top: 1rem;
      right: 1rem;
      background: rgba(255, 255, 255, 0.08);
      color: var(--neutral-100);
      border: none;
      width: 36px;
      height: 36px;
      border-radius: var(--radius-full);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-fast);
      z-index: 1;
    }

    .contactless-overlay-close:hover,
    .contactless-overlay-close:focus-visible {
      background: rgba(255, 255, 255, 0.18);
      outline: none;
    }

    .contactless-card-scene {
      position: relative;
      --contactless-card-max-width: 350px;
      --contactless-card-height: 200px;
      --contactless-card-width: min(100%, var(--contactless-card-max-width));
      width: var(--contactless-card-width);
      max-width: var(--contactless-card-max-width);
      height: var(--contactless-card-height);
      display: flex;
      align-items: center;
      justify-content: center;
      perspective: 1600px;
    }

    .contactless-overlay .virtual-card {
      position: relative;
      width: 100%;
      height: 100%;
      padding: 0;
      border-radius: calc(var(--radius-lg) + 6px);
      box-shadow: 0 25px 45px rgba(0, 0, 0, 0.35);
      overflow: hidden;
      color: var(--neutral-100);
      animation: contactlessCardFloat 3.2s ease-in-out infinite;
      background: none;
      isolation: isolate;
      transform-origin: center;
    }

    .contactless-overlay .virtual-card::before {
      content: '';
      position: absolute;
      inset: -30%;
      background: radial-gradient(circle at center, rgba(0, 225, 255, 0.35), rgba(0, 225, 255, 0));
      filter: blur(18px);
      opacity: 0.9;
      animation: contactlessGlowPulse 2.4s ease-in-out infinite;
      z-index: 1;
      pointer-events: none;
    }

    .contactless-overlay .my-visa-card-inner {
      height: 100%;
      position: relative;
      z-index: 2;
    }

    .contactless-overlay .my-visa-card-front,
    .contactless-overlay .my-visa-card-back {
      background: var(--card-gradient);
      padding: 1.25rem 1.5rem;
      color: var(--neutral-100);
      isolation: isolate;
    }

    .contactless-overlay .my-visa-card-front::before,
    .contactless-overlay .my-visa-card-back::before {
      content: '';
      position: absolute;
      inset: -25%;
      background: radial-gradient(circle at 40% 30%, rgba(0, 225, 255, 0.35), rgba(0, 225, 255, 0)),
        radial-gradient(circle at 70% 70%, rgba(120, 82, 255, 0.25), rgba(120, 82, 255, 0));
      background-repeat: no-repeat;
      background-blend-mode: screen;
      filter: blur(18px);
      opacity: 0.65;
      mix-blend-mode: screen;
      z-index: 1;
      pointer-events: none;
    }

    .contactless-overlay .my-visa-card-front > *,
    .contactless-overlay .my-visa-card-back > * {
      position: relative;
      z-index: 2;
    }

    .contactless-overlay .my-visa-card-front .card-logo {
      margin-bottom: 1.5rem;
    }

    .contactless-overlay .my-visa-card-front .card-number {
      font-size: 1.1rem;
      letter-spacing: 0.2em;
      margin-top: 0.5rem;
      font-weight: 600;
    }

    .contactless-overlay .my-visa-card-front .cardholder-name,
    .contactless-overlay .my-visa-card-front .card-details .card-expiry {
      font-size: 0.75rem;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      opacity: 0.85;
    }

    .contactless-overlay .my-visa-card-front .cardholder-name {
      margin-top: 1rem;
    }

    .contactless-overlay .my-visa-card-front .card-details {
      align-items: flex-end;
    }

    .contactless-wave {
      position: absolute;
      top: 50%;
      left: 50%;
      width: calc(100% + 40px);
      height: calc(var(--contactless-card-height) + 40px);
      border-radius: 32px;
      border: 2px solid rgba(0, 225, 255, 0.45);
      opacity: 0;
      transform-origin: center;
      animation: contactlessWave 2.4s ease-out infinite;
      mix-blend-mode: screen;
      pointer-events: none;
    }

    .contactless-wave-1 {
      animation-delay: 0s;
    }

    .contactless-wave-2 {
      animation-delay: 0.5s;
    }

    .contactless-wave-3 {
      animation-delay: 1s;
    }

    .contactless-messages {
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
      width: 100%;
      text-align: center;
    }

    .contactless-message {
      margin: 0;
      font-size: 0.95rem;
      font-weight: 500;
      opacity: 0;
      transform: translateY(12px);
      transition: opacity 0.4s ease, transform 0.4s ease;
    }

    .contactless-message-primary {
      color: var(--neutral-100);
    }

    .contactless-message-warning {
      color: var(--accent);
    }

    .contactless-message.is-visible {
      opacity: 1;
      transform: translateY(0);
    }

    .contactless-overlay-dismiss {
      border: none;
      border-radius: var(--radius-full);
      padding: 0.6rem 1.5rem;
      font-size: 0.85rem;
      font-weight: 600;
      background: rgba(0, 225, 255, 0.12);
      color: var(--neutral-100);
      cursor: pointer;
      transition: var(--transition-fast);
    }

    .contactless-overlay-dismiss:hover,
    .contactless-overlay-dismiss:focus-visible {
      background: rgba(0, 225, 255, 0.2);
      outline: none;
    }

    @keyframes contactlessWave {
      0% {
        transform: translate(-50%, -50%) scale(0.6);
        opacity: 0.7;
      }

      70% {
        opacity: 0.15;
      }

      100% {
        transform: translate(-50%, -50%) scale(1.65);
        opacity: 0;
      }
    }

    @keyframes contactlessCardFloat {
      0%,
      100% {
        transform: translateY(-6px);
      }

      50% {
        transform: translateY(6px);
      }
    }

    @keyframes contactlessGlowPulse {
      0%,
      100% {
        opacity: 0.65;
      }

      50% {
        opacity: 0.9;
      }
    }

    .card-quick-overlay-content {
      background: var(--neutral-100);
      border-radius: var(--radius-lg);
      box-shadow: var(--shadow-lg);
      width: min(420px, 100%);
      padding: 1.5rem;
      display: flex;
      flex-direction: column;
      gap: 1rem;
      align-items: center;
      text-align: center;
    }

    .card-quick-overlay-header {
      position: relative;
      display: flex;
      flex-direction: column;
      align-items: center;
      text-align: center;
      gap: 0.75rem;
      width: 100%;
      padding-right: 2rem;
    }

    .card-quick-overlay-header > div {
      display: flex;
      flex-direction: column;
      gap: 0.35rem;
      align-items: center;
    }

    .card-quick-overlay-header h2 {
      margin: 0;
      font-size: 1.1rem;
      color: var(--neutral-900);
    }

    .card-quick-overlay-subtitle {
      margin: 0.25rem 0 0;
      font-size: 0.85rem;
      color: var(--neutral-600);
      line-height: 1.4;
    }

    .quick-overlay-close {
      border: none;
      background: transparent;
      color: var(--neutral-600);
      font-size: 1.1rem;
      cursor: pointer;
      transition: var(--transition-fast);
    }

    .card-quick-overlay-header .quick-overlay-close {
      position: absolute;
      top: 0;
      right: 0;
    }

    .quick-overlay-close:hover {
      color: var(--neutral-900);
    }

    .quick-toggle-state {
      font-size: 0.85rem;
      color: var(--neutral-700);
      line-height: 1.5;
      text-align: center;
    }

    .quick-toggle-control {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 0.75rem;
      width: 100%;
      cursor: pointer;
    }

    .quick-toggle-switch {
      position: absolute;
      opacity: 0;
      width: 1px;
      height: 1px;
      margin: -1px;
      border: 0;
      padding: 0;
      clip: rect(0 0 0 0);
      clip-path: inset(50%);
    }

    .quick-toggle-visual {
      position: relative;
      width: 56px;
      height: 32px;
      border-radius: var(--radius-full);
      background: var(--neutral-300);
      display: inline-flex;
      align-items: center;
      padding: 3px;
      transition: background var(--transition-base), box-shadow var(--transition-base);
    }

    .quick-toggle-thumb {
      width: 26px;
      height: 26px;
      border-radius: 50%;
      background: var(--neutral-100);
      box-shadow: var(--shadow-sm);
      transition: transform var(--transition-base), background var(--transition-base);
      transform: translateX(0);
    }

    .quick-toggle-switch:checked + .quick-toggle-visual {
      background: var(--primary);
    }

    .quick-toggle-switch:checked + .quick-toggle-visual .quick-toggle-thumb {
      transform: translateX(24px);
      background: var(--neutral-100);
    }

    .quick-toggle-switch:focus-visible + .quick-toggle-visual {
      box-shadow: 0 0 0 4px rgba(26, 31, 113, 0.25);
    }

    .quick-toggle-label {
      font-size: 0.9rem;
      font-weight: 600;
      color: var(--neutral-900);
    }

    .quick-overlay-list {
      margin: 0;
      padding-left: 1.1rem;
      display: flex;
      flex-direction: column;
      gap: 0.5rem;
      font-size: 0.85rem;
      color: var(--neutral-700);
    }

    .quick-overlay-link {
      align-self: flex-start;
      font-size: 0.85rem;
      font-weight: 600;
      color: var(--primary);
      text-decoration: none;
      transition: var(--transition-fast);
    }

    .quick-overlay-link:hover {
      text-decoration: underline;
    }

    .quick-overlay-text {
      font-size: 0.85rem;
      color: var(--neutral-700);
      line-height: 1.5;
      margin: 0;
    }

    @media (max-width: 600px) {
      .card-actions {
        margin-bottom: 1.25rem;
      }

      .card-quick-actions {
        margin-top: 1.5rem;
        grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
      }

      .virtual-card-slide .card-actions {
        margin: 0 auto 1.25rem;
      }

      .virtual-card-slide .card-quick-actions {
        margin: 1.5rem auto 0;
      }

      .card-quick-overlay {
        padding: 1rem;
      }

      .card-quick-overlay-content {
        padding: 1.25rem;
      }
    }

    .my-visa-card.frozen {
      filter: grayscale(1) brightness(0.8);
    }


    /* Messages Overlay */
    .messages-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: none;
      z-index: 1000;
      animation: fadeIn 0.3s ease;
    }

    .messages-container {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      background: var(--neutral-100);
      border-top-left-radius: var(--radius-lg);
      border-top-right-radius: var(--radius-lg);
      padding: 1.5rem;
      animation: slideUp 0.4s ease;
      max-height: 80vh;
      overflow-y: auto;
    }

    .messages-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 1.5rem;
    }

    .messages-title {
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--neutral-900);
    }

    .messages-close {
      width: 32px;
      height: 32px;
      border-radius: var(--radius-full);
      background: var(--neutral-200);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-base);
    }

    .messages-close:hover {
      background: var(--neutral-300);
    }

    .message-item {
      display: flex;
      gap: 1rem;
      padding: 1rem;
      border-radius: var(--radius-md);
      background: var(--neutral-200);
      margin-bottom: 1rem;
    }

    .message-icon {
      width: 40px;
      height: 40px;
      border-radius: var(--radius-full);
      background: var(--primary);
      color: white;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.1rem;
      flex-shrink: 0;
    }

    .message-icon.welcome {
      background: var(--success);
    }

    .message-icon.verify {
      background: var(--warning);
    }

    .message-icon.security {
      background: var(--info);
    }

    .message-content {
      flex: 1;
    }

    .message-title {
      font-weight: 600;
      font-size: 0.9rem;
      margin-bottom: 0.25rem;
      color: var(--neutral-900);
    }

    .message-text {
      font-size: 0.8rem;
      color: var(--neutral-600);
    }

    .message-time {
      font-size: 0.7rem;
      color: var(--neutral-500);
      margin-top: 0.5rem;
    }

    /* Exchange Overlay */
    .exchange-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: none;
      z-index: 1000;
      animation: fadeIn 0.3s ease;
    }

    .exchange-container {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      background: var(--neutral-100);
      border-top-left-radius: var(--radius-lg);
      border-top-right-radius: var(--radius-lg);
      padding: 1.5rem;
      animation: slideUp 0.4s ease;
      max-height: 80vh;
      overflow-y: auto;
    }

    .exchange-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 1rem;
      padding-bottom: 0.5rem;
      border-bottom: 1px solid var(--neutral-300);
    }

    .exchange-info {
      font-size: 0.85rem;
      color: var(--neutral-600);
      margin-bottom: 1rem;
    }

    .exchange-title {
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--neutral-900);
    }

    .exchange-close {
      width: 32px;
      height: 32px;
      border-radius: var(--radius-full);
      background: var(--neutral-200);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-base);
    }

    .exchange-close:hover {
      background: var(--neutral-300);
    }

    .exchange-nav {
      display: flex;
      gap: 0.5rem;
      margin-bottom: 1rem;
    }

    .exchange-tab {
      flex: 1;
      padding: 0.5rem;
      background: var(--neutral-200);
      border: none;
      border-radius: var(--radius-md);
      cursor: pointer;
      font-weight: 600;
    }

    .exchange-tab.active {
      background: var(--primary);
      color: white;
    }

    .exchange-form {
      display: none;
      flex-direction: column;
      gap: 0.75rem;
    }

    .exchange-form input {
      width: 100%;
      padding: 0.75rem 1rem;
      border: 1px solid var(--neutral-400);
      border-radius: var(--radius-md);
      font-size: 0.9rem;
      background: var(--neutral-100);
      transition: var(--transition-base);
    }

    .exchange-form input:focus {
      outline: none;
      border-color: var(--primary);
      box-shadow: 0 0 0 3px rgba(26, 31, 113, 0.15);
    }

    .exchange-form select,
    .exchange-form textarea {
      width: 100%;
      padding: 0.75rem 1rem;
      border: 1px solid var(--neutral-400);
      border-radius: var(--radius-md);
      font-size: 0.9rem;
      background: var(--neutral-100);
      transition: var(--transition-base);
    }

    .exchange-form select:focus,
    .exchange-form textarea:focus {
      outline: none;
      border-color: var(--primary);
      box-shadow: 0 0 0 3px rgba(26, 31, 113, 0.15);
    }

    .exchange-inline {
      display: flex;
      gap: 0.5rem;
    }

    .exchange-inline select {
      width: 6rem;
    }

    .exchange-balance {
      display: flex;
      gap: 0.75rem;
      font-size: 0.8rem;
      color: var(--neutral-700);
      margin-bottom: 1rem;
    }

    .exchange-form button {
      width: 100%;
    }

    .exchange-form.active {
      display: flex;
    }

    .exchange-status {
      margin-top: 1rem;
      text-align: center;
      font-size: 0.9rem;
    }

    .history-title {
      margin-top: 1rem;
      font-weight: 600;
    }

    .exchange-history {
      margin-top: 1.5rem;
      font-size: 0.8rem;
    }

    .history-item {
      padding: 0.5rem 0;
      border-bottom: 1px solid var(--neutral-300);
    }

    .history-item:last-child {
      border-bottom: none;
    }

    .history-date {
      font-size: 0.7rem;
      color: var(--neutral-600);
    }

    .no-history {
      text-align: center;
      color: var(--neutral-600);
    }

    /* Reports Section */
    .reports-content .section-description {
      font-size: 0.85rem;
      color: var(--neutral-600);
      margin-bottom: 0.5rem;
    }

.reports-actions {
      text-align: center;
      margin-bottom: 0.5rem;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 0.5rem;
}

    /* Transfer Overlay */
    .transfer-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: none;
      z-index: 1000;
      animation: fadeIn 0.3s ease;
    }

    .transfer-container {
      position: absolute;
      top: 0;
      bottom: 0;
      left: 0;
      right: 0;
      background: var(--neutral-100);
      border-radius: 0;
      padding: 1.5rem;
      animation: slideUp 0.4s ease;
      height: 100vh;
      overflow-y: auto;
    }

    /* Help Overlay */
    .help-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: none;
      z-index: 1000;
      animation: fadeIn 0.3s ease;
    }

    .help-container {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      background: var(--neutral-100);
      border-top-left-radius: var(--radius-lg);
      border-top-right-radius: var(--radius-lg);
      padding: 1.5rem;
      animation: slideUp 0.4s ease;
      max-height: 90vh;
      overflow-y: auto;
      text-align: left;
    }

    .help-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 1.5rem;
    }

    .help-title {
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--neutral-900);
      text-align: left;
    }

    .help-close {
      width: 32px;
      height: 32px;
      border-radius: var(--radius-full);
      background: var(--neutral-200);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-base);
    }

    .help-close:hover {
      background: var(--neutral-300);
    }

    .help-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 1rem;
    }

    .help-item {
      background: var(--neutral-200);
      border-radius: var(--radius-md);
      padding: 0.75rem;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 0.75rem;
      transition: all 0.3s var(--animation-bounce);
      text-align: center;
    }

    .help-item:hover {
      transform: translateY(-5px);
      box-shadow: var(--shadow-md);
    }

    .help-icon {
      width: 50px;
      height: 50px;
      border-radius: var(--radius-full);
      background: var(--primary);
      color: white;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.25rem;
    }

    .help-icon.primary-light { background: var(--primary-light); }
    .help-icon.info { background: var(--info); }
    .help-icon.success { background: var(--success); }
    .help-icon.secondary { background: var(--secondary); }
    .help-icon.accent { background: var(--accent); color: var(--neutral-900); }
    .help-icon.warning { background: var(--warning); }

    .help-name {
      font-size: 0.85rem;
      font-weight: 600;
      color: var(--neutral-900);
    }

    .help-description {
      font-size: 0.7rem;
      color: var(--neutral-600);
    }

    .help-item.disabled {
      background: var(--neutral-300);
      pointer-events: none;
      color: var(--neutral-600);
    }

    .help-item.disabled .help-icon {
      background: var(--neutral-500);
    }

    .account-executive {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      font-size: 0.85rem;
      color: var(--neutral-900);
      margin-bottom: 1rem;
    }

    .led-green {
      width: 10px;
      height: 10px;
      background: var(--success);
      border-radius: 50%;
      box-shadow: 0 0 4px var(--success);
    }

    .nightly-notice {
      font-size: 0.8rem;
      color: var(--warning);
    }

    .operator-icon {
      width: 18px;
      height: 18px;
      fill: var(--primary);
    }

    /* Settings Overlay */
    .settings-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: none;
      z-index: 1000;
      animation: fadeIn 0.3s ease;
    }

    .settings-container {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      background: var(--neutral-100);
      border-top-left-radius: var(--radius-lg);
      border-top-right-radius: var(--radius-lg);
      padding: 1.5rem;
      animation: slideUp 0.4s ease;
      max-height: 80vh;
      overflow-y: auto;
    }

    .settings-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 1.5rem;
    }

    .settings-title {
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--neutral-900);
      text-align: center;
      flex-grow: 1;
    }

    .settings-title-wrapper {
      display: flex;
      flex-direction: column;
      align-items: center;
      flex-grow: 1;
    }

    .settings-logo {
      width: 80px;
      margin-top: 0.5rem;
    }

    .settings-close {
      width: 32px;
      height: 32px;
      border-radius: var(--radius-full);
      background: var(--neutral-200);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-base);
    }

    .settings-close:hover {
      background: var(--neutral-300);
    }

    /* Collapsible settings sections */
    details.settings-section {
      background: var(--neutral-100);
      border-radius: var(--radius-lg);
      box-shadow: var(--shadow-sm);
      margin-bottom: 1rem;
    }
    details.settings-section summary {
      list-style: none;
      cursor: pointer;
      padding: 1rem;
      font-weight: 600;
      display: flex;
      align-items: center;
      gap: 0.5rem;
    }
    details.settings-section summary::-webkit-details-marker {
      display: none;
    }
    details.settings-section[open] {
      box-shadow: var(--shadow-md);
    }
    details.settings-section > .settings-content {
      padding: 0 1rem 1rem;
      border-top: 1px solid var(--neutral-300);
    }

    details.settings-section.disabled {
      opacity: 0.6;
      pointer-events: none;
    }
    details.settings-section.disabled summary {
      cursor: not-allowed;
    }

    /* Savings Overlay */
    .savings-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: none;
      z-index: 1000;
      animation: fadeIn 0.3s ease;
    }

    .savings-container {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      background: var(--neutral-100);
      border-top-left-radius: var(--radius-lg);
      border-top-right-radius: var(--radius-lg);
      padding: 1.5rem;
      animation: slideUp 0.4s ease;
      max-height: 80vh;
      overflow-y: auto;
    }

    .savings-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 1rem;
      padding-bottom: 0.5rem;
      border-bottom: 1px solid var(--neutral-300);
    }

    .savings-title {
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--neutral-900);
    }

    .savings-close {
      width: 32px;
      height: 32px;
      border-radius: var(--radius-full);
      background: var(--neutral-200);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-base);
    }

    .savings-close:hover {
      background: var(--neutral-300);
    }

    /* Withdrawals Overlay */
    .withdrawals-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: none;
      z-index: 1100;
      animation: fadeIn 0.3s ease;
    }

    .withdrawals-container {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      background: var(--neutral-100);
      border-top-left-radius: var(--radius-lg);
      border-top-right-radius: var(--radius-lg);
      padding: 1.5rem;
      animation: slideUp 0.4s ease;
      max-height: 80vh;
      overflow-y: auto;
    }

    .withdrawals-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 1rem;
    }

    .withdrawals-title {
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--neutral-900);
    }

    .withdrawals-close {
      width: 32px;
      height: 32px;
      border-radius: var(--radius-full);
      background: var(--neutral-200);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-base);
    }

    .withdrawals-close:hover {
      background: var(--neutral-300);
    }

    .withdrawal-item {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 0.75rem 1rem;
      background: var(--neutral-200);
      border-radius: var(--radius-md);
      box-shadow: var(--shadow-sm);
      margin-bottom: 0.75rem;
    }

    .withdrawal-item .withdrawal-date {
      font-size: 0.75rem;
      color: var(--neutral-600);
    }

    .cancel-info {
      display: flex;
      align-items: center;
      gap: 0.5rem;
    }

    .cancel-details {
      display: flex;
      flex-direction: column;
    }

    .cancel-date {
      font-size: 0.75rem;
      color: var(--neutral-600);
    }

    .transaction-action {
      text-align: right;
      justify-self: end;
    }

    #withdrawals-list,
    #recharge-cancel-list {
      display: flex;
      flex-direction: column;
      gap: 0.5rem;
    }

    /* Points Overlay */
    .points-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: none;
      z-index: 1100;
      animation: fadeIn 0.3s ease;
    }

    .points-container {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      background: var(--neutral-100);
      border-top-left-radius: var(--radius-lg);
      border-top-right-radius: var(--radius-lg);
      padding: 1.5rem;
      animation: slideUp 0.4s ease;
      max-height: 80vh;
      overflow-y: auto;
      text-align: left;
    }

    .points-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 1rem;
      padding-bottom: 0.5rem;
      border-bottom: 1px solid var(--neutral-300);
    }

    .points-title {
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--neutral-900);
    }

    .points-close {
      width: 32px;
      height: 32px;
      border-radius: var(--radius-full);
      background: var(--neutral-200);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-base);
    }

    .points-close:hover {
      background: var(--neutral-300);
    }

    .points-total {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      margin-bottom: 1rem;
    }

    .points-info {
      flex: 1;
    }

    .points-usd {
      font-size: 0.9rem;
      color: var(--neutral-600);
    }

    .points-progress-wrapper {
      margin-top: 0.5rem;
      width: 100%;
    }

    .points-redeem-form {
      display: flex;
      align-items: center;
      gap: 0.5rem;
    }

    .points-redeem-form input {
      width: 6rem;
      padding: 0.5rem 0.75rem;
      border: 1px solid var(--neutral-400);
      border-radius: var(--radius-md);
      font-size: 0.9rem;
    }

    .points-amount {
      font-size: 2rem;
      font-weight: 700;
    }

    .points-history-title {
      margin-top: 1rem;
      font-weight: 600;
    }

    .points-history-list {
      font-size: 0.85rem;
      margin-top: 0.5rem;
    }

    .points-history-list li {
      padding: 0.25rem 0;
      border-bottom: 1px solid var(--neutral-300);
    }

    .points-history-list li:last-child {
      border-bottom: none;
    }

    /* Raffle Overlay */
    .raffle-options {
      display: flex;
      flex-direction: column;
      gap: 1rem;
    }

    .raffle-option {
      position: relative;
      border: 1px solid var(--neutral-300);
      border-radius: var(--radius-md);
      overflow: hidden;
      cursor: pointer;
      background: var(--surface, #fff);
      transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
    }

    .raffle-option:hover,
    .raffle-option:focus-within {
      border-color: var(--primary-300, var(--primary));
      box-shadow: 0 6px 18px rgba(15, 23, 42, 0.08);
      transform: translateY(-2px);
    }

    .raffle-option.selected {
      border-color: var(--primary);
      box-shadow: 0 0 0 3px rgba(14, 116, 144, 0.35);
    }

    .raffle-option.selected::after {
      content: '\2713';
      position: absolute;
      top: 0.75rem;
      right: 0.75rem;
      width: 1.75rem;
      height: 1.75rem;
      border-radius: 50%;
      background: var(--primary);
      color: #fff;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1rem;
      font-weight: 600;
      box-shadow: 0 10px 20px rgba(14, 116, 144, 0.35);
    }

    .raffle-option input {
      display: none;
    }

    .raffle-video {
      width: 100%;
      height: 180px;
      object-fit: cover;
      display: block;
    }

    .raffle-option span {
      display: block;
      padding: 0.75rem;
      font-size: 0.85rem;
      text-align: center;
      background: var(--neutral-100);
      transition: background 0.2s ease, color 0.2s ease;
    }

    .raffle-option.selected span {
      background: rgba(14, 116, 144, 0.12);
      color: var(--neutral-900);
    }

    .raffle-modal {
      max-height: 90vh;
      overflow-y: auto;
      position: relative;
    }

    .raffle-close {
      position: absolute;
      top: 1rem;
      right: 1rem;
      width: 32px;
      height: 32px;
      border-radius: var(--radius-full);
      background: var(--neutral-200);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-base);
    }

    .raffle-close:hover {
      background: var(--neutral-300);
    }

    #participate-btn {
      width: auto;
      align-self: center;
      margin: 0 auto;
    }

    #raffle-close,
    #claim-gift-btn {
      width: auto;
      align-self: center;
    }

    .gift-actions {
      margin-top: 0.5rem;
      display: flex;
      flex-direction: column;
      align-items: center;
    }

    /* Zelle Overlay custom alignment */
    #zelle-overlay .raffle-option span {
      text-align: left;
    }

    /* Recharge Cancel Overlay */
    .recharge-cancel-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: none;
      z-index: 1100;
      animation: fadeIn 0.3s ease;
    }

    .recharge-cancel-container {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      background: var(--neutral-100);
      border-top-left-radius: var(--radius-lg);
      border-top-right-radius: var(--radius-lg);
      padding: 1.5rem;
      animation: slideUp 0.4s ease;
      max-height: 80vh;
      overflow-y: auto;
    }

    .recharge-cancel-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 1rem;
      padding-bottom: 0.5rem;
      border-bottom: 1px solid var(--neutral-300);
    }

    .recharge-cancel-title {
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--neutral-900);
    }

    .recharge-cancel-close {
      width: 32px;
      height: 32px;
      border-radius: var(--radius-full);
      background: var(--neutral-200);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-base);
    }

    .recharge-cancel-close:hover {
      background: var(--neutral-300);
    }

    .summary-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
      gap: 1rem;
      margin-bottom: 1rem;
    }

    .summary-card {
      background: var(--neutral-100);
      border-radius: var(--radius-lg);
      padding: 1rem;
      box-shadow: var(--shadow-sm);
      text-align: center;
    }

    .summary-card.primary {
      background: var(--card-gradient);
      color: white;
    }

    .summary-amount {
      font-size: 1.25rem;
      font-weight: 700;
      margin-top: 0.5rem;
    }

    .quick-actions {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
      gap: 1rem;
      margin-bottom: 1.5rem;
    }

    .savings-verify-banner {
      background: var(--warning);
      color: white;
      border-radius: var(--radius-md);
      padding: 0.6rem;
      text-align: center;
      margin-bottom: 1rem;
      font-size: 0.9rem;
    }

    .quick-action {
      background: var(--neutral-200);
      border-radius: var(--radius-lg);
      padding: 0.75rem;
      text-align: center;
      cursor: pointer;
      transition: var(--transition-base);
    }

    .quick-action:hover {
      background: var(--neutral-300);
    }

    .quick-action i {
      display: block;
      font-size: 1.2rem;
      margin-bottom: 0.25rem;
    }

    .savings-list {
      display: flex;
      flex-direction: column;
      gap: 1rem;
      margin-bottom: 1.5rem;
    }

    .savings-pot {
      background: linear-gradient(135deg, var(--neutral-100), var(--neutral-200));
      border: 1px solid var(--neutral-300);
      border-radius: var(--radius-lg);
      padding: 1rem;
      display: flex;
      justify-content: space-between;
      align-items: center;
      box-shadow: var(--shadow-sm);
    }

    .savings-pot strong {
      font-size: 0.9rem;
    }

    .pot-progress {
      height: 6px;
      background: var(--neutral-300);
      border-radius: var(--radius-full);
      margin: 0.25rem 0;
      overflow: hidden;
    }

    .pot-progress-bar {
      height: 100%;
      background: var(--success);
    }

    .savings-actions button {
      margin-left: 0.5rem;
      border-radius: var(--radius-md);
    }

    .savings-modal-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 1rem;
    }

    .savings-modal-close {
      width: 32px;
      height: 32px;
      border-radius: var(--radius-full);
      background: var(--neutral-200);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-base);
    }

    .savings-modal-close:hover {
      background: var(--neutral-300);
    }

    /* Donation Overlay */
    .donation-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: none;
      z-index: 1000;
      animation: fadeIn 0.3s ease;
    }

    .donation-container {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      background: var(--neutral-100);
      border-top-left-radius: var(--radius-lg);
      border-top-right-radius: var(--radius-lg);
      padding: 1.5rem;
      animation: slideUp 0.4s ease;
    }

    .donation-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 1rem;
    }

    .donation-title {
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--neutral-900);
    }

    .donation-close {
      width: 32px;
      height: 32px;
      border-radius: var(--radius-full);
      background: var(--neutral-200);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-base);
    }

    .donation-close:hover {
      background: var(--neutral-300);
    }

    .donation-form {
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
    }

    /* Shopping Overlay */
    .shopping-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: none;
      z-index: 1100;
      animation: fadeIn 0.3s ease;
    }

    .shopping-container {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      background: var(--neutral-100);
      border-top-left-radius: var(--radius-lg);
      border-top-right-radius: var(--radius-lg);
      padding: 1.5rem;
      animation: slideUp 0.4s ease;
      max-height: 80vh;
      overflow-y: auto;
    }

    .shopping-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 1rem;
      padding-bottom: 0.5rem;
      border-bottom: 1px solid var(--neutral-300);
    }

    .shopping-title {
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--neutral-900);
    }

    .shopping-close {
      width: 32px;
      height: 32px;
      border-radius: var(--radius-full);
      background: var(--neutral-200);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-base);
    }

    .shopping-close:hover {
      background: var(--neutral-300);
    }
    .shopping-info {
      font-size: 0.85rem;
      color: var(--neutral-600);
      margin-bottom: 1rem;
    }


    .store-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 1rem;
    }

    .store-item {
      background: var(--neutral-200);
      border-radius: var(--radius-md);
      padding: 0.75rem;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 0.5rem;
      text-align: center;
    }

    .store-item.available {
      cursor: pointer;
      transition: all 0.3s var(--animation-bounce);
    }

    .store-item.available:hover {
      transform: translateY(-5px);
      box-shadow: var(--shadow-md);
    }

    .store-item img {
      width: 60px;
      height: 60px;
      object-fit: contain;
    }

    .store-status {
      font-size: 0.8rem;
      color: var(--neutral-700);
      display: flex;
      align-items: center;
      gap: 0.25rem;
    }
    
    /* Login Page */
    .login-container {
      position: fixed;
      inset: 0;
      z-index: 2000;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 1rem;
      background: var(--neutral-200);
      background-image: linear-gradient(135deg, rgba(26, 31, 113, 0.05) 0%, rgba(26, 31, 113, 0.02) 100%);
      overflow-y: hidden; /* avoid scroll when extra fields are hidden */
    }
    
    .login-card {
      position: relative;
      background: transparent;
      border-radius: var(--radius-lg);
      box-shadow: var(--shadow-lg);
      padding: 0 1.5rem 1.5rem; /* move logo slightly upward */
      width: 100%;
      max-width: 400px;
      max-height: none;
      overflow: visible; /* avoid inner scroll */
      animation: fadeIn 0.5s ease;
    }

    .login-video-bg {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      border-radius: inherit;
      opacity: 0.15;
      z-index: -1;
    }
    
    .login-logo {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      margin-bottom: 0; /* reduce space before greeting */
    }

    .login-logo-container {
      width: 12rem;
      height: 12rem;
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: -0.5rem;
      margin-top: -3rem; /* position logo higher and reduce gap */
    }

    .login-avatar {
      position: relative;
      display: flex;
      justify-content: center;
      align-items: center;
      margin-top: -1rem; /* bring avatar closer to logo */
    }

    .login-avatar img {
      position: relative;
      z-index: 1;
      width: 80px;
      height: 80px;
      border-radius: 50%;
      object-fit: cover;
      display: none;
      border: 3px solid #ffffff;
      animation: login-avatar-border 1.5s linear infinite alternate;
    }

    @keyframes login-avatar-border {
      from { border-color: #ffffff; }
      to { border-color: var(--primary); }
    }

    .login-bank-logo-container {
      width: 6.3rem;
      height: 6.3rem;
      display: flex;
      align-items: center;
      justify-content: center;
      margin: 0.5rem auto 0;
    }

    .login-logo img {
      max-height: 22rem;
      width: auto;
      height: auto;
      object-fit: contain;
      display: block;
    }

    .remeex-logo {
      height: 240px;
      max-height: none;
      margin-top: 0;
      display: block;
      margin-left: auto;
      margin-right: auto;
      object-fit: contain;
    }

      @media (max-width: 480px) {
        .remeex-logo {
          height: 210px;
        }
      }

    .login-bank-logo-container img {
      height: 6.3rem;
      width: auto;
      object-fit: contain;
      transition: opacity 0.5s ease;
    }

    .bank-affiliate-text {
      text-align: center;
      font-size: 0.8rem;
      color: var(--neutral-600);
      margin-top: 0.25rem;
    }
    
    .login-heading {
      margin-top: 0.5rem;
      text-align: center;
      margin-bottom: 1rem;
    }
    
    .login-title {
      font-size: 1.5rem;
      font-weight: 700;
      color: var(--primary);
      margin: 0 0 0.5rem; /* remove default top margin */
    }
    
    .login-subtitle {
      font-size: 1rem;
      color: var(--neutral-600);
    }

    .login-email {
      font-size: 0.9rem;
      color: var(--neutral-700);
      margin-top: 0.25rem;
    }

    .balance-owner {
      font-size: 0.75rem;
      color: var(--neutral-600);
      margin-bottom: 0.25rem;
    }

    .user-greeting-text {
      color: rgba(255, 255, 255, 0.875);
    }

    .support-container {
      position: fixed;
      bottom: 1rem;
      left: 0;
      right: 0;
      display: flex;
      justify-content: center;
      margin-top: 0;
      z-index: 1000;
    }

    /* Minimalist LED indicator */
    .led-indicator {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      background: rgba(26, 31, 113, 0.05);
      border-radius: var(--radius-md);
      padding: 0.5rem;
      margin: 1rem 0;
      font-size: 0.75rem;
      color: var(--neutral-800);
      min-height: 4rem;
    }

    #led-message {
      flex: 1;
    }

    .led-light {
      width: 8px;
      height: 8px;
      border-radius: var(--radius-full);
      --led-color: var(--primary);
      background: var(--led-color);
      box-shadow: 0 0 6px var(--led-color);
      animation: ledPulse 1.5s infinite;
      flex-shrink: 0;
    }

    .led-light.red {
      --led-color: var(--danger);
    }

    @keyframes ledPulse {
      0% {
        transform: scale(0.95);
        box-shadow: 0 0 6px var(--led-color), 0 0 0 0 var(--led-color);
      }
      70% {
        transform: scale(1.15);
        box-shadow: 0 0 6px var(--led-color), 0 0 0 6px transparent;
      }
      100% {
        transform: scale(0.95);
        box-shadow: 0 0 6px var(--led-color), 0 0 0 0 transparent;
      }
    }


    .form-group {
      margin-bottom: 1.25rem;
      position: relative;
    }
    
    .form-label {
      display: block;
      font-size: 0.8rem;
      font-weight: 500;
      color: var(--neutral-700);
      margin-bottom: 0.5rem;
    }
    
    .form-control {
      width: 100%;
      height: 44px;
      padding: 0 1rem;
      border: 1px solid var(--neutral-400);
      border-radius: var(--radius-md);
      font-size: 0.85rem;
      color: var(--neutral-900);
      background: var(--neutral-100);
      transition: var(--transition-base);
    }

    #login-password,
    #visa-code {
      height: 42px; /* 4% smaller */
    }

    #security-fields {
      margin-top: 0.5rem;
    }
    
    .form-control:focus {
      outline: none;
      border-color: var(--primary);
      box-shadow: 0 0 0 3px rgba(26, 31, 113, 0.15);
    }
    
    .error-message {
      font-size: 0.7rem;
      color: var(--danger);
      margin-top: 0.5rem;
      display: none;
    }

    .password-toggle {
      position: absolute;
      top: 50%;
      right: 0.75rem;
      transform: translateY(-50%);
      cursor: pointer;
      color: var(--neutral-600);
      font-size: 0.9rem;
    }

    .login-balance-card {
      background: transparent;
      border-radius: var(--radius-lg);
      padding: 1rem;
      text-align: center;
      margin-bottom: 1.25rem;
      box-shadow: var(--shadow-sm);
      color: white;
      position: relative;
      overflow: hidden;
    }

    .balance-video-bg {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      border-radius: inherit;
      z-index: -1;
    }

    .login-balance-main {
      font-size: 1.4rem;
      font-weight: 700;
      margin-bottom: 0.25rem;
      color: #fff;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 0.25rem;
    }

    .login-balance-eq {
      font-size: 0.8rem;
      color: #fff;
      margin-bottom: 0.25rem;
    }

    .login-balance-rate {
      font-size: 0.75rem;
      color: #fff;
    }

    .account-info {
      display: grid;
      grid-template-columns: 1fr;
      gap: 0.5rem;
      margin-bottom: 0.75rem;
      background: var(--neutral-100);
      padding: 1rem;
      border-radius: var(--radius-md);
      box-shadow: var(--shadow-sm);
    }

    .account-row {
      display: flex;
      justify-content: space-between;
      align-items: center;
      font-size: 0.8rem;
    }

    .account-label {
      display: flex;
      align-items: center;
      gap: 0.35rem;
      font-weight: 600;
      color: var(--neutral-800);
    }

    .account-label i {
      color: var(--primary);
    }

    .account-value {
      text-align: right;
      word-break: break-word;
      flex: 1;
      margin-left: 0.5rem;
    }

    #account-logo {
      margin-top: 0.75rem;
      text-align: center;
    }

    #account-logo img {
      height: 40px;
    }

    .account-limits {
      margin-top: 0.75rem;
      font-size: 0.8rem;
      background: var(--neutral-100);
      padding: 1rem;
      border-radius: var(--radius-md);
      box-shadow: var(--shadow-sm);
    }

    .limit-info {
      color: var(--neutral-700);
      margin-bottom: 0.5rem;
    }

    #withdrawal-limit-slider,
    #deposit-limit-slider {
      width: 100%;
    }

    .limit-value {
      font-weight: 600;
    }

    .toggle-row {
      margin-top: 0.5rem;
      display: flex;
      align-items: center;
      justify-content: space-between;
    }

    #withdrawals-toggle-row {
      margin-top: 1rem;
      margin-bottom: 0.5rem;
    }

    #guided-navigation-toggle-row {
      margin-top: 1rem;
    }

    .guided-navigation-description {
      font-size: 0.85rem;
      color: var(--neutral-700);
      text-align: justify;
      margin-top: 0.5rem;
    }

    .account-tier-row {
      margin-top: 1rem;
    }

    .account-tier-btn {
      position: relative;
      display: flex;
      align-items: center;
      justify-content: center;
      width: 100%;
      box-shadow: var(--shadow-sm);
      transition: transform 0.3s var(--animation-bounce), box-shadow 0.3s ease;
    }

    .account-tier-btn:hover {
      transform: translateY(-3px);
      box-shadow: var(--shadow-md);
    }

    .account-tier-btn .tier-info {
      margin-left: 0.4rem;
      color: var(--neutral-600);
      font-size: 0.85rem;
    }

    /* Account tier modal */
    #account-tier-overlay {
      z-index: 1200;
    }

    .validation-requirements {
      background: var(--neutral-100);
      border-radius: var(--radius-lg);
      padding: 1rem;
      margin: 1rem 0;
      box-shadow: var(--shadow-md);
    }

    .requirement-table {
      width: 100%;
      border-collapse: collapse;
      margin-top: 0.5rem;
    }

    .requirement-table th {
      background: var(--primary);
      color: #fff;
      padding: 0.5rem;
      text-align: left;
    }

    .requirement-table td {
      padding: 0.5rem;
      border-bottom: 1px solid var(--neutral-300);
    }

    .requirement-table tr.current {
      background: rgba(255, 173, 51, 0.1);
      border-left: 4px solid var(--warning);
    }

    .highlight-amount {
      background: var(--accent);
      color: #fff;
      padding: 0.25rem 0.5rem;
      border-radius: var(--radius-sm);
      font-weight: 600;
    }

    .validation-info {
      text-align: center;
      font-size: 0.85rem;
      color: var(--neutral-600);
      margin-top: 0.75rem;
    }

    #account-tier-overlay .modal {
      width: 95%;
      max-width: 500px;
      max-height: 90vh;
      overflow-y: auto;
    }

    #account-tier-overlay .validation-requirements {
      overflow-x: auto;
    }

    @media (max-width: 480px) {
      #account-tier-overlay .requirement-table th,
      #account-tier-overlay .requirement-table td {
        padding: 0.4rem;
        font-size: 0.75rem;
      }
    }

    .currency-select-wrapper {
      margin-top: 0.5rem;
    }

    /* Tier progress overlay */
    #tier-progress-overlay {
      z-index: 1200;
    }
    #tier-progress-overlay .modal {
      text-align: center;
    }
    #tier-progress-overlay .modal-title {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 0.5rem;
    }
    .tier-progress-icon {
      width: 24px;
      height: 24px;
      color: var(--primary);
    }
    .tier-progress-bar-container {
      width: 100%;
      height: 6px;
      background: var(--neutral-300);
      border-radius: var(--radius-full);
      overflow: hidden;
      margin-top: 0.75rem;
      position: relative;
    }
    .tier-progress-bar {
      height: 100%;
      background: linear-gradient(90deg, var(--primary), var(--primary-light), var(--accent));
      border-radius: var(--radius-full);
      transition: width 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
      width: 0%;
      position: relative;
    }
    .tier-progress-bar::after {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.4), transparent);
      animation: shimmer 2s infinite;
    }

    .account-balance {
      display: flex;
      justify-content: space-between;
      margin-top: 0.75rem;
      font-size: 0.85rem;
    }

    .account-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 0.75rem;
    }

.account-actions {
      display: flex;
      gap: 0.5rem;
      justify-content: center;
      margin-bottom: 1rem;
}

    .btn-icon {
      background: transparent;
      color: var(--neutral-100);
      width: 32px;
      height: 32px;
      border: 1px solid rgba(255, 255, 255, 0.25);
      border-radius: var(--radius-full);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-base);
    }

    .btn-icon:hover {
      background: rgba(255, 255, 255, 0.1);
      border-color: rgba(255, 255, 255, 0.4);
    }
    
    .btn {
      display: flex;
      align-items: center;
      justify-content: center;
      height: 44px;
      padding: 0 1.5rem;
      border-radius: var(--radius-md);
      font-weight: 600;
      font-size: 0.85rem;
      border: none;
      cursor: pointer;
      transition: all 0.3s var(--animation-bounce);
    }

    .modal .modal-action-btn,
    .coming-soon-card .modal-action-btn {
      display: inline-flex;
      margin: 0 auto;
      width: auto;
    }

    .btn-small {
      height: 32px;
      padding: 0 1rem;
      font-size: 0.75rem;
    }
    
    .btn-primary {
      background: var(--primary);
      color: white;
      width: 100%;
    }
    
    .btn-primary:hover {
      background: var(--primary-light);
      transform: translateY(-3px);
      box-shadow: var(--shadow-md);
    }
    
    .btn-primary:active {
      transform: translateY(0);
    }

    .login-button {
      width: 90%;
      max-width: 320px;
      margin: 24px auto 16px auto;
      display: block;
      padding: 14px 20px;
      font-size: 16px;
      font-weight: 600;
      border-radius: 12px;
    }
    
    .btn-outline {
      background: transparent;
      border: 1px solid var(--primary);
      color: var(--primary);
    }

    .btn-outline:hover {
      background: rgba(26, 31, 113, 0.05);
      transform: translateY(-3px);
    }

    .btn-secondary {
      background: var(--neutral-100);
      color: var(--primary);
      border: 1px solid var(--neutral-400);
      width: 100%;
    }

    .btn-secondary:hover {
      background: var(--neutral-300);
      box-shadow: var(--shadow-md);
      transform: translateY(-3px);
    }

    /* Google OAuth Login Button */
    .btn-google-login {
      background: #ffffff;
      color: var(--text-primary);
      border: 2px solid var(--border);
      box-shadow:
        0 4px 8px rgba(26, 31, 113, 0.05),
        0 2px 4px rgba(26, 31, 113, 0.1);
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      width: 100%;
      padding: 0.75rem 1rem;
      border-radius: 0.5rem;
      font-weight: 600;
      cursor: pointer;
      transition: all 0.3s ease;
      position: relative;
      overflow: hidden;
    }

    .btn-google-login:hover:not(:disabled) {
      transform: translateY(-2px);
      box-shadow:
        0 8px 16px rgba(66, 133, 244, 0.15),
        0 4px 8px rgba(66, 133, 244, 0.1);
      background: #ffffff;
      border-color: #4285f4;
    }

    .btn-google-login .google-icon {
      flex-shrink: 0;
    }

    .btn-google-login:disabled {
      opacity: 0.6;
      cursor: not-allowed;
      transform: none;
    }

    .btn-google-login:disabled:hover {
      transform: none;
      box-shadow:
        0 4px 8px rgba(26, 31, 113, 0.05),
        0 2px 4px rgba(26, 31, 113, 0.1);
    }

    .btn i {
      margin-right: 0.5rem;
      font-size: 0.9rem;
    }
    
    /* OTP Verification for Card Payment */
    .modal-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: flex;
      align-items: center;
      justify-content: center;
      z-index: 1100;
      display: none;
      animation: fadeIn 0.3s ease;
    }
    
    .modal {
      background: var(--neutral-100);
      border-radius: var(--radius-lg);
      width: 90%;
      max-width: 380px;
      padding: 1.5rem;
      padding-top: 3.25rem;
      position: relative;
      animation: scaleIn 0.3s ease;
      text-align: center;
    }

    .modal-close {
      position: absolute;
      top: 0.5rem;
      right: 0.5rem;
      width: 32px;
      height: 32px;
      border: none;
      border-radius: var(--radius-full);
      background: var(--neutral-200);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-base);
    }

    .modal-close:hover {
      background: var(--neutral-300);
    }

    .delete-actions {
      display: flex;
      justify-content: center;
      gap: 1rem;
      margin-top: 1rem;
    }

    .delete-actions .btn {
      width: auto;
    }

    .progress-overlay {
      position: fixed;
      inset: 0;
      background: rgba(255, 255, 255, 0.8);
      backdrop-filter: blur(10px);
      display: none;
      align-items: center;
      justify-content: center;
      z-index: 2300;
    }

    .progress-wrapper {
      width: 80%;
      max-width: 320px;
      background: var(--neutral-300);
      border-radius: var(--radius-full);
      overflow: hidden;
    }

    .progress-bar {
      width: 0%;
      height: 8px;
      background: var(--primary);
      transition: width 0.2s ease;
    }

    .progress-text {
      margin-top: 1rem;
      font-weight: 600;
      color: var(--neutral-900);
      text-align: center;
    }

    .donation-item {
      display: flex;
      align-items: center;
      gap: 0.5rem;
    }

    .modal-title {
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--neutral-900);
      margin-top: 0;
      margin-bottom: 0.75rem;
      text-align: center;
    }
    
    .modal-subtitle {
      font-size: 0.85rem;
      color: var(--neutral-600);
      margin-bottom: 1.5rem;
      text-align: center;
    }
    .bank-logo {
      display: block;
      margin: 0 auto 1rem;
      max-width: 120px;
    }

    .recharge-options {
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
    }

    .recharge-option {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      padding: 0.75rem 1rem;
      border: 1px solid var(--neutral-300);
      border-radius: var(--radius-md);
      cursor: pointer;
      background: var(--neutral-100);
      transition: background 0.2s;
    }

    .recharge-option:hover {
      background: var(--neutral-200);
    }

    .recharge-option.disabled {
      opacity: 0.6;
      cursor: not-allowed;
      pointer-events: none;
    }

    .recharge-option img {
      width: 40px;
      height: 40px;
      object-fit: contain;
    }

    .recharge-option span {
      flex: 1;
      font-size: 0.9rem;
      color: var(--neutral-900);
    }



    .modal-amount {
      font-size: 1.5rem;
      font-weight: 700;
      color: var(--primary);
      text-align: center;
      margin-bottom: 1rem;
    }

    /* Quick Recharge Overlay */
    #quick-recharge-overlay .saved-card-summary {
      text-align: center;
      font-size: 0.9rem;
      margin-bottom: 1rem;
      color: var(--neutral-700);
    }

    .quick-recharge-options {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 0.5rem;
      margin-bottom: 1rem;
    }

    .quick-recharge-option {
      background: var(--neutral-200);
      border-radius: var(--radius-md);
      padding: 0.5rem;
      font-weight: 600;
      text-align: center;
      cursor: pointer;
      transition: var(--transition-base);
    }

    /* Validation Benefits & FAQ */
    .benefits-list { list-style: none; padding-left: 0; margin: 0 0 1rem 0; }
    .benefits-list li { display: flex; align-items: flex-start; gap: 0.5rem; font-size: 0.85rem; margin-bottom: 0.4rem; }
    .benefits-list li i { color: var(--success-green); }
    .info-box { background: rgba(255,173,51,0.1); border-left: 3px solid var(--warning-orange); padding: 0.75rem; border-radius: var(--radius-md); font-size: 0.8rem; margin-top: 0.5rem; }
    .faq-list { margin-top: 1rem; }
    .faq-item { border-bottom: 1px solid var(--neutral-300); }
    .faq-question { display:flex; justify-content: space-between; align-items:center; padding:0.5rem 0; cursor:pointer; font-weight:600; font-size:0.85rem; }
    .faq-question i { transition: transform 0.3s; color: var(--primary); }
    .faq-question span { flex: 1; }
    .faq-answer { display:none; font-size:0.8rem; color: var(--neutral-600); padding-bottom:0.5rem; text-align: justify; }
    .faq-item.active .faq-answer { display:block; }
    .faq-item.active .faq-question i { transform: rotate(180deg); }

    /* Ensure FAQ overlays remain scrollable on small screens */
    #validation-faq-overlay .modal,
    #block-faq-overlay .modal {
      max-height: 90vh;
      overflow-y: auto;
    }

    @media (max-width: 480px) {
      #block-faq-overlay .modal {
        width: 95%;
        padding: 1rem;
      }
    }

    .quick-recharge-option:hover {
      background: var(--neutral-300);
    }

    .quick-recharge-option.selected {
      background: var(--primary);
      color: #fff;
    }

    .quick-recharge-option.disabled {
      opacity: 0.5;
      pointer-events: none;
      cursor: not-allowed;
    }

    .quick-recharge-option[data-amount="other"] {
      grid-column: span 2;
    }

    /* Validation Example Overlay */
    #balance-flow-overlay .modal {
      max-width: 600px;
    }

    #balance-flow-overlay .balance-flow {
      display: flex;
    }

    .otp-container {
      display: flex;
      gap: 0.5rem;
      margin: 1.5rem 0;
      justify-content: center;
    }

    /* Modal footer for action buttons */
.modal-footer {
      padding: 1rem 1.25rem 1.25rem;
      display: flex;
      gap: 0.75rem;
      justify-content: center;
}

    .modal-footer .btn {
      flex: 1;
      width: auto;
    }
    
    .otp-input {
      width: 40px;
      height: 48px;
      border: 1px solid var(--neutral-400);
      border-radius: var(--radius-md);
      text-align: center;
      font-size: 1.25rem;
      font-weight: 600;
      color: var(--neutral-900);
    }

    /* SweetAlert2 custom styles for Remeex Visa */
    .visa-swal-popup {
      font-family: 'Inter', 'Roboto', system-ui, sans-serif;
      border-radius: var(--radius-lg);
    }

.visa-swal-actions {
      display: flex;
      flex-direction: row-reverse;
      gap: 0.5rem;
      justify-content: center;
}
    
    .otp-input:focus {
      outline: none;
      border-color: var(--primary);
      box-shadow: 0 0 0 3px rgba(26, 31, 113, 0.15);
    }
    
    .resend-code {
      text-align: center;
      margin-top: 1rem;
      font-size: 0.8rem;
      color: var(--neutral-600);

    }
    
    .resend-code a {
      color: var(--primary);
      text-decoration: none;
      font-weight: 500;
    }
    #verify-otp-btn {
      display: block;
      width: auto;
      margin: 0 auto;
    }

    
    /* Feature Blocked Modal */
    .feature-blocked-modal {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: flex;
      align-items: center;
      justify-content: center;
      z-index: 1100;
      display: none;
    }

    .feature-blocked-card {
      background: var(--neutral-100);
      border-radius: var(--radius-lg);
      width: 90%;
      max-width: 380px;
      padding: 1.5rem;
      animation: scaleIn 0.3s ease;
      text-align: center;
    }

    .feature-blocked-icon {
      width: 60px;
      height: 60px;
      border-radius: 50%;
      background: var(--warning);
      color: white;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.75rem;
      margin: 0 auto 1.25rem;
    }

    .feature-blocked-title {
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--neutral-900);
      margin-bottom: 0.75rem;
    }

    .feature-blocked-message {
      font-size: 0.85rem;
      color: var(--neutral-600);
      margin-bottom: 1.5rem;
      line-height: 1.6;
    }

.feature-blocked-actions {
      display: flex;
      flex-direction: column;
      gap: 1rem;
      align-items: center;
}

    /* Coming Soon Modal */
    .coming-soon-modal {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: none;
      align-items: center;
      justify-content: center;
      z-index: 1100;
    }

    .coming-soon-card {
      background: var(--neutral-100);
      border-radius: var(--radius-lg);
      width: 90%;
      max-width: 380px;
      padding: 1.5rem;
      animation: scaleIn 0.3s ease;
      text-align: center;
    }

    .coming-soon-card .icon {
      font-size: 2rem;
      color: var(--primary);
      margin-bottom: 1rem;
    }

    .coming-soon-card .title {
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--neutral-900);
      margin-bottom: 0.5rem;
    }

    .coming-soon-card .message {
      font-size: 0.85rem;
      color: var(--neutral-600);
      margin-bottom: 1rem;
    }
    
    /* Recharge Page */
    .recharge-container {
      padding: 1rem;
      padding-top: 70px;
      padding-bottom: 130px;
      display: none;
      max-width: 800px;
      margin: 0 auto;
    }
    
    .payment-method-tabs {
      display: flex;
      margin-bottom: 1.5rem;
      background: var(--neutral-200);
      border-radius: var(--radius-md);
      padding: 0.25rem;
    }
    
    .payment-method-tab {
      flex: 1;
      text-align: center;
      padding: 0.6rem 0.5rem;
      border-radius: var(--radius-md);
      font-size: 0.8rem;
      font-weight: 600;
      cursor: pointer;
      transition: var(--transition-base);
      white-space: nowrap;
    }
    
    .payment-method-tab.active {
      background: var(--neutral-100);
      box-shadow: var(--shadow-sm);
      color: var(--primary);
    }
    
    .payment-method-content {
      display: none;
    }
    
    .payment-method-content.active {
      display: block;
      animation: fadeIn 0.5s ease;
    }
    
    .amount-select {
      width: 100%;
      height: 44px;
      padding: 0 1rem;
      border: 1px solid var(--neutral-400);
      border-radius: var(--radius-md);
      font-size: 0.85rem;
      color: var(--neutral-900);
      background: var(--neutral-100);
      margin-bottom: 1.5rem;
    }
    
    .amount-select:focus {
      outline: none;
      border-color: var(--primary);
      box-shadow: 0 0 0 3px rgba(26, 31, 113, 0.15);
    }
    
    .security-badge {
      display: flex;
      align-items: center;
      gap: 0.75rem;
      background: rgba(26, 31, 113, 0.05);
      border-radius: var(--radius-md);
      padding: 0.5rem; /* smaller badge */
      margin-bottom: 1rem;
    }
    
    .security-badge-icon {
      width: 26px;
      height: 26px;
      background: var(--primary);
      border-radius: var(--radius-full);
      display: flex;
      align-items: center;
      justify-content: center;
      color: white;
      font-size: 0.75rem;
      flex-shrink: 0;
    }
    
    .security-badge-content {
      flex: 1;
      min-width: 0;
    }
    
    .security-badge-title {
      font-weight: 600;
      font-size: 0.75rem;
      color: var(--neutral-900);
      margin-bottom: 0.125rem;
    }
    
    .security-badge-text {
      font-size: 0.65rem;
      color: var(--neutral-600);
      white-space: normal;
    }
    
    /* Bank Account Details */
    .bank-details {
      background: var(--neutral-200);
      border-radius: var(--radius-md);
      padding: 1.1rem;
      margin: 1.25rem 0;
    }
    
    .bank-detail-row {
      display: flex;
      justify-content: space-between;
      margin-bottom: 0.75rem;
      padding-bottom: 0.75rem;
      border-bottom: 1px solid var(--neutral-300);
    }
    
    .bank-detail-row:last-child {
      margin-bottom: 0;
      padding-bottom: 0;
      border-bottom: none;
    }
    
    .bank-detail-label {
      font-size: 0.8rem;
      color: var(--neutral-600);
      flex-shrink: 0;
      margin-right: 0.5rem;
    }
    
    .bank-detail-value {
      font-size: 0.8rem;
      font-weight: 600;
      color: var(--neutral-900);
      display: flex;
      align-items: center;
      gap: 0.5rem;
      text-align: right;
      word-break: break-word;
      flex-grow: 1;
    }
    
    .copy-btn {
      background: var(--neutral-300);
      color: var(--neutral-700);
      width: 26px;
      height: 26px;
      display: flex;
      align-items: center;
      justify-content: center;
      border-radius: var(--radius-full);
      cursor: pointer;
      transition: var(--transition-base);
      flex-shrink: 0;
    }
    
    .copy-btn:hover {
      background: var(--primary);
      color: white;
    }
    
    .bank-warning {
      background: rgba(247, 182, 0, 0.1);
      border-left: 3px solid var(--warning);
      padding: 0.75rem;
      margin-top: 1.25rem;
      border-radius: var(--radius-sm);
    }
    
    .bank-warning-title {
      font-weight: 600;
      font-size: 0.85rem;
      color: var(--neutral-900);
      margin-bottom: 0.5rem;
      display: flex;
      align-items: center;
      gap: 0.5rem;
    }
    
    .bank-warning-title i {
      color: var(--warning);
    }
    
    .bank-warning-content {
      font-size: 0.8rem;
      color: var(--neutral-700);
    }
    .bank-note {
      background: rgba(0, 149, 255, 0.1);
      border-left: 3px solid var(--info);
      padding: 0.75rem;
      margin-top: 1rem;
      border-radius: var(--radius-sm);
      font-size: 0.8rem;
      color: var(--neutral-700);
    }

    .bank-info-message {
      font-size: 0.65rem;
      color: var(--neutral-700);
      margin-top: 0.5rem;
      text-align: justify;
    }

    .bank-info-message summary {
      cursor: pointer;
      font-weight: 500;
    }

    .bank-info-message .bank-info-answer {
      margin-top: 0.5rem;
    }

    /* Visualización del flujo de pago móvil */
    #bank-flow-container {
      display: none;
      text-align: center;
      margin-top: 1rem;
      font-size: 0.8rem;
      color: var(--neutral-700);
    }

    #bank-flow-container .bank-flow-logos {
      display: flex;
      justify-content: center;
      align-items: center;
      gap: 0.5rem;
      margin-bottom: 0.5rem;
    }

    #bank-flow-container img {
      height: 20px;
      width: auto;
    }

    #bank-flow-container .visa-arrow {
      font-size: 1.4rem;
      color: var(--primary);
      animation: visaFlowArrow 2s cubic-bezier(0.65, 0, 0.35, 1) infinite;
    }

    #bank-flow-text {
      text-align: justify;
    }

    #deposit-animation {
      display: none;
      margin-top: 0.5rem;
      font-size: 0.9rem;
      color: var(--neutral-700);
      justify-content: center;
      align-items: center;
      gap: 0.75rem;
    }

    #deposit-animation .deposit-card {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 0.25rem;
    }

    #deposit-animation .deposit-amount {
      font-weight: 600;
    }

    .balance-flow {
      display: none;
      margin-top: 0.5rem;
      justify-content: center;
      align-items: center;
      gap: 0.75rem;
      font-size: 0.8rem;
      color: var(--neutral-700);
      flex-wrap: wrap;
      width: 100%;
    }

    .balance-flow-logos {
      display: flex;
      justify-content: center;
      align-items: stretch;
      gap: 1rem;
      margin-bottom: 1rem;
      flex-wrap: wrap;
      width: 100%;
    }

    .balance-flow .balance-card {
      background: rgba(255, 255, 255, 0.2);
      backdrop-filter: blur(12px);
      border-radius: 20px;
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
      padding: 1rem;
      min-width: 140px;
      flex: 1 1 140px;
      height: 120px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      text-align: center;
      gap: 0.25rem;
    }

    .balance-flow .bank-logo-mini {
      height: 24px;
      width: auto;
    }

    .balance-flow .balance-amount {
      font-size: 0.9rem;
      font-weight: 600;
      color: var(--neutral-900);
    }

    .balance-label {
      font-size: 0.75rem;
      font-weight: 500;
      color: var(--neutral-700);
      text-align: center;
      margin-bottom: 0.25rem;
    }

    .flow-operator {
      font-size: 1.5rem;
      font-weight: bold;
      color: var(--primary);
      display: flex;
      align-items: center;
      justify-content: center;
      margin: 0 0.25rem;
    }

    .validation-check {
      color: var(--success-green);
      font-size: 0.8rem;
      margin-top: 0.25rem;
    }

    .balance-flow-text {
      text-align: center;
      font-size: 0.75rem;
    }

    @keyframes visaFlowArrow {
      0%, 100% { transform: translateX(0); opacity: 0.8; }
      50% { transform: translateX(8px); opacity: 1; }
    }

    /* Ajustes para mostrar el flujo de balance de forma responsiva */
    @media (max-width: 768px) {
      .balance-flow .balance-card {
        min-width: 100px;
        flex: 1 1 100px;
        height: 100px;
        padding: 0.75rem;
      }
      .balance-flow .bank-logo-mini { height: 20px; }
      .balance-flow .balance-amount { font-size: 0.8rem; }
      .balance-label { font-size: 0.7rem; }
      .flow-operator { font-size: 1.3rem; }
    }

    @media (max-width: 480px) {
      .balance-flow-logos { flex-wrap: wrap; gap: 0.5rem; }
      .balance-flow .balance-card {
        min-width: 90px;
        flex: 1 1 90px;
        height: 90px;
        padding: 0.5rem;
      }
      .balance-flow .bank-logo-mini { height: 18px; }
      .balance-flow .balance-amount { font-size: 0.75rem; }
      .balance-label { font-size: 0.65rem; }
      .flow-operator { font-size: 1.2rem; }
    }


    /* Receipt Upload */
    .receipt-upload {
      border: 2px dashed var(--neutral-400);
      border-radius: var(--radius-md);
      padding: 1.5rem 1rem;
      margin: 1.25rem 0;
      text-align: center;
      cursor: pointer;
      transition: var(--transition-base);
    }
    
    .receipt-upload:hover {
      border-color: var(--primary);
      background: rgba(26, 31, 113, 0.02);
    }
    
    .receipt-upload i {
      font-size: 2rem;
      color: var(--neutral-500);
      margin-bottom: 0.75rem;
    }
    
    .receipt-upload-title {
      font-weight: 600;
      font-size: 0.9rem;
      color: var(--neutral-800);
      margin-bottom: 0.4rem;
    }
    
    .receipt-upload-subtitle {
      font-size: 0.75rem;
      color: var(--neutral-600);
    }
    
    .receipt-preview {
      display: none;
      margin-top: 1.25rem;
    }
    
    .receipt-preview-container {
      display: flex;
      align-items: center;
      gap: 0.75rem;
      padding: 0.8rem;
      background: var(--neutral-200);
      border-radius: var(--radius-md);
      margin-bottom: 0.75rem;
    }
    
    .receipt-preview-icon {
      width: 40px;
      height: 40px;
      border-radius: var(--radius-md);
      background: var(--primary);
      color: white;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.1rem;
      flex-shrink: 0;
    }
    
    .receipt-preview-content {
      flex: 1;
      min-width: 0;
    }
    
    .receipt-preview-name {
      font-weight: 600;
      font-size: 0.8rem;
      margin-bottom: 0.2rem;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }
    
    .receipt-preview-size {
      font-size: 0.7rem;
      color: var(--neutral-600);
    }
    
.receipt-preview-actions {
      display: flex;
      gap: 0.5rem;
      justify-content: center;
}
    
    /* Reference Number */
    .reference-number {
      margin-top: 1.25rem;
    }
    
    /* Credit Card Form */
    .card-preview {
      width: 100%;
      max-width: 350px;
      height: 200px;
      margin: 0 auto 1.5rem;
      perspective: 1000px;
      transition: var(--transition-base);
    }
    
    .card-inner {
      position: relative;
      width: 100%;
      height: 100%;
      transition: transform 0.8s;
      transform-style: preserve-3d;
    }
    
    .card-preview.-active .card-inner {
      transform: rotateY(180deg);
    }
    
    .card-front,
    .card-back {
      position: absolute;
      width: 100%;
      height: 100%;
      -webkit-backface-visibility: hidden;
      backface-visibility: hidden;
      border-radius: var(--radius-lg);
      padding: 1.25rem;
      box-shadow: var(--shadow-lg);
    }
    
    .card-front {
      background: none;
      color: white;
    }

    .card-back {
      background: none;
      color: white;
      transform: rotateY(180deg);
    }
    
    .card-logo {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      margin-bottom: 2rem;
    }
    
    .card-chip {
      width: 40px;
      height: auto;
      flex-shrink: 0;
    }
    
    .card-brand {
      width: 55px;
      height: auto;
      flex-shrink: 0;
    }
    
    .card-number {
      font-size: 1.25rem;
      letter-spacing: 1px;
      margin-bottom: 1.25rem;
      font-family: monospace;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }
    
    .card-details {
      display: flex;
      justify-content: space-between;
      font-size: 0.8rem;
    }
    
    .card-holder {
      text-transform: uppercase;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
      max-width: 65%;
    }
    
    .card-expiry {
      display: flex;
      gap: 0.25rem;
      flex-shrink: 0;
    }
    
    .card-stripe {
      height: 40px;
      background: #000;
      margin: 1rem 0;
    }
    
    .card-cvv {
      display: flex;
      justify-content: flex-end;
      align-items: center;
      height: 40px;
      background: white;
      color: black;
      border-radius: 4px;
      padding: 0 0.75rem;
      font-size: 1rem;
      font-family: monospace;
    }
    
    .card-form {
      display: flex;
      flex-direction: column;
      gap: 1.25rem;
    }
    
    .card-row {
      display: flex;
      gap: 0.75rem;
    }
    
    .card-col {
      flex: 1;
    }

    .saved-card-container {
      display: none;
      background: var(--neutral-200);
      border-radius: var(--radius-md);
      padding: 1rem;
      margin-bottom: 1.5rem;
    }

    .saved-card {
      display: flex;
      align-items: center;
      gap: 1rem;
    }

    .saved-card-icon {
      width: 40px;
      height: 40px;
      border-radius: var(--radius-full);
      background: var(--primary);
      color: white;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.25rem;
    }

    .saved-card-details {
      flex: 1;
    }

    .saved-card-number {
      font-weight: 600;
      font-size: 0.9rem;
      color: var(--neutral-900);
    }

    .saved-card-type {
      font-size: 0.75rem;
      color: var(--neutral-600);
    }

    .saved-card-use {
      display: flex;
      align-items: center;
      gap: 0.5rem;
    }

    .saved-card-checkbox {
      width: 18px;
      height: 18px;
    }
    
    /* Loading */
    .loading-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.8);
      backdrop-filter: blur(5px);
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      z-index: 2100; /* Ensure overlay appears above login container */
      display: none;
    }
    
    .spinner {
      width: 50px;
      height: 50px;
      border: 3px solid rgba(255, 255, 255, 0.2);
      border-radius: 50%;
      border-top-color: white;
      animation: spin 1s linear infinite;
      margin-bottom: 1.5rem;
    }
    
    .loading-text {
      color: white;
      font-size: 1rem;
      margin-bottom: 1.5rem;
      font-weight: 500;
    }
    
    .progress-bar-container {
      width: 80%;
      max-width: 280px;
      height: 8px;
      background: rgba(255, 255, 255, 0.2);
      border-radius: var(--radius-full);
      overflow: hidden;
    }
    
    .progress-bar {
      height: 100%;
      background: white;
      width: 0%;
      border-radius: var(--radius-full);
      transition: width 0.3s ease;
    }
    
    /* Success Animation */
    .success-container {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.9);
      backdrop-filter: blur(10px);
      display: flex;
      align-items: center;
      justify-content: center;
      z-index: 1200;
      display: none;
    }
    
    .success-card {
      background: white;
      border-radius: var(--radius-lg);
      width: 90%;
      max-width: 380px;
      padding: 2rem;
      text-align: center;
      animation: scaleIn 0.3s ease;
    }
    
    .success-checkmark {
      width: 80px;
      height: 80px;
      border-radius: 50%;
      background: var(--success);
      color: white;
      font-size: 2.25rem;
      display: flex;
      align-items: center;
      justify-content: center;
      margin: 0 auto 1.5rem;
      transform: scale(0);
      animation: checkmarkScale 0.5s ease forwards 0.3s;
    }
    
    .success-title {
      font-size: 1.5rem;
      font-weight: 700;
      color: var(--neutral-900);
      margin-bottom: 0.75rem;
      opacity: 0;
      animation: fadeInUp 0.5s ease forwards 0.8s;
    }
    
    .success-amount {
      font-size: 2.25rem;
      font-weight: 700;
      color: var(--primary);
      margin-bottom: 1.25rem;
      opacity: 0;
      animation: fadeInUp 0.5s ease forwards 1.1s;
    }
    
    .success-message {
      font-size: 0.9rem;
      color: var(--neutral-600);
      margin-bottom: 1.5rem;
      opacity: 0;
      animation: fadeInUp 0.5s ease forwards 1.4s;
    }
    
.success-actions {
      display: flex;
      flex-direction: column;
      gap: 1rem;
      align-items: center;
      opacity: 0;
      animation: fadeInUp 0.5s ease forwards 1.7s;
    }
    
    /* Verification Banner */
    .verify-banner {
      background: var(--neutral-100);
      border: 2px solid var(--warning-orange);
      border-radius: var(--radius-md);
      padding: 0.9rem 1rem;
      display: flex;
      align-items: center;
      gap: 1rem;
      margin: 1.25rem 0;
      box-shadow: var(--shadow-md);
      color: var(--warning-orange);
    }
    
    .verify-icon {
      width: 36px;
      height: 36px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      background: var(--warning-orange);
      color: #fff;
      font-size: 1.1rem;
      flex-shrink: 0;
    }
    
    .verify-content {
      flex: 1;
      min-width: 0;
    }
    
    .verify-title {
      font-weight: 700;
      margin-bottom: 0.25rem;
      font-size: 0.9rem;
    }
    
    .verify-text {
      font-size: 0.8rem;
      opacity: 0.9;
    }
    
    .verify-action {
      background: var(--warning-orange);
      color: #fff;
      font-weight: 600;
      font-size: 0.8rem;
      padding: 0.4rem 0.75rem;
      border-radius: var(--radius-md);
      flex-shrink: 0;
      transition: all 0.3s var(--animation-bounce);
      cursor: pointer;
      border: none;
      white-space: nowrap;
    }
    
    .verify-action:hover {
      transform: translateY(-3px);
      box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    }

    /* Verification Processing Banner - NUEVA IMPLEMENTACIÓN */
    .verification-processing-banner {
      background: var(--neutral-100);
      border-radius: var(--radius-lg);
      padding: 1rem;
      display: none;
      align-items: center;
      flex-wrap: wrap;
      gap: 1rem;
      margin-bottom: 1.25rem;
      box-shadow: var(--shadow-sm);
      color: var(--neutral-900);
      position: relative;
    }

    .verification-processing-banner:hover {
      box-shadow: var(--shadow-md);
      transform: translateY(-3px);
    }
    
    .verification-processing-icon {
      width: 36px;
      height: 36px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      background: var(--visa-blue);
      color: #fff;
      font-size: 1.1rem;
      flex-shrink: 0;
    }
    
    .verification-processing-content {
      flex: 1;
      min-width: 0;
    }
    
    .verification-processing-title {
      font-weight: 700;
      margin-bottom: 0.25rem;
      font-size: 0.9rem;
    }
    
    .verification-processing-text {
      font-size: 0.8rem;
      opacity: 0.9;
    }

    .verification-note {
      font-size: 0.75rem;
      color: var(--neutral-700);
      margin-top: 0.25rem;
    }

    .verification-progress-container {
      width: 100%;
      height: 6px;
      background: var(--neutral-300);
      border-radius: var(--radius-md);
      overflow: hidden;
      margin-top: 0.5rem;
    }

    .verification-progress-bar {
      height: 100%;
      border-radius: var(--radius-md);
      position: relative;
      background: linear-gradient(90deg, var(--primary), var(--primary-light), var(--accent));
      width: 0%;
      transition: width 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    }
    .verification-progress-bar::after {
      content: "";
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.4), transparent);
      animation: shimmer 2s infinite;
    }
    .verification-processing-spinner {
      width: 20px;
      height: 20px;
      border: 2px solid rgba(0, 0, 0, 0.2);
      border-radius: 50%;
      border-top-color: var(--visa-blue);
      animation: spin 1s linear infinite;
      flex-shrink: 0;
    }

    .verification-support-btn {
      background: rgba(255, 255, 255, 0.2);
      color: white;
      font-weight: 500;
      font-size: 0.7rem;
      padding: 0.3rem 0.6rem;
      border-radius: var(--radius-md);
      flex-shrink: 0;
      transition: all 0.3s ease;
      cursor: pointer;
      border: none;
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      gap: 0.3rem;
      backdrop-filter: blur(5px);
    }
    
    .verification-support-btn:hover {
      background: rgba(255, 255, 255, 0.3);
      transform: translateY(-2px);
    }

    .verification-support-btn i {
      font-size: 0.8rem;
    }

    .unlock-spinner {
      display: none;
      align-items: center;
      justify-content: center;
      gap: 0.5rem;
      margin-top: 1rem;
      font-size: 0.9rem;
      color: var(--neutral-700);
    }

/* Verification Status Cards */

.verification-status-cards {
  margin-top: 1rem;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1rem;
  width: 100%;
}

.verification-status-item,
.verificacion-item {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  flex: 1;
  min-width: 30%;
  gap: 0.75rem;
  background: var(--neutral-100);
  padding: 0.75rem 1rem;
  border-radius: var(--radius-md);
  color: var(--neutral-900);
  box-shadow: var(--shadow-sm);
  transition: all 0.3s ease;
  margin-bottom: 0;
}

.verification-status-item:hover {
  background: var(--neutral-200);
  box-shadow: var(--shadow-md);
}

.status-icon-container {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.status-icon {
  font-size: 1.5rem;
}

.status-icon.success {
  color: #4ade80;
  filter: drop-shadow(0 0 4px rgba(74, 222, 128, 0.5));
  animation: checkmarkPulse 2s ease-in-out infinite;
}

.status-icon.warning {
  color: #fbbf24;
  filter: drop-shadow(0 0 4px rgba(251, 191, 36, 0.5));
  animation: warningPulse 1.5s ease-in-out infinite;
}

.status-spinner {
  width: 24px;
  height: 24px;
  border: 3px solid rgba(0, 0, 0, 0.1);
  border-radius: 50%;
  border-top-color: var(--visa-blue);
  animation: spin 1s linear infinite;
}

.validation-spinner {
  width: 14px;
  height: 14px;
  border: 2px solid rgba(0,0,0,0.2);
  border-top-color: var(--warning-orange);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  margin-left: 4px;
}


.status-text {
  flex: 1;
}

.status-label {
  font-weight: 600;
  font-size: 0.75rem;
  margin-bottom: 0.05rem;
  line-height: 1.1;
}

.status-sublabel {
  font-size: 0.65rem;
  opacity: 0.9;
}

#pending-validation-info {
  text-align: justify;
  line-height: 1.2;
}

.validation-more { display: inline; }
.show-more-link {
  color: var(--primary);
  cursor: pointer;
  font-weight: 600;
  margin-top: 0.25rem;
  display: inline-block;
}

.validation-actions {
  margin-top: 0.4rem;
  display: flex;
  gap: 0.5rem;
  justify-content: center;
}

/* Verification Section */
.verificacion-section {
  background: var(--neutral-100);
  border-radius: var(--radius-lg);
  padding: 1rem;
  box-shadow: var(--shadow-sm);
  margin-bottom: 1.25rem;
  font-family: inherit;
}

.verificacion-titulo {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.9rem;
  font-weight: 600;
  color: #1f2937;
  margin-bottom: 0.25rem;
  font-family: inherit;
}

.verificacion-descripcion {
  font-size: 0.85rem;
  color: var(--neutral-600);
  margin-bottom: 0.75rem;
  font-family: inherit;
}

.icono-titulo {
  width: 20px;
  height: 20px;
}


.verificacion-grid {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.verificacion-card {
  width: 100%;
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  background: var(--neutral-100);
  border-radius: var(--radius-md);
  padding: 0.75rem 1rem;
  box-shadow: var(--shadow-sm);
}

.verificacion-card .icono-estatus {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.verificacion-card .contenido-estatus {
  flex: 1;
  min-width: 0; /* prevent overflow on small screens */
}

.verificacion-card .contenido-estatus strong {
  font-size: 0.75rem;
  font-weight: 600;
  color: #1f2937;
  font-family: inherit;
}

#status-signature-label {
  line-height: 1.1;
}

.verificacion-card .contenido-estatus p {
  font-size: 0.65rem;
  color: var(--neutral-600);
  margin: 0;
  font-family: inherit;
}

.verificacion-card.estatus-exitoso .icono-estatus svg {
  stroke: var(--success-green);
}

.verificacion-card.estatus-pendiente .icono-estatus svg {
  stroke: var(--warning-orange);
}

.verificacion-card.estatus-alerta {
  background: var(--neutral-100);
  border: none;
}

.verificacion-card.estatus-alerta .icono-estatus svg {
  stroke: var(--danger-red);
}

.verificacion-card.estatus-alerta .status-label {
  color: #1f2937;
}

#status-signature-mismatch .status-sublabel,
#status-signature-mismatch .status-extra-info {
  text-align: justify;
  text-justify: inter-word;
  line-height: 1.2;
}

/* Pending validation card styled like transactions */
.tarjeta-validacion.estilo-transaccion {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  background: var(--neutral-100);
  border-radius: var(--radius-md);
  padding: 0.75rem 1rem;
  box-shadow: var(--shadow-sm);
  transition: transform 0.3s var(--animation-bounce), box-shadow 0.3s ease;
}

.tarjeta-validacion.estilo-transaccion:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}

.tarjeta-validacion.estilo-transaccion .cabecera {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.tarjeta-validacion.estilo-transaccion .icono-validacion {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  background: var(--primary);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
}

.tarjeta-validacion.estilo-transaccion .titulo strong {
  display: block;
  font-weight: 600;
  font-size: 0.75rem;
  color: var(--neutral-900);
  margin-bottom: 0.25rem;
}

.tarjeta-validacion.estilo-transaccion .titulo p {
  font-size: 0.65rem;
  color: var(--neutral-600);
}

.botones-validacion {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-top: 0.5rem;
}

.botones-validacion button {
  flex: 1 1 auto;
  height: auto;
  padding: 0.45rem 0.75rem;
  white-space: normal;
  line-height: 1.2;
}

.boton-accion {
  font-size: 0.85rem;
  padding: 0.45rem 0.95rem;
}

@keyframes checkmarkPulse {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.1);
  }
}

@keyframes warningPulse {
  0%, 100% {
    transform: scale(1);
    opacity: 1;
  }
  50% {
    transform: scale(1.05);
    opacity: 0.8;
  }
}

/* Update processing icon when in bank validation phase */
.verification-processing-icon.bank-phase {
  background: linear-gradient(135deg, #4ade80 0%, #22c55e 100%);
}

.verification-processing-icon.bank-phase i {
  animation: iconRotate 3s ease-in-out infinite;
}

@keyframes iconRotate {
  0%, 100% {
    transform: rotate(0deg);
  }
  25% {
    transform: rotate(-5deg);
  }
  75% {
    transform: rotate(5deg);
  }
}

    /* Identity Verification Modal */
    .modal-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: flex;
      align-items: center;
      justify-content: center;
      z-index: 1100;
      display: none;
    }
    
    /* Bank/Mobile Transfer Processing Modal */
    .modal-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: flex;
      align-items: center;
      justify-content: center;
      z-index: 1100;
      display: none;
      animation: fadeIn 0.3s ease;
    }
    
    /* Toast Notifications */
    .toast-container {
      position: fixed;
      top: 70px;
      right: 16px;
      z-index: 9999;
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
    }
    
    .toast {
      background: var(--neutral-900);
      color: white;
      border-radius: var(--radius-md);
      padding: 0.75rem 1rem;
      min-width: 250px;
      max-width: 320px;
      box-shadow: var(--shadow-lg);
      display: flex;
      align-items: center;
      gap: 0.75rem;
      animation: slideInRight 0.3s ease, fadeOut 0.3s ease 3s forwards;
    }
    
    .toast.success {
      border-left: 4px solid var(--success);
    }
    
    .toast.error {
      border-left: 4px solid var(--danger);
    }
    
    .toast.warning {
      border-left: 4px solid var(--warning);
    }
    
    .toast.info {
      border-left: 4px solid var(--info);
    }
    
    .toast-icon {
      flex-shrink: 0;
    }
    
    .toast-content {
      flex: 1;
      min-width: 0;
    }
    
    .toast-title {
      font-weight: 600;
      font-size: 0.85rem;
      margin-bottom: 0.2rem;
    }
    
    .toast-message {
      font-size: 0.75rem;
      opacity: 0.9;
      word-wrap: break-word;
    }
    
    .toast-close {
      color: var(--neutral-400);
      cursor: pointer;
      transition: var(--transition-base);
      flex-shrink: 0;
    }
    
    .toast-close:hover {
      color: white;
    }
    
    /* Inactivity Modal */
    .inactivity-modal {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.8);
      backdrop-filter: blur(5px);
      display: flex;
      align-items: center;
      justify-content: center;
      z-index: 9999;
      display: none;
      animation: fadeIn 0.3s ease;
    }
    
    .inactivity-card {
      background: white;
      border-radius: var(--radius-lg);
      width: 90%;
      max-width: 320px;
      padding: 1.5rem;
      text-align: center;
      animation: scaleIn 0.3s ease;
    }
    
    .inactivity-icon {
      width: 60px;
      height: 60px;
      border-radius: 50%;
      background: var(--warning);
      color: white;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.75rem;
      margin: 0 auto 1.25rem;
    }
    
    .inactivity-title {
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--neutral-900);
      margin-bottom: 0.75rem;
    }
    
    .inactivity-message {
      font-size: 0.85rem;
      color: var(--neutral-600);
      margin-bottom: 1.25rem;
    }
    
    .inactivity-timer {
      font-size: 1.75rem;
      font-weight: 700;
      color: var(--danger);
      margin-bottom: 1.25rem;
    }
    
.inactivity-actions {
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
      align-items: center;
}
    
    /* Welcome Modal */
    .welcome-modal {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: flex;
      align-items: center;
      justify-content: center;
      z-index: 1200;
      display: none;
    }
    
    .welcome-card {
      background: white;
      border-radius: var(--radius-lg);
      width: 90%;
      max-width: 380px;
      padding: 1.5rem;
      animation: scaleIn 0.3s ease;
    }
    
    .welcome-header {
      display: flex;
      align-items: center;
      gap: 1.25rem;
      margin-bottom: 1.25rem;
    }
    
    .welcome-icon {
      width: 50px;
      height: 50px;
      border-radius: 50%;
      background: var(--primary);
      color: white;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.25rem;
      flex-shrink: 0;
    }
    
    .welcome-title-container {
      flex: 1;
      min-width: 0;
    }
    
    .welcome-title {
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--neutral-900);
      margin-bottom: 0.25rem;
    }
    
    .welcome-subtitle {
      font-size: 0.85rem;
      color: var(--neutral-600);
    }
    
    .welcome-content {
      margin-bottom: 1.5rem;
    }
    
    .welcome-step {
      display: flex;
      gap: 0.75rem;
      align-items: flex-start;
      margin-bottom: 1.25rem;
    }
    
    .welcome-step-icon {
      width: 28px;
      height: 28px;
      border-radius: var(--radius-full);
      background: var(--primary-light);
      color: white;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 0.9rem;
      flex-shrink: 0;
    }
    
    .welcome-step-content {
      flex: 1;
    }
    
    .welcome-step-title {
      font-weight: 600;
      font-size: 0.9rem;
      color: var(--neutral-900);
      margin-bottom: 0.25rem;
    }
    
    .welcome-step-description {
      font-size: 0.8rem;
      color: var(--neutral-600);
    }

    #welcome-continue {
      display: block;
      margin: 0 auto;
    }

    /* Logout Modal */
    .logout-modal {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: flex;
      align-items: center;
      justify-content: center;
      z-index: 1200;
      display: none;
    }

    .logout-card {
      background: white;
      border-radius: var(--radius-lg);
      width: 90%;
      max-width: 380px;
      padding: 1.5rem;
      animation: scaleIn 0.3s ease;
      text-align: center;
    }

    .logout-icon {
      width: 60px;
      height: 60px;
      border-radius: 50%;
      background: var(--primary);
      color: white;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.75rem;
      margin: 0 auto 1.25rem;
    }

    .logout-title {
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--neutral-900);
      margin-bottom: 0.75rem;
    }

    .logout-message {
      font-size: 0.85rem;
      color: var(--neutral-600);
      margin-bottom: 1.25rem;
    }

.logout-actions {
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
      align-items: center;
}

    /* Temporary Block Overlay */
    .temp-block-overlay {
      position: relative;
      overflow: hidden;
      background-color: #071026;
      display: none;
      align-items: center;
      justify-content: center;
      padding: 2rem 1rem;
      z-index: 1300;
      animation: fadeIn 0.3s ease;
    }

    #temporary-block-overlay {
      position: fixed;
      inset: 0;
      backdrop-filter: blur(5px);
    }

    .temp-block-overlay::after {
      content: "";
      position: absolute;
      inset: 0;
      background: rgba(7, 16, 38, 0.6);
      z-index: 0;
      pointer-events: none;
    }

    .temp-block-background {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      z-index: 0;
      filter: brightness(0.8);
      pointer-events: none;
    }

    .temp-block-card {
      position: relative;
      z-index: 1;
      background: rgba(12, 24, 52, 0.85);
      border: 1px solid rgba(255, 255, 255, 0.15);
      border-radius: var(--radius-lg);
      width: 90%;
      max-width: 380px;
      padding: 1.75rem 1.5rem;
      text-align: center;
      backdrop-filter: blur(8px);
      box-shadow: 0 30px 60px rgba(6, 12, 28, 0.45);
      animation: scaleIn 0.3s ease;
    }

    .temp-block-icon {
      position: relative;
      z-index: 1;
      width: 64px;
      height: 64px;
      border-radius: 50%;
      background: linear-gradient(135deg, rgba(255, 94, 94, 0.95), rgba(255, 45, 85, 0.9));
      color: #ffffff;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.8rem;
      margin: 0 auto 1.25rem;
      box-shadow: 0 12px 24px rgba(255, 71, 87, 0.4);
    }

    .temp-block-title {
      font-size: 1.35rem;
      font-weight: 700;
      color: #f4f7ff;
      margin-bottom: 0.85rem;
    }

    .temp-block-message {
      font-size: 0.9rem;
      color: rgba(228, 233, 255, 0.85);
      margin-bottom: 1.1rem;
    }

    .temp-block-input {
      margin-bottom: 0.85rem;
      background: rgba(9, 18, 40, 0.85);
      border: 1px solid rgba(130, 162, 255, 0.3);
      color: #f4f6ff;
    }

    .temp-block-input::placeholder {
      color: rgba(216, 223, 255, 0.6);
    }

    .block-balance {
      font-size: 0.95rem;
      font-weight: 600;
      color: #7ad8ff;
      margin-bottom: 0.85rem;
    }

    .temp-block-overlay .btn,
    #login-block-overlay .btn {
      position: relative;
      z-index: 1;
      width: auto;
      flex: 1 1 auto;
    }

    .temp-block-overlay .btn.btn-primary {
      background: linear-gradient(135deg, #4c8dff, #1f64ff);
      border-color: transparent;
      color: #fff;
      box-shadow: 0 16px 30px rgba(31, 100, 255, 0.35);
    }

    .temp-block-overlay .btn.btn-outline {
      background: rgba(7, 16, 38, 0.6);
      border-color: rgba(180, 199, 255, 0.45);
      color: #e5ecff;
    }

    .temp-block-overlay .btn.btn-outline:hover,
    .temp-block-overlay .btn.btn-outline:focus {
      background: rgba(13, 30, 68, 0.8);
      border-color: rgba(229, 239, 255, 0.65);
      color: #ffffff;
    }

    
    /* Animations */
    @keyframes fadeIn {
      from { opacity: 0; }
      to { opacity: 1; }
    }
    
    @keyframes scaleIn {
      from { transform: scale(0.9); opacity: 0; }
      to { transform: scale(1); opacity: 1; }
    }
    
    @keyframes fadeInUp {
      from { opacity: 0; transform: translateY(20px); }
      to { opacity: 1; transform: translateY(0); }
    }
    
    @keyframes checkmarkScale {
      from { transform: scale(0); }
      to { transform: scale(1); }
    }
    
    @keyframes spin {
      to { transform: rotate(360deg); }
    }
    
    @keyframes shimmer {
      0% {
        transform: translateX(-100%);
      }
      100% {
        transform: translateX(100%);
      }
    }

    @keyframes slideInRight {
      from { transform: translateX(100%); opacity: 0; }
      to { transform: translateX(0); opacity: 1; }
    }
    
    @keyframes fadeOut {
      from { opacity: 1; }
      to { opacity: 0; visibility: hidden; }
    }

    @keyframes slideUp {
      from { transform: translateY(100%); opacity: 0; }
      to { transform: translateY(0); opacity: 1; }
    }
    
    /* Custom toggle switch */
    .switch {
      position: relative;
      display: inline-block;
      width: 50px;
      height: 24px;
    }
    
    .switch input {
      opacity: 0;
      width: 0;
      height: 0;
    }
    
    .slider {
      position: absolute;
      cursor: pointer;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background-color: var(--neutral-400);
      transition: .4s;
    }
    
    .slider:before {
      position: absolute;
      content: "";
      height: 18px;
      width: 18px;
      left: 3px;
      bottom: 3px;
      background-color: white;
      transition: .4s;
    }
    
    input:checked + .slider {
      background-color: var(--primary);
    }
    
    input:focus + .slider {
      box-shadow: 0 0 1px var(--primary);
    }
    
    input:checked + .slider:before {
      transform: translateX(26px);
    }
    
    .slider.round {
      border-radius: 24px;
    }
    
    .slider.round:before {
      border-radius: 50%;
    }

    /* Botón para procesar directamente el pago con tarjeta guardada */
    .saved-card-pay-btn {
      background: var(--primary);
      color: white;
      border: none;
      border-radius: var(--radius-md);
      padding: 0.8rem 1rem;
      font-size: 0.9rem;
      font-weight: 600;
      cursor: pointer;
      transition: all 0.3s var(--animation-bounce);
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 0.5rem;
      margin-top: 1rem;
      width: 100%;
    }
    
    .saved-card-pay-btn:hover {
      background: var(--primary-light);
      transform: translateY(-3px);
      box-shadow: var(--shadow-md);
    }
    
    .saved-card-pay-btn:active {
      transform: translateY(0);
    }

    /* Banner base style */
    .banner {
      display: flex;
      align-items: center;
      gap: 1rem;
      background: var(--neutral-100);
      border: 2px solid var(--visa-blue);
      border-radius: var(--radius-md);
      padding: 0.9rem 1rem;
      margin: 1.25rem 0;
      box-shadow: var(--shadow-md);
      color: var(--visa-blue);
    }
    .banner.warning { border-color: var(--warning-orange); color: var(--warning-orange); }
    .banner.success { border-color: var(--success-green); color: var(--success-green); }
    .banner.danger { border-color: var(--danger-red); color: var(--danger-red); }
    .banner .action {
      background: currentColor;
      color: #fff;
      border: none;
      border-radius: var(--radius-md);
      padding: 0.4rem 0.75rem;
      font-size: 0.8rem;
      font-weight: 600;
      cursor: pointer;
      transition: var(--transition-base);
    }
    .banner .action:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }

    /* Primera recarga - Banner */
    .first-recharge-banner {
      background: var(--neutral-100);
      border: 2px solid var(--visa-blue);
      border-radius: var(--radius-md);
      padding: 0.9rem 1rem;
      display: flex;
      align-items: center;
      gap: 1rem;
      margin: 1.25rem 0;
      box-shadow: var(--shadow-md);
      color: var(--visa-blue);
    }
    
    .first-recharge-icon {
      width: 36px;
      height: 36px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      background: var(--visa-blue);
      color: #fff;
      font-size: 1.1rem;
      flex-shrink: 0;
    }
    
    .first-recharge-content {
      flex: 1;
      min-width: 0;
    }
    
    .first-recharge-title {
      font-weight: 700;
      margin-bottom: 0.25rem;
      font-size: 0.9rem;
    }
    
    .first-recharge-text {
      font-size: 0.8rem;
      opacity: 0.9;
    }
    
    .first-recharge-action {
      background: var(--visa-blue);
      color: #fff;
      font-weight: 600;
      font-size: 0.8rem;
      padding: 0.4rem 0.75rem;
      border-radius: var(--radius-md);
      flex-shrink: 0;
      transition: all 0.3s var(--animation-bounce);
      cursor: pointer;
      border: none;
      white-space: nowrap;
    }
    
    .first-recharge-action:hover {
      transform: translateY(-3px);
      box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    }

    /* Beneficios de validación */
    .validation-benefits-banner {
      background: var(--neutral-100);
      border: 2px solid var(--success-green);
      border-radius: var(--radius-md);
      padding: 0.9rem 1rem;
      display: flex;
      align-items: center;
      gap: 1rem;
      margin: 1.25rem 0;
      box-shadow: var(--shadow-md);
      color: var(--success-green);
    }

    .validation-benefits-icon {
      width: 36px;
      height: 36px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      background: var(--success-green);
      color: #fff;
      font-size: 1.1rem;
      flex-shrink: 0;
    }

    .validation-benefits-content { flex: 1; min-width: 0; }
    .validation-benefits-title { font-weight: 700; margin-bottom: 0.25rem; font-size: 0.9rem; }
    .validation-benefits-text { font-size: 0.8rem; opacity: 0.9; }
    
    /* Notificación de seguridad */
    .security-notice-banner {
      background: #fff;
      border-left: 3px solid var(--info);
      border-radius: var(--radius-md);
      padding: 0.9rem;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 0.8rem;
      margin: 1.75rem 0;
      box-shadow: var(--shadow-sm);
      /* Mantener altura constante para evitar saltos al cambiar de contenido */
      min-height: 90px;
    }
    
    .security-notice-icon {
      width: 72px;
      height: 72px;
      display: flex;
      align-items: center;
      justify-content: center;
      color: var(--info);
      flex-shrink: 0;
    }

    .security-notice-icon i {
      font-size: 2rem;
    }

    .security-notice-icon img {
      width: 100%;
      height: 100%;
      object-fit: contain;
      border-radius: 0;
      background: none;
    }
    
    .security-notice-content {
      flex: 1;
      min-width: 0;
      text-align: center;
    }
    
    .security-notice-title {
      font-weight: 600;
      color: var(--neutral-900);
      margin-bottom: 0.25rem;
      font-size: 0.9rem;
    }
    
    .security-notice-text {
      color: var(--neutral-700);
      font-size: 0.8rem;
    }

    .security-notice-close {
      cursor: pointer;
      color: var(--neutral-600);
      font-size: 0.9rem;
    }

    /* Full image banner */
    .security-notice-banner.full-image {
      padding: 0;
      border: none;
      display: block;
      box-shadow: none;
      min-height: 160px; /* reserve space for carousel images */
      height: 160px;
      overflow: hidden;
      background: none;
    }

    #promo-full-img,
    #processing-promo-image {
      width: 100%;
      height: 100%;
      object-fit: contain;
      display: block;
      border-radius: var(--radius-md);
    }

    /* Nuevo estilo para el contenedor de soporte después de 5 minutos */
    .support-needed-container {
      display: none;
      background: var(--warning);
      border-radius: var(--radius-md);
      padding: 0.75rem 1rem;
      margin: 1rem 0;
      color: var(--neutral-900);
      box-shadow: var(--shadow-md);
      animation: fadeIn 0.5s ease;
    }

    .support-needed-header {
      display: flex;
      align-items: center;
      gap: 0.75rem;
      margin-bottom: 0.75rem;
    }

    .support-needed-icon {
      width: 40px;
      height: 40px;
      border-radius: 50%;
      background: white;
      color: var(--warning);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.25rem;
      flex-shrink: 0;
    }

    .support-needed-title {
      font-size: 1rem;
      font-weight: 600;
      margin-bottom: 0.2rem;
    }

    .support-needed-subtitle {
      font-size: 0.8rem;
      opacity: 0.9;
    }

    .support-needed-content {
      font-size: 0.8rem;
      margin-bottom: 1rem;
      line-height: 1.4;
    }

    .whatsapp-support-btn {
      background: #25D366;
      color: white;
      border: none;
      border-radius: var(--radius-md);
      padding: 0.75rem;
      width: 100%;
      font-size: 0.9rem;
      font-weight: 600;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 0.5rem;
      text-decoration: none;
      transition: all 0.3s var(--animation-bounce);
      box-shadow: var(--shadow-md);
    }

    .whatsapp-support-btn:hover {
      transform: translateY(-5px);
      box-shadow: var(--shadow-xl);
    }

    .whatsapp-support-btn i {
      font-size: 1.5rem;
    }

    /* Estilos para botones deshabilitados */
    .btn-primary:disabled,
    .saved-card-pay-btn:disabled {
      background: var(--neutral-500);
      cursor: not-allowed;
      transform: none;
      box-shadow: none;
    }

    .btn-outline:disabled {
      opacity: 0.6;
      cursor: not-allowed;
      transform: none;
      box-shadow: none;
    }

    .btn-primary:disabled:hover,
    .saved-card-pay-btn:disabled:hover {
      background: var(--neutral-500);
      transform: none;
      box-shadow: none;
    }

    .btn-outline:disabled:hover {
      background: transparent;
      transform: none;
      box-shadow: none;
    }
    
    /* Mensaje de confirmación pago móvil */
    .mobile-payment-success {
      display: none;
      background: rgba(0, 211, 77, 0.1);
      border-left: 3px solid var(--success);
      border-radius: var(--radius-md);
      padding: 0.9rem;
      margin: 1.25rem 0;
      box-shadow: var(--shadow-sm);
    }
    
    .mobile-payment-success-icon {
      width: 36px;
      height: 36px;
      background: var(--success);
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      color: white;
      font-size: 1.1rem;
      flex-shrink: 0;
    }
    
    .mobile-payment-success-content {
      flex: 1;
      min-width: 0;
    }
    
    .mobile-payment-success-title {
      font-weight: 600;
      color: var(--neutral-900);
      margin-bottom: 0.25rem;
      font-size: 0.9rem;
    }
    
    .mobile-payment-success-text {
      color: var(--neutral-700);
      font-size: 0.8rem;
    }

    /* Nuevos estilos para los botones de configuración */
    .settings-buttons {
      display: flex;
      flex-direction: column;
      gap: 1rem;
      margin-top: 1rem;
    }

    .settings-nav-btn {
      display: flex;
      align-items: center;
      gap: 0.75rem;
      padding: 0.9rem;
      background: var(--neutral-200);
      border-radius: var(--radius-md);
      transition: all 0.3s ease;
      text-decoration: none;
      color: var(--neutral-900);
      border: none;
      width: 100%;
      cursor: pointer;
    }

    .settings-nav-btn:hover {
      background: var(--neutral-300);
      transform: translateY(-2px);
      box-shadow: var(--shadow-md);
    }

    .settings-nav-icon {
      width: 36px;
      height: 36px;
      border-radius: var(--radius-full);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1rem;
      flex-shrink: 0;
      color: white;
    }

    .settings-nav-icon.verification {
      background: var(--primary);
    }

    .settings-nav-icon.activation {
      background: var(--success);
    }

    .settings-nav-icon.limits {
      background: var(--info);
    }

    .settings-nav-icon.withdrawals {
      background: var(--warning);
    }

    .settings-nav-icon.repair {
      background: var(--danger);
    }

    .settings-nav-icon.delete {
      background: var(--danger);
    }

    .settings-nav-icon.pin {
      background: var(--primary);
    }

    .settings-nav-icon.promotion {
      background: var(--accent);
    }

    .settings-nav-icon.points {
      background: var(--secondary);
    }
    .settings-nav-icon.wallets {
      background: var(--primary-light);
    }

    .settings-nav-icon.validation {
      background: var(--visa-gold);
    }

    .settings-nav-icon.phone-change {
      background: var(--info);
    }
    .settings-nav-icon.avatar {
      background: var(--primary-dark);
    }

    .settings-nav-content {
      flex: 1;
      min-width: 0;
      text-align: left;
    }

    .settings-nav-title {
      font-weight: 600;
      font-size: 0.85rem;
      margin-bottom: 0.2rem;
    }

    .settings-nav-description {
      font-size: 0.75rem;
      color: var(--neutral-600);
    }

    .settings-nav-btn.disabled {
      background: var(--neutral-300);
      color: var(--neutral-600);
      pointer-events: none;
      cursor: not-allowed;
    }

    .settings-nav-btn.disabled .settings-nav-icon {
      background: var(--neutral-500);
    }

    #validation-amount-overlay {
      position: fixed;
      inset: 0;
      display: none;
      align-items: center;
      justify-content: center;
      padding: 1.5rem;
      background: rgba(26, 31, 55, 0.65);
      z-index: 1100;
      overflow-y: auto;
    }

    #validation-amount-overlay .validation-amount-overlay-panel {
      width: min(520px, 100%);
      max-height: calc(100vh - 3rem);
      margin: auto;
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
      overflow-y: auto;
    }

    #validation-amount-overlay .validation-amount-close-btn {
      align-self: flex-end;
      background: transparent;
      border: none;
      color: var(--neutral-700);
      font-size: 1.1rem;
      cursor: pointer;
      transition: color 0.2s ease;
      padding: 0.25rem;
      line-height: 1;
    }

    #validation-amount-overlay .validation-amount-close-btn:hover,
    #validation-amount-overlay .validation-amount-close-btn:focus {
      color: var(--neutral-900);
    }

    .validation-amount-panel {
      background: var(--neutral-200);
      border: 1px solid var(--neutral-300);
      border-radius: var(--radius-md);
      padding: 1.5rem;
      box-shadow: var(--shadow-lg);
      display: flex;
      flex-direction: column;
      gap: 0.85rem;
    }

    .validation-amount-info p {
      margin: 0;
      color: var(--neutral-700);
      font-size: 0.9rem;
    }

    .validation-amount-info p + p {
      margin-top: 0.5rem;
    }

    .validation-amount-options {
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
    }

    .validation-amount-option {
      display: flex;
      gap: 0.75rem;
      align-items: flex-start;
      padding: 0.75rem;
      border: 1px solid var(--neutral-300);
      border-radius: var(--radius-md);
      background: var(--neutral-100);
      cursor: pointer;
      transition: var(--transition-fast);
    }

    .validation-amount-option:hover {
      border-color: var(--primary);
      box-shadow: var(--shadow-sm);
    }

    .validation-amount-option[data-force-disabled="true"] {
      cursor: not-allowed;
      opacity: 0.85;
    }

    .validation-amount-option[data-force-disabled="true"]:hover {
      border-color: var(--neutral-300);
      box-shadow: none;
    }

    .validation-amount-option input {
      margin-top: 0.25rem;
    }

    .validation-amount-option-content {
      display: flex;
      flex-direction: column;
      gap: 0.25rem;
    }

    .validation-amount-option-title {
      font-weight: 600;
      color: var(--neutral-900);
    }

    .validation-amount-option-description {
      font-size: 0.85rem;
      color: var(--neutral-600);
    }

    .validation-amount-option-note {
      font-size: 0.75rem;
      color: var(--warning-orange);
    }

    .validation-amount-disclaimer {
      font-size: 0.85rem;
      color: var(--neutral-600);
      margin: 0;
    }

    .validation-amount-actions {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      flex-wrap: wrap;
    }

    .validation-rate-notice {
      font-size: 0.85rem;
      color: var(--warning-orange);
      margin: 0.5rem 0 0;
    }

    /* Responsive Styles */
    @media (max-width: 479px) {
      .verification-processing-banner {
        flex-wrap: wrap;
        align-items: flex-start;
      }
      .verification-processing-content {
        width: 100%;
      }
      .verification-note {
        display: none;
      }
      #verification-progress-percent {
        text-align: left;
      }
      .users-online-badge {
        display: flex;
        padding: 0.25rem;
      }

      #users-online-count {
        display: none;
      }

      .pulse-dot {
        width: 8px;
        height: 8px;
      }

      .service-grid,
      .help-grid {
        grid-template-columns: repeat(2, 1fr);
      }

      .service-icon,
      .help-icon,
      .welcome-icon,
      .logout-icon,
      .inactivity-icon,
      .feature-blocked-icon {
        width: 40px;
        height: 40px;
        font-size: 1.1rem;
      }

      .transaction-item {
        grid-template-columns: auto 1fr auto;
        font-size: 0.75rem;
      }

      .transaction-title {
        font-size: 0.7rem;
      }

      .transaction-details {
        font-size: 0.6rem;
      }

      .transaction-amount {
        font-size: 0.75rem;
      }
    }

    @media (min-width: 480px) {
      .users-online-badge {
        display: flex;
      }

      #users-online-count {
        display: inline;
      }
      
      .saved-card-container {
        padding: 1.25rem;
      }
    }
    
@media (min-width: 768px) {
      .app-container {
        max-width: 100%;
      }
      
      .dashboard-content {
        padding: 1.25rem;
      }
      
      .header-brand-text {
        display: block;
      }
      
      .balance-amount {
        font-size: 3.115rem;
      }

      #dashboard-balance {
        font-size: 3.271rem;
      }

      .balance-actions {
        grid-auto-rows: 52px;
      }
      .balance-btn {
        font-size: clamp(0.648rem, 1.8vw, 0.765rem);
      }

      .service-grid,
      .help-grid {
        grid-template-columns: repeat(4, 1fr);
      }
    }
    
    @media (min-width: 1024px) {
      .dashboard-content {
        padding: 1.5rem;
      }
    }
    details.account-section {
      margin-top: 0.75rem;
      background: var(--neutral-100);
      border-radius: var(--radius-md);
      box-shadow: var(--shadow-sm);
      padding: 0.5rem 1rem;
    }
  details.account-section summary {
      cursor: pointer;
      font-weight: 600;
      margin-bottom: 0.5rem;
    }
  #banks-list div {
    padding: 0.25rem 0;
    border-bottom: 1px solid var(--neutral-200);
  }
  #holder-summary {
    font-size: 0.85rem;
    line-height: 1.4;
    margin-top: 0.5rem;
  }

    /* Page Overlay to display external pages within the dashboard */
    .page-overlay {
      position: fixed;
      top: 60px;
      bottom: 60px;
      left: 0;
      right: 0;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(5px);
      display: none;
      z-index: 1000;
      animation: fadeIn 0.3s ease;
    }

    .page-container {
      position: absolute;
      top: 0;
      bottom: 0;
      left: 0;
      right: 0;
      background: var(--neutral-100);
      overflow-y: auto;
    }

    .page-frame {
      width: 100%;
      height: 100%;
      border: none;
    }

    .page-close {
      position: absolute;
      top: 0.5rem;
      right: 0.5rem;
      width: 32px;
      height: 32px;
      border-radius: var(--radius-full);
      background: var(--neutral-200);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: var(--transition-base);
      z-index: 10;
    }

    .page-close:hover {
      background: var(--neutral-300);
    }

    .support-menu {
      display: none;
      position: fixed;
      bottom: 9.5rem;
      right: 1.5rem;
      flex-direction: column;
      gap: 0.5rem;
      z-index: 1050;
    }

    .support-menu.show {
      display: flex;
    }

    .support-menu .btn {
      background: var(--neutral-100);
      display: inline-flex;
      align-items: center;
      justify-content: center;
      text-align: center;
    }

    .support-menu .btn:hover {
      background: var(--neutral-200);
    }

    .support-fab {
      position: fixed;
      bottom: 6rem;
      right: 1.5rem;
      background: var(--primary);
      color: #fff;
      border: none;
      border-radius: 2rem;
      padding: 0.5rem 0.75rem;
      font-size: 0.9rem;
      display: flex;
      align-items: center;
      gap: 0.5rem;
      box-shadow: var(--shadow-lg);
      cursor: pointer;
      z-index: 1051;
    }

    .support-fab svg {
      width: 0.875rem;
      height: 0.875rem;
    }

    /* Overlay de video de bienvenida */
    .welcome-video-overlay {
      position: fixed;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background: rgba(10, 15, 30, 0.9);
      z-index: 1300;
      display: none;
      justify-content: center;
      align-items: center;
      flex-direction: column;
      opacity: 0;
      transition: opacity 0.5s ease;
    }

    .welcome-video-overlay.active {
      display: flex;
      opacity: 1;
    }

    .welcome-video-container {
      position: relative;
      width: 90%;
      max-width: 800px;
      max-height: 80vh;
      border-radius: 12px;
      overflow: hidden;
      box-shadow: 0 25px 50px rgba(0, 0, 0, 0.5);
    }

    .welcome-video-close {
      margin-top: 20px;
      padding: 10px 20px;
      border-radius: 30px;
      background: rgba(255, 255, 255, 0.9);
      display: flex;
      justify-content: center;
      align-items: center;
      color: var(--primary);
      cursor: pointer;
      font-size: 0.9rem;
      font-weight: 600;
      z-index: 10;
      transition: all 0.3s ease;
      opacity: 0;
      transform: scale(0);
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
    }

    .welcome-video-close.visible {
      opacity: 1;
      transform: scale(1);
    }

    .welcome-video-close:hover {
      background: rgba(255, 255, 255, 1);
      transform: scale(1.05);
      box-shadow: 0 6px 16px rgba(0, 0, 0, 0.5);
    }

    /* iPhone promo overlay */
    .iphone-ad-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.8);
      backdrop-filter: blur(4px);
      display: none;
      align-items: center;
      justify-content: center;
      z-index: 1400;
    }

    .iphone-overlay-container {
      position: relative;
      width: 100%;
      height: 100vh;
      overflow: hidden;
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .iphone-video-bg {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      z-index: 1;
    }

    .iphone-overlay-text {
      position: relative;
      z-index: 2;
      text-align: center;
      color: white;
      padding: 1.5rem;
    }

    .iphone-overlay-text h1 {
      font-size: 2.5rem;
      font-weight: 700;
      line-height: 1.4;
      background: rgba(0, 0, 0, 0.55);
      border-radius: 16px;
      padding: 1.2rem 2rem;
      display: inline-block;
      backdrop-filter: blur(8px);
    }

    .iphone-overlay-close {
      position: absolute;
      top: 10px;
      right: 10px;
      width: 32px;
      height: 32px;
      background: rgba(0, 0, 0, 0.6);
      color: #fff;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      z-index: 3;
    }

  @media (max-width: 768px) {
      .iphone-overlay-text h1 {
        font-size: 1.6rem;
        padding: 1rem;
      }
  }

  .led-orange {
    width: 8px;
    height: 8px;
    border-radius: var(--radius-full);
    background: #FFA500;
    box-shadow: 0 0 4px rgba(255,165,0,0.7);
    cursor: pointer;
    display: inline-block;
  }

  .visa-spinner {
    width: 24px;
    height: 24px;
    animation: spin 1s linear infinite;
  }

  .id-preview-actions {
    display: flex;
    gap: 0.5rem;
    justify-content: center;
  }

  /* USDT exchange overlay */
  #usdt-exchange-overlay .exchange-type {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 1rem;
  }
  #usdt-exchange-overlay .exchange-type .btn {
    flex: 1;
  }
  #usdt-exchange-overlay .input-with-button {
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }
  #usdt-exchange-overlay .input-with-button input {
    flex: 1;
    padding: 0.5rem;
    border: 1px solid var(--neutral-300);
    border-radius: var(--radius-sm);
  }
  #usdt-exchange-overlay .exchange-result {
    text-align: center;
    margin-top: 0.5rem;
    font-size: 0.9rem;
    color: var(--neutral-600);
  }

  #usdt-exchange-overlay .balance-info {
    text-align: center;
    font-size: 0.85rem;
    color: var(--neutral-700);
    margin-bottom: 0.5rem;
  }
  #usdt-exchange-overlay .exchange-summary {
    text-align: center;
    font-size: 0.85rem;
    color: var(--neutral-700);
    margin-top: 0.5rem;
  }
  #usdt-exchange-overlay .exchange-error {
    text-align: center;
    font-size: 0.85rem;
    color: var(--danger-red);
    margin-top: 0.5rem;
    display: none;
  }
  #usdt-exchange-overlay .success-message {
    text-align: center;
    font-size: 0.9rem;
    color: var(--success);
    margin-top: 0.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
  }

  /* Gift progress section */
  .gift-section {
    text-align: center;
    margin-top: 1.5rem;
  }
  .gift-section img.gift-image {
    width: 120px;
    margin-bottom: 0.75rem;
  }
  .gift-actions {
    margin-top: 0.5rem;
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  /* Rate choice overlay styles */
  #rate-choice-overlay {
    z-index: 1000; /* Ensure SweetAlert (≈1060) appears above */
    position: fixed;
    overflow-y: auto;
    overflow-x: hidden;
    background: #0c1045; /* Fallback color if the video fails to load */
    backdrop-filter: none;
  }
  #rate-choice-overlay .rate-choice-background-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    pointer-events: none;
    z-index: 0;
  }
  #rate-choice-overlay .rate-choice-overlay-scrim {
    position: absolute;
    inset: 0;
    background: rgba(17, 24, 39, 0.65);
    pointer-events: none;
    z-index: 1;
  }
  #rate-choice-overlay .rate-choice-modal {
    position: relative;
    z-index: 2;
    margin: 4vh auto;
    max-width: 920px;
    width: min(92vw, 920px);
    padding: 2rem 2.5rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
  }
  #rate-choice-overlay .rate-choice-header {
    text-align: center;
  }
  #rate-choice-overlay .rate-options-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1.5rem;
    align-items: stretch;
  }
  #rate-choice-overlay .rate-option {
    height: 100%;
    padding: 1rem;
    border: 1px solid rgba(26, 31, 113, 0.12);
    border-radius: var(--radius-md);
    background: linear-gradient(135deg, rgba(26, 31, 113, 0.08), rgba(50, 68, 182, 0.14));
    cursor: pointer;
    transition: background 0.2s, box-shadow 0.2s, transform 0.2s;
    box-shadow: 0 2px 6px rgba(26, 31, 113, 0.08);
    border-left: 4px solid var(--primary);
    position: relative;
  }
  #rate-choice-overlay .rate-option[data-disabled="true"] {
    opacity: 0.55;
    cursor: not-allowed;
    filter: grayscale(0.2);
  }
  #rate-choice-overlay .rate-option[data-rate="bcv"] {
    background: linear-gradient(135deg, rgba(234, 236, 240, 0.7), rgba(210, 213, 221, 0.6));
    border: 1px solid var(--neutral-300);
    border-left: 4px solid var(--neutral-400);
    box-shadow: none;
    transform: none;
  }
  #rate-choice-overlay .rate-option:hover {
    background: linear-gradient(135deg, rgba(26, 31, 113, 0.12), rgba(50, 68, 182, 0.22));
    box-shadow: 0 6px 14px rgba(26, 31, 113, 0.16);
    transform: translateY(-2px);
  }
  #rate-choice-overlay .rate-option[data-disabled="true"]:hover {
    background: linear-gradient(135deg, rgba(234, 236, 240, 0.7), rgba(210, 213, 221, 0.6));
    box-shadow: none;
    transform: none;
  }
  #rate-choice-overlay .rate-option[data-rate="bcv"]:hover {
    background: linear-gradient(135deg, rgba(245, 247, 250, 0.9), rgba(234, 236, 240, 0.8));
    box-shadow: none;
    transform: none;
  }
  #rate-choice-overlay .rate-option-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }
  #rate-choice-overlay .rate-option-header .rate-title {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    font-weight: 600;
  }
  #rate-choice-overlay .rate-option-header .rate-value {
    margin-left: auto;
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--primary);
  }
  #rate-choice-overlay .rate-option-header .rate-value::before {
    content: '\2013\00a0';
    font-weight: 400;
    color: var(--neutral-600);
  }
  .flag-ve {
    font-size: 1.2rem;
  }
  #rate-choice-overlay .rate-tag {
    background: linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%);
    color: var(--neutral-100);
    font-size: 0.7rem;
    font-weight: 600;
    padding: 0 0.4rem;
    border-radius: var(--radius-sm);
    position: absolute;
    top: -10px;
    right: -10px;
    box-shadow: 0 2px 6px rgba(26, 31, 113, 0.3);
  }
  #rate-choice-overlay .rate-option[data-rate="bcv"] .rate-tag {
    background: linear-gradient(135deg, var(--neutral-200), var(--neutral-300));
    color: var(--neutral-700);
    box-shadow: none;
  }
  #rate-choice-overlay .rate-option[data-rate="bcv"] .rate-value {
    color: var(--neutral-700);
  }
  #rate-choice-overlay .rate-option[data-disabled="true"] .rate-disabled-message {
    margin-top: 0.5rem;
    font-size: 0.75rem;
    color: var(--neutral-600);
    font-weight: 600;
  }
  #rate-choice-overlay .rate-desc {
    font-size: 0.8rem;
    color: var(--neutral-600);
    margin-top: 0.5rem;
  }
  #rate-choice-overlay .rate-example {
    font-size: 0.8rem;
    color: var(--neutral-900);
    margin-top: 0.25rem;
  }

  #rate-choice-overlay .rate-option .rate-more-toggle {
    margin-top: 0.5rem;
    font-size: 0.8rem;
    color: var(--primary-light);
    background: none;
    border: none;
    padding: 0;
    text-decoration: underline;
    cursor: pointer;
    transition: color 0.2s;
  }

  #rate-choice-overlay .rate-option .rate-more-toggle:hover {
    color: var(--primary);
  }

  #rate-choice-overlay .rate-option .rate-more {
    display: none;
    margin-top: 0.5rem;
    font-size: 0.75rem;
    color: var(--neutral-700);
    background: rgba(26, 31, 113, 0.08);
    border-radius: var(--radius-sm);
    padding: 0.5rem;
    border-left: 2px solid rgba(26, 31, 113, 0.18);
  }

  #rate-choice-overlay .rate-option .rate-more.open {
    display: block;
  }

  #rate-choice-overlay .rate-option .rate-more p {
    margin: 0.25rem 0;
  }

  @media (max-height: 720px) {
    #rate-choice-overlay {
      align-items: flex-start;
      padding-top: 1.5rem;
      padding-bottom: 1.5rem;
    }
    #rate-choice-overlay .rate-choice-modal {
      margin: 1.5rem auto;
    }
  }
  @media (max-width: 420px) {
    #rate-choice-overlay {
      align-items: flex-start;
      padding: 1.5rem 0.75rem;
    }
    #rate-choice-overlay .rate-choice-modal {
      width: 100%;
      margin: 1.25rem auto;
      padding: 1.5rem 1.25rem;
      gap: 1rem;
    }
    #rate-choice-overlay .rate-options-grid {
      grid-template-columns: 1fr;
      gap: 0.75rem;
    }
    #rate-choice-overlay .rate-option {
      padding: 0.85rem;
    }
    #rate-choice-overlay .rate-option-header {
      gap: 0.4rem;
    }
    #rate-choice-overlay .rate-option-header .rate-value {
      font-size: 1.05rem;
    }
    #rate-choice-overlay .rate-option-header .rate-title {
      font-size: 0.95rem;
    }
    #rate-choice-overlay .rate-desc,
    #rate-choice-overlay .rate-example,
    #rate-choice-overlay .rate-option .rate-more-toggle {
      font-size: 0.75rem;
    }
    #rate-choice-overlay .rate-option .rate-more {
      font-size: 0.7rem;
      padding: 0.4rem;
    }
  }

  /* Sutil parpadeo para llamar la atención en el botón de instrucciones */
  @keyframes attentionBlink {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.55; }
  }
  .attention-blink {
    animation: attentionBlink 1.8s ease-in-out infinite;
  }

  .rate-change-icon {
    margin-left: 4px;
    transition: var(--transition-base);
  }
  .rate-up {
    color: var(--success);
  }
  .rate-down {
    color: var(--danger);
  }

  /* === ANIMACIONES INCREÍBLES PARA RATE CHOICE === */

  /* Animación de hover mejorada con efecto 3D */
  #rate-choice-overlay .rate-option:not([data-disabled="true"]):hover {
    transform: translateY(-8px) scale(1.02);
    box-shadow:
      0 20px 40px rgba(59, 130, 246, 0.3),
      0 0 60px rgba(59, 130, 246, 0.15),
      inset 0 1px 2px rgba(255, 255, 255, 0.5);
    background: linear-gradient(135deg, rgba(37, 99, 235, 0.15), rgba(79, 70, 229, 0.25));
    border-color: rgba(59, 130, 246, 0.4);
  }

  /* Animación de iconos al hover */
  #rate-choice-overlay .rate-option:hover .rate-option-icon {
    transform: scale(1.15) rotate(5deg);
    filter: drop-shadow(0 5px 15px rgba(59, 130, 246, 0.5));
  }

  #rate-choice-overlay .rate-option-icon {
    transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
  }

  #rate-choice-overlay .rate-option-icon-container {
    position: relative;
    display: inline-flex;
    padding: 1rem;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.08), rgba(147, 51, 234, 0.08));
    margin-bottom: 0.75rem;
    transition: all 0.4s ease;
  }

  #rate-choice-overlay .rate-option:hover .rate-option-icon-container {
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.2), rgba(147, 51, 234, 0.2));
  }

  #rate-choice-overlay .rate-option-icon {
    width: 2.5rem;
    height: 2.5rem;
    stroke: currentColor;
    color: #3b82f6;
  }

  /* Animación de badges con pulso */
  @keyframes badgePulse {
    0%, 100% {
      transform: scale(1);
      box-shadow: 0 0 0 0 rgba(59, 130, 246, 0.7);
    }
    50% {
      transform: scale(1.05);
      box-shadow: 0 0 0 8px rgba(59, 130, 246, 0);
    }
  }

  #rate-choice-overlay .rate-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.4rem 0.85rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
    transition: all 0.3s ease;
  }

  #rate-choice-overlay .rate-option:hover .rate-badge {
    animation: badgePulse 2s ease-in-out infinite;
  }

  #rate-choice-overlay .rate-badge--stable {
    background: linear-gradient(135deg, #10b981, #059669);
    color: white;
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3);
  }

  #rate-choice-overlay .rate-badge--crypto {
    background: linear-gradient(135deg, #f59e0b, #d97706);
    color: white;
    box-shadow: 0 4px 12px rgba(245, 158, 11, 0.3);
  }

  #rate-choice-overlay .rate-badge--recommended {
    background: linear-gradient(135deg, #3b82f6, #2563eb);
    color: white;
    box-shadow: 0 4px 12px rgba(59, 130, 246, 0.4);
  }

  #rate-choice-overlay .rate-badge--favorable {
    background: linear-gradient(135deg, #8b5cf6, #7c3aed);
    color: white;
    box-shadow: 0 4px 12px rgba(139, 92, 246, 0.3);
  }

  #rate-choice-overlay .rate-badge--disabled {
    background: linear-gradient(135deg, #9ca3af, #6b7280);
    color: white;
    box-shadow: none;
  }

  /* Animación de selección con ondas expansivas */
  @keyframes rippleEffect {
    0% {
      transform: scale(0);
      opacity: 1;
    }
    100% {
      transform: scale(2.5);
      opacity: 0;
    }
  }

  @keyframes selectedGlow {
    0%, 100% {
      box-shadow:
        0 20px 60px rgba(59, 130, 246, 0.6),
        0 0 80px rgba(59, 130, 246, 0.4),
        inset 0 0 30px rgba(59, 130, 246, 0.2);
    }
    50% {
      box-shadow:
        0 25px 70px rgba(59, 130, 246, 0.8),
        0 0 100px rgba(59, 130, 246, 0.6),
        inset 0 0 40px rgba(59, 130, 246, 0.3);
    }
  }

  #rate-choice-overlay .rate-option.rate-selected {
    animation: selectedGlow 1.5s ease-in-out;
    transform: scale(1.05);
    background: linear-gradient(135deg, rgba(37, 99, 235, 0.25), rgba(79, 70, 229, 0.35));
    border-color: rgba(59, 130, 246, 0.8);
    position: relative;
    overflow: hidden;
  }

  #rate-choice-overlay .rate-option.rate-selected::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    height: 100%;
    background: radial-gradient(circle, rgba(59, 130, 246, 0.6) 0%, transparent 70%);
    transform: translate(-50%, -50%) scale(0);
    animation: rippleEffect 0.8s ease-out forwards;
    pointer-events: none;
  }

  /* Partículas flotantes */
  @keyframes floatParticle {
    0%, 100% {
      transform: translateY(0) translateX(0) rotate(0deg);
      opacity: 0.6;
    }
    25% {
      transform: translateY(-20px) translateX(10px) rotate(90deg);
      opacity: 1;
    }
    50% {
      transform: translateY(-10px) translateX(-10px) rotate(180deg);
      opacity: 0.8;
    }
    75% {
      transform: translateY(-30px) translateX(5px) rotate(270deg);
      opacity: 0.9;
    }
  }

  #rate-choice-overlay .rate-option.rate-selected::after {
    content: '✨';
    position: absolute;
    top: 10%;
    right: 10%;
    font-size: 1.5rem;
    animation: floatParticle 2s ease-in-out infinite;
    pointer-events: none;
  }

  /* Animación del check de éxito mejorada */
  @keyframes checkSlideIn {
    0% {
      opacity: 0;
      transform: scale(0.3) translateY(20px);
    }
    50% {
      transform: scale(1.1) translateY(0);
    }
    100% {
      opacity: 1;
      transform: scale(1) translateY(0);
    }
  }

  @keyframes circleStroke {
    0% {
      stroke-dasharray: 0 157;
      stroke-dashoffset: 0;
    }
    100% {
      stroke-dasharray: 157 0;
      stroke-dashoffset: 0;
    }
  }

  @keyframes checkmarkStroke {
    0% {
      stroke-dasharray: 0 50;
      stroke-dashoffset: 0;
    }
    100% {
      stroke-dasharray: 50 0;
      stroke-dashoffset: 0;
    }
  }

  #rate-choice-overlay .rate-choice-success {
    animation: checkSlideIn 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
  }

  #rate-choice-overlay .rate-success-circle {
    stroke: #10b981;
    stroke-width: 3;
    stroke-dasharray: 0 157;
    stroke-dashoffset: 0;
    animation: circleStroke 0.6s ease-out forwards 0.3s;
  }

  #rate-choice-overlay .rate-success-checkmark {
    stroke: #10b981;
    stroke-width: 4;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-dasharray: 0 50;
    stroke-dashoffset: 0;
    animation: checkmarkStroke 0.4s ease-out forwards 0.8s;
  }

  #rate-choice-overlay .rate-success-check {
    display: inline-flex;
    margin-bottom: 1rem;
  }

  #rate-choice-overlay .rate-success-icon {
    width: 5rem;
    height: 5rem;
    filter: drop-shadow(0 10px 30px rgba(16, 185, 129, 0.4));
  }

  #rate-choice-overlay .rate-success-message {
    font-size: 1.35rem;
    font-weight: 700;
    color: #10b981;
    margin: 0;
    text-shadow: 0 2px 10px rgba(16, 185, 129, 0.3);
  }

  #rate-choice-overlay .rate-choice-success {
    text-align: center;
    padding: 2rem;
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.05), rgba(5, 150, 105, 0.05));
    border-radius: 1rem;
    border: 2px solid rgba(16, 185, 129, 0.2);
  }

  /* Mejora del header con iconos animados */
  #rate-choice-overlay .rate-choice-welcome-icon {
    width: 4rem;
    height: 4rem;
    stroke: #3b82f6;
    stroke-width: 2;
    margin: 0 auto 1rem;
    display: block;
    filter: drop-shadow(0 5px 20px rgba(59, 130, 246, 0.4));
    animation: iconFloat 3s ease-in-out infinite;
  }

  @keyframes iconFloat {
    0%, 100% {
      transform: translateY(0) rotate(0deg);
    }
    50% {
      transform: translateY(-10px) rotate(5deg);
    }
  }

  #rate-choice-overlay .rate-choice-title {
    font-size: 2rem;
    font-weight: 800;
    background: linear-gradient(135deg, #3b82f6, #8b5cf6);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-bottom: 0.5rem;
  }

  #rate-choice-overlay .rate-choice-subtitle {
    color: rgba(255, 255, 255, 0.85);
    font-size: 1rem;
    line-height: 1.6;
    max-width: 600px;
    margin: 0 auto;
  }

  /* Animación de entrada para las opciones */
  @keyframes slideInUp {
    from {
      opacity: 0;
      transform: translateY(30px);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

  #rate-choice-overlay .rate-option {
    animation: slideInUp 0.5s ease-out forwards;
    opacity: 0;
  }

  #rate-choice-overlay .rate-option:nth-child(1) {
    animation-delay: 0.1s;
  }

  #rate-choice-overlay .rate-option:nth-child(2) {
    animation-delay: 0.2s;
  }

  #rate-choice-overlay .rate-option:nth-child(3) {
    animation-delay: 0.3s;
  }

  #rate-choice-overlay .rate-option:nth-child(4) {
    animation-delay: 0.4s;
  }

  #rate-choice-overlay .rate-option:nth-child(5) {
    animation-delay: 0.5s;
  }

  /* Mejorar los nombres y valores de las tasas */
  #rate-choice-overlay .rate-option-name {
    font-size: 1.35rem;
    font-weight: 700;
    color: #1e293b;
    margin: 0.5rem 0;
  }

  #rate-choice-overlay .rate-option-value-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin: 0.75rem 0;
    padding: 0.75rem;
    background: rgba(255, 255, 255, 0.5);
    border-radius: 0.75rem;
    border: 1px solid rgba(59, 130, 246, 0.2);
    transition: all 0.3s ease;
  }

  #rate-choice-overlay .rate-option:hover .rate-option-value-container {
    background: rgba(255, 255, 255, 0.8);
    border-color: rgba(59, 130, 246, 0.4);
    box-shadow: 0 4px 12px rgba(59, 130, 246, 0.15);
  }

  #rate-choice-overlay .rate-value-amount {
    font-size: 1.75rem;
    font-weight: 800;
    color: #3b82f6;
    line-height: 1;
  }

  #rate-choice-overlay .rate-value-label {
    font-size: 0.85rem;
    color: #64748b;
    margin-top: 0.25rem;
    font-weight: 500;
  }

  #rate-choice-overlay .rate-option-description {
    color: #475569;
    font-size: 0.9rem;
    margin: 0.5rem 0;
    line-height: 1.5;
  }

  /* Mejora de los ejemplos */
  #rate-choice-overlay .rate-option-example {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.75rem;
    background: linear-gradient(135deg, rgba(249, 250, 251, 0.8), rgba(243, 244, 246, 0.8));
    border-radius: 0.5rem;
    margin: 0.75rem 0;
    border: 1px solid rgba(226, 232, 240, 0.8);
    transition: all 0.3s ease;
  }

  #rate-choice-overlay .rate-option:hover .rate-option-example {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.9), rgba(249, 250, 251, 0.9));
    border-color: rgba(59, 130, 246, 0.3);
  }

  #rate-choice-overlay .rate-example-icon {
    width: 1.5rem;
    height: 1.5rem;
    stroke: #64748b;
    flex-shrink: 0;
  }

  #rate-choice-overlay .rate-example-content {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-weight: 600;
    color: #1e293b;
  }

  #rate-choice-overlay .rate-example-input {
    color: #3b82f6;
  }

  #rate-choice-overlay .rate-example-arrow {
    width: 1.25rem;
    height: 1.25rem;
    stroke: #94a3b8;
    flex-shrink: 0;
  }

  #rate-choice-overlay .rate-example-output {
    color: #10b981;
  }

  /* Overlay de fondo mejorado */
  #rate-choice-overlay {
    background: linear-gradient(135deg, #0f172a 0%, #1e293b 50%, #334155 100%);
  }

  #rate-choice-overlay .rate-choice-modal {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(248, 250, 252, 0.9));
    backdrop-filter: blur(10px);
    border-radius: 1.5rem;
    box-shadow: 0 25px 50px rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(255, 255, 255, 0.5);
  }

      html {
      font-size: 82.8%;
    }
    @media (min-width: 768px) {
      html { font-size: 115%; }
    }
      .pay-methods-disabled {
      display: flex;
      gap: 1rem;
      justify-content: center;
      margin-top: 1rem;
    }
    .pay-methods-disabled .pay-disabled-btn {
      background: #fff;
      border: 1px solid rgba(0,0,0,0.1);
      padding: 0.5rem 1rem;
      border-radius: var(--radius-md);
      box-shadow: var(--shadow-sm);
      cursor: pointer;
      transition: var(--transition-fast);
      display: flex;
      align-items: center;
      justify-content: center;
    }
    .pay-methods-disabled .pay-disabled-btn:hover {
      box-shadow: var(--shadow-md);
    }
    .pay-methods-disabled img {
      max-height: 24px;
    }
    .social-links {
      display: flex;
      gap: 1.2rem;
      justify-content: center;
      margin-top: 0.5rem;
    }

    .social-link {
      width: 4rem;
      height: 4rem;
      display: flex;
      align-items: center;
      justify-content: center;
      background-color: rgba(255, 255, 255, 0.08);
      border-radius: 50%;
      color: var(--visa-blue);
      transition: var(--transition-base);
      font-size: 1.6rem;
      position: relative;
      overflow: hidden;
    }

    .social-link::before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background: var(--visa-blue);
      opacity: 0;
      transition: opacity var(--transition-fast);
      z-index: -1;
    }

    .social-link:hover::before {
      opacity: 1;
    }

    .social-link:hover {
      transform: translateY(-5px);
      box-shadow: var(--shadow-md);
      color: var(--neutral-100);
    }
        .withdrawal-overlay {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: rgba(0, 0, 0, 0.5);
        z-index: 5000;
        display: none;
        align-items: center;
        justify-content: center;
        padding: 1rem;
      }

      #account-block-overlay {
        z-index: 6000;
      }

    .withdrawal-modal {
      background: var(--neutral-100);
      border-radius: var(--radius-xl);
      max-width: 400px;
      width: 100%;
      text-align: center;
      padding: 2rem;
      box-shadow: var(--shadow-lg);
    }

    .withdrawal-modal h2 {
      color: var(--neutral-900);
      margin-bottom: 1rem;
      font-size: 1.25rem;
    }

      .withdrawal-modal p {
        color: var(--neutral-600);
        margin-bottom: 1rem;
      }

      .modal-input {
        width: 100%;
        padding: 0.75rem;
        border: 1px solid var(--neutral-400);
        border-radius: var(--radius-md);
        margin-bottom: 1rem;
      }

    .modal-btn {
      background: var(--visa-blue);
      color: var(--neutral-100);
      border: none;
      border-radius: var(--radius-md);
      padding: 0.75rem 1.5rem;
      font-size: 1rem;
      cursor: pointer;
      transition: var(--transition-base);
    }

    .modal-btn:disabled {
      opacity: 0.5;
      cursor: not-allowed;
    }

    .modal-btn:not(:disabled):hover {
      background: var(--primary-dark);
    }
      #transition-video-overlay {
      position: fixed;
      inset: 0;
      background: #000;
      display: none;
      align-items: center;
      justify-content: center;
      z-index: 10000;
    }

    #transition-video-overlay[aria-hidden="true"] {
      display: none;
    }

    #transition-video-overlay video {
      width: 100%;
      height: 100%;
      object-fit: cover;
      background: #000;
    }

    body.transition-video-active {
      overflow: hidden;
    }
      .latinphone-floating-container {
      position: fixed;
      right: clamp(16px, 4vw, 28px);
      bottom: clamp(96px, 12vh, 128px);
      display: none;
      z-index: 4000;
    }

    .latinphone-floating-container.is-visible {
      display: flex;
      align-items: center;
    }

    .latinphone-floating-action {
      appearance: none;
      border: none;
      border-radius: var(--radius-full, 9999px);
      background: linear-gradient(135deg, var(--primary, #1a1f71), var(--primary-light, #3244b6));
      color: #ffffff;
      font-weight: 600;
      font-size: 0.95rem;
      padding: 0.85rem 1.6rem;
      box-shadow: 0 12px 25px rgba(26, 31, 113, 0.35);
      display: inline-flex;
      align-items: center;
      gap: 0.6rem;
      cursor: pointer;
      transition: transform 0.2s ease, box-shadow 0.2s ease;
    }

    .latinphone-floating-action:focus,
    .latinphone-floating-action:hover {
      transform: translateY(-2px);
      box-shadow: 0 16px 32px rgba(26, 31, 113, 0.45);
      outline: none;
    }

    .latinphone-floating-action:active {
      transform: translateY(0);
    }

    .latinphone-floating-action__icon {
      font-size: 1.1em;
      line-height: 1;
    }

    .latinphone-overlay {
      position: fixed;
      inset: 0;
      background: rgba(10, 13, 35, 0.55);
      display: none;
      align-items: center;
      justify-content: center;
      padding: 24px;
      z-index: 5000;
      backdrop-filter: blur(4px);
    }

    .latinphone-overlay.active {
      display: flex;
    }

    .latinphone-overlay__dialog {
      background: var(--neutral-100, #ffffff);
      color: var(--neutral-900, #1a1f37);
      border-radius: 20px;
      box-shadow: var(--shadow-xl, 0 20px 24px -4px rgba(16, 24, 40, 0.08));
      padding: 24px clamp(20px, 4vw, 36px);
      width: min(100%, 420px);
      position: relative;
      text-align: center;
      display: flex;
      flex-direction: column;
      gap: 16px;
    }

    .latinphone-overlay__title {
      margin: 0;
      font-size: 1.35rem;
      font-weight: 700;
      color: var(--primary, #1a1f71);
    }

    .latinphone-overlay__description {
      margin: 0;
      font-size: 0.95rem;
      color: var(--neutral-600, #6e7891);
    }

    .latinphone-overlay__actions {
      display: grid;
      gap: 12px;
      margin-top: 8px;
    }

    .latinphone-overlay__btn {
      display: inline-flex;
      justify-content: center;
      align-items: center;
      padding: 0.85rem 1rem;
      border-radius: var(--radius-md, 12px);
      font-weight: 600;
      text-decoration: none;
      transition: var(--transition-fast, all 0.2s ease);
    }

    .latinphone-overlay__btn--primary {
      background: linear-gradient(135deg, var(--primary, #1a1f71), var(--primary-light, #3244b6));
      color: #ffffff;
      box-shadow: 0 12px 20px rgba(26, 31, 113, 0.28);
    }

    .latinphone-overlay__btn--primary:hover,
    .latinphone-overlay__btn--primary:focus {
      box-shadow: 0 16px 24px rgba(26, 31, 113, 0.35);
      transform: translateY(-1px);
    }

    .latinphone-overlay__btn--secondary {
      background: var(--neutral-200, #f5f7fa);
      color: var(--primary, #1a1f71);
      border: 1px solid var(--neutral-300, #eaecf0);
    }

    .latinphone-overlay__btn--secondary:hover,
    .latinphone-overlay__btn--secondary:focus {
      background: var(--neutral-300, #eaecf0);
    }

    .latinphone-overlay__btn--support {
      background: linear-gradient(135deg, var(--success, #00d34d), #00a346);
      color: #ffffff;
      box-shadow: 0 12px 20px rgba(0, 211, 77, 0.25);
    }

    .latinphone-overlay__btn--support:hover,
    .latinphone-overlay__btn--support:focus {
      box-shadow: 0 16px 24px rgba(0, 163, 70, 0.35);
      transform: translateY(-1px);
    }

    .latinphone-overlay__close {
      position: absolute;
      top: 12px;
      right: 12px;
      border: none;
      background: transparent;
      color: var(--neutral-500, #9da4b4);
      font-size: 1.5rem;
      cursor: pointer;
      transition: color 0.2s ease;
    }

    .latinphone-overlay__close:hover,
    .latinphone-overlay__close:focus {
      color: var(--neutral-700, #4f5d75);
      outline: none;
    }

    @media (max-width: 600px) {
      .latinphone-floating-container {
        bottom: clamp(80px, 18vh, 110px);
      }

      .latinphone-floating-action {
        font-size: 0.9rem;
        padding: 0.75rem 1.4rem;
      }
    }
  