/* ============================================================
   NEON CYBERPUNK UI OVERRIDE
   Full visual enhancement for the Admin Dashboard
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;600;700&family=Exo+2:ital,wght@0,300;0,400;0,600;0,700;1,300&family=Share+Tech+Mono&display=swap');

/* ── CSS Variables ─────────────────────────────────────────── */
:root {
  --neon-cyan:    #00f5ff;
  --neon-green:   #39ff14;
  --neon-pink:    #ff2079;
  --neon-purple:  #bf00ff;
  --neon-yellow:  #fff200;
  --neon-orange:  #ff6b00;

  --bg-deep:      #050b15;
  --bg-panel:     #080f1e;
  --bg-card:      #0d1828;
  --bg-hover:     #111f35;
  --bg-active:    #0a1e33;

  --border-dim:   #1a2e4a;
  --border-glow:  #00f5ff40;

  --text-primary: #e8f4fd;
  --text-dim:     #6b8aad;
  --text-accent:  #00f5ff;

  --sidebar-w:    240px;
  --header-h:     56px;
  --radius:       8px;
  --radius-lg:    12px;
}

/* ── Reset & Base ──────────────────────────────────────────── */
html, body, #root {
  background: var(--bg-deep) !important;
  color: var(--text-primary) !important;
  font-family: 'Exo 2', 'Rajdhani', sans-serif !important;
  height: 100%;
  margin: 0;
  padding: 0;
  overflow: hidden;
}

/* Subtle animated grid background */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image:
    linear-gradient(rgba(0,245,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,245,255,0.03) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
  z-index: 0;
  animation: gridShift 60s linear infinite;
}

@keyframes gridShift {
  0%   { background-position: 0 0; }
  100% { background-position: 40px 40px; }
}

/* ── Auth / Login Page ─────────────────────────────────────── */
.auth-container {
  background:
    radial-gradient(ellipse at 20% 50%, #00f5ff0d 0%, transparent 60%),
    radial-gradient(ellipse at 80% 20%, #bf00ff0d 0%, transparent 60%),
    linear-gradient(135deg, #050b15 0%, #080f1e 50%, #050b15 100%) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 100vh !important;
  position: relative;
}

.auth-container::after {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%2300f5ff' fill-opacity='0.02'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  pointer-events: none;
}

.auth-box {
  background: linear-gradient(145deg, #0d1828, #080f1e) !important;
  border: 1px solid #00f5ff30 !important;
  border-radius: var(--radius-lg) !important;
  box-shadow:
    0 0 40px #00f5ff15,
    0 0 80px #00f5ff08,
    inset 0 1px 0 #00f5ff20 !important;
  padding: 44px 40px !important;
  width: 420px !important;
  position: relative;
  overflow: hidden;
}

.auth-box::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--neon-cyan), var(--neon-purple), transparent);
  animation: scanline 3s ease-in-out infinite;
}

@keyframes scanline {
  0%, 100% { opacity: 0.5; }
  50% { opacity: 1; }
}

.auth-box h2 {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 28px !important;
  font-weight: 700 !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: var(--neon-cyan) !important;
  text-shadow: 0 0 20px var(--neon-cyan), 0 0 40px #00f5ff80 !important;
  margin-bottom: 28px !important;
}

.auth-input {
  background: #050b1580 !important;
  border: 1px solid #1a3a5c !important;
  border-radius: var(--radius) !important;
  color: var(--text-primary) !important;
  font-family: 'Exo 2', sans-serif !important;
  font-size: 14px !important;
  padding: 13px 16px !important;
  width: 100% !important;
  box-sizing: border-box !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
  margin-bottom: 14px !important;
}

.auth-input:focus {
  outline: none !important;
  border-color: var(--neon-cyan) !important;
  box-shadow: 0 0 0 3px #00f5ff15, 0 0 20px #00f5ff20 !important;
}

.auth-input::placeholder { color: #3a5a7a !important; }

.auth-btn {
  background: linear-gradient(135deg, #0057d9, #0099ff) !important;
  border: none !important;
  border-radius: var(--radius) !important;
  color: #fff !important;
  cursor: pointer !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  padding: 14px !important;
  text-transform: uppercase !important;
  width: 100% !important;
  transition: all 0.2s !important;
  position: relative;
  overflow: hidden;
}

.auth-btn::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, transparent 40%, rgba(255,255,255,0.15));
  pointer-events: none;
}

.auth-btn:hover {
  background: linear-gradient(135deg, #0066ff, #00c8ff) !important;
  box-shadow: 0 0 24px #0099ff60, 0 4px 20px #0066ff40 !important;
  transform: translateY(-1px) !important;
}

.auth-link {
  color: var(--neon-cyan) !important;
  font-size: 13px !important;
  opacity: 0.8 !important;
  transition: opacity 0.2s !important;
}
.auth-link:hover { opacity: 1 !important; text-shadow: 0 0 8px var(--neon-cyan) !important; }

.auth-message {
  background: #fff21012;
  border: 1px solid #fff21030;
  border-radius: 6px;
  color: var(--neon-yellow) !important;
  font-size: 13px !important;
  padding: 10px 14px;
  margin-top: 14px !important;
}

/* ── Sidebar ───────────────────────────────────────────────── */
/* The sidebar is rendered on the left via React. We style it globally. */

/* Fixed sidebar container — assuming Tailwind renders it at left:0 */
.fixed.inset-y-0.left-0,
[class*="sidebar"],
aside,
nav {
  background: linear-gradient(180deg, #080f1e, #050b15) !important;
  border-right: 1px solid #00f5ff15 !important;
  box-shadow: 4px 0 30px #00000060 !important;
}

.sidebar-link {
  background: transparent !important;
  border: 1px solid transparent !important;
  border-radius: var(--radius) !important;
  color: #7a9ab8 !important;
  display: flex !important;
  align-items: center;
  font-family: 'Exo 2', sans-serif !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  letter-spacing: 0.5px !important;
  padding: 10px 14px !important;
  text-decoration: none !important;
  transition: all 0.18s ease !important;
  margin-bottom: 2px;
  position: relative;
}

.sidebar-link:hover {
  background: #00f5ff0a !important;
  border-color: #00f5ff20 !important;
  color: #c8e8f8 !important;
  padding-left: 18px !important;
}

.sidebar-link.active {
  background: linear-gradient(90deg, #00f5ff15, #00f5ff05) !important;
  border-color: var(--neon-cyan) !important;
  color: var(--neon-cyan) !important;
  font-weight: 700 !important;
  box-shadow: inset 0 0 20px #00f5ff10 !important;
}

.sidebar-link.active::before {
  content: '';
  position: absolute;
  left: 0; top: 20%; bottom: 20%;
  width: 3px;
  background: var(--neon-cyan);
  border-radius: 0 3px 3px 0;
  box-shadow: 0 0 8px var(--neon-cyan);
}

/* Sidebar header/title area */
.sidebar-title, [class*="sidebar"] h1, [class*="sidebar"] h2 {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: var(--neon-cyan) !important;
  text-shadow: 0 0 12px #00f5ff80 !important;
}

/* ── Main Content Area ─────────────────────────────────────── */
.main-content {
  background: var(--bg-deep) !important;
  left: var(--sidebar-w) !important;
  padding: 24px !important;
  overflow-y: auto !important;
  scrollbar-width: thin;
  scrollbar-color: #1a3a5c transparent;
}

.main-content::-webkit-scrollbar { width: 5px; }
.main-content::-webkit-scrollbar-track { background: transparent; }
.main-content::-webkit-scrollbar-thumb { background: #1a3a5c; border-radius: 10px; }
.main-content::-webkit-scrollbar-thumb:hover { background: var(--neon-cyan); }

/* Page title / headings */
.main-content h1,
.main-content h2,
.main-content h3,
.text-3xl, .text-4xl {
  font-family: 'Rajdhani', sans-serif !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
}

/* ── Layout Lines ──────────────────────────────────────────── */
.layout-line-top {
  border-bottom: 1px solid transparent !important;
  border-image: linear-gradient(90deg, transparent, var(--neon-cyan), transparent) 1 !important;
  opacity: 0.4 !important;
  margin-bottom: 16px !important;
}

.layout-line-bottom {
  border-top: 1px solid transparent !important;
  border-image: linear-gradient(90deg, transparent, var(--neon-cyan), transparent) 1 !important;
  opacity: 0.4 !important;
  margin-top: 16px !important;
}

/* ── Tables ────────────────────────────────────────────────── */
.table-wrapper {
  background: var(--bg-panel) !important;
  border: 1px solid #00f5ff15 !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: 0 0 30px #00000080, inset 0 1px 0 #00f5ff10 !important;
  overflow: hidden !important;
  overflow-x: auto !important;
  overflow-y: auto !important;
  max-height: calc(100vh - 180px) !important;
}

.table-wrapper table {
  border-collapse: collapse !important;
  width: 100% !important;
  min-width: 1000px !important;
}

.table-wrapper th {
  background: linear-gradient(180deg, #0d1e33, #0a1828) !important;
  border: none !important;
  border-bottom: 1px solid #00f5ff20 !important;
  color: var(--neon-cyan) !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px !important;
  padding: 12px 14px !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: background 0.2s !important;
  white-space: nowrap;
}

.table-wrapper th:hover {
  background: #00f5ff10 !important;
}

.table-wrapper td {
  border: none !important;
  border-bottom: 1px solid #0d1e33 !important;
  color: #c0d8f0 !important;
  font-size: 13.5px !important;
  padding: 11px 14px !important;
  transition: background 0.15s !important;
}

.table-wrapper tr:hover td {
  background: #00f5ff06 !important;
  color: var(--text-primary) !important;
}

.table-wrapper tr:last-child td {
  border-bottom: none !important;
}

/* Table search inputs */
.table-wrapper input {
  background: #050b1590 !important;
  border: 1px solid #1a3a5c !important;
  border-radius: 6px !important;
  color: var(--text-primary) !important;
  font-size: 12px !important;
  padding: 5px 10px !important;
  transition: border-color 0.2s !important;
}

.table-wrapper input:focus {
  border-color: var(--neon-cyan) !important;
  outline: none !important;
  box-shadow: 0 0 10px #00f5ff20 !important;
}

/* ── Buttons ───────────────────────────────────────────────── */
.btn-primary {
  background: linear-gradient(135deg, #0057d9, #007aff) !important;
  border: 1px solid #0088ff40 !important;
  border-radius: var(--radius) !important;
  color: #fff !important;
  cursor: pointer !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 1px !important;
  padding: 8px 18px !important;
  text-transform: uppercase !important;
  transition: all 0.2s !important;
  box-shadow: 0 2px 12px #0066ff30 !important;
}

.btn-primary:hover {
  background: linear-gradient(135deg, #0066ff, #00aaff) !important;
  box-shadow: 0 0 20px #0088ff50, 0 4px 16px #004fcc40 !important;
  transform: translateY(-1px) !important;
}

.btn-secondary {
  background: linear-gradient(135deg, #1a3a5c, #1e4570) !important;
  border: 1px solid #00f5ff25 !important;
  border-radius: var(--radius) !important;
  color: #8ecaf5 !important;
  cursor: pointer !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 1px !important;
  padding: 8px 18px !important;
  text-transform: uppercase !important;
  transition: all 0.2s !important;
}

.btn-secondary:hover {
  background: linear-gradient(135deg, #224470, #275580) !important;
  box-shadow: 0 0 16px #00f5ff20 !important;
  color: var(--neon-cyan) !important;
  transform: translateY(-1px) !important;
}

.btn-danger {
  background: linear-gradient(135deg, #8b0000, #cc1111) !important;
  border: 1px solid #ff000030 !important;
  border-radius: var(--radius) !important;
  color: #ffaaaa !important;
  cursor: pointer !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 1px !important;
  padding: 8px 18px !important;
  text-transform: uppercase !important;
  transition: all 0.2s !important;
}

.btn-danger:hover {
  background: linear-gradient(135deg, #aa0000, #ff2222) !important;
  box-shadow: 0 0 20px #ff000040 !important;
  color: #fff !important;
  transform: translateY(-1px) !important;
}

/* Generic Tailwind button overrides */
.bg-blue-600, .bg-blue-500 {
  background: linear-gradient(135deg, #0057d9, #007aff) !important;
}
.bg-green-600, .bg-green-500 {
  background: linear-gradient(135deg, #007a2a, #00b340) !important;
}
.bg-red-600, .bg-red-500 {
  background: linear-gradient(135deg, #8b0000, #cc1111) !important;
}
.bg-yellow-500 {
  background: linear-gradient(135deg, #886600, #ccaa00) !important;
}
.bg-teal-500, .bg-teal-600 {
  background: linear-gradient(135deg, #006060, #009999) !important;
}
.bg-purple-500, .bg-purple-600 {
  background: linear-gradient(135deg, #5a0080, #9900cc) !important;
}
.bg-indigo-500 {
  background: linear-gradient(135deg, #3030aa, #5555ff) !important;
}

/* ── Pagination ────────────────────────────────────────────── */
.pagination {
  align-items: center !important;
  display: flex !important;
  justify-content: space-between !important;
  margin-top: 16px !important;
}

.pagination .btn {
  background: #0d1e33 !important;
  border: 1px solid #1a3a5c !important;
  border-radius: 6px !important;
  color: #8ecaf5 !important;
  cursor: pointer !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: 1px !important;
  padding: 6px 16px !important;
  transition: all 0.2s !important;
}

.pagination .btn:hover:not(:disabled) {
  background: #00f5ff15 !important;
  border-color: var(--neon-cyan) !important;
  color: var(--neon-cyan) !important;
  box-shadow: 0 0 10px #00f5ff20 !important;
}

.pagination .btn:disabled {
  cursor: not-allowed !important;
  opacity: 0.3 !important;
}

/* ── Dashboard Stat Cards ──────────────────────────────────── */
.bg-gray-800, .bg-\\[\\#0B1320\\], .bg-\\[\\#0F172A\\] {
  background: var(--bg-card) !important;
}

/* Stat card wrappers that typically use .rounded-lg.p-4 or similar */
.rounded-lg {
  border-radius: var(--radius-lg) !important;
}

/* Any card-like element inside main content */
.main-content .rounded-lg,
.main-content .shadow-lg {
  background: var(--bg-card) !important;
  border: 1px solid #00f5ff12 !important;
  box-shadow: 0 4px 24px #00000060, 0 0 0 1px #00f5ff08 !important;
  transition: transform 0.2s, box-shadow 0.2s !important;
}

.main-content .rounded-lg:hover {
  box-shadow: 0 8px 32px #00000080, 0 0 20px #00f5ff15 !important;
  transform: translateY(-2px) !important;
}

/* ── Modals / Overlays ─────────────────────────────────────── */
.fixed.inset-0 {
  backdrop-filter: blur(4px) !important;
}

/* Modal box */
.bg-gray-900 {
  background: linear-gradient(145deg, #0a1525, #080e1c) !important;
  border: 1px solid #00f5ff20 !important;
  box-shadow: 0 0 60px #00000090, 0 0 30px #00f5ff10 !important;
}

/* Modal heading top border */
.bg-gray-900 .border-b {
  border-bottom-color: #00f5ff20 !important;
}

/* ── Form Inputs (modal / add forms) ───────────────────────── */
input:not(.auth-input):not(.table-wrapper input),
select,
textarea {
  background: #050b1590 !important;
  border: 1px solid #1a3a5c !important;
  border-radius: 6px !important;
  color: var(--text-primary) !important;
  font-family: 'Exo 2', sans-serif !important;
  font-size: 14px !important;
  padding: 10px 14px !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
  width: 100%;
  box-sizing: border-box;
}

input:not(.auth-input):not(.table-wrapper input):focus,
select:focus,
textarea:focus {
  border-color: var(--neon-cyan) !important;
  box-shadow: 0 0 0 3px #00f5ff12 !important;
  outline: none !important;
}

select option {
  background: #0d1828 !important;
  color: var(--text-primary) !important;
}

label {
  color: #7a9ab8 !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
}

/* ── Status / Color badges ─────────────────────────────────── */
.text-green-400 { color: #39ff14 !important; text-shadow: 0 0 8px #39ff1480; }
.text-blue-400  { color: var(--neon-cyan) !important; }
.text-yellow-300 { color: var(--neon-yellow) !important; }
.text-gray-300  { color: #aac4dd !important; }
.text-gray-400  { color: #6b8aad !important; }

/* ── Photos ────────────────────────────────────────────────── */
.photo-img {
  border: 2px solid #00f5ff30 !important;
  border-radius: 8px !important;
  box-shadow: 0 0 12px #00f5ff20 !important;
  height: 52px !important;
  object-fit: cover !important;
  width: 52px !important;
  transition: box-shadow 0.2s !important;
}

.photo-img:hover {
  box-shadow: 0 0 20px var(--neon-cyan) !important;
  border-color: var(--neon-cyan) !important;
}

/* ── Scrollbar for table-wrapper ───────────────────────────── */
.table-wrapper::-webkit-scrollbar { width: 5px; height: 5px; }
.table-wrapper::-webkit-scrollbar-track { background: transparent; }
.table-wrapper::-webkit-scrollbar-thumb { background: #1a3a5c; border-radius: 10px; }
.table-wrapper::-webkit-scrollbar-thumb:hover { background: var(--neon-cyan); }

/* ── Topbar / Header (if present) ─────────────────────────── */
header, .header, [class*="topbar"], [class*="navbar"] {
  background: linear-gradient(90deg, #080f1e, #0a1525) !important;
  border-bottom: 1px solid #00f5ff15 !important;
  box-shadow: 0 2px 20px #00000060 !important;
}

/* ── Typography polish ─────────────────────────────────────── */
.text-2xl { font-family: 'Rajdhani', sans-serif !important; font-weight: 700 !important; letter-spacing: 1.5px !important; }
.text-xl  { font-family: 'Rajdhani', sans-serif !important; font-weight: 600 !important; }
.font-bold { font-family: 'Rajdhani', sans-serif !important; }

/* ── Glow animations for accent elements ───────────────────── */
@keyframes glowPulse {
  0%, 100% { text-shadow: 0 0 10px var(--neon-cyan), 0 0 20px #00f5ff60; }
  50%       { text-shadow: 0 0 20px var(--neon-cyan), 0 0 40px var(--neon-cyan), 0 0 60px #00f5ff40; }
}

/* Dashboard numeric stats */
.text-3xl, .text-4xl {
  animation: glowPulse 4s ease-in-out infinite;
  color: var(--neon-cyan) !important;
}

/* ── Loading / Spinner ─────────────────────────────────────── */
@keyframes neonSpin {
  to { transform: rotate(360deg); }
}

.animate-spin {
  border-color: var(--neon-cyan) transparent transparent transparent !important;
  animation: neonSpin 0.7s linear infinite !important;
}

/* ── Misc polish ───────────────────────────────────────────── */
.border-gray-700 { border-color: #1a3a5c !important; }
.divide-gray-700 > :not([hidden]) ~ :not([hidden]) { border-color: #1a3a5c !important; }

/* Focus ring override */
*:focus-visible {
  outline: 2px solid var(--neon-cyan) !important;
  outline-offset: 2px !important;
}

/* Cursor hover on interactive table rows */
.table-wrapper tr { cursor: default; }
.table-wrapper tbody tr { transition: background 0.12s; }

/* Page section titles */
.main-content > div > h2,
.main-content > div > h1 {
  color: var(--text-primary) !important;
  font-size: 22px !important;
  letter-spacing: 2px !important;
  text-shadow: 0 0 20px #00f5ff30 !important;
}
