
/* =========================================
   1. Reset & Variables
   ========================================= */
:root {
  /* Colors */
  --c-bg-body: #0f1115;
  --c-bg-card: #1c1f26;
  --c-bg-card-hover: #252932;
  --c-text-primary: #ffffff;
  --c-text-secondary: #8d95a5;
  --c-text-accent: #ffb700;
  
  --c-primary: #ff4d00;
  --c-primary-dark: #cc3e00;
  --c-success: #2ecc71;
  --c-success-dark: #27ae60;
  --c-warning: #f1c40f;
  
  --c-gradient-primary: linear-gradient(135deg, #ff4d00 0%, #ff8800 100%);
  --c-gradient-success: linear-gradient(135deg, #2ecc71 0%, #27ae60 100%);
  --c-gradient-dark: linear-gradient(to bottom, #2b303b, #1c1f26);
  
  --c-border: rgba(255, 255, 255, 0.1);
  --c-shadow: 0 10px 20px rgba(0, 0, 0, 0.3);
  
  /* Dimensions */
  --container-width: 1200px;
  --header-height: 80px;
  --radius-sm: 0.25rem;
  --radius-md: 0.5rem;
  --radius-lg: 1rem;
  
  /* Transitions */
  --transition-fast: 0.2s ease;
  --transition-smooth: 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
}

body {
  font-family: 'Inter', 'Roboto', sans-serif;
  background-color: var(--c-bg-body);
  color: var(--c-text-primary);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

ul, li {
  list-style: none;
}

a {
  text-decoration: none;
  color: inherit;
  transition: color var(--transition-fast);
}

img, video, svg {
  max-width: 100%;
  height: auto;
  display: block;
}

/* Scrollbar Customization */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}
::-webkit-scrollbar-track {
  background: var(--c-bg-body);
}
::-webkit-scrollbar-thumb {
  background: #3a404d;
  border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
  background: var(--c-primary);
}

/* =========================================
   2. Layout & Utilities
   ========================================= */
.layout__container {
  width: 100%;
  max-width: var(--container-width);
  margin: 0 auto;
  padding: 0 1rem;
}

.layout__mb-30 { margin-bottom: 2rem; }
.layout__mb-20 { margin-bottom: 1.25rem; }
.layout__mb-15 { margin-bottom: 1rem; }
.layout__mb-10 { margin-bottom: 0.625rem; }
.layout__mb-3 { margin-bottom: 0.2rem; }
.layout__mt-3 { margin-top: 0.2rem; }
.layout__mv-10 { margin: 0.625rem 0; }

.line {
  height: 1px;
  background: var(--c-border);
  margin: 2rem 0;
  width: 100%;
}

/* =========================================
   3. Header Styling
   ========================================= */
.head-control-panel {
  background: rgba(28, 31, 38, 0.95);
  backdrop-filter: blur(10px);
  position: sticky;
  top: 0;
  z-index: 100;
  border-bottom: 1px solid var(--c-border);
  padding: 0.5rem 0;
}

.head-control-panel .layout__container {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.layout__pull-left {
  display: flex;
  align-items: center;
  gap: 2rem;
}

/* Logo */
.head-control-panel__logo svg {
  width: 140px;
  height: 40px;
  fill: var(--c-text-primary);
}

/* Dynamic Menu (Login/Reg) */
.head-dynamic-menu {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.head-dynamic-menu__pseudo-link {
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--c-text-secondary);
}
.head-dynamic-menu__pseudo-link:hover {
  color: var(--c-text-primary);
}

/* Social Icons */
.social-list {
  display: flex;
  gap: 0.5rem;
}

.social-list__link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: rgba(255,255,255,0.1);
  border-radius: 50%;
  transition: var(--transition-fast);
}

.social-list__link:hover {
  background: var(--c-primary);
  transform: translateY(-2px);
}

.social-list__title {
  display: none; /* Icon only usually */
}
.social.icons {
  font-size: 1rem;
  color: #fff;
}

/* Lang Switcher */
.head-control-panel__lang-pseudo-link {
  text-transform: uppercase;
  font-weight: bold;
  padding: 0.25rem 0.5rem;
  border: 1px solid var(--c-border);
  border-radius: var(--radius-sm);
}

/* Tabs Navigation */
.head-control-tabs {
  display: flex;
  justify-content: center;
  background: var(--c-bg-card);
  padding: 0;
  margin-bottom: 2rem;
  border-bottom: 1px solid var(--c-border);
}

.head-control-tabs__item {
  position: relative;
}

.head-control-tabs__link {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 1rem 1.5rem;
  font-weight: 600;
  font-size: 0.9rem;
  text-transform: uppercase;
  color: var(--c-text-secondary);
  position: relative;
  overflow: hidden;
}

.head-control-tabs__link:hover,
.head-control-tabs__link_state_active {
  color: var(--c-text-primary);
}

.head-control-tabs__link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: var(--c-primary);
  transform: scaleX(0);
  transition: transform var(--transition-fast);
}

.head-control-tabs__link_state_active::after,
.head-control-tabs__link:hover::after {
  transform: scaleX(1);
}

.head-control-tabs__icon svg {
  width: 20px;
  height: 20px;
  fill: currentColor;
}

/* =========================================
   4. Hero Slider & Banners
   ========================================= */
.main-slider {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: 2rem;
  box-shadow: var(--c-shadow);
}

.main-slider__img-holder {
  position: relative;
  width: 100%;
  height: 400px;
}

.main-slider__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Slider Overlay Content */
.main-slider .layout__container {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 100%;
  z-index: 2;
  padding: 0 3rem;
}

.grids {
  display: flex;
  align-items: center;
}
.grids__item { flex: 1; }
.grids__item_width_60pct { flex: 0 0 60%; }

.main-slider__title {
  font-size: clamp(1.5rem, 4vw, 3rem);
  font-weight: 800;
  text-shadow: 0 2px 10px rgba(0,0,0,0.7);
  line-height: 1.1;
  margin-bottom: 1rem;
}

/* Buttons */
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1.5rem;
  border-radius: var(--radius-md);
  font-weight: 700;
  text-transform: uppercase;
  font-size: 0.9rem;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: all var(--transition-fast);
  box-shadow: 0 4px 6px rgba(0,0,0,0.2);
}

.button:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 12px rgba(0,0,0,0.3);
}

.button:active {
  transform: translateY(0);
}

.button_style_success {
  background: var(--c-gradient-success);
  color: white;
}

.button_style_flat-warning {
  background: var(--c-warning);
  color: #000;
}

.button_size_xl {
  padding: 1rem 2.5rem;
  font-size: 1.1rem;
}

.button__icon svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
  margin-right: 0.5rem;
}

/* =========================================
   5. Game Filter Menu
   ========================================= */
.layout__games-list-filter {
  margin-bottom: 2rem;
  overflow-x: auto;
  padding-bottom: 0.5rem;
}

.menu-filter {
  display: flex;
  gap: 1.5rem;
  padding: 0 0.5rem;
}

.menu-filter__item {
  flex-shrink: 0;
}

.menu-filter__link {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  color: var(--c-text-secondary);
  transition: var(--transition-fast);
}

.menu-filter__icon {
  width: 48px;
  height: 48px;
  background: var(--c-bg-card);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
  border: 1px solid transparent;
}

.menu-filter__icon svg {
  width: 24px;
  height: 24px;
  fill: currentColor;
}

.menu-filter__link:hover .menu-filter__icon,
.menu-filter__item_state_acitve .menu-filter__icon {
  background: var(--c-bg-card-hover);
  border-color: var(--c-primary);
  color: var(--c-primary);
  box-shadow: 0 0 15px rgba(255, 77, 0, 0.2);
}

.menu-filter__link:hover .menu-filter__text,
.menu-filter__item_state_acitve .menu-filter__text {
  color: var(--c-text-primary);
}

.menu-filter__text {
  font-size: 0.85rem;
  font-weight: 500;
}

/* Search Input */
.menu-filter__input-holder {
  position: relative;
  display: flex;
  align-items: center;
}

.menu-filter__input {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: 20px;
  padding: 0.5rem 1rem 0.5rem 2.5rem;
  color: white;
  outline: none;
  transition: border-color var(--transition-fast);
  width: 150px;
}

.menu-filter__input:focus {
  border-color: var(--c-primary);
  width: 200px;
}

.menu-filter__search-btn {
  position: absolute;
  left: 10px;
  color: var(--c-text-secondary);
}
.menu-filter__search-btn svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
}

/* =========================================
   6. Games Grid
   ========================================= */
.games-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 1.5rem;
  margin-bottom: 2rem;
}

.game-box {
  position: relative;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--c-bg-card);
  aspect-ratio: 16/9;
  transition: transform var(--transition-smooth), box-shadow var(--transition-smooth);
}

.game-box:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 30px rgba(0,0,0,0.4);
  z-index: 10;
}

.game-box__img-holder {
  display: block;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  background-color: #2a2a2a; /* Placeholder */
}

/* Hover Overlay */
.game-box__action-content {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(3px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity var(--transition-fast);
}

.game-box:hover .game-box__action-content {
  opacity: 1;
}

.game-box__title {
  color: white;
  font-weight: 700;
  margin-bottom: 1rem;
  text-align: center;
  transform: translateY(20px);
  transition: transform var(--transition-fast);
}

.game-box:hover .game-box__title {
  transform: translateY(0);
}

.game-box__holder .button {
  font-size: 0.8rem;
  padding: 0.5rem 1.5rem;
}

.game-box__demo-holder {
  margin-top: 0.5rem;
}

.game-box__pseudo-link {
  font-size: 0.8rem;
  color: var(--c-text-secondary);
  border-bottom: 1px dashed currentColor;
}
.game-box__pseudo-link:hover {
  color: white;
  border-bottom-style: solid;
}

/* New Label */
.game-box__label-new {
  position: absolute;
  top: 10px;
  right: 10px;
  background: var(--c-primary);
  color: white;
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 0.7rem;
  font-weight: bold;
  z-index: 5;
  box-shadow: 0 2px 5px rgba(0,0,0,0.3);
}
.game-box__label-new svg {
  width: 30px;
  height: auto;
}

.game-box__icon-decor {
  position: absolute;
  width: 20px;
  height: 20px;
  fill: rgba(255,255,255,0.2);
}

/* =========================================
   7. Information Sliders & Tables (Jackpot/Tournaments)
   ========================================= */
.widgets-slider { margin-bottom: 2rem; }

.title-section {
  text-align: center;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--c-text-accent);
  margin-bottom: 1rem;
}

/* Jackpot SVG Text Override */
.title-section + div svg text tspan {
  font-family: 'Inter', sans-serif !important; 
  font-weight: 800;
}

/* Info Cards */
.all-info-slider__item {
  background: var(--c-bg-card);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  border: 1px solid var(--c-border);
}

.iconed-title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 700;
  color: var(--c-text-primary);
}

.iconed-title__icon svg {
  width: 24px;
  height: 24px;
  fill: var(--c-text-accent);
}

/* Tables */
.table-info {
  width: 100%;
  border-collapse: collapse;
}

.table-info__cell {
  padding: 1rem;
  vertical-align: middle;
}

.counter {
  display: flex;
  gap: 0.5rem;
}

.counter__item {
  text-align: center;
  background: #000;
  padding: 0.25rem 0.5rem;
  border-radius: var(--radius-sm);
  min-width: 40px;
}

.counter__numbers {
  display: block;
  font-size: 1.2rem;
  font-weight: bold;
  color: var(--c-primary);
}
.counter__label {
  font-size: 0.7rem;
  color: var(--c-text-secondary);
}

/* Tournament List */
.tournament-list {
  width: 100%;
}

.tournament-list__row {
  display: flex;
  padding: 0.75rem;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  align-items: center;
}

.tournament-list__row:hover {
  background: rgba(255,255,255,0.02);
}

.tournament-list__row_type_header {
  color: var(--c-text-secondary);
  font-size: 0.8rem;
  text-transform: uppercase;
}

.tournament-list__cell {
  flex: 1;
}
.tournament-list__cell:first-child { flex: 0 0 50px; }
.tournament-list__cell:last-child { flex: 0 0 80px; text-align: right; color: var(--c-text-accent); font-weight: bold; }

.booster-indicator {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: #333;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
}
.booster-indicator_type_active {
  background: var(--c-primary);
  color: white;
}
.booster-indicator_type_super-active {
  background: var(--c-text-accent);
  color: black;
}

.tournament-list__player-info {
  color: white;
  font-weight: 500;
}

/* Split Columns */
.layout__col-wrap {
  display: flex;
  gap: 1.5rem;
  flex-wrap: wrap;
}
.layout__col-50pct {
  flex: 1 1 300px;
}

/* =========================================
   8. SEO Content Area (.pcontent)
   ========================================= */
.pcontent {
  background: var(--c-bg-card);
  padding: 2rem;
  border-radius: var(--radius-lg);
  color: #ccc;
  margin-top: 3rem;
}

.pcontent h1, .pcontent h2 {
  color: white;
  margin-bottom: 1.5rem;
  margin-top: 2rem;
}
.pcontent h1 { font-size: 2rem; }
.pcontent h2 { font-size: 1.5rem; color: var(--c-primary); }

.pcontent p { margin-bottom: 1rem; }

.pcontent ul {
  list-style: disc;
  padding-left: 1.5rem;
  margin-bottom: 1.5rem;
}
.pcontent li { margin-bottom: 0.5rem; }

.pcontent table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.5rem 0;
  border-radius: var(--radius-sm);
  overflow: hidden;
}

.pcontent th, .pcontent td {
  padding: 1rem;
  text-align: left;
  border: 1px solid rgba(255,255,255,0.1);
}

.pcontent th {
  background: rgba(255,255,255,0.05);
  color: var(--c-primary);
}

/* =========================================
   9. Footer & Icons
   ========================================= */
.menu-simple {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.5rem;
  margin: 2rem 0;
}

.menu-simple__link {
  font-size: 0.9rem;
  text-transform: uppercase;
  color: var(--c-text-secondary);
}
.menu-simple__link:hover {
  color: var(--c-text-primary);
  text-decoration: underline;
}

.list-media {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  opacity: 0.6;
}

.list-media:hover { opacity: 1; }

.list-media__item i {
  display: block;
  width: 50px;
  height: 30px;
  background-color: #333; /* Placeholder for sprite icons */
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  border-radius: 4px;
}
/* Note: Real icons depend on CSS Sprite positions which aren't provided, 
   but basic box styling is applied. */

/* =========================================
   10. Mobile Responsiveness
   ========================================= */
@media (max-width: 768px) {
  html { font-size: 14px; }
  
  .head-dynamic-menu__item:not(:last-child) {
    display: none; /* Simplify header on mobile */
  }
  
  .main-slider__img-holder {
    height: 250px;
  }
  
  .grids {
    flex-direction: column;
    text-align: center;
  }
  
  .grids__item_width_60pct { flex: auto; }
  
  .games-list {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.75rem;
  }
  
  .menu-filter {
    gap: 1rem;
  }
  
  .pcontent {
    padding: 1rem;
  }
  
  .table-info td {
    display: block;
    width: 100%;
    text-align: center;
  }
  
  .counter {
    justify-content: center;
  }
}

@media (max-width: 480px) {
  .games-list {
    grid-template-columns: 1fr; 
  }
  
  .layout__pull-left {
    gap: 1rem;
  }
  
  .head-control-panel__logo svg {
    width: 100px;
  }
}
