/* ============================================
   🔧 UI Fixes (Safe Overrides)
   Focus: Modals + Modal Forms + Profile-only patches
   Avoid: global card/stat/nav overrides
   ============================================ */

/* --------------------------------------------
   1) Modal: prevent double scroll
   -------------------------------------------- */
body.modal-open {
  overflow: hidden !important;
}

.modal-overlay {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(0, 0, 0, 0.75) !important;
  backdrop-filter: blur(10px) saturate(140%) !important;
  -webkit-backdrop-filter: blur(10px) saturate(140%) !important;
  z-index: 9999 !important;

  display: none; /* JS controls visibility */
  align-items: center !important;
  justify-content: center !important;
  padding: 20px !important;

  overflow: hidden !important;
}

.modal-content {
  width: min(680px, 100%) !important;
  max-height: 80vh !important;
  overflow: auto !important;
  overflow-x: hidden !important;

  border-radius: 20px !important;
  background: rgba(15, 23, 42, 0.96) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;

  padding: 22px !important;
  position: relative !important;
}

/* Modal scrollbar */
.modal-content::-webkit-scrollbar {
  width: 6px !important;
}
.modal-content::-webkit-scrollbar-track {
  background: transparent !important;
}
.modal-content::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.16) !important;
  border-radius: 999px !important;
}

/* Close button inside modal only */
.modal-close {
  position: absolute !important;
  top: 12px !important;
  left: 12px !important;
  right: auto !important;

  width: 36px !important;
  height: 36px !important;
  border-radius: 12px !important;

  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;

  color: var(--text) !important;
  cursor: pointer !important;

  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  transition:
    transform 0.2s ease,
    background 0.2s ease,
    border-color 0.2s ease !important;
  z-index: 10 !important;
}

.modal-close:hover {
  background: rgba(239, 68, 68, 0.18) !important;
  border-color: rgba(239, 68, 68, 0.22) !important;
  transform: translateY(-1px) !important;
}

/* --------------------------------------------
   2) Inputs inside modal only (do not global override)
   -------------------------------------------- */
.modal-content input,
.modal-content textarea,
.modal-content select {
  border-radius: 14px !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  background: rgba(255, 255, 255, 0.03) !important;
  padding: 12px 14px !important;
  color: var(--text) !important;
  font-size: 14px !important;
  width: 100% !important;
  box-sizing: border-box !important;
  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    background 0.2s ease !important;
}

.modal-content input:focus,
.modal-content textarea:focus,
.modal-content select:focus {
  outline: none !important;
  border-color: rgba(24, 174, 243, 0.35) !important;
  box-shadow: 0 0 0 3px rgba(24, 174, 243, 0.12) !important;
}

.modal-content textarea {
  min-height: 100px !important;
  max-height: 240px !important;
  resize: vertical !important;
}

/* Radio/checkbox groups inside modal only */
.modal-content .radio-group,
.modal-content .image-mode-toggle {
  display: flex !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
}

.modal-content .radio-group label,
.modal-content .image-mode-toggle label {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 10px 14px !important;
  border-radius: 12px !important;
  background: rgba(255, 255, 255, 0.03) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  cursor: pointer !important;
  transition:
    transform 0.2s ease,
    border-color 0.2s ease,
    background 0.2s ease !important;
}

.modal-content .radio-group label:hover,
.modal-content .image-mode-toggle label:hover {
  background: rgba(24, 174, 243, 0.08) !important;
  border-color: rgba(24, 174, 243, 0.22) !important;
  transform: translateY(-1px) !important;
}

/* --------------------------------------------
   3) Profile page: scoped fixes only
   -------------------------------------------- */
#profileCard {
  border-radius: 22px !important;
}

/* User works grid in profile only */
#userWorks,
.user-works-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important;
  gap: 20px !important;
}

/* Profile work cards only */
#userWorks .card,
.work-card {
  border-radius: 16px !important;
  overflow: hidden !important;
}

#userWorks .card img,
.work-thumb {
  width: 100% !important;
  height: 180px !important;
  object-fit: cover !important;
  display: block !important;
}

/* --------------------------------------------
   4) Light mode for modal only
   -------------------------------------------- */
html[data-theme="light"] .modal-content {
  background: rgba(255, 255, 255, 0.96) !important;
  border-color: rgba(0, 0, 0, 0.1) !important;
}

html[data-theme="light"] .modal-content input,
html[data-theme="light"] .modal-content textarea,
html[data-theme="light"] .modal-content select {
  background: rgba(0, 0, 0, 0.03) !important;
  border-color: rgba(0, 0, 0, 0.1) !important;
}

/* --------------------------------------------
   5) Mobile tweaks (modal + profile)
   -------------------------------------------- */
@media (max-width: 768px) {
  .modal-content {
    max-height: 90vh !important;
    padding: 18px !important;
  }

  #userWorks,
  .user-works-grid {
    grid-template-columns: 1fr !important;
  }
}

/* --------------------------------------------
   C) News page: Map follow selector (chips)
   -------------------------------------------- */
.follow-maps .games {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  align-items: center !important;
  justify-content: center !important;
}

.follow-maps .games .map-pill {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 10px 14px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  background: rgba(255, 255, 255, 0.04) !important;
  color: var(--text) !important;
  cursor: pointer !important;
  user-select: none !important;
  transition:
    transform 0.18s ease,
    background 0.18s ease,
    border-color 0.18s ease,
    box-shadow 0.18s ease !important;
}

.follow-maps .games .map-pill input {
  position: absolute !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.follow-maps .games .map-pill .dot {
  width: 10px !important;
  height: 10px !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.22) !important;
  box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.06) !important;
}

.follow-maps .games .map-pill:hover {
  transform: translateY(-1px) !important;
  border-color: rgba(24, 174, 243, 0.22) !important;
  background: rgba(24, 174, 243, 0.08) !important;
}

/* Checked state (safe: use :has where supported) */
.follow-maps .games .map-pill:has(input:checked) {
  border-color: rgba(24, 174, 243, 0.35) !important;
  background: rgba(24, 174, 243, 0.14) !important;
  box-shadow: 0 12px 35px rgba(24, 174, 243, 0.12) !important;
}

.follow-maps .games .map-pill:has(input:checked) .dot {
  background: rgba(24, 174, 243, 0.95) !important;
  box-shadow: 0 0 0 4px rgba(24, 174, 243, 0.18) !important;
}

@media (max-width: 768px) {
  .follow-maps .games {
    justify-content: flex-start !important;
  }
}

/* --------------------------------------------
   D) Portfolio upload modal: layout + scrolling + segmented
   -------------------------------------------- */
.modal-overlay { /* allow animation without affecting pages */
  animation: modalFadeIn 180ms ease both;
}

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

.modal-content.upload-modal {
  width: min(720px, 100%) !important;
  max-height: min(78vh, 760px) !important;
  overflow: auto !important;
}

.modal-content.upload-modal .form-group {
  margin: 12px 0 !important;
}

.modal-content.upload-modal .form-group label {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
}

.modal-content.upload-modal .segmented {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
  margin-top: 10px !important;
}

.modal-content.upload-modal .segmented .seg-opt {
  justify-content: center !important;
  padding: 10px 12px !important;
  border-radius: 14px !important;
}

/* File inputs: consistent (still native) */
.modal-content.upload-modal input[type="file"] {
  padding: 10px 12px !important;
}

.modal-content.upload-modal input[type="file"]::file-selector-button {
  margin-inline: 0 12px !important;
  padding: 10px 12px !important;
  border-radius: 12px !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  background: rgba(255, 255, 255, 0.06) !important;
  color: var(--text) !important;
}

.modal-content.upload-modal input[type="file"]::file-selector-button:hover {
  border-color: rgba(24, 174, 243, 0.25) !important;
  box-shadow: 0 0 0 3px rgba(24, 174, 243, 0.12) !important;
}

/* Submit button: modern sweep + subtle lift */
.btn-primary.btn-sweep {
  position: relative !important;
  overflow: hidden !important;
}

.btn-primary.btn-sweep::before {
  content: "";
  position: absolute;
  top: -40%;
  left: -60%;
  width: 50%;
  height: 200%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.22), transparent);
  transform: rotate(18deg);
  opacity: 0;
}

.btn-primary.btn-sweep:hover::before {
  opacity: 1;
  animation: btnSweep 900ms cubic-bezier(0.2, 0.8, 0.2, 1) 1;
}

@keyframes btnSweep {
  0% { transform: translateX(0) rotate(18deg); }
  100% { transform: translateX(260%) rotate(18deg); }
}

.btn-primary.is-loading {
  opacity: 0.8 !important;
  pointer-events: none !important;
}

/* --------------------------------------------
   E) Admin page: ensure ads never render
   -------------------------------------------- */
body.admin-page .ad-col,
body.admin-page .ad-slot,
body.admin-page [data-ad],
body.admin-page .ad-wrapper {
  display: none !important;
}

/* Map subscription (current markup: .maps-subscription .map-checkbox) */
.maps-subscription {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  align-items: center !important;
  justify-content: center !important;
  margin-top: 8px !important;
}

.maps-subscription .map-checkbox {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 0 !important;
  cursor: pointer !important;
  user-select: none !important;
}

.maps-subscription .map-checkbox input {
  position: absolute !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.maps-subscription .map-checkbox span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  padding: 10px 14px !important;
  border-radius: 999px !important;
  border: 1px solid color-mix(in srgb, var(--border) 55%, transparent) !important;
  background: color-mix(in srgb, var(--surface-1) 55%, transparent) !important;
  color: var(--muted) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  transition: transform .18s ease, background .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease !important;
}

.maps-subscription .map-checkbox span::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 2px solid currentColor;
  opacity: .75;
}

.maps-subscription .map-checkbox:hover span {
  transform: translateY(-1px) !important;
  border-color: color-mix(in srgb, var(--accent) 60%, transparent) !important;
  background: color-mix(in srgb, var(--accent) 16%, transparent) !important;
  color: var(--text) !important;
}

.maps-subscription .map-checkbox input:checked + span {
  background: color-mix(in srgb, var(--accent) 22%, transparent) !important;
  border-color: color-mix(in srgb, var(--accent) 65%, transparent) !important;
  color: var(--text) !important;
  box-shadow: 0 12px 35px rgba(24,174,243,0.12) !important;
}

.maps-subscription .map-checkbox input:checked + span::before {
  background: currentColor;
  opacity: 1;
}

/* ===== Admin team live status (online/offline + colored dot) ===== */
.team-status{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 12px;
  letter-spacing: .2px;
  border: 1px solid color-mix(in srgb, var(--border) 65%, transparent);
  background: color-mix(in srgb, var(--surface-1) 65%, transparent);
}
.team-status .status-dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: currentColor;
  box-shadow: 0 0 0 3px color-mix(in srgb, currentColor 18%, transparent);
}
.team-status[data-status="online"]{ color: #22c55e; }
.team-status[data-status="offline"]{ color: #ef4444; }

/* Subscribe card layout: keep game buttons above "Save" button */
.subscribe-card{display:flex;flex-direction:column;gap:16px;}
.subscribe-card .subscribe-actions{display:flex;justify-content:flex-end;}

/* ===== Upload modal: image source selector (more professional segmented control) ===== */
.segmented.image-source{
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
  padding: 0;
  background: transparent;
  border: none;
}
.segmented.image-source .seg-opt{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--border) 70%, transparent);
  background: color-mix(in srgb, var(--surface-2) 82%, transparent);
  cursor: pointer;
  transition: transform .12s ease, border-color .12s ease, background .12s ease;
}
.segmented.image-source .seg-opt:hover{ transform: translateY(-1px); }
.segmented.image-source .seg-opt input{ position:absolute; opacity:0; pointer-events:none; }
.segmented.image-source .seg-opt span{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 800;
}
.segmented.image-source .seg-opt span::before{
  content:"";
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 2px solid color-mix(in srgb, var(--text-muted) 70%, transparent);
  opacity: .9;
}
.segmented.image-source .seg-opt:has(input:checked){
  border-color: color-mix(in srgb, var(--accent) 55%, transparent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 18%, transparent);
}
.segmented.image-source .seg-opt:has(input:checked) span::before{
  border-color: var(--accent);
  background: var(--accent);
}

@media (max-width: 520px){
  .segmented.image-source{ grid-template-columns: 1fr; }
}
