/* Game Top-Up System - Main Stylesheet */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
html, body { max-width: 100%; overflow-x: hidden; }

/* Slightly reduce spacing/text before mobile breakpoint to keep single row */
@media (max-width: 1100px) {
  .nav-links { gap: 0.8rem; }
  .nav-links a { font-size: 0.97rem; }
  .credits-badge { padding: 0.4rem 0.8rem; font-size: 0.95rem; }
  .nav-links .admin-link { padding: 0.4rem 0.7rem; font-size: 0.95rem; }
}

/* Slightly compact header just below large desktop to keep single row */
@media (max-width: 1260px) {
  .nav-links { gap: 0.7rem; }
  .nav-links a { font-size: 0.95rem; }
  .nav-links .admin-link,
  .nav-links .topup-link { padding: 0.4rem 0.7rem; }
  .credits-badge { padding: 0.4rem 0.75rem; }
}

:root {
    --primary-color: #2563eb;
    --secondary-color: #0ea5e9;
    --success-color: #10b981;
    --warning-color: #f59e0b;
    --error-color: #ef4444;
    --dark: #0f172a;
    --gray: #475569;
    --light-gray: #f1f5f9;
    --border-color: #e2e8f0;
    --shadow: 0 1px 3px rgba(0,0,0,0.1);
    --shadow-md: 0 4px 6px rgba(0,0,0,0.1);
    --shadow-lg: 0 10px 15px rgba(0,0,0,0.1);
}

html {
    font-family: 'Prompt', sans-serif;
}

body {
    font-family: 'Prompt', sans-serif;
    background: var(--page-bg, #f8fafc);
    color: var(--dark);
    line-height: 1.6;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* Navigation */
.navbar {
    background: white;
    box-shadow: var(--shadow);
    position: sticky;
    top: 0;
    z-index: 1000;
}

.nav-wrapper {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 0;
}

.nav-brand {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--primary-color);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    white-space: nowrap; /* keep brand in one line */
}

.nav-menu {
    display: flex;
    align-items: center;
    flex: 1 1 auto;        /* take remaining space */
    justify-content: flex-end; /* push links to the right in a single row */
}

.nav-links {
    display: flex;
    list-style: none;
    gap: 1rem;              /* tighter spacing to fit one line */
    align-items: center;
    flex-wrap: nowrap;      /* keep single row on desktop */
}

/* Add slight left spacing for the first nav item */
.nav-links li:first-child {
    margin-left: 0.5rem;
}

/* Ensure nav items align properly */
.nav-links li { display: flex; align-items: center; white-space: nowrap; }

.nav-links a {
    color: var(--dark);
    text-decoration: none;
    transition: color 0.3s;
    white-space: nowrap;         /* prevent link text wrapping */
    display: inline-flex;        /* keep icon and text together */
    align-items: center;
    gap: 0.35rem;
}

.nav-links a:hover {
    color: var(--primary-color);
}

/* Admin link button in header */
.nav-links .admin-link {
    background: var(--primary-color);
    color: #fff;
    padding: 0.45rem 0.85rem;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    box-shadow: var(--shadow);
}

.nav-links .admin-link i { 
    color: #fff; 
}

.nav-links .admin-link:hover {
    color: #fff;
    background: var(--primary-hover, #1d4ed8);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.nav-links .topup-link {
    background: var(--success-color);
    color: #fff;
    padding: 0.45rem 0.85rem;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    box-shadow: var(--shadow);
}

.nav-links .topup-link i {
    color: #fff;
}

.nav-links .topup-link:hover {
    color: #fff;
    background: var(--success-hover, #059669);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

/* Dropdown */
.nav-links .dropdown {
    position: relative;
}

.nav-links .dropdown-toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
}

.nav-links .dropdown-menu {
    position: absolute;
    top: 120%;
    right: 0;
    background: #fff;
    border: 1px solid var(--border-color);
    border-radius: 10px;
    box-shadow: var(--shadow-lg);
    min-width: 200px;
    padding: 0.5rem 0;
    display: none;
    z-index: 1100;
}

.nav-links .dropdown-menu li {
    list-style: none;
    display: block;
}

.nav-links .dropdown-menu a {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    width: 100%;
    padding: 0.6rem 1rem;
    color: var(--dark);
    text-align: center;
}

.nav-links .dropdown-menu a:hover {
    background: var(--light-gray);
    color: var(--primary-color);
}

.nav-links .dropdown.open > .dropdown-menu {
    display: block;
}

.nav-links .dropdown:hover > .dropdown-menu,
.nav-links .dropdown:focus-within > .dropdown-menu {
    display: block;
}

.nav-toggle {
    display: none;
    flex-direction: column;
    gap: 4px;
    background: none;
    border: none;
    cursor: pointer;
}

.nav-toggle span {
    width: 25px;
    height: 3px;
    background: var(--dark);
    border-radius: 2px;
}

/* Hero Section */
.hero-section {
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    color: white;
    padding: 4rem 0;
    text-align: center;
}
@media (max-width: 520px) {
  .hero-section { padding: 2.5rem 0; }
}

.hero-title {
    font-size: 3rem;
    margin-bottom: 1rem;
}

.hero-subtitle {
    font-size: 1.25rem;
    margin-bottom: 2rem;
}

.hero-features {
    display: flex;
    justify-content: center;
    gap: 2rem;
    flex-wrap: wrap;
}

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

/* Buttons */
.btn {
    display: inline-block;
    padding: 0.75rem 1.5rem;
    border-radius: 8px;
    text-decoration: none;
    font-weight: 500;
    font-family: inherit;
    transition: all 0.3s;
    border: none;
    cursor: pointer;
    text-align: center;
}

.btn-primary {
    background: var(--primary-color);
    color: white;
}

.btn-primary:hover {
    background: var(--primary-hover, #1d4ed8);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.btn-secondary {
    background: var(--gray);
    color: white;
}

.btn-success {
    background: var(--success-color);
    color: white;
}

.btn-success:hover {
    background: var(--success-hover, #059669);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.btn-block {
    display: block;
    width: 100%;
}

.btn-lg {
    padding: 1rem 2rem;
    font-size: 1.1rem;
}

.btn-sm {
    padding: 0.5rem 1rem;
    font-size: 0.9rem;
}

/* Games Grid */
.games-section {
    padding: 3rem 0;
}

.section-title {
    font-size: 2rem;
    margin-bottom: 2rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
@media (max-width: 520px) {
  .section-title { font-size: 1.6rem; }
}

/* Center only the headings for specific sections */
.how-it-works .section-title,
.features-section .section-title { justify-content: center; text-align: center; }

.games-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 2rem;
}

/* Compact grid for listing many items horizontally (8-10 per row on desktop) */
.games-grid-compact {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
    width: 100%;
    margin: 0 auto;
}

.games-grid-compact .game-card {
    border: 1px solid var(--border-color);
    width: calc(25% - 1rem);
    min-width: 220px;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.games-grid-compact .game-image {
    height: 110px;
    width: 100%;
}

.games-grid-compact .game-placeholder { font-size: 2rem; }

.games-grid-compact .game-info {
    padding: 0.75rem;
    width: 100%;
    text-align: center; /* center text */
}

.games-grid-compact .game-name {
    font-size: 1rem;
    margin-bottom: 0.25rem;
}

.games-grid-compact .game-description {
    display: none; /* hide to keep cards compact */
}

.games-grid-compact .btn { padding: 0.5rem 0.75rem; font-size: 0.9rem; }

/* Responsive column counts for compact grid */
@media (max-width: 768px) {
  .games-grid-compact { justify-content: center; }
  .games-grid-compact .game-card { width: 92%; max-width: 420px; margin-left: auto; margin-right: auto; }
}

/* Ensure single centered column on mobile-width devices up to 640px */
@media (max-width: 640px) {
  .games-grid-compact { justify-content: center; }
  .games-grid-compact .game-card { width: 92%; max-width: 420px; margin-left: auto; margin-right: auto; }
  .games-grid .game-card { width: 92%; max-width: 420px; margin-left: auto; margin-right: auto; }
  .game-info { text-align: center; }
  .games-grid { justify-items: center; }
  .games-grid .game-card { justify-self: center; }
}
@media (max-width: 768px) {
  body > .container.main-content > section.games-section > .games-grid .game-card,
  body > .container.main-content > section.games-section > div.section-card .games-grid .game-card {
    width: 92%;
    max-width: 420px;
    margin-left: auto;
    margin-right: auto;
  }
  body > .container.main-content > section.games-section .game-info { text-align: center; }
}

@media (max-width: 520px) {
  .games-grid-compact { justify-content: center; }
  .games-grid-compact .game-card { width: 92%; max-width: 420px; margin-left: auto; margin-right: auto; }
}

@media (max-width: 480px) {
  .games-grid-compact .game-card { width: 92%; max-width: 420px; }
  .games-grid-compact .game-image { height: 140px; }
}
.pagination-bar {
  margin-top: 1rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.pagination-actions { display: flex; gap: 0.5rem; }
.chat-floating-btn {
  position: fixed;
  right: 16px;
  bottom: 16px;
  width: auto;
  min-height: 48px;
  padding: 10px 14px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: #10b981;
  color: #fff;
  box-shadow: var(--shadow-lg);
  z-index: 1200;
  cursor: pointer;
}
.chat-floating-btn:hover {
  filter: brightness(0.95);
}
.chat-floating-btn i { color: #fff; }
.chat-floating-label {
  color: #fff;
  font-weight: 600;
  line-height: 1;
}
.chat-floating-panel {
  position: fixed;
  right: 16px;
  bottom: 72px;
  width: 340px;
  max-height: 520px;
  background: #fff;
  border: 1px solid var(--border-color);
  border-radius: 12px;
  box-shadow: var(--shadow-lg);
  display: flex;
  flex-direction: column;
  z-index: 1200;
}
.chat-floating-panel .btn-sm { padding: 0.4rem 0.6rem; font-size: 0.85rem; }
.chat-widget-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 12px;
  border-bottom: 1px solid var(--border-color);
  background: #f8fafc;
}
.chat-widget-messages {
  flex: 1;
  padding: 10px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
  background: #f8fafc;
}
.chat-widget-input {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  padding: 10px;
  border-top: 1px solid var(--border-color);
  background: #fff;
}
@media (max-width: 640px) {
  .pagination-bar { flex-direction: column; align-items: stretch; gap: 0.5rem; }
  .pagination-actions { justify-content: center; }
}

.game-card {
    background: white;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: var(--shadow);
    transition: transform 0.3s, box-shadow 0.3s;
}

.game-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-lg);
}

.game-image {
    width: 100%;
    height: 200px;
    overflow: hidden;
    background: var(--light-gray);
    display: flex;
    align-items: center;
    justify-content: center;
}

.game-image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.game-placeholder {
    font-size: 4rem;
    color: var(--gray);
}

.game-info {
    padding: 1.5rem;
}

.game-info .btn + .btn {
    margin-top: 0.5rem;
}

.game-availability {
    font-size: 0.88rem;
    color: var(--gray);
    margin: 0.25rem 0;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}
.game-availability i {
    color: var(--gray);
}

/* How It Works */
.how-it-works {
    padding: 3rem 0;
}

.steps-grid {
    display: flex;
    gap: 1.25rem;
    align-items: stretch;
    justify-content: space-between;
    flex-wrap: nowrap; /* horizontal no-wrap on desktop */
}

.step-item {
    flex: 1 1 0;
    background: #fff;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    box-shadow: var(--shadow);
    padding: 1.25rem;
    min-width: 200px; /* keep card width when overflow */
    text-align: center;
}

.step-number {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--primary-color);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    margin-bottom: 0.5rem;
}

.step-item h3 { margin-bottom: 0.25rem; }
.step-item p { color: var(--gray); }

/* Features */
.features-section { padding: 3rem 0; }

.features-grid {
    display: flex;
    gap: 1.25rem;
    align-items: stretch;
    justify-content: space-between;
    flex-wrap: nowrap; /* horizontal no-wrap on desktop */
}

/* Recent Activities Slider */
.recent-activities { padding: 2rem 0 2rem; }
.recent-slider { position: relative; overflow: hidden; overflow-x: hidden; width: 100%; max-width: 100vw; }
.recent-activities, #recentActivitiesSection { overflow-x: hidden; }
.recent-track { display: inline-flex; gap: 12px; will-change: transform; }
.recent-item { display: inline-flex; align-items: center; gap: 10px; background:#fff; border:1px solid var(--border-color); border-radius: 999px; padding: 8px 12px; box-shadow: var(--shadow); white-space: nowrap; }
.recent-avatar { width: 32px; height: 32px; border-radius: 50%; overflow: hidden; background: var(--light-gray); display:flex; align-items:center; justify-content:center; }
.recent-avatar img { width: 100%; height: 100%; object-fit: cover; }
.recent-avatar .avatar-fallback { color: var(--primary-color); }
.recent-info { display: grid; line-height: 1.1; }
.recent-line { font-size: 0.95rem; }
.recent-line .pkg { color: var(--primary-color); font-weight: 700; }
.recent-sub { font-size: 0.82rem; color: var(--gray); }
.recent-empty { display:flex; align-items:center; justify-content:center; gap:8px; width:100%; min-height:54px; background:#fff; border:1px dashed var(--border-color); border-radius:10px; color: var(--gray); }

.recent-images { position: relative; overflow: hidden; width: 100%; }
#recentImagesSlider { position: relative; overflow: hidden; width: 100%; }
#recentImagesTrack { display: inline-flex; gap: 8px; will-change: transform; }
.image-item { display:inline-block; width: 160px; height: 90px; border-radius: 10px; overflow: hidden; background: var(--light-gray); }
.image-item img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Recent Activities title (ensure visible on mobile) */
#recentActivitiesSection .section-title {
  color: var(--dark);
  justify-content: center;
  text-align: center;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
  font-weight: 700;
}
@media (max-width: 520px) {
  #recentActivitiesSection .section-title {
    font-size: 1.25rem;
    line-height: 1.3;
  }
}

/* Cover slider (top) */
#coverSliderSection { padding-top: 1rem; padding-bottom: 0.5rem; overflow-x: hidden; }
#coverSliderSection .section-title { justify-content: center; text-align: center; }
#coverSliderSection #recentImagesSlider { width: 100%; max-width: 860px; margin: 0 auto; border-radius: 12px; overflow: hidden; }
#coverSliderSection #recentImagesTrack { display: flex; gap: 0; align-items: stretch; width: 100%; }
#coverSliderSection .image-item { flex: 0 0 100%; width: 100% !important; height: auto; border-radius: 12px; overflow: hidden; background: #000; }
#coverSliderSection .image-item img { width: 100%; height: auto; display: block; object-fit: contain; }
@media (max-width: 768px) {
  #coverSliderSection #recentImagesSlider { max-width: 100%; border-radius: 10px; }
  #coverSliderSection .image-item { border-radius: 10px; }
  .container { padding: 0 12px; }
}
@media (max-width: 520px) {
  #coverSliderSection #recentImagesSlider { max-width: 100%; }
  #coverSliderSection .image-item img { max-height: 50vh; }
}

.feature-box {
    flex: 1 1 0;
    background: #fff;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    box-shadow: var(--shadow);
    padding: 1.25rem;
    text-align: center;
    min-width: 220px;
}

@media (max-width: 992px) {
  .feature-box { flex: 1 1 calc(50% - 1.25rem); }
}

@media (max-width: 520px) {
  .feature-box { flex: 1 1 100%; }
}

.feature-icon {
    font-size: 28px;
    color: var(--primary-color);
    margin-bottom: 0.5rem;
}

.feature-box p {
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.game-name {
    font-size: 1.25rem;
    margin-bottom: 0.5rem;
}

.game-description {
    color: var(--gray);
    margin-bottom: 1rem;
}

/* Forms */
.form-group {
    margin-bottom: 1.5rem;
}

.form-group label {
    display: block;
    margin-bottom: 0.5rem;
    font-weight: 500;
}

.form-control {
    width: 100%;
    padding: 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    font-size: 1rem;
    font-family: inherit;
}

.form-control:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px var(--primary-ring, rgba(37, 99, 235, 0.1));
}

.form-actions {
    display: flex;
    justify-content: center;
}

/* Auth Pages */
.auth-page {
    min-height: 80vh;
    display: flex;
    align-items: center;
    padding: 2rem 0;
}

.auth-container {
    max-width: 450px;
    margin: 0 auto;
}

.auth-box {
    background: white;
    padding: 2.5rem;
    border-radius: 12px;
    box-shadow: var(--shadow-lg);
}

.auth-header {
    text-align: center;
    margin-bottom: 2rem;
}

.auth-header h1 {
    margin-bottom: 0.5rem;
}

/* Alerts */
.auth-footer {
    margin-top: 1rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    justify-content: center;
}

.auth-footer .btn {
    margin-left: 0.5rem;
}

.alert {
    padding: 1rem;
    border-radius: 8px;
    margin-bottom: 1rem;
}

.alert-success {
    background: #d1fae5;
    color: #065f46;
}

.alert-error {
    background: #fee2e2;
    color: #991b1b;
}

.alert-warning {
    background: #fef3c7;
    color: #92400e;
}

/* Footer */
.footer {
    background: var(--dark);
    color: white;
    padding: 3rem 0 1rem;
    margin-top: auto;
}

.footer-content {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 2rem;
    margin-bottom: 2rem;
    justify-items: center;
}

.footer-section { text-align: center; }

.social-links { display: flex; gap: 0.75rem; justify-content: center; }
.social-links a { color: #fff; }
.social-links a:hover { color: #fff; opacity: 0.85; }

.footer-contacts { list-style: none; padding: 0; margin: 0; text-align: center; }
.footer-contacts i { color: #fff; }

.footer-section h3, .footer-section h4 {
    margin-bottom: 1rem;
}

.footer-links {
    list-style: none;
}

.footer-links a {
    color: #94a3b8;
    text-decoration: none;
    transition: color 0.3s;
}

.footer-links a:hover {
    color: white;
}

.footer-bottom {
    border-top: 1px solid #334155;
    padding-top: 1rem;
    text-align: center;
    color: #94a3b8;
}

/* Packages */
.package-card {
    background: white;
    border: 0;
    border-radius: 12px;
    padding: 0;
    cursor: pointer;
    transition: all 0.3s;
    position: relative;
    display: block;
    height: 100%;
}

.package-card input[type="radio"] {
    position: absolute;
    opacity: 0;
}

.package-card input[type="radio"]:checked + .package-content {
    border-color: var(--primary-color);
    box-shadow: var(--shadow-md);
}

.package-card:hover .package-content {
    border-color: var(--primary-color);
    box-shadow: var(--shadow-md);
}

.game-detail-page { padding: 2rem 0 3rem; }
.game-header { margin-bottom: 1.25rem; }
.game-header-content { display:flex; align-items:center; gap:0.9rem; justify-content:center; }
.game-icon { width:60px; height:60px; border-radius:14px; background: var(--light-gray); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.game-icon img { width:100%; height:100%; object-fit: cover; border-radius:14px; }
.game-header-info { text-align:center; }
.game-header-info h1 { line-height:1.1; }
.game-header-info p { color: var(--gray); }

.order-container { background:#fff; border:1px solid var(--border-color); border-radius:14px; box-shadow: var(--shadow); padding:1rem; }
.order-steps { display:flex; align-items:center; gap:1rem; padding:0.5rem; border-bottom:1px solid var(--border-color); margin-bottom:1rem; }
.order-steps .step { display:flex; align-items:center; gap:0.5rem; color: var(--gray); font-weight:600; }
.order-steps .step.active { color: var(--primary-color); }
.order-steps .step-icon { width:32px; height:32px; border-radius:999px; background: var(--light-gray); display:inline-flex; align-items:center; justify-content:center; font-weight:700; }

.order-grid { display:grid; grid-template-columns: 1.2fr 1fr; gap:1rem; }
.packages-section h2,
.player-info-section h2 { display:flex; align-items:center; gap:0.5rem; margin-bottom:0.75rem; }
.packages-section h2 { justify-content:center; text-align:center; }
.packages-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap:0.75rem; align-items: stretch; grid-auto-rows: 1fr; }
.package-content { border:2px solid var(--border-color); border-radius:12px; padding:1rem; display:grid; gap:0.35rem; position:relative; height:100%; grid-template-rows: auto auto 1fr; }
.package-content { text-align: center; }
.package-badge { position:absolute; top:10px; right:10px; background: #fee2e2; color:#b91c1c; border:1px solid #fecaca; padding:0.25rem 0.5rem; border-radius:999px; font-size:0.8rem; font-weight:700; }
.package-amount { font-size:1.1rem; font-weight:700; }
.package-name { color: var(--gray); }
.package-name.is-month { color: var(--success-color); font-weight: 700; }
.package-price { display:flex; align-items:center; justify-content:center; gap:0.5rem; }
.package-price .original-price { color:#94a3b8; text-decoration: line-through; font-size:0.95rem; }
.package-price .current-price { font-weight:800; color: var(--primary-color); }

.player-info-section .info-box { background:#fbfdff; border:1px solid var(--border-color); border-radius:12px; padding:1rem; margin-bottom:1rem; }
.user-credits-info { display:flex; align-items:center; gap:0.5rem; color: var(--dark); background:#ecfdf5; border:1px solid #a7f3d0; border-radius:10px; padding:0.5rem 0.75rem; }

.order-summary { background:#fff; border:1px solid var(--border-color); border-radius:12px; box-shadow: var(--shadow); padding:1rem; display:grid; gap:0.5rem; }
.order-summary h3 { display:flex; align-items:center; gap:0.5rem; margin-bottom:0.25rem; }
.summary-item { display:flex; align-items:center; justify-content:space-between; }
.summary-divider { height:1px; background: var(--border-color); margin:0.25rem 0; }
.summary-total { display:flex; align-items:center; justify-content:space-between; font-weight:800; font-size:1.05rem; }
.warning-box { display:flex; align-items:flex-start; gap:0.5rem; background:#fff7ed; border:1px solid #fed7aa; color:#b45309; border-radius:10px; padding:0.6rem 0.75rem; }

@media (max-width: 992px) {
  .order-grid { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  .order-steps { flex-wrap: wrap; }
  .packages-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
}

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

/* Responsive */
@media (max-width: 768px) {
    .nav-toggle {
        display: flex;
        width: 40px;
        height: 36px;
        align-items: center;
        justify-content: center;
        border-radius: 10px;
        margin-left: auto;
    }
    
    .nav-menu {
        display: none;
    }
    
    .nav-wrapper {
        align-items: center;
        flex-wrap: wrap;
    }
    
    .nav-brand {
        max-width: calc(100% - 44px);
        overflow: hidden;
        text-overflow: ellipsis;
    }
    
    #navMenu {
        flex-basis: 100%;
    }
    
    #navMenu.active {
        display: flex;
        flex-direction: column;
        width: 100%;
        margin-top: 0.75rem;
        gap: 0.5rem;
    }
    
    .nav-links {
        flex-direction: column;
        align-items: stretch;
        gap: 0.25rem;
    }
    
    .nav-links li {
        width: 100%;
    }
    
    .nav-links a {
        width: 100%;
        justify-content: flex-start;
        padding: 0.75rem 0.75rem;
        border-radius: 10px;
    }
    
    .nav-links .admin-link,
    .nav-links .topup-link {
        justify-content: center;
    }
    
    .credits-badge {
        justify-content: center;
        width: 100%;
    }
    
    /* Dropdown on mobile - render inline */
    .nav-links .dropdown-menu {
        position: static;
        border: none;
        box-shadow: none;
        padding: 0;
        margin-top: 0.25rem;
        display: none;
    }
    .nav-links .dropdown.open > .dropdown-menu {
        display: block;
    }
    
    .hero-title {
        font-size: 2rem;
    }
    
    .games-grid {
        grid-template-columns: 1fr;
    }

    /* Allow wrap on mobile for horizontal sections */
    .steps-grid,
    .features-grid {
        flex-wrap: wrap;
    }
}

.credits-badge {
    background: var(--success-color);
    color: white;
    padding: 0.5rem 1rem;
    border-radius: 20px;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    white-space: nowrap; /* prevent breaking into two lines */
}

/* add slight spacing so the badge doesn't touch the next item */
.nav-credits { margin-right: 0.25rem; }

.required {
    color: var(--error-color);
}

/* Modal Overlay */
.modal-overlay {
    position: fixed;
    inset: 0; /* ensure full viewport coverage */
    background: rgba(0,0,0,0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    z-index: 100000; /* sit above any page content such as footer/navbar */
    animation: fadeIn 0.2s ease forwards;
}

.nav-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.35);
    z-index: 999;
    display: none;
}
.nav-overlay.show { display: block; }

.modal {
    background: #fff;
    border-radius: 16px;
    box-shadow: var(--shadow-lg);
    padding: 2rem;
    width: 90%;
    max-width: 420px;
    text-align: center;
    margin: 0 1rem; /* keep safe gap on small screens */
    animation: popIn 0.25s ease forwards;
}

.success-modal .modal-title {
    margin-top: 0.75rem;
    margin-bottom: 0.25rem;
    color: var(--success-color);
    text-align: center;
}

.success-modal .modal-message {
    color: var(--dark);
}

.success-modal .modal-sub {
    color: var(--gray);
    margin-top: 0.5rem;
    text-align: center;
}

/* Success Check Animation */
.success-anim {
    display: flex;
    align-items: center;
    justify-content: center;
}

.checkmark {
    width: 84px;
    height: 84px;
}

.checkmark-circle {
    stroke: var(--success-color);
    stroke-width: 3;
    stroke-miterlimit: 10;
    stroke-dasharray: 166;
    stroke-dashoffset: 166;
    animation: stroke 0.6s cubic-bezier(0.65, 0, 0.45, 1) forwards;
}

.checkmark-check {
    transform-origin: 50% 50%;
    stroke: var(--success-color);
    stroke-width: 3;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-dasharray: 48;
    stroke-dashoffset: 48;
    animation: stroke 0.4s cubic-bezier(0.65, 0, 0.45, 1) 0.6s forwards;
}

@keyframes stroke {
    to { stroke-dashoffset: 0; }
}

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

@keyframes popIn {
    from { opacity: 0.98; transform: scale(0.98); }
    to { opacity: 1; transform: scale(1); }
}

/* Orders Page */
.orders-page { padding: 2rem 0 3rem; }

.orders-header { margin-bottom: 1.25rem; }
.orders-title { display: flex; align-items: center; gap: 0.75rem; }
.orders-title i { font-size: 1.6rem; color: var(--primary-color); }
.orders-title h1 { line-height: 1.1; }
.orders-sub { color: var(--gray); font-size: 0.975rem; }

/* Center align for orders page title/subtitle */
.orders-header { text-align: center; }
.orders-title { justify-content: center; }
.orders-title > div { text-align: center; }

.orders-empty { 
  background: #fff; 
  border: 1px solid var(--border-color); 
  border-radius: 14px; 
  padding: 2.25rem 1.5rem; 
  text-align: center; 
  box-shadow: var(--shadow);
}
.orders-empty .empty-graphic { 
  width: 84px; height: 84px; margin: 0 auto 0.75rem; 
  border-radius: 50%; background: var(--light-gray); 
  display:flex; align-items:center; justify-content:center; 
  color: var(--gray); font-size: 1.75rem; 
}
.orders-empty h2 { margin-bottom: 0.25rem; }
.orders-empty p { color: var(--gray); margin-bottom: 1rem; }

.orders-list { 
  display: grid; 
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); 
  gap: 1rem; 
}

.order-card { 
  background: #fff; 
  border: 1px solid var(--border-color); 
  border-radius: 12px; 
  box-shadow: var(--shadow); 
  overflow: hidden;
}

.order-header { 
  display: flex; 
  align-items: center; 
  justify-content: space-between; 
  padding: 0.9rem 1rem; 
  border-bottom: 1px solid var(--border-color); 
  background: #f9fbfd; 
}
.order-number .label { display:block; font-size: 0.75rem; color: var(--gray); }
.order-number strong { font-size: 1.1rem; }

.order-status-badge { 
  padding: 0.35rem 0.65rem; 
  border-radius: 999px; 
  font-size: 0.85rem; 
  font-weight: 600; 
  white-space: nowrap; 
}
.order-status-badge.status-pending { background: #fff7ed; color: #b45309; border: 1px solid #fed7aa; }
.order-status-badge.status-processing { background: #eff6ff; color: #1d4ed8; border: 1px solid #bfdbfe; }
.order-status-badge.status-completed { background: #ecfdf5; color: #047857; border: 1px solid #a7f3d0; }
.order-status-badge.status-failed { background: #fef2f2; color: #b91c1c; border: 1px solid #fecaca; }
.order-status-badge.status-refunded { background: #f5f3ff; color: #6d28d9; border: 1px solid #ddd6fe; }

.order-body { padding: 1rem; display: grid; gap: 0.9rem; }
.order-game { display: flex; align-items: center; gap: 0.75rem; }
.order-game-icon { width: 42px; height: 42px; border-radius: 10px; background: var(--light-gray); display:flex; align-items:center; justify-content:center; color: var(--primary-color); }
.order-game-info .game-name { font-weight: 600; }
.order-game-info .package-name { color: var(--gray); font-size: 0.95rem; }

.order-details { 
  display: grid; 
  grid-template-columns: repeat(2, minmax(0,1fr)); 
  gap: 0.75rem; 
}
.order-details .detail-item { 
  background: #fbfdff; 
  border: 1px solid var(--border-color); 
  border-radius: 10px; 
  padding: 0.6rem 0.75rem; 
}
.order-details dt { font-size: 0.75rem; color: var(--gray); }
.order-details dd { margin: 0; font-weight: 600; }

@media (max-width: 640px) {
  .orders-list { grid-template-columns: 1fr; }
  .order-details { grid-template-columns: 1fr; }
}

/* Orders List - list view */
.orders-list.list-view { display: block; border: 1px solid var(--border-color); border-radius: 12px; background:#fff; box-shadow: var(--shadow); overflow:hidden; }
.orders-list.list-view .orders-list-head { display:grid; grid-template-columns: 1.1fr 1.6fr 1fr 0.8fr 0.9fr 1fr 0.9fr; gap:0; padding:0.6rem 0.75rem; background:#f9fbfd; border-bottom:1px solid var(--border-color); color: var(--gray); font-weight:700; font-size:0.95rem; }
.orders-list.list-view .order-row { display:grid; grid-template-columns: 1.1fr 1.6fr 1fr 0.8fr 0.9fr 1fr 0.9fr; align-items:center; gap:0; padding:0.7rem 0.75rem; border-bottom:1px solid var(--border-color); }
.orders-list.list-view .order-row:last-child { border-bottom:none; }
.orders-list.list-view .order-row .col-order strong { font-size: 0.98rem; }
.orders-list.list-view .order-game-inline { display:flex; align-items:center; gap:0.6rem; }
.orders-list.list-view .order-game-inline .icon { width:34px; height:34px; border-radius:8px; background: var(--light-gray); display:inline-flex; align-items:center; justify-content:center; color: var(--primary-color); }
.orders-list.list-view .order-game-inline .game-name { font-weight:700; line-height:1.2; }
.orders-list.list-view .order-game-inline .package-name { color: var(--gray); font-size:0.92rem; }
.orders-list.list-view .col-price { font-weight:800; color: var(--primary-color); }

@media (max-width: 992px) {
  .orders-list.list-view .orders-list-head { display:none; }
  .orders-list.list-view .order-row { grid-template-columns: 1fr 1fr; grid-auto-rows:auto; row-gap:0.25rem; }
  .orders-list.list-view .order-row .col-order { grid-column: 1 / span 2; }
  .orders-list.list-view .order-row .col-game { grid-column: 1 / span 2; }
  .orders-list.list-view .order-row .col-status { justify-self: start; }
}

/* Profile Page */
.profile-page { padding: 2rem 0 3rem; }
.profile-header { margin-bottom: 1.25rem; }
.profile-title { display:flex; align-items:center; gap:0.75rem; }
.profile-title i { font-size:1.6rem; color: var(--primary-color); }
.profile-sub { color: var(--gray); font-size: 0.975rem; }

.profile-grid { 
  display: grid; 
  grid-template-columns: 1.2fr 1fr; 
  gap: 1rem; 
}

.profile-card { 
  background:#fff; border:1px solid var(--border-color); border-radius:12px; 
  box-shadow: var(--shadow); padding: 1rem; 
}
.profile-top { display:flex; align-items:center; gap:0.9rem; }
.avatar-circle { width:56px; height:56px; border-radius:50%; background: var(--light-gray); display:flex; align-items:center; justify-content:center; color: var(--primary-color); font-size: 1.2rem; }
.profile-meta .profile-name { font-weight:700; }
.profile-meta .profile-email { color: var(--gray); font-size:0.95rem; }
.profile-credits { margin-left:auto; }

.profile-details { margin-top: 0.9rem; display:grid; gap:0.5rem; }
.profile-details .detail-row { display:flex; align-items:center; justify-content:space-between; background:#fbfdff; border:1px solid var(--border-color); border-radius:10px; padding:0.6rem 0.75rem; }
.profile-details dt { color: var(--gray); font-size:0.85rem; }
.profile-details dd { margin:0; font-weight:600; }

.profile-actions { margin-top: 1rem; display:flex; gap:0.5rem; flex-wrap: wrap; justify-content: center; }
 .profile-page .profile-actions .btn { padding: 0.6rem 1rem; font-size: 0.95rem; }
 .profile-page .profile-actions .btn i { margin-right: 0.35rem; }
 .profile-page .profile-actions .btn.btn-lg { padding: 0.75rem 1.25rem; font-size: 1rem; }

.transactions-card { background:#fff; border:1px solid var(--border-color); border-radius:12px; box-shadow: var(--shadow); overflow:hidden; }
.transactions-head { padding:0.9rem 1rem; border-bottom:1px solid var(--border-color); background:#f9fbfd; }
.transactions-list { padding: 0.5rem 0.5rem 0.75rem; display:grid; gap:0.5rem; }
.transaction-item { display:flex; align-items:center; justify-content:space-between; background:#fff; border:1px solid var(--border-color); border-radius:10px; padding:0.6rem 0.75rem; }
.transaction-desc { color: var(--dark); }
.transaction-amount { font-weight:700; }
.transaction-amount.positive { color: var(--success-color); }
.transaction-amount.negative { color: var(--error-color); }
.transactions-empty { 
  color: var(--gray); 
  text-align: center; 
  padding: 1.25rem 0.75rem; 
  border: 1px dashed var(--border-color); 
  border-radius: 10px; 
  background: #fff; 
}

@media (max-width: 900px) {
  .profile-grid { grid-template-columns: 1fr; }
}

/* Checkout Page */
.checkout-page { padding: 2rem 0 3rem; }
.checkout-container { background:#fff; border:1px solid var(--border-color); border-radius:14px; box-shadow: var(--shadow); padding:1.25rem; }
.checkout-container .page-title { display:flex; align-items:center; gap:0.6rem; margin-bottom:0.75rem; font-size:1.5rem; }
.checkout-container .page-title i { color: var(--success-color); }

.checkout-grid { display:grid; grid-template-columns: 1.25fr 0.9fr; gap:1rem; }
.checkout-section { display:grid; gap:0.9rem; }
.grid-2 { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:1rem; }
@media (max-width: 768px) { .grid-2 { grid-template-columns: 1fr; } }
.section-card { background:#fff; border:1px solid var(--border-color); border-radius:12px; padding:1rem; margin-bottom:1rem; }
.section-card h2 { display:flex; align-items:center; gap:0.5rem; margin-bottom:0.75rem; font-size:1.15rem; }
.section-card-muted { background: linear-gradient(180deg, #fbfdff, #ffffff); }
@media (max-width: 520px) {
  body > .container.main-content > section.games-section > div.section-card {
    margin-left: -12px;
    margin-right: -12px;
    padding: 12px;
    border-radius: 0;
    padding-bottom: 72px;
  }
  body > .container.main-content > section.games-section > div.section-card .games-grid { gap: 0.75rem; }
  body > .container.main-content > section.games-section > div.section-card .game-image { height: 160px; }
  body > .container.main-content > section.games-section > div.section-card .game-info { padding: 1rem; }
  body > .container.main-content > section.games-section > .games-grid { gap: 1rem; }
}

/* Order details */
.order-details { display:grid; gap:0.5rem; }
.order-details .detail-row { display:flex; align-items:center; justify-content:space-between; background:#fbfdff; border:1px solid var(--border-color); border-radius:10px; padding:0.6rem 0.75rem; }
.order-details .label { color: var(--gray); }
.order-details .value { font-weight:700; }

/* Payment methods */
.payment-methods { display:grid; gap:0.6rem; }
.payment-option { border:1.8px solid var(--border-color); border-radius:12px; overflow:hidden; cursor:pointer; transition: all 0.2s ease; }
.payment-option input { position:absolute; opacity:0; }
.payment-option .payment-content { display:flex; align-items:center; gap:0.75rem; padding:0.75rem; }
.payment-option i { font-size:1.25rem; color: var(--primary-color); width:28px; text-align:center; }
.payment-option .payment-info { display:grid; gap:0.15rem; }
.payment-option .payment-name { font-weight:700; }
.payment-option .payment-desc { color: var(--gray); font-size:0.95rem; }
.payment-option .insufficient { color: var(--error-color); font-weight:600; margin-left:0.35rem; }
.payment-option:hover { border-color: var(--primary-color); box-shadow: var(--shadow-md); }
.payment-option.disabled { opacity: 0.6; cursor:not-allowed; }
.payment-option input:checked + .payment-content { background:#f9fbff; }

.payment-note { display:flex; align-items:flex-start; gap:0.5rem; background:#fff7ed; border:1px solid #fed7aa; color:#b45309; border-radius:10px; padding:0.6rem 0.75rem; margin-top:0.6rem; }

/* Sidebar summary */
.checkout-sidebar .summary-card { position:sticky; top:84px; background:#fff; border:1px solid var(--border-color); border-radius:12px; box-shadow: var(--shadow); padding:1rem; display:grid; gap:0.6rem; }
.checkout-sidebar h3 { display:flex; align-items:center; gap:0.5rem; margin-bottom:0.25rem; }
.summary-details { display:grid; gap:0.4rem; }
.summary-row { display:flex; align-items:center; justify-content:space-between; }
.summary-row.discount { color: var(--success-color); }
.summary-divider { height:1px; background: var(--border-color); margin:0.25rem 0; }
.summary-total { display:flex; align-items:center; justify-content:space-between; font-weight:800; font-size:1.05rem; }
.summary-total .total-amount { color: var(--primary-color); }

.terms-agreement .checkbox-label { display:flex; align-items:flex-start; gap:0.5rem; font-size:0.95rem; }
.terms-agreement a { color: var(--primary-color); text-decoration:none; }
.terms-agreement a:hover { text-decoration:underline; }

@media (max-width: 992px) {
  .checkout-grid { grid-template-columns: 1fr; }
  .checkout-sidebar .summary-card { position: static; }
}

/* Top-up Credits Page */
.topup-page { padding: 2rem 0 3rem; }
.topup-container { background:#fff; border:1px solid var(--border-color); border-radius:14px; box-shadow: var(--shadow); padding:1.25rem; }
.topup-container h1 { display:flex; align-items:center; gap:0.5rem; margin-bottom:0.25rem; }
.topup-container .subtitle { color: var(--gray); margin-bottom: 1rem; }

.topup-grid { display:grid; grid-template-columns: 1.1fr 1fr; gap:1rem; }
@media (max-width: 992px) { .topup-grid { grid-template-columns: 1fr; } }

.quick-amounts h2 { margin-bottom: 0.5rem; font-size: 1.15rem; }
.amounts-grid { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap:0.5rem; }
@media (max-width: 480px) { .amounts-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 520px) { .amounts-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }

.amount-btn {
  border: 1.8px solid var(--border-color);
  background:#fff;
  border-radius: 10px;
  padding: 0.6rem 0.75rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s ease;
}
.amount-btn:hover { border-color: var(--primary-color); box-shadow: var(--shadow); }
.amount-btn.active { background:#f0f7ff; border-color: var(--primary-color); color: var(--primary-color); box-shadow: var(--shadow-md); }

.payment-options { display:flex; gap:0.5rem; flex-wrap: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: thin; }
.payment-options .payment-card { flex: 0 0 auto; min-width: 220px; }
@media (max-width: 520px) {
  .payment-options { flex-wrap: wrap; overflow-x: visible; }
  .payment-options .payment-card { min-width: auto; width: 100%; }
}

.payment-card { border:1.8px solid var(--border-color); border-radius:12px; overflow:hidden; cursor:pointer; transition: all 0.2s ease; display:block; }
.payment-card input { position:absolute; opacity:0; }
.payment-card .payment-info { display:flex; align-items:center; gap:0.6rem; padding:0.7rem; }
.payment-card .payment-info i { font-size:1.1rem; color: var(--primary-color); width:26px; text-align:center; }
.payment-card:hover { border-color: var(--primary-color); box-shadow: var(--shadow); }
.payment-card input:checked + .payment-info { background:#f9fbff; }

.summary-box { background:#fbfdff; border:1px solid var(--border-color); border-radius:12px; padding:0.75rem; margin: 0.25rem 0 0.75rem; display:grid; gap:0.4rem; }
.summary-row { display:flex; align-items:center; justify-content:space-between; }
.summary-row strong { color: var(--primary-color); }
@media (max-width: 520px) { .summary-box { position: sticky; bottom: 12px; z-index: 10; } }

.btn.loading { opacity: 0.7; pointer-events: none; }
