@charset "UTF-8";

/**
 * CafeTal777 - Consolidated Core Styles
 * Merged from: cafetal777-theme.css, cafetal777-professional.css,
 *   cafetal777-layout.css, cafetal777-dashboard.css,
 *   cafetal777-complete-fix.css, cafetal777-innovations.css,
 *   cafetal777-geniusbet.css, custom.css
 *
 * Sections:
 *  1.  Variables & Fonts
 *  2.  Global Resets & Dark Mode
 *  3.  Layout - Header, Body, Home Page
 *  4.  Navigation - Primary Menu, Mobile Nav
 *  5.  Sidebar - Sports Category (Premium)
 *  6.  Cards - Sports Cards, Game Cards
 *  7.  Tables - Sport Hub, Sport Table
 *  8.  Forms - Inputs, Select2, Deposit
 *  9.  Buttons - Base, Outline, Danger, Success
 * 10.  Badges - Status, Text Colors
 * 11.  Bet Components - Betslip, Odds, Markets
 * 12.  Dashboard - Sidebar, Widgets, KPIs
 * 13.  Modals - Login, Consent, Bet Modal
 * 14.  Footer - Multi-column, Bottom Bar, Legal
 * 15.  Innovation Features - Simulator, Theme Toggle, Favorites, Charts
 * 16.  Trust & Safety Panels
 * 17.  Banner / Hero Slider
 * 18.  Animations & Micro-interactions
 * 19.  Utilities - Scrollbar, Empty States, Misc
 * 20.  Custom.css - Payment, Select2, Cookies
 */

@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800&family=Roboto:wght@400;500;600;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&display=swap");


/* ==========================================================================
   1. VARIABLES & FONTS
   ========================================================================== */
:root {
  --ct777-primary: #00D4FF;
  --ct777-accent: #00D4FF;
  --ct777-dark: #0B0F14;
  --ct777-dark-soft: #111827;
  --ct777-dark-card: #1A2233;
  --ct777-success: #22C55E;
  --ct777-error: #EF4444;
  --ct777-text: #E8EDF5;
  --ct777-text-muted: rgba(232, 237, 245, 0.92);
  --ct777-border: rgba(232, 237, 245, 0.10);
  --heading-font: "Montserrat", "Inter", sans-serif;
  --body-font: "Roboto", sans-serif;
  --ct777-sidebar-width: 268px;
  --ct777-betslip-width: 300px;
  --left-side: 268px;
  --right-side: 300px;
}

/* Layout-scoped tokens (gb-* for backward compat) */
.cafetal777-layout {
  --gb-header-bg: #0B0F14;
  --gb-header-border: rgba(232, 237, 245, 0.10);
  --gb-body-bg: #060910;
  --gb-sidebar-bg: #111827;
  --gb-card-bg: #1A2233;
  --gb-card-border: rgba(232, 237, 245, 0.10);
  --gb-text: #E8EDF5;
  --gb-text-muted: #94A3B8;
  --gb-accent: #00D4FF;
  --gb-primary: #00D4FF;
  --gb-hover: rgba(0, 212, 255, 0.12);
  --gb-nav-h: 56px;
}


/* ==========================================================================
   2. GLOBAL RESETS & DARK MODE
   ========================================================================== */

/* Professional: Remove visual bulk */
* {
  text-shadow: none !important;
}

body {
  background: var(--ct777-dark) !important;
  color: var(--ct777-text) !important;
  font-family: var(--body-font) !important;
  font-size: 0.9375rem;
  line-height: 1.6;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--heading-font) !important;
  color: var(--ct777-text) !important;
  font-weight: 600;
  line-height: 1.3;
}

/* Links: underline on focus for accessibility */
a:focus,
a:focus-visible {
  text-decoration: underline;
}

/* Dark overrides for Bootstrap white backgrounds */
.bg-white, .bg--white,
[style*="background: white"],
[style*="background: #fff"],
[style*="background-color: white"],
[style*="background-color: #fff"],
[style*="background-color: #ffffff"] {
  background: var(--ct777-dark-card) !important;
}

/* Remove blue (#4634ff, #336699) */
[style*="#4634ff"], [style*="rgb(70, 52, 255)"] {
  color: var(--ct777-accent) !important;
  background: var(--ct777-accent) !important;
  border-color: var(--ct777-accent) !important;
}

[style*="#336699"], [style*="rgb(51, 102, 153)"] {
  color: var(--ct777-primary) !important;
  background: var(--ct777-primary) !important;
  border-color: var(--ct777-primary) !important;
}

.text-dark, .text-black { color: var(--ct777-text) !important; }
.text-muted { color: var(--ct777-text-muted) !important; }


/* ==========================================================================
   3. LAYOUT - HEADER, BODY, HOME PAGE
   ========================================================================== */

.cafetal777-layout .header-primary {
  background: var(--gb-header-bg) !important;
  padding: 0 !important;
  min-height: var(--gb-nav-h);
  border-bottom: 1px solid var(--gb-header-border);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
  position: sticky;
  top: 0;
  z-index: 1200;
}

.cafetal777-layout .header-fluid-custom-parent {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  min-height: var(--gb-nav-h);
  flex-wrap: wrap;
}

.cafetal777-layout .logo { flex-shrink: 0; max-width: 160px; }

.cafetal777-layout .logo-text-brand {
  font-size: 1.35rem;
  background: var(--ct-brand-gradient-text, linear-gradient(135deg, #00D4FF, #A78BFA));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 800;
}
.logo-text,
.site-logo a,
.header-logo a {
  background: var(--ct-brand-gradient-text, linear-gradient(135deg, #00D4FF, #A78BFA));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 800;
}
.cafetal777-layout .logo-text-brand .logo-cafe,
.cafetal777-layout .logo-text-brand .logo-tal {
  -webkit-text-fill-color: transparent;
}

.cafetal777-layout .primary-menu-container {
  display: flex;
  align-items: center;
  flex: 1;
  min-width: 0;
}

.cafetal777-layout .primary-menu-container > ul:first-of-type { display: flex !important; gap: 4px; margin-inline-end: 16px; }

.cafetal777-layout .primary-menu-container .primary-menu a.text-white.sm-text {
  color: var(--gb-text) !important;
  font-size: 14px;
  font-weight: 500;
  padding: 10px 14px;
  border-radius: 6px;
  transition: background 0.2s, color 0.2s;
}

.cafetal777-layout .primary-menu-container .primary-menu a.text-white.sm-text:hover { background: var(--gb-hover); color: var(--gb-accent) !important; }
.cafetal777-layout .primary-menu-container .primary-menu a.text-white.sm-text.active { background: var(--gb-hover); color: var(--gb-accent) !important; font-weight: 600; }
.cafetal777-layout .primary-menu-container .right-side-nav { margin-inline-start: auto; }

.cafetal777-layout .primary-menu-container .form-select.oddsType,
.cafetal777-layout .primary-menu-container .language-btn {
  font-size: 13px;
  color: var(--gb-text);
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid var(--gb-card-border);
  border-radius: 6px;
}

/* Desktop bet slip toggle */
.cafetal777-layout .bet-slip-button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: rgba(0, 212, 255, 0.15);
  border: 1px solid rgba(0, 212, 255, 0.3);
  border-radius: 6px;
  color: var(--gb-accent);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s;
}

.cafetal777-layout .bet-slip-button:hover { background: rgba(0, 212, 255, 0.25); border-color: var(--gb-accent); color: #fff; }

.cafetal777-layout .bet-slip-button .bet-count-badge {
  background: var(--gb-accent);
  color: #1a1a1a;
  font-size: 11px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 9px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.cafetal777-layout .bet-slip-button .bet-count-badge:empty { display: none; }

/* Main layout */
.cafetal777-layout .home-page { background: var(--gb-body-bg) !important; min-height: calc(100vh - var(--gb-nav-h)); }

@media screen and (min-width: 992px) {
  .home-page { display: flex !important; align-items: stretch !important; min-height: calc(100vh - var(--header-h)); }
}

.cafetal777-layout .sports-category { background: var(--gb-sidebar-bg) !important; border-inline-end: 1px solid var(--gb-card-border) !important; box-shadow: 2px 0 12px rgba(0, 0, 0, 0.2); }
.cafetal777-layout .sports-body { background: var(--gb-body-bg) !important; padding: 16px 20px 24px !important; flex: 1 !important; min-width: 0 !important; }

@media screen and (min-width: 992px) {
  .sports-body { width: calc(100% - var(--left-side) - var(--right-side)) !important; }
}

.sports-body, .home-page { background: var(--ct777-dark) !important; }



/* ==========================================================================
   4. NAVIGATION - PRIMARY MENU, MOBILE NAV
   ========================================================================== */

.cafetal777-layout .app-nav { background: var(--gb-header-bg) !important; border-top: 1px solid var(--gb-card-border); }
.cafetal777-layout .app-nav__menu-link, .cafetal777-layout .app-nav__menu-text { color: var(--gb-text-muted) !important; }
.cafetal777-layout .app-nav__menu-link.active .app-nav__menu-icon, .cafetal777-layout .app-nav__menu-link.active .app-nav__menu-text { color: var(--gb-accent) !important; }
.cafetal777-layout .app-nav__menu-link-important { background: var(--gb-primary) !important; border-color: var(--gb-accent) !important; color: var(--gb-accent) !important; }
.cafetal777-layout .app-nav__drawer { background: var(--gb-sidebar-bg) !important; }
.cafetal777-layout .app-nav__drawer-link { color: var(--gb-text) !important; }

/* Theme: app-nav premium */
.app-nav {
  background: linear-gradient(0deg, var(--ct777-primary) 0%, var(--ct777-dark-soft) 100%) !important;
  border-top: 2px solid rgba(0, 212, 255, 0.3) !important;
  box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.3) !important;
}

.app-nav__menu-link.active .app-nav__menu-icon,
.app-nav__menu-link.active .app-nav__menu-text { color: var(--ct777-accent) !important; }

.app-nav__menu-link-important {
  background: linear-gradient(135deg, var(--ct777-accent) 0%, var(--ct-brand-primary-dark, #00A3CC) 100%) !important;
  border-color: var(--ct777-accent) !important;
  color: var(--ct777-dark) !important;
  box-shadow: 0 0 25px rgba(0, 212, 255, 0.5) !important;
}

.bet-count { background: var(--ct777-accent) !important; color: var(--ct777-dark) !important; font-weight: 700 !important; }

.app-nav__menu-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  color: rgba(255, 255, 255, 0.7) !important;
  text-decoration: none;
  padding: 8px 12px;
  border-radius: 8px;
  transition: all 0.3s ease;
  font-size: 11px;
  font-weight: 500;
}

.app-nav__menu { list-style: none; padding: 0; margin: 0; }


/* ==========================================================================
   5. SIDEBAR - SPORTS CATEGORY (PREMIUM)
   ========================================================================== */

.sports-category {
  width: var(--ct777-sidebar-width) !important;
  min-width: var(--ct777-sidebar-width) !important;
  background: rgba(11, 15, 20, 0.75) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-inline-end: 1px solid rgba(0, 212, 255, 0.08) !important;
  box-shadow: 4px 0 24px rgba(0, 0, 0, 0.25);
  display: flex !important;
  flex-direction: column !important;
  flex-shrink: 0 !important;
  font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, sans-serif !important;
  transition: box-shadow 0.3s ease;
}

@supports not (backdrop-filter: blur(16px)) {
  .sports-category {
    background: rgba(11, 15, 20, 0.95) !important;
  }
}

.dashboard_sidebar .widget-card,
.dashboard-sidebar-widget {
  background: rgba(26, 34, 51, 0.8);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(0, 212, 255, 0.08);
}

@media screen and (min-width: 992px) {
  .sports-category { position: sticky !important; top: 0 !important; align-self: flex-start !important; max-height: 100vh !important; overflow: hidden !important; }
  .sports-category::after { display: none !important; }
}

.sports-category__link.live-btn {
  background: linear-gradient(135deg, rgba(239, 68, 68, 0.15) 0%, rgba(239, 68, 68, 0.25) 100%) !important;
  border-bottom: 2px solid rgba(239, 68, 68, 0.4) !important;
  padding: 14px 12px !important;
  position: relative !important;
}

.sports-category__link.live-btn i { color: var(--ct777-error, #EF4444) !important; font-size: 1.75rem !important; }
.sports-category__link.live-btn .sports-category__text { color: var(--ct777-error, #EF4444) !important; font-weight: 700 !important; letter-spacing: 0.15em !important; font-size: 0.7rem !important; }

.sports-category__list { flex: 1 !important; padding: 8px 6px !important; gap: 6px !important; }

.sports-category__link:not(.live-btn) {
  background: rgba(255, 255, 255, 0.02) !important;
  border-radius: 8px !important;
  padding: 8px 10px !important;
  margin-bottom: 4px !important;
  border: 1px solid transparent !important;
  transition: background-color 0.25s ease, border-color 0.25s ease, color 0.25s ease !important;
}

.sports-category__link:hover { background: rgba(0, 212, 255, 0.08) !important; border-color: rgba(0, 212, 255, 0.2) !important; }
.sports-category__link.active { background: linear-gradient(135deg, rgba(0, 212, 255, 0.2) 0%, rgba(0, 212, 255, 0.1) 100%) !important; border-color: var(--ct777-accent) !important; }
.sports-category__link.active .sports-category__icon, .sports-category__link.active .sports-category__text { color: var(--ct777-accent) !important; }
.sports-category__icon { color: var(--ct777-text-muted) !important; font-size: 1.25rem !important; transition: color 0.2s ease; }
.sports-category__text { color: var(--ct777-text-muted) !important; font-size: 0.7rem !important; font-weight: 600 !important; letter-spacing: 0.03em !important; margin-top: 6px !important; }

/* Premium sidebar: category names readable */
.sports-category--premium .sports-category__link--category .sports-category__text { font-size: 14px !important; color: #f0f0f0 !important; margin-top: 0 !important; }

/* Sidebar scrollbar */
.sports-category__list::-webkit-scrollbar { width: 6px !important; }
.sports-category__list::-webkit-scrollbar-track { background: rgba(0, 0, 0, 0.3) !important; border-radius: 3px !important; }
.sports-category__list::-webkit-scrollbar-thumb { background: linear-gradient(180deg, var(--ct777-accent), rgba(0, 212, 255, 0.5)) !important; border-radius: 3px !important; }

/* Premium sidebar category links */
.sports-category--premium .sports-category__link--category {
  position: relative !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  text-align: start !important;
  gap: 12px !important;
  padding: 14px 44px 14px 14px !important;
  border-radius: 10px !important;
  margin-bottom: 4px !important;
  border: 1px solid transparent !important;
  background: rgba(255, 255, 255, 0.1) !important;
  transition: all 0.25s ease !important;
  text-decoration: none !important;
  font-weight: 500 !important;
  font-size: 14px !important;
  line-height: 1.35 !important;
  color: #f0f0f0 !important;
  min-height: 52px !important;
  flex: none !important;
  max-height: none !important;
}

.sports-category--premium .sports-category__link--category:hover { background: rgba(0, 212, 255, 0.08) !important; border-color: rgba(0, 212, 255, 0.25) !important; color: #fff !important; }
.sports-category--premium .sports-category__link--category.active { background: linear-gradient(135deg, rgba(0, 212, 255, 0.35) 0%, rgba(0, 212, 255, 0.12) 100%) !important; border-color: var(--ct777-accent, #00D4FF) !important; color: var(--ct777-accent, #00D4FF) !important; font-weight: 600 !important; }

.sports-category--premium .sports-category__link--category .sports-category__icon { font-size: 1.25rem !important; width: 32px; height: 32px; flex-shrink: 0; display: inline-flex; align-items: center; justify-content: center; border-radius: 8px; background: rgba(255, 255, 255, 0.1); color: #d0d0d0; }
.sports-category--premium .sports-category__link--category:hover .sports-category__icon,
.sports-category--premium .sports-category__link--category.active .sports-category__icon { color: var(--ct777-accent, #00D4FF); background: rgba(0, 212, 255, 0.12); }

.sports-category--premium .sports-category__link--category .sports-category__label-wrap { flex: 1 !important; min-width: 0 !important; display: flex; flex-direction: column; gap: 4px; }
.sports-category--premium .sports-category__link--category .sports-category__counts { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; font-size: 12px; font-weight: 500; color: rgba(255, 255, 255, 0.75); }
.sports-category--premium .sports-category__link--category .sports-category__count { display: inline-flex; align-items: center; gap: 3px; }
.sports-category--premium .sports-category__link--category .sports-category__count--live i { color: #6f6; }
.sports-category--premium .sports-category__link--category .sports-category__count--upcoming i { color: var(--ct777-accent, #00D4FF); }
.sports-category--premium .sports-category__link--category .sports-category__count--today i { color: #8cf; }

/* Stats strip */
.sports-category__stats { padding: 10px 12px; margin: 0 8px 10px; background: rgba(0, 0, 0, 0.25); border: 1px solid var(--ct777-border, #333); border-radius: 8px; }
.sports-category__stats-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; flex-wrap: wrap; }
.sports-category__stats-item { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; color: var(--ct777-text-muted, #999); font-weight: 500; }
.sports-category__stats-item--live i { color: #ff4444; animation: pulse-dot 1.5s ease-in-out infinite; }
@keyframes pulse-dot { 0%, 100% { opacity: 1; } 50% { opacity: 0.5; } }
.sports-category__stats-value { font-weight: 700; color: var(--ct777-text, #fff); min-width: 1.2em; text-align: center; }
.sports-category__stats-divider { width: 1px; height: 14px; background: var(--ct777-border, #333); flex-shrink: 0; }

/* Block titles & leagues */
.sports-category__block-title { display: flex; align-items: center; gap: 8px; padding: 8px 10px 6px; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ct777-accent, #00D4FF); }
.sports-category__block-title--section { margin-top: 4px; padding-top: 12px; border-top: 1px solid var(--ct777-border, #333); }

.sports-category__game-link {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  font-size: 12px !important;
  color: var(--ct777-text-muted, #999) !important;
  text-decoration: none !important;
  padding: 6px 6px 6px 4px !important;
  border-radius: 6px !important;
  transition: color 0.3s ease, background 0.3s ease !important;
  font-family: 'Montserrat', sans-serif !important;
}

.sports-category__game-link:hover { color: var(--ct777-accent, #00D4FF) !important; background: linear-gradient(135deg, rgba(0, 212, 255, 0.15), rgba(0, 212, 255, 0.08)) !important; }
.sports-category__game-link.active { color: var(--ct777-accent, #00D4FF) !important; font-weight: 600 !important; background: rgba(0, 212, 255, 0.1) !important; }

.sports-category__game-count { flex-shrink: 0; font-size: 11px; font-weight: 600; color: var(--ct777-text-muted, #888); }
.sports-category__games { list-style: none; padding: 0; margin: 6px 0 0 0; border-inline-start: 2px solid rgba(0, 212, 255, 0.25); margin-inline-start: 14px; padding-inline-start: 12px; }

/* Category search */
.sports-category__search-wrap { padding: 8px; border-bottom: 1px solid var(--ct777-border, #333); }
.sports-category__search { width: 100%; padding: 8px 12px 8px 36px; font-size: 14px; background: var(--ct777-dark-soft, #111827); border: 1px solid var(--ct777-border, #333); border-radius: 8px; color: var(--ct777-text, #fff); transition: border-color 0.3s ease; }
.sports-category__search:focus { border-color: var(--ct777-accent, #00D4FF); outline: none; }
.sports-category__search::placeholder { color: var(--ct777-text-muted, #999); }

.sports-category__link.sidebar-hidden,
.sports-category__item.sidebar-hidden,
.sports-category__top-leagues.sidebar-hidden,
.sports-category__heading.sidebar-hidden { display: none !important; }

/* Games toggle (show more) */
.sports-category__games-more { overflow: hidden; max-height: 1500px; transition: max-height 0.3s ease, opacity 0.3s ease; }
.sports-category__games-more.collapsed { max-height: 0 !important; margin: 0 !important; padding: 0 !important; opacity: 0; pointer-events: none; }
.sports-category__games-toggle { display: inline-flex; align-items: center; gap: 6px; margin-top: 6px; margin-inline-start: 14px; padding: 6px 10px; font-size: 12px; font-weight: 500; color: var(--ct777-accent, #00D4FF); background: transparent; border: 1px solid rgba(0, 212, 255, 0.3); border-radius: 6px; cursor: pointer; }
.sports-category__games-toggle:hover { background: rgba(0, 212, 255, 0.1); }

/* Collapsible sidebar */
.sports-category--collapsed { width: 72px !important; min-width: 72px !important; }
.sports-category--collapsed .sports-category__text, .sports-category--collapsed .sports-category__search-wrap,
.sports-category--collapsed .sports-category__games, .sports-category--collapsed .sports-category__stats,
.sports-category--collapsed .sports-category__block, .sports-category--collapsed .sports-category__heading { display: none !important; }
.sports-category--collapsed .sports-category__link { justify-content: center; padding-inline-start: 8px; padding-inline-end: 8px; }

/* Esports Hub */
.sports-category__esports-hub { padding: 10px 12px; margin: 8px; background: linear-gradient(135deg, rgba(0, 212, 255, 0.15), rgba(0, 212, 255, 0.2)); border: 1px solid rgba(0, 212, 255, 0.3); border-radius: 8px; }
.sports-category__esports-hub-title { font-size: 12px; font-weight: 700; color: var(--ct777-accent, #00D4FF); text-transform: uppercase; letter-spacing: 0.1em; display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }

/* Heading */
.sports-category--premium .sports-category__heading { padding: 14px 12px 10px; margin-bottom: 4px; border-bottom: 1px solid rgba(0, 212, 255, 0.2); }
.sports-category--premium .sports-category__heading-text { font-size: 12px; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; color: var(--ct777-accent, #00D4FF); }
.sports-category--premium .sports-category__stats { margin: 0 10px 14px; padding: 12px 14px; background: rgba(0, 0, 0, 0.2); border: 1px solid rgba(255, 255, 255, 0.08); border-radius: 10px; }
.sports-category--premium .sports-category__link.live-btn { padding: 14px 14px !important; margin-bottom: 8px; border-radius: 10px !important; }
.sports-category--premium .sports-category__list { display: flex; flex-direction: column; gap: 6px; padding: 12px 10px 20px; flex: 1 !important; min-height: 0 !important; overflow-y: auto !important; overflow-x: hidden !important; }



/* ==========================================================================
   6. CARDS - SPORTS CARDS, GAME CARDS
   ========================================================================== */

/* Professional flat cards (overrides heavy theme shadows) */
.sports-card, .sports-card-wrapper {
  background: linear-gradient(145deg, var(--ct777-dark-card) 0%, rgba(37, 37, 37, 0.95) 100%) !important;
  border: 1px solid var(--ct777-border, rgba(255, 255, 255, 0.1)) !important;
  border-radius: 6px !important;
  box-shadow: none !important;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.sports-card:hover { border-color: rgba(0, 212, 255, 0.3); transform: translateY(-1px); }

.cafetal777-layout .sports-card { background: var(--gb-card-bg) !important; border-radius: 8px; overflow: hidden; margin-bottom: 12px; }
.cafetal777-layout .sports-card-wrapper { background: transparent !important; }
.cafetal777-layout .sports-card-left { background: rgba(0, 0, 0, 0.15) !important; border-inline-end: 1px solid var(--gb-card-border); }
.cafetal777-layout .sports-card-heading { background: rgba(0, 0, 0, 0.2) !important; color: var(--gb-text-muted); font-size: 12px; }
.cafetal777-layout .sports-card__info-text, .cafetal777-layout .sports-card__stream { color: var(--gb-text-muted); }
.cafetal777-layout .sports-card__stream.live, .cafetal777-layout .sports-card__stream .text--danger { color: #ff4444 !important; }
.cafetal777-layout .sports-card-body { color: var(--gb-text); }
.cafetal777-layout .sports-card-inner { border-inline-end: 1px solid var(--gb-card-border); }
.cafetal777-layout .sports-card-inner .sports-card-heading { background: rgba(0, 0, 0, 0.15) !important; }
.cafetal777-layout .team-select-title { color: var(--gb-text-muted); font-size: 12px; }

/* Cards and panels - dark */
.card { background: var(--ct777-dark-card) !important; border: 1px solid var(--ct777-border); border-radius: 10px; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3); color: var(--ct777-text) !important; transition: transform 0.2s ease-out, box-shadow 0.2s ease-out; }
.card:not(.card--static):hover { transform: translateY(-2px); box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3); }
.card-body { padding: 20px; color: var(--ct777-text) !important; }
.card-header { background: rgba(0, 212, 255, 0.2) !important; border-bottom: 1px solid var(--ct777-border); padding: 16px 20px; color: var(--ct777-text) !important; }
.card-footer { background: var(--ct777-dark-card) !important; border-color: var(--ct777-border) !important; color: var(--ct777-text) !important; }

/* Modals dark */
.modal-content, .modal-body, .modal-header, .modal-footer { background: var(--ct777-dark-card) !important; border-color: var(--ct777-accent) !important; color: var(--ct777-text) !important; }

/* Dropdowns dark */
.dropdown-menu { background: var(--ct777-dark-card) !important; color: var(--ct777-text) !important; border: 1px solid var(--ct777-accent) !important; }
.dropdown-item { background: var(--ct777-dark-card) !important; color: var(--ct777-text) !important; }
.dropdown-item:hover, .dropdown-item:focus { background: rgba(0, 212, 255, 0.1) !important; color: var(--ct777-accent) !important; }

/* List groups */
.list-group { background: var(--ct777-dark-card); border: 1px solid var(--ct777-border); border-radius: 8px; }
.list-group-item { background: var(--ct777-dark-card) !important; border-color: var(--ct777-border) !important; color: var(--ct777-text-muted); padding: 14px 16px; }

/* Accordions dark */
.accordion-item, .accordion-button, .accordion-body, .accordion-header { background: var(--ct777-dark-card) !important; color: var(--ct777-text) !important; border-color: var(--ct777-border) !important; }
.accordion-button:not(.collapsed) { background: var(--ct777-dark-soft) !important; color: var(--ct777-accent) !important; }


/* ==========================================================================
   7. TABLES - SPORT HUB, SPORT TABLE
   ========================================================================== */

/* Professional sport hub (flat, clean) */
.sport-hub--creative {
  border-radius: 6px !important;
  border: 1px solid var(--ct777-border, rgba(255, 255, 255, 0.1)) !important;
  background: var(--ct777-dark-card, #0B0F14) !important;
  overflow: hidden;
  margin-bottom: 1.5rem;
}

.sport-hub__header--creative, .sport-hub__header {
  background: var(--ct777-dark-soft, #1A2233) !important;
  border-bottom: 1px solid var(--ct777-border, rgba(255, 255, 255, 0.1)) !important;
  padding: 10px 12px !important;
}

.sport-hub__tabs { background: var(--ct777-dark-soft, #1A2233) !important; border-bottom: 1px solid var(--ct777-border) !important; padding: 0 12px !important; display: flex; gap: 0; margin: 0; list-style: none; }

.sport-hub__tab { padding: 12px 20px; font-weight: 600; font-size: 0.9rem; color: var(--ct777-text-muted); background: none; border: none; border-bottom: 3px solid transparent; margin-bottom: -2px; cursor: pointer; transition: color 0.2s, border-color 0.2s; }
.sport-hub__tab:hover { color: var(--ct777-text); }
.sport-hub__tab.active { color: var(--ct777-accent); border-bottom-color: var(--ct777-accent); }

.sport-hub__tabs--pills .sport-hub__tab { padding: 8px 12px; margin-inline-end: 4px; border-radius: 4px !important; font-size: 0.85rem; font-weight: 500; border: none; background: transparent; }
.sport-hub__tabs--pills .sport-hub__tab.active { background: var(--ct777-dark-soft, #1A2233) !important; color: var(--ct777-accent, #00D4FF) !important; border: 1px solid var(--ct777-accent, #00D4FF) !important; }
.sport-hub__tab:focus-visible { outline: 2px solid var(--ct777-accent, #00D4FF); outline-offset: 2px; border-radius: 4px; }

.sport-hub__title { font-size: 1rem; font-weight: 600; text-transform: none; letter-spacing: 0; margin: 0; color: var(--ct777-text); }
.sport-hub__match-badge { font-size: 0.75rem; padding: 3px 8px; background: var(--ct777-dark-soft, #1A2233); border: 1px solid var(--ct777-border); border-radius: 4px !important; color: var(--ct777-accent, #00D4FF); font-weight: 600; }

.sport-hub__toolbar { background: var(--ct777-dark-soft, #1A2233) !important; border-bottom: 1px solid var(--ct777-border) !important; padding: 10px 16px !important; gap: 12px !important; display: flex; flex-wrap: wrap; align-items: center; }

.sport-hub__content { display: grid; grid-template-columns: 1fr; gap: 0; }
.sport-hub__main { min-width: 0; }
.sport-hub__sidebar { padding: 16px; border-top: 1px solid var(--ct777-border); }

@media (min-width: 992px) {
  .sport-hub__content { grid-template-columns: 1fr 300px !important; gap: 0 !important; }
  .sport-hub__sidebar { border-inline-start: 1px solid var(--ct777-border) !important; border-top: none !important; }
}

.sport-hub-section-wrap { margin-bottom: 1rem !important; }
.sport-hub-section-wrap:last-child { margin-bottom: 0 !important; }

/* Sport table */
.sport-table-wrap { border-top: 1px solid var(--ct777-border) !important; overflow-x: auto; }
.sport-table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.sport-table__th { padding: 8px 10px; font-size: 0.875rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.02em; background: var(--ct777-dark-soft, #1A2233); border-bottom: 1px solid var(--ct777-border); white-space: nowrap; text-align: start; }
.sport-table__cell { padding: 10px; font-size: 0.9rem; line-height: 1.5; border-bottom: 1px solid var(--ct777-border, rgba(255, 255, 255, 0.05)); vertical-align: middle; color: var(--ct777-text); }
.sport-table__row { border-bottom: 1px solid var(--ct777-border); transition: background 0.15s; }
.sport-table__row:hover { background: rgba(255, 255, 255, 0.06); }
.sport-table__row--creative { background: transparent !important; }
.sport-table__row--creative:hover { background: var(--ct777-dark-soft, #1A2233) !important; }
.sport-table__row--today { background: var(--ct777-dark-soft, #1A2233) !important; }
.sport-table__team { font-weight: 500; }
.sport-table__match-link { color: var(--ct777-text); text-decoration: none; }
.sport-table__match-link:hover { color: var(--ct777-accent); }
.sport-table__league { font-size: 0.85rem; color: var(--ct777-text-muted); display: block; margin-top: 2px; }
.sport-table__more { font-size: 0.8rem; color: var(--ct777-text-muted, #999) !important; text-decoration: none; }
.sport-table__more:hover { color: var(--ct777-text, #e0e0e0) !important; }
.sport-table__empty { padding: 32px 16px; text-align: center; color: var(--ct777-text-muted); }

/* Gradient border for featured matches */
.sport-table__row--featured,
.sport-table__row--promoted,
.match-card--featured {
  position: relative;
  border: none;
}

.sport-table__row--featured::before,
.sport-table__row--promoted::before,
.match-card--featured::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: var(--ct-brand-gradient, linear-gradient(135deg, #00D4FF, #7C3AED));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}

/* Animated gradient border */
@keyframes ct-gradient-rotate {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

.gradient-border-animated::before {
  background: linear-gradient(270deg, #00D4FF, #7C3AED, #00D4FF);
  background-size: 200% 200%;
  animation: ct-gradient-rotate 3s ease infinite;
}

/* Utility class for any element needing gradient border */
.gradient-border {
  position: relative;
  border: none !important;
}

.gradient-border::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: var(--ct-brand-gradient, linear-gradient(135deg, #00D4FF, #7C3AED));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  opacity: 0.6;
}

/* Tables dark */
.table, .table tbody, .table thead, .table tfoot { background: transparent !important; color: var(--ct777-text) !important; }
.table thead th { background: var(--ct777-dark-soft) !important; border-color: var(--ct777-border) !important; color: var(--ct777-accent) !important; }
.table tbody td { background: transparent !important; border-color: var(--ct777-border) !important; color: rgba(255, 255, 255, 0.92) !important; }
.table-striped tbody tr:nth-of-type(odd) { background: rgba(255, 255, 255, 0.04) !important; }
.table tbody tr { transition: background-color 0.15s ease; }
.table tbody tr:hover { background-color: rgba(255, 255, 255, 0.06); }

/* Custom table (dashboard) */
.custom--table { background: var(--ct777-dark-card) !important; border-radius: 8px; overflow: hidden; }
.custom--table thead { background: linear-gradient(135deg, var(--ct777-primary) 0%, var(--ct777-dark-soft) 100%) !important; border-bottom: 2px solid var(--ct777-accent); }
.custom--table thead th { color: var(--ct777-accent, #00D4FF); font-weight: 600; padding: 14px 16px; border: none; font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.03em; }
.custom--table tbody td { background: var(--ct777-dark-card); color: rgba(255, 255, 255, 0.92); border-bottom: 1px solid var(--ct777-border); padding: 14px 16px; }
.custom--table tbody tr:hover { background: rgba(0, 212, 255, 0.05) !important; }
.custom--table tbody tr:last-child td { border-bottom: none; }
.table-responsive { border: 1px solid var(--ct777-border); border-radius: 8px; background: var(--ct777-dark-card); }

/* Live widget */
.sport-widget, .sport-widget--creative { background: var(--ct777-dark-card, #0B0F14) !important; border: 1px solid var(--ct777-border) !important; border-radius: 6px !important; box-shadow: none !important; overflow: hidden; }
.sport-widget__title, .sport-widget__title--creative { font-size: 0.9rem; font-weight: 600; padding: 10px 12px; border-bottom: 1px solid var(--ct777-border); background: var(--ct777-dark-soft, #1A2233); border-radius: 6px 6px 0 0; margin: 0; color: var(--ct777-text); display: flex; align-items: center; gap: 8px; }
.sport-widget__live-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--ct777-error, #e00); }
.sport-widget__item { padding: 10px 12px; border-bottom: 1px solid var(--ct777-border, rgba(255, 255, 255, 0.05)); }
.sport-widget__item:last-child { border-bottom: none; }
.sport-widget__item:hover { background: rgba(255, 255, 255, 0.05); transition: background 0.15s ease; }
.sport-widget__odd { font-size: 0.8rem; min-width: 36px; min-height: 32px; padding: 4px 8px; border-radius: 4px; border: 1px solid var(--ct777-border); background: var(--ct777-dark-card); color: var(--ct777-text); text-align: center; }
.sport-widget__odd:hover:not(:disabled) { border-color: var(--ct777-accent); background: rgba(0, 212, 255, 0.1); }


/* ==========================================================================
   8. FORMS
   ========================================================================== */

.form-control, .form--control {
  background: var(--ct777-dark-soft) !important;
  border: 1px solid var(--ct777-border) !important;
  color: var(--ct777-text) !important;
  border-radius: 6px;
  padding: 10px 14px;
  font-size: 0.875rem;
  transition: all 0.3s ease;
}

.form-control:focus, .form--control:focus {
  background: var(--ct777-dark-soft) !important;
  border-color: var(--ct777-accent) !important;
  color: var(--ct777-text) !important;
  box-shadow: 0 0 0 3px rgba(0, 212, 255, 0.15);
  outline: none;
}

.form-control::placeholder, .form--control::placeholder, input::placeholder, textarea::placeholder { color: var(--ct777-text-muted) !important; }

.form-label, label { color: var(--ct777-text); font-weight: 500; margin-bottom: 8px; }

.form-select { background: var(--ct777-dark-card) !important; border: 1px solid var(--ct777-border) !important; color: var(--ct777-text) !important; }
.form-select:focus { background: var(--ct777-dark) !important; border-color: var(--ct777-accent) !important; box-shadow: 0 0 10px rgba(0, 212, 255, 0.2) !important; color: var(--ct777-text) !important; }

/* Input groups */
.input-group-text { background: var(--ct777-dark-soft) !important; border: 1px solid var(--ct777-border) !important; color: var(--ct777-text) !important; }

/* Checkboxes */
.form-check-input { background-color: var(--ct777-dark-soft) !important; border: 1px solid var(--ct777-border) !important; }
.form-check-input:checked { background-color: var(--ct777-accent) !important; border-color: var(--ct777-accent) !important; }
.form-check-label { color: var(--ct777-text) !important; }

/* Select2 */
.select2-container--default .select2-selection--single { background: var(--ct777-dark-soft) !important; border: 1px solid var(--ct777-border) !important; border-radius: 6px; height: 42px; }
.select2-container--default .select2-selection--single .select2-selection__rendered { color: var(--ct777-text) !important; line-height: 42px; padding-inline-start: 14px; }
.select2-dropdown { background: var(--ct777-dark-card) !important; border: 1px solid var(--ct777-border) !important; }
.select2-container--default .select2-results__option { color: var(--ct777-text) !important; padding: 10px 14px; }
.select2-container--default .select2-results__option--highlighted { background: var(--ct777-accent) !important; color: var(--ct777-dark) !important; }

/* Date Range Picker */
.daterangepicker { background: var(--ct777-dark-card) !important; border: 1px solid var(--ct777-border) !important; color: var(--ct777-text) !important; }
.daterangepicker .calendar-table { background: var(--ct777-dark-card) !important; }
.daterangepicker .calendar-table th, .daterangepicker .calendar-table td { color: var(--ct777-text) !important; }
.daterangepicker .calendar-table .available:hover { background: var(--ct777-accent) !important; color: var(--ct777-dark) !important; }
.daterangepicker td.active, .daterangepicker td.active:hover, .daterangepicker .ranges li.active { background-color: var(--ct777-accent) !important; color: var(--ct777-dark) !important; }

/* Textarea */
textarea.form-control, textarea.form--control { min-height: 120px; resize: vertical; }

/* File Input */
.form-control[type="file"]::file-selector-button { background: var(--ct777-accent) !important; color: var(--ct777-dark) !important; border: none; padding: 8px 16px; border-radius: 4px; margin-inline-end: 12px; cursor: pointer; font-weight: 600; }
.form-control[type="file"]::file-selector-button:hover { background: var(--ct-brand-primary, #00D4FF) !important; }


/* ==========================================================================
   9. BUTTONS
   ========================================================================== */

.btn { font-weight: 600; padding: 10px 20px; border-radius: 6px; transition: all 0.3s ease; position: relative; overflow: hidden; }
.btn:active:not(:disabled) { transform: scale(0.97); }
.btn:disabled, .btn.disabled { opacity: 0.4; cursor: not-allowed; }

.btn--base, .btn--signup, .bet-type__btn:has(input:checked) span, .betslip__footer-btn, .modal .btn--lg.btn--base, .btn-primary {
  background: linear-gradient(135deg, #00D4FF, #00A3CC) !important;
  color: #0B0F14 !important;
  border-color: #00D4FF !important;
  font-weight: 600;
  box-shadow: 0 4px 12px rgba(0, 212, 255, 0.25);
}

.btn--base:hover, .btn--signup:hover, .betslip__footer-btn:hover, .btn-primary:hover {
  background: linear-gradient(135deg, #33DDFF, #00D4FF) !important;
  color: #0B0F14 !important;
  box-shadow: 0 6px 20px rgba(0, 212, 255, 0.4);
  transform: translateY(-2px);
  filter: brightness(1.1);
}

.btn--base:active, .btn--signup:active, .betslip__footer-btn:active, .btn-primary:active {
  background: linear-gradient(135deg, #00A3CC, #0891B2) !important;
  box-shadow: 0 2px 8px rgba(0, 212, 255, 0.2);
  transform: translateY(0);
  filter: brightness(0.95);
}

.btn--danger, .btn-danger { background: var(--ct777-error) !important; color: var(--ct777-text) !important; border-color: var(--ct777-error); }
.btn--success, .btn-success { background: var(--ct777-success) !important; color: var(--ct777-dark) !important; border-color: var(--ct777-success); }

.btn-outline--base, .btn-outline-primary { border: 2px solid var(--ct777-accent) !important; color: var(--ct777-accent) !important; background: transparent; }
.btn-outline--base:hover, .btn-outline-primary:hover { background: var(--ct777-accent) !important; color: var(--ct777-dark) !important; }

.cmn-btn { background: linear-gradient(135deg, #00D4FF, #00A3CC) !important; color: #0B0F14 !important; border-color: #00D4FF !important; }


/* ==========================================================================
   10. BADGES & TEXT COLORS
   ========================================================================== */

.badge { padding: 6px 12px; border-radius: 4px; font-weight: 600; font-size: 0.75rem; }
.badge--success, .bg-success { background: var(--ct777-success) !important; color: var(--ct777-dark) !important; }
.badge--danger, .bg-danger { background: var(--ct777-error) !important; color: var(--ct777-text) !important; }
.badge--warning, .bg-warning { background: #F59E0B !important; color: #0B0F14 !important; }
.badge--primary { background: rgba(0, 212, 255, 0.2) !important; color: #00D4FF !important; }

.text--base, .text-primary { color: var(--ct777-accent) !important; }
.text--success { color: var(--ct777-success) !important; }
.text--danger { color: var(--ct777-error) !important; }

/* Links */
a { color: var(--ct777-accent); transition: color 0.3s ease; }
a:hover { color: var(--ct-brand-primary, #00D4FF); }
.t-link--base, a.t-link--base { color: var(--ct777-accent) !important; }
.t-link--base:hover { color: var(--ct-brand-primary, #00D4FF) !important; }


/* ==========================================================================
   11. BET COMPONENTS - BETSLIP, ODDS, MARKETS
   ========================================================================== */

/* Odds buttons (Professional: clean, functional) */
.oddBtn {
  min-width: 44px !important;
  min-height: 40px !important;
  padding: 6px 10px !important;
  font-size: 0.85rem !important;
  font-weight: 600 !important;
  color: var(--ct-text-primary, #E8EDF5) !important;
  border: 1px solid rgba(232, 237, 245, 0.12) !important;
  border-radius: 6px !important;
  background: rgba(26, 34, 51, 0.8) !important;
  transition: background 0.15s, border-color 0.15s, color 0.15s, transform 0.15s !important;
  font-family: var(--ct-font-tabular, 'JetBrains Mono', monospace);
  text-align: center;
}

.oddBtn:hover:not(.locked):not(:disabled) { background: rgba(32, 43, 62, 0.95) !important; border-color: rgba(0, 212, 255, 0.3) !important; color: #00D4FF !important; transform: translateY(-1px); }
.oddBtn.active { background: var(--ct777-accent, #00D4FF) !important; color: #000 !important; border-color: var(--ct777-accent, #00D4FF) !important; box-shadow: 0 0 16px rgba(0, 212, 255, 0.3); }
.oddBtn.locked { opacity: 0.5 !important; cursor: not-allowed !important; }

/* Betslip */
.betslip {
  background: linear-gradient(180deg, #2d3530 0%, #363d38 8%, #3a403b 100%) !important;
  border-inline-start: 3px solid var(--ct777-accent) !important;
  box-shadow: -4px 0 24px rgba(0, 0, 0, 0.35) !important;
  padding: 0 !important;
  flex-shrink: 0 !important;
  width: var(--ct777-betslip-width) !important;
  min-width: var(--ct777-betslip-width) !important;
  display: flex !important;
  flex-direction: column !important;
  max-height: calc(100vh - var(--header-h, 67px)) !important;
  position: sticky !important;
  right: 0;
  top: var(--header-h, 67px) !important;
  z-index: var(--ct-z-sticky) !important;
  align-self: flex-start;
  overflow: hidden !important;
}

.betslip-header { background: linear-gradient(135deg, rgba(0, 212, 255, 0.4), #111827 50%, #1A2233) !important; border-bottom: 2px solid var(--ct777-accent) !important; padding: 12px 16px !important; }
.bet-type { display: flex !important; gap: 8px !important; }
.bet-type__btn { padding: 10px 16px !important; border-radius: 8px !important; }
.bet-type__btn span { color: #c8c8c8 !important; font-weight: 600 !important; font-size: 0.8rem !important; }
.bet-type__btn:has(input:checked) { background: linear-gradient(135deg, var(--ct777-accent) 0%, var(--ct-brand-primary-dark, #00A3CC) 100%) !important; border-color: var(--ct777-accent) !important; }
.bet-type__btn:has(input:checked) span { color: #1a1a1a !important; }

.betslip__body { background: var(--ct777-dark-card) !important; padding: 16px !important; border-bottom: 1px solid var(--ct777-border) !important; overflow-y: auto !important; flex: 1 1 0% !important; min-height: 0 !important; }

.betslip__body::-webkit-scrollbar { width: 8px; }
.betslip__body::-webkit-scrollbar-track { background: var(--ct777-dark-soft); border-radius: 4px; }
.betslip__body::-webkit-scrollbar-thumb { background: var(--ct777-accent); border-radius: 4px; }

.betslip__footer { background: linear-gradient(180deg, #111827 0%, #1A2233 100%) !important; border-top: 2px solid var(--ct777-accent) !important; padding: 20px 16px !important; flex-shrink: 0 !important; position: sticky !important; bottom: 0 !important; z-index: 2 !important; }
.betslip__footer-btn { background: linear-gradient(135deg, #00D4FF, #0891B2) !important; color: #0B0F14 !important; border-radius: 10px !important; padding: 14px 24px !important; font-weight: 700 !important; border: none !important; font-size: 0.95rem !important; box-shadow: 0 4px 12px rgba(0, 212, 255, 0.25) !important; }
.betslip__footer-btn:hover { background: linear-gradient(135deg, #33DDFF, #00D4FF) !important; box-shadow: 0 6px 20px rgba(0, 212, 255, 0.35) !important; filter: brightness(1.1); }

/* Bet slip list items */
.betslip-item, .betslip__list li { background: var(--ct777-dark-card, #1A2233) !important; border: 1px solid rgba(255, 255, 255, 0.1) !important; border-radius: 10px !important; margin-bottom: 10px !important; overflow: hidden; transition: border-color 0.2s ease !important; }
.betslip-item:hover, .betslip__list li:hover { border-color: rgba(0, 212, 255, 0.2) !important; }
.betslip__list { list-style: none !important; padding: 0 !important; margin: 0 !important; }

.betslip-item-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 12px; border-bottom: 1px solid rgba(255, 255, 255, 0.06); background: transparent !important; }
.betslip-item-body { padding: 10px 12px; background: transparent !important; }
.betslip-item-league p, .betslip-item-league .betslip-item-league__name { color: var(--ct777-text) !important; font-size: 0.85rem !important; font-weight: 600 !important; }

.betslip-item-close { width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; border-radius: 6px; background: rgba(255, 255, 255, 0.06); border: none; color: rgba(255, 255, 255, 0.5); cursor: pointer; transition: all 0.2s ease; flex-shrink: 0; }
.betslip-item-close:hover { background: rgba(239, 68, 68, 0.15); color: #f87171; }

.betslip-item-market { margin-top: 8px; }
.betslip-item-market__type { font-size: 0.72rem; color: rgba(255, 255, 255, 0.5); text-transform: uppercase; letter-spacing: 0.03em; margin-bottom: 4px; }
.betslip-item-market__score {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 56px;
  padding: 4px 10px;
  background: var(--ct777-accent, #00D4FF);
  color: var(--ct777-dark, #1a1a1a);
  font-weight: 700;
  font-size: 0.875rem;
  border-radius: 6px;
  text-align: center;
}

.betslip-item-market__wrapper {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.betslip-item-market__label {
  font-size: 0.85rem;
  font-weight: 600;
  color: #fff;
}

.betslip-item-teams {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

.betslip-item-team {
  display: flex;
  align-items: center;
  gap: 6px;
  flex: 1;
  min-width: 0;
}

.betslip-item-team__logo {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}

.betslip-item-team__name {
  font-size: 0.8rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.92);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.betslip-item-stake {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.betslip-item-stake__label {
  font-size: 0.72rem;
  color: rgba(255, 255, 255, 0.5);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  margin-bottom: 4px;
}

.betslip-item-return { display: flex; justify-content: space-between; align-items: center; margin-top: 8px; padding: 6px 10px; background: rgba(0, 212, 255, 0.05); border-radius: 6px; }
.betslip-item-return__text { font-size: 0.78rem; color: rgba(255, 255, 255, 0.6); }
.betslip-item-return .bet-return-amount, .bet-return-amount { font-weight: 600; color: var(--ct777-accent, #00D4FF); }

.bet-slip-container, .mybet-container { background: transparent !important; display: flex !important; flex-direction: column !important; flex: 1 !important; overflow: hidden !important; min-height: 0 !important; }
.betslip-inner { display: flex !important; flex-direction: column !important; flex: 1 1 auto !important; overflow: hidden !important; min-height: 0 !important; }

.empty-slip-message { color: #a8a8a8 !important; padding: 2rem 1rem !important; text-align: center !important; }

.mybet-container .empty-slip-message {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 250px;
  padding: 2rem 1rem;
  text-align: center;
  color: rgba(232, 237, 245, 0.5);
}

.mybet-container .empty-slip-message img {
  max-width: 100px;
  height: auto;
  opacity: 0.5;
  margin-bottom: 1rem;
}

/* ---- Slip Nudges ---- */
.slip-nudge {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  margin: 8px 0;
  border-radius: 8px;
  font-size: 0.8rem;
  line-height: 1.4;
  animation: ct-fade-up 0.3s ease-out;
}

.slip-streak-nudge {
  background: rgba(0, 212, 255, 0.08);
  border: 1px solid rgba(0, 212, 255, 0.2);
  color: var(--ct777-accent, #00D4FF);
}

.responsible-gaming-nudge {
  background: rgba(59, 130, 246, 0.08);
  border: 1px solid rgba(59, 130, 246, 0.2);
  color: #93c5fd;
}

.slip-nudge__icon {
  font-size: 1rem;
  flex-shrink: 0;
}

.slip-nudge__text {
  flex: 1;
}

.slip-nudge__link {
  color: #93c5fd;
  text-decoration: underline;
  text-decoration-color: rgba(147, 197, 253, 0.4);
}

.slip-nudge__link:hover {
  color: #bfdbfe;
  text-decoration-color: #bfdbfe;
}

/* ---- Slip Smart Stats ---- */
.slip-smart-stats {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 0;
  margin-bottom: 8px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  font-size: 0.8rem;
}

.slip-smart-stats__odds {
  color: var(--ct777-accent, #00D4FF);
  font-weight: 600;
}

.slip-smart-stats__risk {
  color: rgba(255, 255, 255, 0.6);
  font-size: 0.75rem;
}

/* ---- Slip Builder Hint ---- */
.slip-builder-hint {
  padding: 8px 14px;
  font-size: 0.8rem;
  color: rgba(255, 255, 255, 0.7);
  border-radius: 6px;
  background: rgba(0, 212, 255, 0.05);
  transition: opacity 0.3s ease, max-height 0.3s ease;
}

.slip-builder-hint--hidden {
  opacity: 0;
  max-height: 0;
  padding: 0;
  overflow: hidden;
}

/* ---- Slip Copy Button ---- */
.slip-copy-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 8px 12px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 8px;
  color: rgba(255, 255, 255, 0.8);
  font-size: 0.8rem;
  cursor: pointer;
  transition: all 0.2s ease;
}

.slip-copy-btn:hover {
  background: rgba(0, 212, 255, 0.1);
  border-color: rgba(0, 212, 255, 0.3);
  color: var(--ct777-accent, #00D4FF);
}

/* ---- Balance Warning ---- */
.balance-warning {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 6px 10px;
  margin: 6px 0;
  background: rgba(245, 158, 11, 0.1);
  border: 1px solid rgba(245, 158, 11, 0.2);
  border-radius: 6px;
  font-size: 0.78rem;
  color: #fbbf24;
}

/* ---- Betslip Footer Bottom polish ---- */
.betslip__footer-bottom {
  display: flex;
  align-items: center;
  gap: 8px;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.betslip__footer-bottom .delete-btn {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid rgba(239, 68, 68, 0.2);
  color: #f87171;
  font-size: 1.1rem;
  cursor: pointer;
  transition: all 0.2s ease;
  flex-shrink: 0;
}

.betslip__footer-bottom .delete-btn:hover {
  background: rgba(239, 68, 68, 0.2);
  border-color: rgba(239, 68, 68, 0.4);
  color: #fca5a5;
}

.betslip__footer-bottom .place-btn {
  flex: 1;
}

/* ---- Empty Slip Rotating Tip ---- */
.empty-slip-rotating-tip {
  display: block;
  margin-top: 8px;
  font-size: 0.78rem;
  color: rgba(255, 255, 255, 0.5);
  font-style: italic;
  transition: opacity 0.3s ease;
}

/* ---- Login Message (My Bets - guest) ---- */
.login-message {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 200px;
  padding: 2rem;
  text-align: center;
}

.login-message-text {
  color: rgba(255, 255, 255, 0.6);
  font-size: 0.9rem;
}

/* Footer labels */
.betslip__list-text, .betslip__list-odd { color: var(--ct777-accent) !important; font-weight: 600 !important; }
.betslip__list-match, .betslip__list-team .name { color: #e8e8e8 !important; }
.bet-return .total-return-amount { color: var(--ct777-accent) !important; font-weight: 700 !important; font-size: 1rem !important; }

/* My Bets tab */
.mybet-container .bet-list-item, .mybet-container .single-bet { background: #1A2233 !important; border: 1px solid rgba(0, 212, 255, 0.2) !important; border-radius: 10px !important; color: #e8e8e8 !important; padding: 12px !important; margin-bottom: 10px !important; }

/* My Bets list polish */
.mybet-container .bet-list-item {
  background: var(--ct777-dark-card, #1A2233);
  border: 1px solid rgba(0, 212, 255, 0.15);
  border-radius: 10px;
  padding: 0;
  margin-bottom: 12px;
  overflow: hidden;
}

.mybet-container .bet-list-item__body {
  padding: 12px 14px;
}

.mybet-container .bet-list-item__footer {
  padding: 10px 14px;
  background: rgba(255, 255, 255, 0.03);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.mybet-container .bet-single {
  padding-bottom: 10px;
  margin-bottom: 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.mybet-container .bet-single:last-child {
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom: 0;
}

.bet-single__teams {
  font-size: 0.85rem;
  color: rgba(255, 255, 255, 0.92);
  margin-bottom: 4px;
}

.bet-single__vs {
  color: rgba(255, 255, 255, 0.5);
  margin: 0 4px;
  font-size: 0.75rem;
}

.bet-single__selected-team .name {
  color: var(--ct777-accent, #00D4FF);
  font-weight: 600;
  font-size: 0.85rem;
}

.bet-market_type {
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.6);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.bet-single-info {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.bet-single-info__item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.bet-single-info__item .label {
  font-size: 0.72rem;
  color: rgba(255, 255, 255, 0.6);
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.bet-single-info__item .value {
  font-size: 0.9rem;
  font-weight: 600;
  color: #fff;
}

.betslip-item-league {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 6px;
}

.betslip-item-league__name {
  font-size: 0.78rem;
  color: rgba(255, 255, 255, 0.7);
  font-weight: 500;
}

/* Markets page */
.odd-list { background: var(--ct777-dark) !important; color: var(--ct777-text) !important; padding: 20px 0; }
.odd-list__head { background: linear-gradient(135deg, var(--ct777-primary), var(--ct777-dark-soft)) !important; border: 2px solid var(--ct777-accent) !important; border-radius: 12px !important; padding: 24px 20px !important; margin-bottom: 24px !important; }
.odd-list__team-name { color: var(--ct777-text) !important; font-size: 0.875rem; font-weight: 600; }
.odd-list__team-img { width: 50px; height: 50px; border: 2px solid var(--ct777-accent) !important; border-radius: 50%; padding: 2px; }
.odd-list__team-divide { width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; border-radius: 8px; background: var(--ct777-accent) !important; color: var(--ct777-dark) !important; font-weight: 700; }

.accordion--odd .accordion-item { background: var(--ct777-dark-card) !important; border: 1px solid var(--ct777-border) !important; border-radius: 10px !important; overflow: hidden; }
.accordion--odd .accordion-button { background: transparent !important; color: var(--ct777-text) !important; padding: 16px 20px !important; font-weight: 600; box-shadow: none !important; }
.accordion--odd .accordion-button:not(.collapsed) { background: linear-gradient(135deg, rgba(0, 212, 255, 0.3), rgba(0, 212, 255, 0.15)) !important; color: var(--ct777-accent) !important; }

.odd-list__outcome.oddBtn { background: var(--ct777-dark-soft) !important; border: 2px solid var(--ct777-border) !important; color: var(--ct777-text) !important; padding: 10px 18px !important; border-radius: 8px !important; min-width: 70px; cursor: pointer; }
.odd-list__outcome.oddBtn:hover:not(.locked) { background: rgba(0, 212, 255, 0.15) !important; border-color: var(--ct777-accent) !important; color: var(--ct777-accent) !important; }
.odd-list__outcome.oddBtn.active { background: var(--ct777-accent) !important; border-color: var(--ct777-accent) !important; color: var(--ct777-dark) !important; }

/* Leagues strip */
.top-sticky, .leagues-bar { background: var(--ct777-dark-soft) !important; border-bottom: 1px solid var(--ct777-border); }
.leagues-strip { margin-bottom: 1rem; }
.leagues-strip__label { font-size: 0.85rem; font-weight: 600; color: var(--ct777-accent); display: inline-flex; align-items: center; gap: 6px; }
.leagues-strip__btn { border: 1px solid var(--ct777-border) !important; background: var(--ct777-dark-soft, #1A2233) !important; color: var(--ct777-text) !important; width: 36px; height: 36px; border-radius: 8px; display: inline-flex; align-items: center; justify-content: center; cursor: pointer; }
.leagues-strip__nav { display: none; gap: 6px; }

.sub-category-drawer {
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  padding: 8px 0;
}

.sub-category-drawer__list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.sub-category-drawer__link {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.85);
  font-size: 0.8rem;
  font-weight: 500;
  text-decoration: none;
  transition: all 0.2s ease;
  white-space: nowrap;
}

.sub-category-drawer__link:hover {
  background: rgba(0, 212, 255, 0.1);
  border-color: rgba(0, 212, 255, 0.3);
  color: var(--ct777-accent, #00D4FF);
}

.sub-category-drawer__link.active {
  background: rgba(0, 212, 255, 0.15);
  border-color: var(--ct777-accent, #00D4FF);
  color: var(--ct777-accent, #00D4FF);
}

.sub-category-drawer__flag {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  background: rgba(255, 255, 255, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
}

.sub-category-drawer__flag-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}

.sub-category-drawer__text {
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 160px;
}

.cafetal777-layout .sub-category-drawer { background: var(--gb-card-bg) !important; border: 1px solid var(--gb-card-border); border-radius: 8px; padding: 10px 14px; margin-bottom: 16px; overflow: visible !important; }
.cafetal777-layout .sub-category-drawer__list { display: flex; flex-wrap: wrap; gap: 8px; min-width: 0; }
.cafetal777-layout .sub-category-drawer__text { color: inherit; }

/* Instant Bet Widget */
.widget-box.instant-bet-widget { background: var(--ct777-dark-card) !important; border: 1px solid var(--ct777-border); border-radius: 10px; padding: 20px; margin-top: 20px; margin-bottom: 20px; display: block !important; }
.instant-bet-title { display: block; font-size: 1.5rem; font-weight: 700; color: var(--ct777-text) !important; margin-bottom: 20px; text-align: center; }
.instant-bet-input { background: var(--ct777-dark-soft) !important; border: 1px solid var(--ct777-border) !important; color: var(--ct777-text) !important; border-radius: 8px; padding: 12px 16px; width: 100%; font-size: 1rem; }
.instant-bet-input:focus { border-color: var(--ct777-accent) !important; box-shadow: 0 0 0 3px rgba(0, 212, 255, 0.1); outline: none; }
.instant-bet-btn { background: var(--ct777-accent) !important; color: var(--ct777-dark) !important; border: none; padding: 12px 24px; border-radius: 8px; font-weight: 600; width: 100%; margin-top: 8px; }
.instant-bet-btn:hover { background: var(--ct-brand-primary, #00D4FF) !important; }



/* ==========================================================================
   12. DASHBOARD
   ========================================================================== */

.user-dashboard { background: var(--ct777-dark) !important; color: var(--ct777-text) !important; min-height: calc(100vh - 120px); }

.user-header-primary { background: #0B0F14 !important; box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3); border-bottom: 2px solid rgba(0, 212, 255, 0.3); padding: 12px 0; }
.user-header-primary .logo img { max-height: 45px; }
.user-header-primary .btn--signup { background: linear-gradient(135deg, #00D4FF, #00A3CC) !important; color: #0B0F14 !important; border-color: #00D4FF; font-weight: 600; padding: 10px 24px; border-radius: 6px; }
.user-header-primary .btn--signup:hover { background: linear-gradient(135deg, #33DDFF, #00D4FF) !important; filter: brightness(1.1); }

.dashboard-wrapper { display: flex; align-items: flex-start; gap: 32px; --sidebar-width: 280px; }
.dashboard-right { width: calc(100% - (var(--sidebar-width) + 32px)); background: transparent; }
@media (max-width: 991px) { .dashboard-right { width: 100%; } }
.dashboard-right h5 { color: var(--ct777-text); font-family: "Montserrat", sans-serif; font-weight: 600; margin-bottom: 20px; }

/* Dashboard sidebar */
.dashboard-sidebar { width: var(--sidebar-width); flex-shrink: 0; position: sticky; top: 120px; }

@media (max-width: 991px) {
  .dashboard-sidebar { position: fixed; background: var(--ct777-dark-card) !important; z-index: 9999; transform: translateX(-100%); transition: all 0.3s ease; height: calc(100vh - var(--nav-h)); width: 320px; top: 0; left: 0; display: flex; flex-direction: column; }
  .dashboard-sidebar.active-sidebar { transform: translate(0); }
}

/* Widget card */
.widget-card { border-radius: 10px; border: 1px solid var(--ct777-border); background: var(--ct777-dark-card) !important; overflow: hidden; margin-bottom: 20px; }
.widget-card--primary { background: linear-gradient(135deg, var(--ct777-primary) 0%, var(--ct777-dark-soft) 100%) !important; border: 2px solid var(--ct777-accent); position: relative; overflow: hidden; }
.widget-card__head { display: flex; align-items: center; justify-content: space-between; padding: 14px 16px; background: rgba(0, 0, 0, 0.2); border-bottom: 1px solid rgba(0, 212, 255, 0.2); position: relative; z-index: 1; }
.widget-card__body { padding: 20px 16px; position: relative; z-index: 1; }
.widget-card__balance { margin: 0 0 8px 0; font-size: 2rem; font-weight: 700; color: var(--ct777-text); font-family: "Montserrat", sans-serif; }
.widget-card__deposit { background: var(--ct777-accent); color: var(--ct777-dark); border: none; font-size: 0.875rem; font-weight: 600; padding: 10px 16px; border-radius: 6px; transition: all 0.3s ease; display: inline-flex; align-items: center; gap: 6px; }
.widget-card__deposit:hover { background: var(--ct-brand-primary, #00D4FF); transform: translateY(-2px); }
.widget-card__withdraw { background: rgba(255, 255, 255, 0.1); color: var(--ct777-text); border: 1px solid rgba(255, 255, 255, 0.2); font-size: 0.875rem; font-weight: 600; padding: 10px 16px; border-radius: 6px; }
.widget-card__withdraw:hover { background: rgba(255, 255, 255, 0.2); color: var(--ct777-accent); border-color: var(--ct777-accent); }
.widget-card__reload { background: transparent; border: none; color: var(--ct777-text); font-size: 18px; cursor: pointer; padding: 4px 8px; border-radius: 4px; }
.widget-card__reload:hover { background: rgba(0, 212, 255, 0.2); color: var(--ct777-accent); transform: rotate(180deg); }
.widget-card__id { font-size: 13px; font-weight: 600; color: var(--ct777-text); display: flex; align-items: center; gap: 8px; }
.widget-card__id i { color: var(--ct777-accent); }

/* Dashboard menu */
.dashboard-menu { margin-top: 0; border: 1px solid var(--ct777-border); border-radius: 10px; background: var(--ct777-dark-card) !important; overflow: hidden; }
.dashboard-menu__list { list-style: none; padding: 0; margin: 0; }
.dashboard-menu__list li { border-bottom: 1px solid var(--ct777-border); }
.dashboard-menu__list li:last-child { border-bottom: none; }
.dashboard-menu__link { display: flex; align-items: center; gap: 12px; padding: 14px 16px; background: transparent; font-size: 14px; font-weight: 500; color: var(--ct777-text-muted); text-decoration: none; transition: all 0.3s ease; }
.dashboard-menu__link:hover { background: rgba(0, 212, 255, 0.1); color: var(--ct777-accent); padding-inline-start: 20px; }
.dashboard-menu__link.active { background: linear-gradient(90deg, rgba(0, 212, 255, 0.3), rgba(0, 212, 255, 0.15)); color: var(--ct777-accent); border-inline-start: 3px solid var(--ct777-accent); font-weight: 600; }
.dashboard-menu__icon { display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 24px; font-size: 18px; color: var(--ct777-accent); flex-shrink: 0; }

/* Dashboard welcome */
.dashboard-welcome { background: linear-gradient(135deg, var(--ct777-dark-card), rgba(0, 212, 255, 0.2), var(--ct777-dark-soft)) !important; border: 1px solid rgba(0, 212, 255, 0.2) !important; }
.dashboard-welcome__body { padding: 1.25rem !important; }
.dashboard-welcome__greeting { color: var(--ct777-text) !important; font-size: 1.35rem; font-weight: 700; }
.dashboard-welcome__meta { display: flex; flex-wrap: wrap; gap: 1rem; }
.dashboard-welcome__meta-item { font-size: 0.78rem; color: var(--ct777-text-muted) !important; opacity: 0.82; }

.dashboard-tier-badge { display: inline-flex; align-items: center; gap: 0.35rem; padding: 0.3rem 0.7rem; border-radius: 999px; background: rgba(255, 255, 255, 0.1); border: 1.5px solid var(--tier-color, var(--ct777-accent)); color: var(--tier-color, var(--ct777-accent)) !important; font-size: 0.78rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; }
.dashboard-quick-actions { display: flex; flex-wrap: wrap; gap: 0.5rem; justify-content: flex-end; }

/* Dashboard KPIs */
.dashboard-kpi { background: var(--ct777-dark-card) !important; border: 1px solid var(--ct777-border) !important; border-radius: 10px; transition: transform 0.2s ease, box-shadow 0.2s ease; }
.dashboard-kpi:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0, 0, 0, 0.3); border-color: rgba(0, 212, 255, 0.3) !important; }
.dashboard-kpi .card-body { padding: 1.25rem !important; }
.dashboard-kpi__icon { display: block; font-size: 1.5rem; margin-bottom: 0.35rem; }
.dashboard-kpi__value { font-size: 1.5rem; font-weight: 700; color: var(--ct777-accent) !important; font-family: "Montserrat", sans-serif; line-height: 1.2; }
.dashboard-kpi__label { font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.5px; color: var(--ct777-text-muted) !important; margin-top: 0.25rem; }

/* Dashboard stat pill */
.dashboard-stat-pill { display: inline-flex; flex-direction: column; align-items: flex-start; padding: 10px 16px; border-radius: 8px; background: rgba(255, 255, 255, 0.1); border: 1px solid var(--ct777-border); }
.dashboard-stat-pill__label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.5px; color: var(--ct777-text-muted) !important; margin-bottom: 4px; }
.dashboard-stat-pill__value { font-size: 1.25rem; font-weight: 700; color: var(--ct777-accent) !important; }

/* Dashboard chart card */
.dashboard-chart-card #betChart { width: 100%; max-height: 400px; }

/* Dashboard referral card */
.dashboard-referral-card { background: linear-gradient(135deg, var(--ct777-dark-card), rgba(0, 212, 255, 0.15)) !important; border: 1px solid rgba(0, 212, 255, 0.25) !important; }

/* QR Code Copy Form */
.qr-code-copy-form { display: flex; gap: 8px; margin-bottom: 12px; }
.qr-code-copy-form input { flex: 1; background: var(--ct777-dark-soft) !important; border: 1px solid var(--ct777-border) !important; color: var(--ct777-text) !important; padding: 10px 14px; border-radius: 6px; }
.copy-btn, .text-copy-btn { background: var(--ct777-accent) !important; color: var(--ct777-dark) !important; border: none; padding: 10px 20px; border-radius: 6px; font-weight: 600; cursor: pointer; }
.copy-btn:hover, .text-copy-btn:hover { background: var(--ct-brand-primary, #00D4FF) !important; }

/* Search form */
.search--form { position: relative; min-width: 250px; }
.search--form .form-control { padding-inline-end: 50px; }
.search--form .btn { position: absolute; right: 4px; top: 50%; transform: translateY(-50%); padding: 8px 16px; background: var(--ct777-accent) !important; color: var(--ct777-dark) !important; border: none; }

/* Action area */
.action-area { display: flex; gap: 8px; flex-wrap: wrap; }
.action-area .btn.active { background: var(--ct777-accent) !important; color: var(--ct777-dark) !important; border-color: var(--ct777-accent); }

/* Dashboard scrollbar */
.dashboard-sidebar::-webkit-scrollbar, .dashboard-menu::-webkit-scrollbar { width: 6px; }
.dashboard-sidebar::-webkit-scrollbar-track, .dashboard-menu::-webkit-scrollbar-track { background: var(--ct777-dark-soft); }
.dashboard-sidebar::-webkit-scrollbar-thumb, .dashboard-menu::-webkit-scrollbar-thumb { background: var(--ct777-accent); border-radius: 3px; }

/* ApexCharts */
#betChart { background: transparent; }
.apexcharts-canvas { background: transparent !important; }
.apexcharts-text { fill: var(--ct777-text) !important; }
.apexcharts-legend-text { color: var(--ct777-text) !important; }
.apexcharts-gridline { stroke: var(--ct777-border) !important; }


/* ==========================================================================
   13. MODALS - LOGIN, CONSENT, BET MODAL
   ========================================================================== */

/* Login page */
.login-page { min-height: calc(100vh - 120px); padding: 60px 0; background: linear-gradient(135deg, var(--ct777-dark), var(--ct777-primary)) !important; position: relative; }
.login-page::before { content: ""; position: absolute; inset: 0; background: rgba(0, 0, 0, 0.4); z-index: 0; }
.login-page .container { position: relative; z-index: 1; }
.login-form { background: var(--ct777-dark-card) !important; border: 2px solid var(--ct777-accent); border-radius: 10px; padding: 40px; box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5); }
.login-form__title { color: var(--ct777-text) !important; font-family: "Montserrat", sans-serif; font-weight: 700; margin-bottom: 24px; text-align: center; font-size: 1.75rem; }
.login-form__title::after { content: ""; display: block; width: 60px; height: 3px; background: var(--ct777-accent); margin: 12px auto 0; border-radius: 2px; }

.cafetal777-layout .login-page .login-form .form-control { background: var(--ct777-dark-soft); border: 1px solid var(--ct777-border); color: var(--ct777-text); }
.cafetal777-layout .login-page .login-form .form-control:focus { border-color: var(--ct777-accent); box-shadow: 0 0 0 2px rgba(0, 212, 255, 0.2); }
.cafetal777-layout .login-page .login-form a { color: var(--ct777-accent); }
.cafetal777-layout .login-page .login-form a:hover { color: var(--ct-brand-primary, #00D4FF); }

/* Modal */
.modal .modal-content, .login-modal .modal-content { background: var(--ct777-dark-card) !important; border: 1px solid var(--ct777-accent); border-radius: 8px; }
.modal .modal-title { color: var(--ct777-text) !important; }

/* Consent gate - must stack above .header-primary (mobile z-index ~8000) */
.consent-gate-overlay { position: fixed; inset: 0; z-index: var(--ct-z-consent) !important; background: linear-gradient(180deg, var(--ct777-primary) 0%, var(--ct777-dark) 50%) !important; display: flex; align-items: center; justify-content: center; padding: 20px; overflow-y: auto; }
.consent-gate { max-width: 520px; width: 100%; background: var(--ct777-dark-card) !important; border: 2px solid var(--ct777-accent); border-radius: 12px; padding: 2rem; color: var(--ct777-text); box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5); }
.consent-gate__title { font-size: 1.5rem; font-weight: 700; text-align: center; color: var(--ct777-text) !important; }
.consent-gate__sub { text-align: center; font-size: 0.875rem; color: var(--ct777-accent); margin: 0 0 1.25rem; }
.consent-gate__text { font-size: 0.9rem; line-height: 1.55; color: var(--ct777-text-muted); margin-bottom: 1.5rem; }
.consent-gate__btn--accept { background: var(--ct777-accent) !important; color: var(--ct777-dark) !important; border: 2px solid var(--ct777-accent); display: block; text-align: center; padding: 14px 24px; font-weight: 600; border-radius: 8px; }
.consent-gate__btn--accept:hover { background: var(--ct-brand-primary, #00D4FF) !important; }
.consent-gate__btn--deny { background: var(--ct777-dark-soft) !important; color: var(--ct777-text) !important; border: 2px solid var(--ct777-border); display: block; text-align: center; padding: 14px 24px; font-weight: 600; border-radius: 8px; }

/* Login gate - same top layer as consent */
.login-gate-overlay { position: fixed; inset: 0; z-index: var(--ct-z-consent) !important; background: rgba(0, 0, 0, 0.75); backdrop-filter: blur(4px); display: flex; align-items: center; justify-content: center; padding: 20px; }
body.login-gate-active { overflow: hidden; }
body.login-gate-active > *:not(.login-gate-overlay) { pointer-events: none !important; }
.login-gate { max-width: 480px; width: 100%; background: var(--ct777-dark-card) !important; border: 1px solid var(--ct777-accent); border-radius: 12px; color: var(--ct777-text); box-shadow: 0 20px 60px rgba(0, 0, 0, 0.8); }
.login-gate__content { padding: 2rem; }
.login-gate__title { font-size: 1.5rem; font-weight: 700; color: var(--ct777-text) !important; }
.login-gate__body .form-control { background: var(--ct777-dark-soft) !important; border: 1px solid var(--ct777-border) !important; color: var(--ct777-text) !important; }
.login-gate__body .form-control:focus { border-color: var(--ct777-accent) !important; }


/* ==========================================================================
   14. FOOTER
   ========================================================================== */

.cafetal777-layout .footer--light, .cafetal777-layout .footer-ct777 { background: var(--gb-header-bg) !important; border-top: 1px solid var(--gb-card-border); padding: 32px 16px 24px; }
.cafetal777-layout .footer-ct777__grid { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 32px; max-width: 1200px; margin: 0 auto; }
@media (max-width: 992px) { .cafetal777-layout .footer-ct777__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 576px) { .cafetal777-layout .footer-ct777__grid { grid-template-columns: 1fr; gap: 24px; } }
.cafetal777-layout .footer-ct777__title { color: var(--gb-accent) !important; font-size: 14px; font-weight: 700; margin-bottom: 12px; text-transform: uppercase; letter-spacing: 0.5px; }
.cafetal777-layout .footer-ct777__about, .cafetal777-layout .footer-ct777__link { color: var(--gb-text-muted) !important; font-size: 13px; }
.cafetal777-layout .footer-ct777__link:hover { color: var(--gb-accent) !important; }
.cafetal777-layout .footer-ct777__list { list-style: none; padding: 0; margin: 0; }
.cafetal777-layout .footer-ct777__list li { margin-bottom: 8px; }
.cafetal777-layout .footer-ct777__social-icon { color: var(--gb-text-muted); }
.cafetal777-layout .footer-ct777__social-icon:hover { color: var(--gb-accent); }

/* Footer bottom bar */
.cafetal777-layout .footer-bottom, .cafetal777-layout .footer-bottom-ct777 { background: #141414 !important; border-top: 1px solid var(--gb-card-border); padding: 14px 0; }
.cafetal777-layout .footer-bottom-ct777__inner { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 12px; max-width: 1200px; margin: 0 auto; padding: 0 16px; }
.cafetal777-layout .footer-bottom-ct777__copy, .cafetal777-layout .footer-bottom-ct777__brand { color: var(--gb-text-muted) !important; font-size: 12px; }
.cafetal777-layout .footer-bottom-ct777__brand:hover { color: var(--gb-accent) !important; }
.cafetal777-layout .footer-bottom-ct777__tip { color: var(--gb-text-muted); font-size: 12px; }
.cafetal777-layout .empty-message p { color: var(--gb-text-muted); }

/* Innovation footer */
.footer-ct777 { padding: 2rem 0; }
.footer-ct777__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 2rem; max-width: 100%; }
.footer-ct777__title { font-size: 14px; font-weight: 600; color: var(--ct777-accent, #00D4FF); margin: 0 0 12px; text-transform: uppercase; letter-spacing: 0.05em; }
.footer-ct777__about { font-size: 13px; line-height: 1.5; color: var(--ct777-text-muted, #999); margin: 0; max-width: 280px; }
.footer-ct777__link { color: var(--ct777-text-muted, #999); text-decoration: none; font-size: 14px; transition: color 0.2s ease; }
.footer-ct777__link:hover { color: var(--ct777-accent, #00D4FF); }
.footer-ct777__social-icon { display: inline-flex; align-items: center; justify-content: center; gap: 6px; min-width: 40px; height: 40px; padding: 0 12px; border-radius: 8px; background: var(--ct777-dark-soft, #111827); color: var(--ct777-text-muted, #999); font-size: 18px; text-decoration: none; transition: all 0.2s ease; }
.footer-ct777__social-icon:hover { background: var(--ct777-accent, #00D4FF); color: var(--ct777-dark, #0B0F14); }

/* Footer compliance & legal */
.footer-compliance--block { padding: 1rem 0 0.5rem; border-top: 1px solid var(--ct777-border, rgba(255, 255, 255, 0.1)); }
.footer-compliance__text { margin: 0; font-size: 13px; line-height: 1.5; color: var(--ct777-text-muted, rgba(255, 255, 255, 0.9)); text-align: center; }
.footer-legal__text { margin: 0; font-size: 12px; line-height: 1.5; color: var(--ct777-text-muted, rgba(255, 255, 255, 0.92)); text-align: center; }
.footer-legal-links { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 0.5rem 1rem; padding-bottom: 1rem; }
.footer-legal-links__link { color: var(--ct777-accent, #00D4FF); text-decoration: none; font-size: 13px; font-weight: 500; }
.footer-legal-links__link:hover { color: var(--ct-brand-primary, #00D4FF); text-decoration: underline; }
.footer-legal-links__sep { color: var(--ct777-text-muted, rgba(255, 255, 255, 0.5)); font-size: 12px; user-select: none; }

.footer-bottom-ct777 { padding: 1rem 0; border-top: 1px solid var(--ct777-border, #333); }
.footer-bottom-ct777__inner { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 1rem 2rem; max-width: 1200px; margin: 0 auto; padding: 0 16px; }
.footer-bottom-ct777__copy { margin: 0; font-size: 13px; color: var(--ct777-text-muted, #999); white-space: nowrap; }
.footer-bottom-ct777__brand { color: var(--ct777-accent, #00D4FF); text-decoration: none; font-weight: 600; }
.footer-bottom-ct777__brand:hover { color: var(--ct777-accent, #00D4FF); text-decoration: underline; }
.footer-bottom-ct777__tip { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--ct777-text-muted, #999); max-width: 320px; padding-left: 1rem; border-left: 1px solid var(--ct777-border, #333); }
.footer-bottom-ct777__tip i { color: var(--ct777-accent, #00D4FF); flex-shrink: 0; }
.footer-bottom-ct777__crypto { display: flex; align-items: center; justify-content: center; gap: 8px; margin: 0; padding: 8px 14px; background: rgba(0, 212, 255, 0.08); border: 1px solid rgba(0, 212, 255, 0.3); border-radius: 8px; font-size: 13px; color: var(--ct777-text-muted, rgba(255,255,255,0.9)); }
.footer-bottom-ct777__crypto i { color: var(--ct777-accent, #00D4FF); font-size: 1.25rem; flex-shrink: 0; }
@media (max-width: 768px) { .footer-bottom-ct777__inner { justify-content: center; text-align: center; } .footer-bottom-ct777__tip { border-left: none; padding-left: 0; } }

.footer--dark, .footer-bottom--dark { background: linear-gradient(180deg, var(--ct777-primary) 0%, var(--ct777-dark-soft) 100%) !important; border-top: 2px solid var(--ct777-accent); }


/* ==========================================================================
   15. INNOVATION FEATURES
   ========================================================================== */

/* Bet Simulator: single source in cafetal777-innovations.css */

.sim-selection { display: flex; align-items: center; gap: 10px; padding: 10px; background: var(--ct777-dark-soft, #111827); border-radius: 8px; margin-bottom: 8px; border-inline-start: 3px solid var(--ct777-accent, #00D4FF); }
.sim-odds { background: var(--ct777-accent, #00D4FF); color: var(--ct777-dark, #0B0F14); padding: 4px 10px; border-radius: 4px; font-weight: bold; }
.simulator-results { background: var(--ct777-dark-soft, #111827); border-radius: 8px; padding: 15px; margin-bottom: 15px; }
.result-item { display: flex; justify-content: space-between; padding: 8px 0; border-bottom: 1px solid var(--ct777-border, #333); font-size: 14px; }
.result-item:last-child { border-bottom: none; }
.result-profit strong { color: var(--ct777-accent, #00D4FF); }
.result-return strong { color: #00FF00; font-size: 18px; }
.simulator-actions { display: flex; gap: 10px; }
.btn-sim-clear, .btn-sim-place { flex: 1; padding: 12px; border: none; border-radius: 8px; font-weight: 600; cursor: pointer; }
.btn-sim-clear { background: var(--ct777-dark-soft, #111827); color: var(--ct777-text, #fff); border: 1px solid var(--ct777-border, #333); }
.btn-sim-place { background: linear-gradient(135deg, var(--ct777-accent, #00D4FF), var(--ct-brand-primary-dark, #00A3CC)); color: var(--ct777-dark, #0B0F14); }

/* Live odds pulse */
.oddBtn.odds-pulse { animation: oddsPulse 2s ease; }
@keyframes oddsPulse { 0%, 100% { box-shadow: 0 0 0 transparent; } 25%, 75% { box-shadow: 0 0 15px 3px rgba(0, 212, 255, 0.5); } }
@keyframes resultPulse { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.2); } }
.oddBtn.odds-pulse--up::after { content: '\25B2'; position: absolute; top: -5px; right: -5px; color: #00FF00; font-size: 10px; animation: arrowUp 2s ease forwards; }
.oddBtn.odds-pulse--down::after { content: '\25BC'; position: absolute; top: -5px; right: -5px; color: #FF4444; font-size: 10px; animation: arrowDown 2s ease forwards; }
@keyframes arrowUp { 0% { opacity: 0; transform: translateY(5px); } 20% { opacity: 1; transform: translateY(0); } 80% { opacity: 1; } 100% { opacity: 0; } }
@keyframes arrowDown { 0% { opacity: 0; transform: translateY(-5px); } 20% { opacity: 1; transform: translateY(0); } 80% { opacity: 1; } 100% { opacity: 0; } }

/* Esports theme */
body.theme-esports { --ct777-primary: #0B0F14; --ct777-accent: #00D4FF; }
body.theme-esports .header-primary { background: #0B0F14 !important; border-bottom-color: #00D4FF; }
body.theme-esports .btn--base, body.theme-esports .betslip__footer-btn { background: linear-gradient(135deg, #00D4FF, #0891B2) !important; color: #0B0F14 !important; border-color: #00D4FF !important; }

/* Favorite teams */
.fav-star { display: inline-flex; margin-inline-start: 5px; cursor: pointer; font-size: 14px; color: var(--ct777-text-muted, #999); transition: all 0.2s ease; }
.fav-star:hover { transform: scale(1.2); }
.fav-star i.active { color: var(--ct777-accent, #00D4FF); }
.sports-card.has-favorite, .game-card.has-favorite { border-inline-start: 3px solid var(--ct777-accent, #00D4FF) !important; }
.sports-card.fav-hidden, .game-card.fav-hidden, .sport-table__row.fav-hidden, .sport-match-card.fav-hidden { display: none !important; }

/* Professional: fav star minimal */
.fav-star { opacity: 0.4 !important; transition: opacity 0.15s !important; }
.fav-star:hover, .fav-star.active { opacity: 1 !important; color: var(--ct777-accent, #00D4FF) !important; }

/* Enhanced charts */
.enhanced-chart-container { background: var(--ct777-dark-card, #1A2233); border-radius: 12px; padding: 20px; border: 1px solid var(--ct777-border, #333); }
.enhanced-chart-container h5 { color: var(--ct777-accent, #00D4FF); margin-bottom: 20px; }

/* Streak tracker */
.streak-tracker-widget { background: var(--ct777-dark-card, #1A2233) !important; border: 1px solid var(--ct777-border, #333) !important; border-radius: 12px !important; }
.streak-tracker-title { font-size: 14px; color: var(--ct777-accent, #00D4FF); margin-bottom: 8px; }
.streak-tracker-value { font-size: 28px; font-weight: 700; color: var(--ct777-text, #fff); margin: 0 0 4px 0; }

/* Keyboard shortcuts */
.shortcuts-hint { position: fixed; bottom: 16px; left: 16px; background: rgba(30, 30, 30, 0.85); backdrop-filter: blur(6px); border: 1px solid rgba(0, 212, 255, 0.2); border-radius: 6px; padding: 8px 12px; display: flex; align-items: center; gap: 8px; z-index: 9998; font-size: 12px; color: var(--ct777-text-muted, #999); transition: opacity 0.3s ease; pointer-events: auto; }
.shortcuts-hint kbd { background: var(--ct777-accent, #00D4FF); color: var(--ct777-dark, #0B0F14); padding: 1px 6px; border-radius: 3px; font-weight: bold; font-size: 11px; }
.shortcuts-hint .hint-close { background: none; border: none; color: var(--ct777-text-muted, #999); cursor: pointer; font-size: 14px; padding: 0 0 0 4px; line-height: 1; }
.shortcuts-modal-overlay { position: fixed; inset: 0; background: rgba(0, 0, 0, 0.8); display: flex; justify-content: center; align-items: center; z-index: 99999; }
.shortcuts-modal { background: var(--ct777-dark-card, #1A2233); border: 2px solid var(--ct777-accent, #00D4FF); border-radius: 12px; padding: 25px; max-width: 400px; width: 90%; }

/* Infinite scroll */
.infinite-loader { text-align: center; padding: 20px; color: var(--ct777-accent, #00D4FF); }
.load-more-btn { display: block; width: 100%; max-width: 300px; margin: 20px auto; padding: 15px 30px; background: linear-gradient(135deg, var(--ct777-primary, #00D4FF), #00A3CC); color: white; border: 1px solid var(--ct777-accent, #00D4FF); border-radius: 8px; font-weight: 600; cursor: pointer; }
.load-more-btn:hover { background: linear-gradient(135deg, var(--ct777-accent, #00D4FF), var(--ct-brand-primary-dark, #00A3CC)); color: var(--ct777-dark, #0B0F14); }

/* Live match timer */
.live-timer { display: inline-flex; align-items: center; gap: 5px; background: linear-gradient(135deg, #FF4444, #cc0000); color: white; padding: 3px 10px; border-radius: 4px; font-weight: bold; font-size: 12px; }

/* First-time CTA */
.first-time-cta { position: fixed; bottom: 20px; left: 50%; transform: translateX(-50%); z-index: 9998; max-width: 90%; width: 420px; box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4); border-radius: 12px; overflow: hidden; }
.first-time-cta__inner { display: flex; align-items: center; gap: 12px; padding: 14px 16px; background: var(--ct777-dark-card, #1A2233); border: 2px solid var(--ct777-accent, #00D4FF); border-radius: 12px; }

/* Hub scroll animation */
.sport-hub--animate-ready { opacity: 0; transform: translateY(20px); transition: opacity 0.5s ease, transform 0.5s ease; }
.sport-hub--animate-ready.sport-hub--in-view { opacity: 1; transform: translateY(0); }


/* ==========================================================================
   16. TRUST & SAFETY PANELS (from professional.css)
   ========================================================================== */

.trust-panel, .safety-overview, .deposit-hero-card, .rg-hub, .safety-metric {
  background: linear-gradient(180deg, rgba(17, 24, 39, 0.96), rgba(11, 18, 31, 0.96)) !important;
  border: 1px solid rgba(148, 163, 184, 0.16) !important;
  border-radius: 12px !important;
  color: #e5edf7 !important;
}

.trust-panel__eyebrow, .deposit-selection-hero__eyebrow, .rg-hub__eyebrow { display: inline-block; margin-bottom: 0.6rem; font-size: 0.72rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: #8fb8ff; }
.trust-panel__title, .deposit-hero-card__title, .rg-hub__title { color: #f8fbff; font-weight: 700; }
.trust-panel__subtitle, .deposit-hero-card__subtitle { color: rgba(226, 232, 240, 0.92); max-width: 62ch; }

.trust-panel__grid, .safety-overview__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-top: 1.15rem; align-items: stretch; }

.trust-chip, .safety-mini-card, .deposit-hero-card__stat, .rg-highlight { padding: 1rem; border-radius: 12px; background: rgba(15, 23, 42, 0.72); border: 1px solid rgba(148, 163, 184, 0.16); }
.trust-chip strong, .safety-mini-card strong, .deposit-hero-card__stat strong { color: #fff; }
.trust-chip span:last-child, .safety-mini-card span { color: rgba(226, 232, 240, 0.92); }

.trust-pill, .safety-overview__status, .session-center__hero-stat, .session-card__badge { display: inline-flex; align-items: center; gap: 0.45rem; min-height: 34px; padding: 0.4rem 0.8rem; border-radius: 999px; border: 1px solid rgba(148, 163, 184, 0.16); background: rgba(8, 15, 28, 0.72); color: #d8e6fb; font-size: 0.79rem; font-weight: 600; }
.trust-pill--success { border-color: rgba(16, 185, 129, 0.3); background: rgba(6, 78, 59, 0.28); color: #bbf7d0; }
.trust-pill--warning { border-color: rgba(245, 158, 11, 0.32); background: rgba(120, 53, 15, 0.28); color: #fde68a; }
.trust-pill--danger { border-color: rgba(239, 68, 68, 0.32); background: rgba(127, 29, 29, 0.28); color: #fecaca; }

.trust-score { width: min(100%, 248px); display: grid; justify-items: center; gap: 0.85rem; padding: 1rem; border-radius: 20px; border: 1px solid rgba(148, 163, 184, 0.16); background: linear-gradient(180deg, rgba(10, 18, 31, 0.92), rgba(6, 13, 24, 0.9)); }
.trust-score__ring { width: 122px; height: 122px; display: grid; place-items: center; border-radius: 50%; background: conic-gradient(var(--trust-score-color) calc(var(--trust-score) * 1%), rgba(148, 163, 184, 0.14) 0); }
.trust-score__inner { width: 90px; height: 90px; display: grid; place-items: center; text-align: center; border-radius: 50%; background: rgba(8, 15, 28, 0.98); border: 1px solid rgba(148, 163, 184, 0.14); }
.trust-score__inner strong { display: block; color: #f8fbff; font-size: 1.5rem; line-height: 1; }
.trust-score--success { --trust-score-color: #34d399; }
.trust-score--warning { --trust-score-color: #f59e0b; }
.trust-score--danger { --trust-score-color: #f87171; }

.trust-panel__body, .safety-overview__body { display: grid; gap: 1.25rem; padding: 1.5rem; }

.trust-signal { display: flex; align-items: flex-start; gap: 0.85rem; padding: 1rem; border-radius: 12px; background: rgba(8, 15, 28, 0.72); border: 1px solid rgba(148, 163, 184, 0.12); transition: transform 160ms ease; }
.trust-signal:hover { transform: translateY(-1px); }
.trust-signal--complete { border-color: rgba(16, 185, 129, 0.22); }
.trust-signal--action { border-color: rgba(59, 130, 246, 0.28); }
.trust-signal--warning { border-color: rgba(245, 158, 11, 0.22); }
.trust-signal__icon { width: 42px; height: 42px; flex: 0 0 42px; display: grid; place-items: center; border-radius: 12px; background: rgba(15, 23, 42, 0.8); color: #dbeafe; font-size: 1.1rem; }
.trust-signal__top strong { color: #f8fbff; font-size: 0.96rem; font-weight: 700; }
.trust-signal__content p { margin-top: 0.35rem; color: rgba(226, 232, 240, 0.92); font-size: 0.86rem; line-height: 1.5; }

.trust-signal-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0.85rem; }

/* History cards */
.history-card, .activity-feed__day, .referral-tree-shell { padding: 1.25rem; border-radius: 12px; border: 1px solid rgba(148, 163, 184, 0.12); background: rgba(8, 15, 28, 0.74); }
.history-status-chip { display: inline-flex; align-items: center; gap: 0.35rem; min-height: 30px; padding: 0.35rem 0.7rem; border-radius: 999px; font-size: 0.74rem; font-weight: 700; background: rgba(15, 23, 42, 0.84); color: #dbeafe; }
.history-status-chip--success { border-color: rgba(16, 185, 129, 0.25); color: #bbf7d0; }
.history-status-chip--warning, .history-status-chip--pending { border-color: rgba(245, 158, 11, 0.24); color: #fde68a; }
.history-status-chip--danger { border-color: rgba(239, 68, 68, 0.24); color: #fecaca; }
.history-amount { font-size: 1.1rem; font-weight: 700; color: #f8fbff; font-variant-numeric: tabular-nums; }

/* Account pages */
.account-shell__hero, .account-surface, .channel-card, .notification-summary-card, .security-side-card, .profile-overview-card, .form-section-card, .form-note-card { border-radius: 12px; border: 1px solid rgba(148, 163, 184, 0.12); background: rgba(8, 15, 28, 0.72); }
.account-badge { display: inline-flex; align-items: center; gap: 0.45rem; min-height: 34px; padding: 0.4rem 0.8rem; border-radius: 999px; background: rgba(15, 23, 42, 0.84); border: 1px solid rgba(148, 163, 184, 0.14); color: #dbeafe; font-size: 0.76rem; font-weight: 700; }
.account-badge--success { border-color: rgba(16, 185, 129, 0.25); color: #bbf7d0; }
.account-badge--warning { border-color: rgba(245, 158, 11, 0.22); color: #fde68a; }

.segmented-filters { display: inline-flex; flex-wrap: wrap; gap: 0.6rem; padding: 0.35rem; background: rgba(15, 23, 42, 0.72); border: 1px solid rgba(148, 163, 184, 0.12); border-radius: 12px; }
.segmented-filters__btn { display: inline-flex; align-items: center; gap: 0.45rem; min-height: 40px; padding: 0.6rem 0.85rem; border: 0; border-radius: 12px; background: transparent; color: rgba(226, 232, 240, 0.92); font-size: 0.84rem; font-weight: 700; transition: background 0.18s ease; }
.segmented-filters__btn.is-active { background: linear-gradient(135deg, rgba(37, 99, 235, 0.88), rgba(59, 130, 246, 0.92)); color: #f8fbff; }

/* Responsive trust panels */
@media (max-width: 991.98px) {
  .trust-panel__grid, .safety-overview__grid, .trust-signal-list, .trust-panel__actions,
  .trust-panel__insight-grid, .trust-score-breakdown, .trust-timeline,
  .account-grid, .account-shell__stat-grid, .profile-overview-grid,
  .form-section-card__grid, .account-mini-grid { grid-template-columns: 1fr; }
}


/* ==========================================================================
   17. BANNER / HERO SLIDER
   ========================================================================== */

.banner-slider, .banner-slider--placeholder { border-radius: 12px; overflow: hidden; }

.banner-slider--hero { position: relative; width: 100%; max-width: 700px; margin-left: auto; margin-right: auto; aspect-ratio: 700 / 360; min-height: 160px; max-height: 360px; }
.banner-slider--hero .banner_slide { position: absolute; left: 0; top: 0; width: 100%; height: 100%; opacity: 0; }
.banner-slider--hero .banner_slide:first-child { opacity: 1; }
.banner-slider--hero .banner_image { width: 100%; height: 100%; object-fit: cover; display: block; }

.banner_slide__link { display: block; width: 100%; height: 100%; text-decoration: none; color: inherit; cursor: pointer; position: relative; }

.banner-slider__nav.navDots { position: absolute; bottom: 12px; left: 0; right: 0; z-index: 10; display: flex; justify-content: center; gap: 8px; pointer-events: none; }
.banner-slider__nav .navDot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: rgba(255, 255, 255, 0.5); border: 2px solid rgba(255, 255, 255, 0.8); padding: 0; text-indent: -9999px; transition: background 0.2s, transform 0.2s; }
.banner-slider__nav .navDot.selected { background: var(--ct777-accent, #00D4FF); border-color: var(--ct777-accent, #00D4FF); transform: scale(1.2); }

.banner-placeholder { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 150px; background: linear-gradient(135deg, #001a00, var(--ct777-primary), #0d2d0d, var(--ct777-dark)); }
.banner-placeholder__icon { font-size: 3rem; color: var(--ct777-accent); margin-bottom: 0.5rem; }
.banner-placeholder__text { font-family: var(--heading-font); font-weight: 800; font-size: 1.25rem; letter-spacing: 0.3em; color: var(--ct777-text); }
.banner-placeholder__sub { font-weight: 600; font-size: 0.9rem; color: var(--ct777-accent); letter-spacing: 0.2em; }

.hero-wrap { position: relative; }
.hero-live-badge { position: absolute; top: 12px; left: 12px; z-index: 12; display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; background: rgba(0, 0, 0, 0.7); border: 1px solid rgba(255, 80, 80, 0.6); border-radius: 999px; color: #ff6b6b; font-size: 0.8rem; font-weight: 700; }
.hero-live-badge__dot { width: 6px; height: 6px; border-radius: 50%; background: #ff4444; }

.hero-slider__arrow { position: absolute; top: 50%; z-index: 11; width: 40px; height: 40px; margin-top: -20px; display: flex; align-items: center; justify-content: center; background: rgba(0, 0, 0, 0.5); border: 1px solid rgba(255, 255, 255, 0.2); border-radius: 50%; color: #fff; font-size: 1.25rem; cursor: pointer; transition: background 0.2s, transform 0.2s; opacity: 0.8; }
.hero-slider__arrow:hover { background: var(--ct777-accent, #00D4FF); color: #000; opacity: 1; transform: scale(1.1); }
.hero-slider__arrow--prev { left: 10px; }
.hero-slider__arrow--next { right: 10px; }
.hero-slider__arrow--pause { right: 10px; top: auto; bottom: 10px; margin-top: 0; width: 32px; height: 32px; font-size: 1rem; opacity: 0.6; }
.hero-slider__arrow--pause:hover { opacity: 1; }

.hero-slider__progress { position: absolute; bottom: 0; left: 0; right: 0; height: 3px; background: rgba(255, 255, 255, 0.2); z-index: 10; overflow: hidden; }
.hero-slider__progress-bar { display: block; height: 100%; width: 0; background: var(--ct777-accent, #00D4FF); }

.cafetal777-layout .banner-slider, .cafetal777-layout .hero-slider { border-radius: 8px; overflow: hidden; margin-bottom: 16px; border: 1px solid var(--gb-card-border); }
.cafetal777-layout .banner-placeholder { background: linear-gradient(135deg, var(--gb-primary), var(--gb-sidebar-bg)); color: var(--gb-text); }

/* Slip invoice */
.slip-invoice-overlay { position: fixed; inset: 0; z-index: var(--ct-z-modal); display: flex; align-items: center; justify-content: center; padding: 20px; background: rgba(0, 0, 0, 0.75); opacity: 0; visibility: hidden; pointer-events: none; transition: opacity 0.3s ease, visibility 0.3s ease; }
.slip-invoice-overlay.is-open { opacity: 1; visibility: visible; pointer-events: auto; }
.slip-invoice__paper { position: relative; width: 100%; max-width: 420px; max-height: 90vh; overflow: hidden; background: #fff; color: #111; box-shadow: 0 25px 80px rgba(0, 0, 0, 0.5); border-radius: 2px; font-family: "Courier New", "Consolas", monospace; display: flex; flex-direction: column; transform: scale(0.95); transition: transform 0.3s ease; }
.slip-invoice-overlay.is-open .slip-invoice__paper { transform: scale(1); }
.slip-invoice__head { padding: 24px 20px 16px; text-align: center; border-bottom: 2px dashed #333; }
.slip-invoice__brand { font-size: 0.7rem; letter-spacing: 0.35em; font-weight: 700; color: #000; }
.slip-invoice__content { flex: 1 1 auto; overflow-y: auto; padding: 16px 20px; min-height: 120px; }
.slip-invoice__item { padding: 12px 0; border-bottom: 1px dashed #ccc; font-size: 0.8rem; }
.slip-invoice__footer { padding: 16px 20px 20px; border-top: 2px dashed #333; background: #fafafa; }
.slip-invoice__btn--primary { background: #000; border: 2px solid #000; color: #fff; padding: 10px 20px; font-size: 0.8rem; font-weight: 700; border-radius: 2px; cursor: pointer; }
.slip-invoice__btn--primary:hover { background: #333; border-color: #333; }


/* ==========================================================================
   18. ANIMATIONS
   ========================================================================== */

@keyframes livePulse { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.8; transform: scale(1.1); } }
.sports-card__stream, .fa-circle-play.text--danger { animation: livePulse 2s ease-in-out infinite; }

@keyframes cardEntrance { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
.sports-card { animation: cardEntrance 0.3s ease; }

@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

@keyframes ct-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.6; } }

/* Live badge premium glow */
.badge--live,
.live-indicator,
.sports-category__link.live-btn,
.sport-widget__live-dot {
  position: relative;
}

.badge--live::before,
.live-indicator::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(239, 68, 68, 0.4), rgba(124, 58, 237, 0.4));
  filter: blur(6px);
  z-index: -1;
  animation: ct-pulse 2s ease-in-out infinite;
}

.badge--live {
  background: linear-gradient(135deg, #EF4444, #DC2626);
  color: #fff;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.7rem;
  padding: 3px 8px;
  border-radius: 4px;
}

.badge--live, .live-indicator { animation: ct-pulse 2s ease-in-out infinite; }

@keyframes ct-shimmer { 0% { background-position: -200% 0; } 100% { background-position: 200% 0; } }
.skeleton-loader, .skeleton { background: linear-gradient(90deg, var(--ct-surface-2, #1A2233) 25%, var(--ct-surface-3, #111827) 50%, var(--ct-surface-2, #1A2233) 75%); background-size: 200% 100%; animation: ct-shimmer 1.5s ease-in-out infinite; }

@keyframes esportsBadgePulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.7; } }
.sports-category__esports-badge { animation: esportsBadgePulse 2s ease-in-out infinite; }

@keyframes timerPulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.8; } }
@keyframes liveDot { 0%, 100% { opacity: 1; } 50% { opacity: 0.3; } }
.live-timer { animation: timerPulse 2s infinite; }
.live-timer::before { content: ''; width: 8px; height: 8px; background: white; border-radius: 50%; animation: liveDot 1s infinite; }

@keyframes heroLivePulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.9; } }
.hero-live-badge__dot { animation: heroLivePulse 1.2s ease-in-out infinite; }


/* ==========================================================================
   19. UTILITIES
   ========================================================================== */

/* Tabular/monospace for numbers */
.font-tabular,
.oddBtn .odds-value,
.betslip-item-market__score,
.bet-return-amount,
.total-return-amount,
.widget-card-amount,
.dashboard-kpi__value,
[data-count],
[data-amount],
[data-profit] {
  font-family: var(--ct-font-tabular, 'Roboto Mono', monospace);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}

/* Scrollbar */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--ct-surface-1, #1a1a1a); }
::-webkit-scrollbar-thumb { background: var(--ct-surface-4, #333); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--ct-surface-5, #444); }

/* Empty states */
.empty-message { background: var(--ct777-dark-card); border-radius: 12px; padding: 3rem 2rem; border: 2px dashed var(--ct777-border); text-align: center; }
.empty-message img { max-width: 200px; opacity: 0.5; margin-bottom: 20px; }
.empty-message p { font-size: 0.9rem; color: var(--ct777-text-muted, #999) !important; margin-top: 0.5rem; }

.empty-state { text-align: center; padding: 60px 20px; color: var(--ct777-text-muted); }

/* Alerts */
.alert { border-radius: 8px; border: none; padding: 16px 20px; }
.alert-danger { background: rgba(255, 0, 0, 0.15); color: #ff6b6b; border-inline-start: 4px solid var(--ct777-error); }
.alert-success { background: rgba(0, 255, 0, 0.15); color: var(--ct777-success); border-inline-start: 4px solid var(--ct777-success); }
.alert-warning { background: rgba(0, 212, 255, 0.15); color: var(--ct777-accent); border-inline-start: 4px solid var(--ct777-accent); }
.alert-info { background: rgba(0, 212, 255, 0.15); color: #90ee90; border-inline-start: 4px solid var(--ct777-primary); }

/* Breadcrumbs */
.breadcrumb { background: transparent; padding: 0; margin-bottom: 20px; }
.breadcrumb-item { color: var(--ct777-text-muted) !important; }
.breadcrumb-item.active { color: var(--ct777-accent) !important; }

/* Nav tabs */
.nav-tabs, .nav-tabs .nav-link { background: var(--ct777-dark-card) !important; border-color: var(--ct777-border) !important; color: var(--ct777-text-muted) !important; }
.nav-tabs .nav-link.active { background: var(--ct777-dark-soft) !important; color: var(--ct777-accent) !important; border-bottom-color: var(--ct777-accent) !important; }

/* Tooltips */
.tooltip-inner { background: var(--ct777-dark-card) !important; color: var(--ct777-text) !important; border: 1px solid var(--ct777-border); }
.popover { background: var(--ct777-dark-card) !important; border-color: var(--ct777-accent) !important; }
.popover-body { color: var(--ct777-text) !important; }

/* Progress bars */
.progress { background: var(--ct777-dark-soft) !important; border-radius: 4px; height: 8px; }
.progress-bar { background: var(--ct777-accent) !important; }

/* Spinners */
.spinner-border { border-color: var(--ct777-accent); border-right-color: transparent; }

/* Pagination */
.pagination { margin-top: 24px; }
.pagination .page-item.active .page-link { background: var(--ct777-accent) !important; border-color: var(--ct777-accent) !important; color: var(--ct777-dark) !important; }
.pagination .page-link:hover { background: rgba(0, 212, 255, 0.1) !important; color: var(--ct777-accent) !important; }

/* Preloader */
.preloader { background: var(--ct777-dark) !important; }

/* Back to top */
.back-to-top { background: var(--ct777-accent) !important; color: var(--ct777-dark) !important; }

/* Cookies card */
.cookies-card { background: var(--ct777-dark-card) !important; border: 2px solid var(--ct777-accent); color: var(--ct777-text); }

/* Body overlay */
.body-overlay { background: rgba(0, 0, 0, 0.7); backdrop-filter: blur(4px); }

/* Modal fade */
.modal.fade .modal-dialog { transition: transform 0.25s ease-out, opacity 0.25s ease-out; }

/* Flex utility */
.flex-between { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; width: 100%; }

/* Dashboard sections */
.dashboard-wrapper, .dashboard-right, .dashboard-sidebar { background: transparent !important; }

/* Frontend pages */
.cafetal777-layout .section { background: var(--ct777-dark); color: var(--ct777-text); }
.cafetal777-layout .contact-section { background-color: var(--ct777-dark); }
.cafetal777-layout .contact-section .login-form { background: var(--ct777-dark-card); border: 2px solid var(--ct777-accent); border-radius: 10px; color: var(--ct777-text); padding: 2rem; }
.cafetal777-layout .contact-section .contact-card__icon { color: var(--ct777-accent); }

/* Banner/breadcrumb */
.cafetal777-layout .banner { background-color: var(--ct777-dark-soft); min-height: 120px; }
.cafetal777-layout .banner::after { background: linear-gradient(180deg, var(--ct777-primary), var(--ct777-dark)); opacity: 0.95; }
.cafetal777-layout .static-page-content { background: var(--ct777-dark); color: var(--ct777-text); }
.cafetal777-layout .static-page-content a { color: var(--ct777-accent); }
.cafetal777-layout .static-page-content a:hover { color: var(--ct-brand-primary, #00D4FF); }
.cafetal777-layout .legal-highlight-box { background: var(--ct777-dark-card); border: 1px solid var(--ct777-accent); color: var(--ct777-text); }

/* Link underline animation */
.dashboard-menu a:not(.btn), .footer a:not(.btn) { text-decoration: none; background-image: linear-gradient(var(--ct-brand-accent, #00D4FF), var(--ct-brand-accent, #00D4FF)); background-size: 0% 1px; background-position: left bottom; background-repeat: no-repeat; transition: background-size 0.3s ease; }
.dashboard-menu a:not(.btn):hover, .footer a:not(.btn):hover { background-size: 100% 1px; }

/* Professional overrides */
.sport-hub__sport-icon-wrap .custom-icon { color: var(--ct777-text, #e0e0e0) !important; font-size: 1.3rem; }
.leagues-strip__label { color: var(--ct777-text, #e0e0e0) !important; }
.sport-table__more:hover { color: var(--ct777-text, #e0e0e0) !important; }
.sport-hub__sport-emoji { font-size: 1.2rem; }

/* Professional: Remove promotional bulk */
.banner-slider, .banner-slider--placeholder, .sport-hub--creative, .sport-hub, .sport-widget--creative, .sport-card, .betting-body--hub { box-shadow: none !important; }

/* Professional: Countdown */
.sport-table__countdown { font-size: 0.8rem !important; font-weight: 500 !important; color: var(--ct777-text-muted, #999) !important; }
.countdown-live { color: #ff4444 !important; font-weight: 600 !important; }

/* Professional: League filter bar */
.sport-table-league-filter-bar { padding: 8px 12px !important; background: var(--ct777-dark-soft, #1A2233) !important; border-bottom: 1px solid var(--ct777-border) !important; font-size: 0.85rem !important; }


/* ==========================================================================
   20. CUSTOM.CSS - PAYMENT, SELECT2, COOKIES
   ========================================================================== */

/* Copy Animation */
.base-color { color: hsl(var(--main)) !important; }
.copyInput { display: inline-block; line-height: 50px; position: absolute; top: 0; right: 0; width: 40px; text-align: center; font-size: 14px; cursor: pointer; transition: all 0.3s; }
.copied::after { position: absolute; top: 8px; right: 12%; width: 100px; display: block; content: "COPIED"; font-size: 1em; padding: 5px; color: #fff; background-color: #ff7000; border-radius: 3px; opacity: 0; will-change: opacity, transform; animation: showcopied 1.5s ease; }
@keyframes showcopied { 0% { opacity: 0; transform: translateX(100%); } 50% { opacity: 0.7; transform: translateX(40%); } 70% { opacity: 1; transform: translateX(0); } 100% { opacity: 0; } }

.cookies-card { width: 520px; padding: 30px; position: fixed; bottom: 15px; left: 15px; z-index: 999999; transition: all 0.5s; border-radius: 5px; }
.cookies-card.hide { bottom: -500px !important; }
.cookies-card__icon { width: 55px; height: 55px; border-radius: 50%; background-color: #6e6f70; color: #fff; font-size: 32px; display: inline-flex; justify-content: center; align-items: center; }
.cookies-btn { padding: 10px 35px; margin: 3px 5px; display: inline-block; border-radius: 999px; text-decoration: none; }
@media (max-width: 767px) { .cookies-card { width: 100%; left: 0; bottom: 0; font-size: 14px; padding: 15px; } }

/* Input popup */
.hover-input-popup { position: relative; z-index: 9999; }
.input-popup { display: none; }
.hover-input-popup .input-popup { display: block; position: absolute; bottom: 130%; left: 50%; width: 280px; background-color: #1a1a1a; color: #fff; padding: 20px; border-radius: 5px !important; transform: translateX(-50%); transition: all 0.3s; }
.input-popup p.error::before { content: "\f057"; color: #ea5455; }
.input-popup p.success::before { content: "\f058"; color: #28c76f; }

/* Show filter */
.show-filter { display: none; }
@media (max-width: 767px) { .responsive-filter-card { display: none; } .show-filter { display: block; } }

/* Payment system */
.payment-system-list { --thumb-width: 100px; --thumb-height: 40px; --radio-size: 12px; --border-color: #cccccf59; --hover-border-color: hsl(var(--base)); border-radius: 5px; height: 100%; }
.payment-system-list.is-scrollable { max-height: min(340px, 70vh); overflow-x: auto; padding-block: 4px; }
.payment-item { width: 100%; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; padding: 10px 18px; border: 1px solid transparent; border-top-color: var(--border-color); transition: all 0.3s; border-inline-start: 3px solid transparent; background: var(--ct777-dark-card) !important; border-color: var(--ct777-border) !important; color: var(--ct777-text) !important; }
.payment-item:hover { border-color: rgba(0, 212, 255, 0.3) !important; }
.payment-item:has(.payment-item__radio:checked) { border-inline-start: 3px solid var(--hover-border-color); }
.payment-item__info { display: flex; align-items: center; flex-wrap: wrap; max-width: calc(100% - var(--thumb-width)); }
.payment-item__name { padding-inline-start: 10px; width: calc(100% - var(--radio-size)); transition: all 0.3s; overflow: hidden; text-overflow: ellipsis; display: -webkit-box !important; -webkit-line-clamp: 1; -webkit-box-orient: vertical; }
.payment-item__thumb { width: var(--thumb-width); height: var(--thumb-height); text-align: end; padding-inline-start: 10px; }
.payment-item__thumb img { max-width: var(--thumb-width); max-height: var(--thumb-height); object-fit: cover; }

.deposit-info { display: flex; align-items: center; flex-wrap: wrap; justify-content: space-between; background: var(--ct777-dark-card) !important; border-color: var(--ct777-border) !important; color: var(--ct777-text) !important; }
.deposit-info__title { max-width: 50%; margin-bottom: 0; text-align: start; }
.deposit-info__input { max-width: 50%; text-align: end; width: 100%; }
.deposit-info__input-group { border: 1px solid var(--border-color); border-radius: 5px; }
.deposit-info__input-group .form--control { padding: 5px; border: 0; height: 35px; text-align: end; }
.total-amount { border-top: 1px solid var(--border-color); }

.payment-card-title { padding: 13px 25px; text-align: center; background-color: hsl(var(--base)); border-radius: 5px; border: 0; margin-bottom: 0; color: #fff; }

label.required:after { content: "*"; color: #dc3545 !important; margin-inline-start: 2px; }
.mobile-code { cursor: pointer; padding-inline-end: 5px; font-size: 0.875rem; font-weight: 500; }
.text--extra-small { font-size: 0.625rem !important; }
.text--small { font-size: 0.75rem !important; }
.social-login-btn { border: 1px solid #cbc4c4; }

button .spinner-border { --bs-spinner-width: 1.5rem; --bs-spinner-height: 1.5rem; }

@media (max-width: 1199px) { .payment-item { padding: 10px 6px; } .payment-item__name { font-size: 0.875rem; } }

/* Betting body spacing */
.betting-body { padding-top: 0.5rem; }
.betting-body--hub { padding-bottom: 1rem !important; }

/* ============================================
   MOBILE BET SLIP FAB
   ============================================ */
@media (max-width: 991px) {
  .betslip-fab {
    position: fixed;
    bottom: 20px;
    right: 20px;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--ct-brand-gradient, linear-gradient(135deg, #00D4FF, #7C3AED));
    border: none;
    color: #fff;
    font-size: 1.3rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: var(--ct-z-fixed, 300);
    box-shadow: 0 4px 20px rgba(0, 212, 255, 0.3), 0 4px 20px rgba(124, 58, 237, 0.2);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
  }

  .betslip-fab:active {
    transform: scale(0.92);
  }

  .betslip-fab__count {
    position: absolute;
    top: -4px;
    right: -4px;
    min-width: 20px;
    height: 20px;
    border-radius: 10px;
    background: #EF4444;
    color: #fff;
    font-size: 0.7rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 5px;
    font-family: var(--ct-font-tabular, 'JetBrains Mono', monospace);
  }

  .betslip-fab__count:empty,
  .betslip-fab__count[data-count="0"] {
    display: none;
  }

  .betslip-fab--hidden { display: none; }
}

@media (min-width: 992px) {
  .betslip-fab { display: none; }
}

/* Session timer */
.session-timer {
  font-family: var(--ct-font-tabular, 'JetBrains Mono', monospace);
  font-size: 0.72rem;
  color: rgba(232, 237, 245, 0.4);
  padding: 4px 8px;
  border-radius: 4px;
  background: rgba(232, 237, 245, 0.04);
  letter-spacing: 0.02em;
  white-space: nowrap;
}

.session-timer--warning {
  color: #F59E0B;
  background: rgba(245, 158, 11, 0.08);
}

/* ============================================
   INNOVATION FEATURE STYLES
   ============================================ */

/* Progressive loading */
.ct-lazy {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.ct-lazy.ct-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Quick-bet toggle */
.quick-bet-toggle {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  border: 1px solid rgba(232, 237, 245, 0.12);
  background: rgba(232, 237, 245, 0.04);
  color: rgba(232, 237, 245, 0.6);
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 1rem;
  flex-shrink: 0;
}

.quick-bet-toggle:hover {
  border-color: rgba(0, 212, 255, 0.3);
  color: #00D4FF;
}

.quick-bet-toggle.active {
  background: rgba(0, 212, 255, 0.15);
  border-color: #00D4FF;
  color: #00D4FF;
  box-shadow: 0 0 12px rgba(0, 212, 255, 0.2);
}

/* Bet tracker widget */
.bet-tracker-widget {
  position: fixed;
  bottom: 20px;
  left: 20px;
  z-index: 300;
  transition: all 0.3s ease;
}

.bet-tracker__inner {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: rgba(17, 24, 39, 0.9);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(0, 212, 255, 0.15);
  border-radius: 10px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
  font-size: 0.78rem;
  color: rgba(232, 237, 245, 0.7);
  white-space: nowrap;
}

.bet-tracker__icon {
  color: #00D4FF;
  font-size: 1rem;
}

.bet-tracker__count {
  font-family: var(--ct-font-tabular, 'JetBrains Mono', monospace);
  font-weight: 700;
  color: #E8EDF5;
}

.bet-tracker--has-bets .bet-tracker__count {
  color: #00D4FF;
}

.bet-tracker--collapsed .bet-tracker__inner {
  padding: 6px 8px;
  gap: 0;
}

.bet-tracker--collapsed .bet-tracker__label {
  width: 0;
  overflow: hidden;
  opacity: 0;
}

/* Notification badge pulse */
.ct-notif-has-new {
  position: relative;
}

@keyframes ct-badge-pulse {
  0%, 100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(0, 212, 255, 0.4); }
  50% { transform: scale(1.15); box-shadow: 0 0 12px rgba(0, 212, 255, 0.3); }
}

.ct-badge-pulse-dot {
  position: absolute;
  top: 2px;
  right: 2px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #EF4444;
  border: 1.5px solid #0B0F14;
}

.ct-notif-has-new .ct-badge-pulse-dot {
  animation: ct-badge-pulse 2s ease-in-out infinite;
}

/* Keyboard odds focus */
.odds-keyboard-focus {
  outline: 2px solid #00D4FF !important;
  outline-offset: 2px;
  z-index: 2;
  position: relative;
}

/* Drag reorder */
.drag-handle {
  cursor: grab;
  color: rgba(232, 237, 245, 0.3);
  padding: 4px;
  margin-inline-end: 4px;
  font-size: 1rem;
  transition: color 0.2s;
  user-select: none;
  touch-action: none;
}

.drag-handle:hover {
  color: rgba(232, 237, 245, 0.7);
}

.drag-handle:active {
  cursor: grabbing;
}

.betslip-item.dragging {
  opacity: 0.5;
  border: 1px dashed rgba(0, 212, 255, 0.3);
}

/* Parallax hero overflow */
.banner-slider--hero {
  overflow: hidden;
}

.banner-slider--hero img {
  will-change: transform;
}

@media (max-width: 576px) {
  .bet-tracker-widget { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  .ct-lazy { opacity: 1; transform: none; transition: none; }
  .ct-badge-pulse-dot { animation: none; }
  .banner-slider--hero img { transform: none !important; }
}

/* ==========================================================================
   Support Ticket Dark Theme
   ========================================================================== */

.support-card {
  background: var(--ct777-dark-card, #1A2233);
  border: 1px solid rgba(232, 237, 245, 0.08);
  border-radius: 10px;
  padding: 1rem;
  margin-bottom: 1rem;
}

.support-card.admin-reply,
.support-card--admin {
  background: rgba(0, 212, 255, 0.04);
  border-color: rgba(0, 212, 255, 0.12);
}

.support-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Custom card dark theme */
.custom--card {
  background: var(--ct777-dark-card, #1A2233);
  border: 1px solid rgba(232, 237, 245, 0.08);
  border-radius: 12px;
}

.custom--card .card-header {
  background: rgba(232, 237, 245, 0.03);
  border-bottom: 1px solid rgba(232, 237, 245, 0.08);
  color: var(--ct-text-primary, #E8EDF5);
}

.custom--card .card-body {
  color: var(--ct-text-primary, #E8EDF5);
}

/* ============================================
   TRUST CENTER - COMPLETE STYLING
   ============================================ */

/* Trust Panel Card */
.trust-panel {
  background: var(--ct-surface-3, #1A2233) !important;
  border: 1px solid rgba(232, 237, 245, 0.08) !important;
  border-radius: 12px !important;
}

.trust-panel__body {
  padding: 1.5rem !important;
}

.trust-panel__eyebrow {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #00D4FF;
  display: block;
  margin-bottom: 0.5rem;
}

.trust-panel__title {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--ct-text-primary, #E8EDF5);
}

.trust-panel__subtitle {
  font-size: 0.82rem;
  color: rgba(232, 237, 245, 0.6);
  line-height: 1.5;
}

.trust-panel__headline {
  font-size: 0.85rem;
  color: rgba(232, 237, 245, 0.7);
  margin-top: 0.75rem;
}

.trust-panel__hero {
  display: flex;
  gap: 1.5rem;
  align-items: flex-start;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
}

.trust-panel__intro {
  flex: 1;
  min-width: 200px;
}

.trust-panel__hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.75rem;
}

/* Trust Pills */
.trust-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 0.72rem;
  font-weight: 600;
}

.trust-pill--danger {
  background: rgba(239, 68, 68, 0.12);
  color: #F87171;
  border: 1px solid rgba(239, 68, 68, 0.2);
}

.trust-pill--warning {
  background: rgba(245, 158, 11, 0.12);
  color: #FBBF24;
  border: 1px solid rgba(245, 158, 11, 0.2);
}

.trust-pill--success {
  background: rgba(34, 197, 94, 0.12);
  color: #4ADE80;
  border: 1px solid rgba(34, 197, 94, 0.2);
}

.trust-pill--neutral {
  background: rgba(232, 237, 245, 0.06);
  color: rgba(232, 237, 245, 0.7);
  border: 1px solid rgba(232, 237, 245, 0.1);
}

/* Trust Score Circle */
.trust-score {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem;
  background: rgba(232, 237, 245, 0.03);
  border: 1px solid rgba(232, 237, 245, 0.08);
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.2s ease;
  flex-shrink: 0;
}

.trust-score:hover {
  background: rgba(232, 237, 245, 0.06);
  border-color: rgba(0, 212, 255, 0.2);
}

.trust-score--interactive {
  cursor: pointer;
}

.trust-score__ring {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  position: relative;
}

.trust-score--danger .trust-score__ring {
  background: conic-gradient(#EF4444 0% var(--trust-score, 45%), rgba(239, 68, 68, 0.15) var(--trust-score, 45%) 100%);
}

.trust-score--warning .trust-score__ring {
  background: conic-gradient(#F59E0B 0% var(--trust-score, 45%), rgba(245, 158, 11, 0.15) var(--trust-score, 45%) 100%);
}

.trust-score--success .trust-score__ring {
  background: conic-gradient(#22C55E 0% var(--trust-score, 45%), rgba(34, 197, 94, 0.15) var(--trust-score, 45%) 100%);
}

.trust-score__inner {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--ct-surface-3, #1A2233);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.trust-score__inner strong {
  font-size: 1.1rem;
  font-weight: 800;
  color: #E8EDF5;
  font-family: var(--ct-font-tabular, 'JetBrains Mono', monospace);
}

.trust-score__inner span {
  font-size: 0.6rem;
  color: rgba(232, 237, 245, 0.5);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.trust-score__meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.trust-score__label {
  font-size: 0.8rem;
  font-weight: 600;
  color: #E8EDF5;
}

.trust-score__copy {
  font-size: 0.75rem;
  color: rgba(232, 237, 245, 0.6);
  line-height: 1.4;
}

.trust-score__trigger {
  font-size: 0.72rem;
  color: #00D4FF;
  margin-top: 4px;
}

/* Trust Insight Grid */
.trust-panel__insight-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

@media (max-width: 991px) {
  .trust-panel__insight-grid { grid-template-columns: 1fr; }
  .trust-panel__hero { flex-direction: column; }
}

/* Trust Progress Card */
.trust-progress-card {
  background: rgba(232, 237, 245, 0.03);
  border: 1px solid rgba(232, 237, 245, 0.08);
  border-radius: 10px;
  padding: 1rem;
}

.trust-progress-card__top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 0.5rem;
}

.trust-progress-card__top strong {
  font-size: 0.85rem;
  color: #E8EDF5;
}

.trust-progress-card__ratio {
  font-family: var(--ct-font-tabular, 'JetBrains Mono', monospace);
  font-weight: 700;
  font-size: 0.85rem;
  color: #00D4FF;
}

.trust-progress-card p {
  font-size: 0.78rem;
  color: rgba(232, 237, 245, 0.6);
}

.trust-progress-card__bar {
  height: 6px;
  background: rgba(232, 237, 245, 0.08);
  border-radius: 3px;
  margin: 0.75rem 0;
  overflow: hidden;
}

.trust-progress-card__bar span {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, #00D4FF, #7C3AED);
  border-radius: 3px;
  transition: width 0.6s ease;
}

.trust-progress-card__steps {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.trust-progress-step {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.72rem;
  color: rgba(232, 237, 245, 0.5);
}

.trust-progress-step.is-complete {
  color: #4ADE80;
}

.trust-progress-step.is-complete i {
  color: #22C55E;
}

.trust-progress-step.is-pending {
  color: rgba(232, 237, 245, 0.4);
}

.trust-progress-step.is-pending i {
  color: rgba(232, 237, 245, 0.25);
}

/* Trust Unlock Card */
.trust-unlock-card {
  background: rgba(232, 237, 245, 0.03);
  border: 1px solid rgba(232, 237, 245, 0.08);
  border-radius: 10px;
  padding: 1rem;
}

.trust-unlock-card--warning {
  border-color: rgba(245, 158, 11, 0.2);
  background: rgba(245, 158, 11, 0.04);
}

.trust-unlock-card__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.5rem;
}

.trust-unlock-card strong {
  font-size: 0.85rem;
  color: #E8EDF5;
  display: block;
  margin-bottom: 0.25rem;
}

.trust-unlock-card p {
  font-size: 0.78rem;
  color: rgba(232, 237, 245, 0.6);
  line-height: 1.5;
}

.trust-unlock-card__footer {
  margin-top: 0.75rem;
}

/* Section Heads */
.trust-panel__section-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 1rem 0;
  margin-bottom: 0.75rem;
  border-bottom: 1px solid rgba(232, 237, 245, 0.06);
}

.trust-panel__section-head strong {
  font-size: 0.9rem;
  color: #E8EDF5;
}

.trust-panel__section-head span {
  font-size: 0.75rem;
  color: rgba(232, 237, 245, 0.5);
}

.trust-panel__section-stat {
  font-size: 0.75rem;
  font-weight: 600;
  color: #00D4FF;
  white-space: nowrap;
}

.trust-panel__secondary-label {
  font-size: 0.68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: rgba(232, 237, 245, 0.45);
  display: block;
  margin-bottom: 0.25rem;
}

/* Trust Signals List */
.trust-signal-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}

.trust-signal {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.85rem;
  border-radius: 10px;
  background: rgba(232, 237, 245, 0.03);
  border: 1px solid rgba(232, 237, 245, 0.06);
  transition: border-color 0.2s;
}

.trust-signal:hover {
  border-color: rgba(232, 237, 245, 0.12);
}

.trust-signal__icon {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
}

.trust-signal--complete .trust-signal__icon {
  background: rgba(34, 197, 94, 0.12);
  color: #22C55E;
}

.trust-signal--warning .trust-signal__icon {
  background: rgba(245, 158, 11, 0.12);
  color: #F59E0B;
}

.trust-signal--action .trust-signal__icon {
  background: rgba(239, 68, 68, 0.12);
  color: #EF4444;
}

.trust-signal__content {
  flex: 1;
  min-width: 0;
}

.trust-signal__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 2px;
}

.trust-signal__title {
  display: flex;
  align-items: center;
  gap: 4px;
}

.trust-signal__title strong {
  font-size: 0.82rem;
  color: #E8EDF5;
}

.trust-signal__badge {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 2px 6px;
  border-radius: 4px;
  white-space: nowrap;
}

.trust-signal--complete .trust-signal__badge {
  background: rgba(34, 197, 94, 0.12);
  color: #4ADE80;
}

.trust-signal--warning .trust-signal__badge {
  background: rgba(245, 158, 11, 0.12);
  color: #FBBF24;
}

.trust-signal--action .trust-signal__badge {
  background: rgba(239, 68, 68, 0.12);
  color: #FCA5A5;
}

.trust-signal p {
  font-size: 0.72rem;
  color: rgba(232, 237, 245, 0.5);
  margin: 0;
}

.trust-help {
  background: rgba(232, 237, 245, 0.06);
  border: 1px solid rgba(232, 237, 245, 0.1);
  color: rgba(232, 237, 245, 0.4);
  cursor: pointer;
  padding: 0;
  font-size: 0.75rem;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  vertical-align: middle;
  transition: all 0.2s ease;
  flex-shrink: 0;
  line-height: 1;
}

.trust-help:hover {
  color: #00D4FF;
  background: rgba(0, 212, 255, 0.1);
  border-color: rgba(0, 212, 255, 0.3);
}

.trust-help i {
  font-size: 0.7rem;
  line-height: 1;
}

/* Trust Timeline */
.trust-timeline {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}

.trust-timeline__item {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.85rem;
  border-radius: 10px;
  background: rgba(232, 237, 245, 0.02);
  border: 1px solid rgba(232, 237, 245, 0.06);
}

.trust-timeline__icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  flex-shrink: 0;
}

.trust-timeline__item--success .trust-timeline__icon {
  background: rgba(34, 197, 94, 0.12);
  color: #22C55E;
}

.trust-timeline__item--warning .trust-timeline__icon {
  background: rgba(245, 158, 11, 0.12);
  color: #F59E0B;
}

.trust-timeline__item--danger .trust-timeline__icon {
  background: rgba(239, 68, 68, 0.12);
  color: #EF4444;
}

.trust-timeline__content {
  flex: 1;
  min-width: 0;
}

.trust-timeline__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 2px;
}

.trust-timeline__top strong {
  font-size: 0.82rem;
  color: #E8EDF5;
}

.trust-timeline__status {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: rgba(232, 237, 245, 0.5);
}

.trust-timeline__content p {
  font-size: 0.75rem;
  color: rgba(232, 237, 245, 0.5);
  line-height: 1.4;
  margin: 0;
}

.trust-timeline__time {
  font-size: 0.7rem;
  color: rgba(232, 237, 245, 0.4);
  white-space: nowrap;
  flex-shrink: 0;
  font-family: var(--ct-font-tabular, 'JetBrains Mono', monospace);
}

/* Trust Score Explainer (hidden by default) */
.trust-score-explainer {
  margin-bottom: 1.5rem;
}

.trust-score-explainer[hidden] {
  display: none;
}

.trust-score-breakdown {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.trust-breakdown-card {
  padding: 1rem;
  border-radius: 10px;
  background: rgba(232, 237, 245, 0.03);
  border: 1px solid rgba(232, 237, 245, 0.06);
}

.trust-breakdown-card__top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 0.5rem;
}

.trust-breakdown-card__top strong {
  font-size: 0.85rem;
  color: #E8EDF5;
}

.trust-breakdown-card__top span {
  font-size: 0.72rem;
  color: rgba(232, 237, 245, 0.5);
}

.trust-breakdown-card__score {
  font-family: var(--ct-font-tabular, 'JetBrains Mono', monospace);
  font-weight: 700;
  font-size: 0.9rem;
}

.trust-breakdown-card--success .trust-breakdown-card__score { color: #4ADE80; }
.trust-breakdown-card--warning .trust-breakdown-card__score { color: #FBBF24; }
.trust-breakdown-card--danger .trust-breakdown-card__score { color: #F87171; }

.trust-breakdown-card--success { border-left: 3px solid #22C55E; }
.trust-breakdown-card--warning { border-left: 3px solid #F59E0B; }
.trust-breakdown-card--danger { border-left: 3px solid #EF4444; }

.trust-breakdown-card p {
  font-size: 0.75rem;
  color: rgba(232, 237, 245, 0.5);
  line-height: 1.4;
}

.trust-breakdown-card__subitems {
  display: flex;
  gap: 1rem;
  margin-top: 0.5rem;
  font-size: 0.72rem;
  color: rgba(232, 237, 245, 0.5);
}

.trust-breakdown-card__subitems strong {
  color: #4ADE80;
  font-size: 0.72rem;
}

/* Trust Meta Grid */
.trust-panel__meta-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}

.trust-meta-card {
  padding: 0.75rem 1rem;
  background: rgba(232, 237, 245, 0.03);
  border: 1px solid rgba(232, 237, 245, 0.06);
  border-radius: 8px;
  flex: 1;
  min-width: 120px;
}

.trust-meta-card__label {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: rgba(232, 237, 245, 0.4);
  display: block;
  margin-bottom: 2px;
}

.trust-meta-card__value {
  font-size: 0.85rem;
  color: #E8EDF5;
}

/* Trust Action Card */
.trust-panel__actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-top: 1.5rem;
}

@media (max-width: 767px) {
  .trust-panel__actions { grid-template-columns: 1fr; }
}

.trust-action-card {
  padding: 1.25rem;
  background: linear-gradient(135deg, rgba(0, 212, 255, 0.06), rgba(124, 58, 237, 0.04));
  border: 1px solid rgba(0, 212, 255, 0.15);
  border-radius: 10px;
}

.trust-action-card__eyebrow {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #00D4FF;
  display: block;
  margin-bottom: 0.5rem;
}

.trust-action-card strong {
  font-size: 1rem;
  color: #E8EDF5;
  display: block;
  margin-bottom: 0.25rem;
}

.trust-action-card p {
  font-size: 0.78rem;
  color: rgba(232, 237, 245, 0.6);
  line-height: 1.5;
}

.trust-action-card__footer {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.75rem;
}

.trust-panel__secondary-note {
  padding: 1rem;
  background: rgba(232, 237, 245, 0.03);
  border: 1px solid rgba(232, 237, 245, 0.06);
  border-radius: 10px;
}

.trust-panel__secondary-note strong {
  font-size: 0.85rem;
  color: #E8EDF5;
  display: block;
  margin-bottom: 0.25rem;
}

.trust-panel__secondary-note p {
  font-size: 0.75rem;
  color: rgba(232, 237, 245, 0.5);
  line-height: 1.5;
}

/* ============================================
   SAFETY OVERVIEW - COMPLETE STYLING
   (User dashboard Controls card: .controls-card - refined overrides in dashboard-premium.css)
   ============================================ */

.safety-overview {
  background: var(--ct-surface-3, #1A2233) !important;
  border: 1px solid rgba(232, 237, 245, 0.08) !important;
  border-radius: 12px !important;
}

.safety-overview__body {
  padding: 1.5rem !important;
}

.safety-overview__title {
  font-size: 1.1rem;
  font-weight: 700;
  color: #E8EDF5;
}

.safety-overview__subtitle {
  font-size: 0.78rem;
  color: rgba(232, 237, 245, 0.55);
  line-height: 1.5;
}

.safety-overview__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 1rem;
}

.safety-overview__status {
  text-align: right;
  flex-shrink: 0;
}

.safety-overview__status-label {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: rgba(232, 237, 245, 0.4);
  display: block;
}

.safety-overview__status strong {
  font-size: 1.5rem;
  font-weight: 800;
  color: #00D4FF;
  font-family: var(--ct-font-tabular, 'JetBrains Mono', monospace);
  display: block;
}

.safety-overview__status span {
  font-size: 0.72rem;
  color: rgba(232, 237, 245, 0.5);
}

.safety-overview__insight {
  padding: 0.75rem 1rem;
  background: rgba(0, 212, 255, 0.05);
  border: 1px solid rgba(0, 212, 255, 0.12);
  border-radius: 8px;
  margin-bottom: 1rem;
}

.safety-overview__insight strong {
  font-size: 0.78rem;
  color: #00D4FF;
  display: block;
  margin-bottom: 2px;
}

.safety-overview__insight span {
  font-size: 0.75rem;
  color: rgba(232, 237, 245, 0.6);
}

.safety-overview__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
  margin-bottom: 1rem;
  align-items: stretch;
}

@media (max-width: 575px) {
  .safety-overview__grid { grid-template-columns: 1fr; }
}

.safety-mini-card {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  padding: 1rem;
  border-radius: 10px;
  background: rgba(17, 24, 39, 0.6);
  border: 1px solid rgba(232, 237, 245, 0.08);
  min-height: 140px;
}

.safety-mini-card.is-configured {
  border-color: rgba(34, 197, 94, 0.2);
  background: rgba(34, 197, 94, 0.04);
}

.safety-mini-card.is-pending {
  border-color: rgba(245, 158, 11, 0.15);
  background: rgba(245, 158, 11, 0.03);
}

.safety-mini-card__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
}

.safety-mini-card__top > span:first-child {
  font-size: 0.78rem;
  font-weight: 600;
  color: #E8EDF5;
}

.safety-mini-card__state {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 2px 6px;
  border-radius: 4px;
}

.safety-mini-card.is-configured .safety-mini-card__state {
  color: #4ADE80;
  background: rgba(34, 197, 94, 0.12);
}

.safety-mini-card.is-pending .safety-mini-card__state {
  color: #FBBF24;
  background: rgba(245, 158, 11, 0.12);
}

.safety-mini-card strong {
  font-size: 1rem;
  font-weight: 700;
  color: #E8EDF5;
  font-family: var(--ct-font-tabular, 'JetBrains Mono', monospace);
}

.safety-mini-card__detail {
  font-size: 0.72rem;
  color: rgba(232, 237, 245, 0.5);
  line-height: 1.4;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}

.safety-mini-card__progress {
  height: 4px;
  background: rgba(232, 237, 245, 0.08);
  border-radius: 2px;
  overflow: hidden;
  margin-top: auto;
}

.safety-mini-card__progress span {
  display: block;
  height: 100%;
  border-radius: 2px;
  transition: width 0.6s ease;
}

.safety-mini-card.is-configured .safety-mini-card__progress span {
  background: linear-gradient(90deg, #22C55E, #4ADE80);
}

.safety-mini-card.is-pending .safety-mini-card__progress span {
  background: linear-gradient(90deg, #F59E0B, #FBBF24);
}

.safety-overview__footer {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

/* KYC Alert Override */
.alert-warning {
  background: rgba(245, 158, 11, 0.08) !important;
  border: 1px solid rgba(245, 158, 11, 0.2) !important;
  border-radius: 10px !important;
  color: #E8EDF5 !important;
}

.alert-warning h5 {
  color: #FBBF24 !important;
}

.alert-warning a {
  color: #00D4FF !important;
}

/* Dashboard Referral Card */
.dashboard-referral-card {
  background: var(--ct-surface-3, #1A2233) !important;
  border: 1px solid rgba(232, 237, 245, 0.08) !important;
}

/* Dashboard Chart Card */
.dashboard-chart-card {
  background: var(--ct-surface-3, #1A2233) !important;
  border: 1px solid rgba(232, 237, 245, 0.08) !important;
}

/* Dashboard Empty State */
.dashboard-empty-state {
  color: rgba(232, 237, 245, 0.6);
}

.dashboard-empty-state h6 {
  color: #E8EDF5;
}

/* Latest Transactions Card */
.dashboard-right .card {
  background: var(--ct-surface-3, #1A2233) !important;
  border: 1px solid rgba(232, 237, 245, 0.08) !important;
  border-radius: 12px !important;
}

.dashboard-right .list-group-item {
  background: transparent !important;
  border-color: rgba(232, 237, 245, 0.06) !important;
  color: rgba(232, 237, 245, 0.6) !important;
}

/* Date range picker dark */
.dashboard-right input[name="date"] {
  background: rgba(17, 24, 39, 0.8) !important;
  border: 1px solid rgba(232, 237, 245, 0.12) !important;
  color: #E8EDF5 !important;
  border-radius: 8px !important;
}

/* ============================================
   LANGUAGE SWITCHER
   ============================================ */
.lang-switcher-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  background: rgba(232, 237, 245, 0.06);
  border: 1px solid rgba(232, 237, 245, 0.1);
  border-radius: 8px;
  color: rgba(232, 237, 245, 0.8);
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}

.lang-switcher-btn::after {
  font-size: 0.6rem;
  margin-left: 2px;
  opacity: 0.5;
}

.lang-switcher-btn:hover,
.lang-switcher-btn:focus {
  background: rgba(0, 212, 255, 0.1);
  border-color: rgba(0, 212, 255, 0.3);
  color: #00D4FF;
}

.lang-switcher-btn .las {
  font-size: 1rem;
}

.lang-switcher-btn__label {
  letter-spacing: 0.04em;
}

.lang-switcher-dropdown {
  background: var(--ct-surface-3, #1A2233) !important;
  border: 1px solid rgba(232, 237, 245, 0.1) !important;
  border-radius: 10px !important;
  padding: 4px !important;
  min-width: 150px !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4) !important;
}

.lang-switcher-item {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 8px 12px !important;
  border-radius: 6px !important;
  color: rgba(232, 237, 245, 0.8) !important;
  font-size: 0.85rem !important;
  transition: all 0.15s ease !important;
}

.lang-switcher-item:hover {
  background: rgba(0, 212, 255, 0.1) !important;
  color: #E8EDF5 !important;
}

.lang-switcher-item.active {
  background: rgba(0, 212, 255, 0.12) !important;
  color: #00D4FF !important;
}

.lang-switcher-flag {
  width: 20px;
  height: 14px;
  border-radius: 2px;
  object-fit: cover;
}

.lang-switcher-check {
  margin-left: auto;
  font-size: 0.85rem;
  color: #00D4FF;
}

/* =============================================================================
   Desktop fixture table - key markets 3-slot grid (LIVE: must live in this file)
   layouts/app.blade.php does NOT load cafetal777-theme.css; rules there are inert.
   Blade: templates/basic/partials/sport_key_market_group.blade.php
   DOM: Whitespace text nodes between grid children become extra grid items and
   steal columns (slots wrap vertically). The Blade partial emits slots with no
   inter-element whitespace; do not reformat with newlines between slot divs.
   ============================================================================= */
.cafetal777-layout .sport-table--key-markets.sport-table--creative,
.sport-table--key-markets.sport-table--creative {
  min-width: 1020px;
}
.sport-table--key-markets .sport-table__th--keygrid,
.sport-table--key-markets .sport-table__cell--keygrid {
  width: 8rem;
  min-width: 7.5rem;
  max-width: 9rem;
  text-align: center;
  vertical-align: middle;
  padding: 10px 5px;
  white-space: normal;
}
.sport-table--key-markets .sport-key-grid.sport-key-grid--fixture,
td.sport-table__cell--keygrid > .sport-key-grid.sport-key-grid--fixture {
  --sport-key-slot-min-h: 2.38rem;
  --sport-key-gap: 5px;
  display: grid !important;
  grid-template-columns: 1fr 1fr 1fr !important;
  grid-auto-flow: row !important;
  grid-auto-rows: auto;
  gap: var(--sport-key-gap);
  align-items: stretch;
  align-content: stretch;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}
.sport-table--key-markets .sport-key-grid__slot {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center;
  justify-content: center;
  align-content: center;
  min-width: 0;
  min-height: var(--sport-key-slot-min-h);
}
.sport-table--key-markets .sport-key-grid__slot:nth-child(1),
.sport-table--key-markets .sport-key-grid__slot:nth-child(3) {
  padding: 0 1px;
}
.sport-table--key-markets .sport-key-grid__btn {
  box-sizing: border-box;
  flex: 1 1 auto;
  align-self: stretch;
  min-width: 0;
  width: 100%;
  max-width: 100%;
  min-height: var(--sport-key-slot-min-h);
  padding: 0 5px !important;
  font-size: 0.8rem !important;
  font-weight: 600;
  line-height: 1.2;
  border-radius: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.01em;
  -webkit-font-smoothing: antialiased;
}
.sport-table--key-markets .sport-key-grid__btn.locked {
  opacity: 0.45;
  cursor: not-allowed;
  pointer-events: none;
}
.sport-table--key-markets .sport-key-grid__slot:nth-child(2) .sport-key-grid__chip:not(.sport-key-grid__chip--empty) {
  max-width: 94%;
  margin-inline: auto;
}
.sport-table--key-markets .sport-key-grid__chip {
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: var(--sport-key-slot-min-h);
  align-self: stretch;
  padding: 0 3px;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  line-height: 1.15;
  color: var(--ct777-text-muted, #8a9bb8);
  border-radius: 5px;
  border: 1px solid rgba(255, 255, 255, 0.07);
  background: rgba(255, 255, 255, 0.035);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
  min-width: 0;
  font-variant-numeric: tabular-nums;
}
.sport-table--key-markets .sport-key-grid__chip-text {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 100%;
  color: rgba(232, 237, 245, 0.88);
}
.sport-table--key-markets .sport-key-grid__chip--empty {
  max-width: 88%;
  margin-inline: auto;
  opacity: 1;
  border-style: solid;
  border-color: rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.025);
  box-shadow: none;
}
.sport-table--key-markets .sport-key-grid__empty {
  display: block;
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  min-height: var(--sport-key-slot-min-h);
  align-self: stretch;
  border-radius: 6px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.03);
  opacity: 1;
  pointer-events: none;
}
@media (min-width: 992px) {
  .cafetal777-layout .sport-table--key-markets .sport-key-grid .oddBtn.sport-key-grid__btn {
    flex: 0 1 auto !important;
    min-width: 0 !important;
  }
}
