/* ============================================
   THRIVEMINE — SHARED STYLES
   ============================================ */
@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;600;700&family=Exo+2:wght@300;400;500;600&display=swap');

:root {
  --green:    #39ff14;
  --green2:   #00e5b0;
  --glow-sm:  0 0 12px rgba(57,255,20,.35);
  --glow-md:  0 0 24px rgba(57,255,20,.45),0 0 50px rgba(57,255,20,.15);
  --bg:       #090909;
  --bg2:      #0f0f0f;
  --bg3:      #141414;
  --border:   rgba(57,255,20,.15);
  --border2:  rgba(255,255,255,.07);
  --text:     #ffffff;
  --muted:    rgba(255,255,255,.45);
  --danger:   #ff4d4d;
  --warning:  #f0b429;
  --success:  #39ff14;
  --info:     #00b4ff;
  --sidebar-w:240px;
}

*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  background:var(--bg);
  color:var(--text);
  font-family:'Exo 2',sans-serif;
  font-size:15px;
  -webkit-font-smoothing:antialiased;
}
::-webkit-scrollbar { width:4px; height:4px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:rgba(57,255,20,.3); border-radius:2px; }
a { text-decoration:none; color:inherit; }
img { display:block; max-width:100%; }

/* ── LOGO ── */
.logo {
  display:flex; align-items:center; gap:10px;
  font-family:'Rajdhani',sans-serif; font-weight:700;
  font-size:1.35rem; letter-spacing:.1em; color:#fff;
}
.logo-icon {
  width:32px; height:32px; background:var(--green);
  display:flex; align-items:center; justify-content:center;
  font-size:.9rem; color:#000; font-weight:900;
}
.logo span { color:var(--green); }

/* ── BUTTONS ── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:'Rajdhani',sans-serif; font-weight:700;
  font-size:.8rem; letter-spacing:.18em; text-transform:uppercase;
  padding:12px 28px; cursor:pointer; border:none; border-radius:4px;
  transition:all .25s;
}
.btn-green {
  background:var(--green); color:#000;
  box-shadow:var(--glow-sm);
}
.btn-green:hover { box-shadow:var(--glow-md); transform:translateY(-1px); }
.btn-green:disabled { opacity:.5; cursor:not-allowed; transform:none; }
.btn-outline {
  background:transparent; color:var(--green);
  border:1px solid var(--green);
}
.btn-outline:hover { background:rgba(57,255,20,.08); }
.btn-danger {
  background:rgba(255,77,77,.12); color:var(--danger);
  border:1px solid rgba(255,77,77,.3);
}
.btn-danger:hover { background:rgba(255,77,77,.2); }
.btn-sm { padding:7px 16px; font-size:.72rem; }
.btn-full { width:100%; }

/* ── FORM FIELDS ── */
.field { display:flex; flex-direction:column; gap:6px; margin-bottom:16px; }
.field label {
  font-size:.65rem; letter-spacing:.25em; text-transform:uppercase;
  color:var(--muted);
}
.input {
  background:rgba(255,255,255,.04);
  border:1px solid var(--border2);
  color:#fff; padding:11px 14px;
  font-family:'Exo 2',sans-serif; font-size:.9rem;
  outline:none; border-radius:4px; width:100%;
  transition:border-color .2s;
}
.input::placeholder { color:rgba(255,255,255,.2); }
.input:focus { border-color:rgba(57,255,20,.5); }
.input-icon-wrap { position:relative; }
.input-icon-wrap .input { padding-left:42px; }
.input-icon-wrap .field-icon {
  position:absolute; left:13px; top:50%; transform:translateY(-50%);
  color:rgba(255,255,255,.3); font-size:1rem; pointer-events:none;
}
.select {
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2339ff14' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center;
  cursor:pointer;
}
.select option { background:#111; color:#fff; }

/* ── CARDS ── */
.card {
  background:var(--bg2);
  border:1px solid var(--border2);
  border-radius:12px;
  padding:24px;
}
.card-green {
  border-color:var(--border);
  box-shadow:0 0 20px rgba(57,255,20,.06);
}

/* ── STAT CARD ── */
.stat-card {
  background:var(--bg2);
  border:1px solid var(--border2);
  border-radius:10px;
  padding:20px;
  transition:border-color .25s;
}
.stat-card:hover { border-color:var(--border); }
.stat-card .label {
  font-size:.65rem; letter-spacing:.2em; text-transform:uppercase;
  color:var(--muted); margin-bottom:10px;
}
.stat-card .value {
  font-family:'Rajdhani',sans-serif; font-weight:700;
  font-size:1.8rem; color:#fff;
}
.stat-card .value.green { color:var(--green); text-shadow:var(--glow-sm); }
.stat-card .change {
  font-size:.75rem; margin-top:4px;
  display:flex; align-items:center; gap:4px;
}
.stat-card .icon {
  width:38px; height:38px;
  background:rgba(57,255,20,.08); border:1px solid var(--border);
  border-radius:8px; display:flex; align-items:center; justify-content:center;
  font-size:1.1rem;
}

/* ── TABLE ── */
.table-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; }
thead tr { border-bottom:1px solid var(--border2); }
th {
  text-align:left; padding:10px 14px;
  font-size:.62rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--muted); font-weight:500; white-space:nowrap;
}
td {
  padding:12px 14px; font-size:.85rem;
  color:rgba(255,255,255,.7);
  border-bottom:1px solid rgba(255,255,255,.03);
  white-space:nowrap;
}
tr:hover td { background:rgba(255,255,255,.015); }

/* ── BADGES ── */
.badge {
  display:inline-flex; align-items:center; gap:5px;
  padding:3px 10px; border-radius:20px; font-size:.7rem;
  font-weight:600; letter-spacing:.05em;
}
.badge-success { background:rgba(57,255,20,.12); color:var(--green); }
.badge-warning { background:rgba(240,180,41,.12); color:var(--warning); }
.badge-danger  { background:rgba(255,77,77,.12);  color:var(--danger);  }
.badge-info    { background:rgba(0,180,255,.12);  color:var(--info);    }
.badge-muted   { background:rgba(255,255,255,.06);color:var(--muted);   }

/* ── ALERT ── */
.alert {
  padding:12px 16px; border-radius:6px; font-size:.85rem;
  display:flex; align-items:flex-start; gap:10px; margin-bottom:16px;
}
.alert-error   { background:rgba(255,77,77,.1); border:1px solid rgba(255,77,77,.25); color:#ff8080; }
.alert-success { background:rgba(57,255,20,.08); border:1px solid rgba(57,255,20,.2); color:var(--green); }
.alert-info    { background:rgba(0,180,255,.08); border:1px solid rgba(0,180,255,.2); color:var(--info); }

/* ── SIDEBAR ── */
.sidebar {
  position:fixed; top:0; left:0; bottom:0;
  width:var(--sidebar-w);
  background:#0b0b0b;
  border-right:1px solid var(--border2);
  display:flex; flex-direction:column;
  z-index:100; overflow-y:auto;
  transition:transform .3s;
}
.sidebar-logo {
  padding:20px 20px 16px;
  border-bottom:1px solid var(--border2);
}
.sidebar-nav {
  flex:1; padding:12px 10px; display:flex; flex-direction:column; gap:2px;
}
.nav-item {
  display:flex; align-items:center; gap:10px;
  padding:10px 12px; border-radius:6px;
  font-size:.82rem; color:rgba(255,255,255,.45);
  cursor:pointer; transition:all .2s;
  border-left:2px solid transparent;
}
.nav-item:hover { background:rgba(255,255,255,.04); color:#fff; }
.nav-item.active {
  background:rgba(57,255,20,.08);
  color:var(--green);
  border-left-color:var(--green);
}
.nav-item .nav-icon { font-size:1rem; width:18px; text-align:center; flex-shrink:0; }
.nav-section-label {
  font-size:.58rem; letter-spacing:.3em; text-transform:uppercase;
  color:rgba(255,255,255,.2); padding:12px 12px 4px;
}
.sidebar-footer {
  padding:16px 10px;
  border-top:1px solid var(--border2);
}

/* ── TOPBAR ── */
.topbar {
  height:60px;
  background:rgba(9,9,9,.95);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border2);
  display:flex; align-items:center;
  justify-content:space-between;
  padding:0 24px;
  position:sticky; top:0; z-index:50;
}
.topbar-left { display:flex; align-items:center; gap:12px; }
.topbar-right { display:flex; align-items:center; gap:14px; }
.menu-btn {
  background:none; border:none; color:#fff; cursor:pointer;
  font-size:1.2rem; display:none;
}
@media(max-width:768px) { .menu-btn { display:block; } }

/* ── LAYOUT ── */
.app-layout {
  display:flex; min-height:100vh;
}
.main-content {
  flex:1;
  margin-left:var(--sidebar-w);
  min-height:100vh;
  display:flex; flex-direction:column;
}
.page-content { flex:1; padding:28px 28px 40px; }
@media(max-width:768px) {
  .main-content { margin-left:0; }
  .sidebar { transform:translateX(-100%); }
  .sidebar.open { transform:translateX(0); }
}

/* ── OVERLAY ── */
.overlay {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.6); z-index:90;
}
.overlay.open { display:block; }

/* ── PAGE HEADER ── */
.page-hdr { margin-bottom:24px; }
.page-hdr h1 {
  font-family:'Rajdhani',sans-serif; font-weight:700;
  font-size:1.6rem; letter-spacing:.04em;
}
.page-hdr p { color:var(--muted); font-size:.88rem; margin-top:4px; }
.page-hdr-row {
  display:flex; align-items:center;
  justify-content:space-between; flex-wrap:wrap; gap:12px;
}

/* ── MODAL ── */
.modal-bg {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.75); z-index:200;
  align-items:center; justify-content:center; padding:20px;
}
.modal-bg.open { display:flex; }
.modal {
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:14px;
  padding:32px;
  width:100%; max-width:480px;
  position:relative;
  animation:fadeUp .25s ease;
}
.modal-title {
  font-family:'Rajdhani',sans-serif; font-weight:700;
  font-size:1.25rem; margin-bottom:6px;
}
.modal-close {
  position:absolute; top:16px; right:16px;
  background:none; border:none; color:var(--muted);
  font-size:1.2rem; cursor:pointer;
}
.modal-close:hover { color:#fff; }

/* ── SPINNER ── */
.spinner {
  width:18px; height:18px; border-radius:50%;
  border:2px solid rgba(57,255,20,.2);
  border-top-color:var(--green);
  animation:spin .7s linear infinite;
  display:inline-block;
}
@keyframes spin { to { transform:rotate(360deg); } }
@keyframes fadeUp {
  from { opacity:0; transform:translateY(16px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ── MISC ── */
.sep { height:1px; background:var(--border2); margin:20px 0; }
.text-green  { color:var(--green); }
.text-muted  { color:var(--muted); }
.text-danger { color:var(--danger); }
.text-warning{ color:var(--warning); }
.flex        { display:flex; }
.items-center{ align-items:center; }
.gap-2       { gap:8px; }
.gap-3       { gap:12px; }
.mt-1        { margin-top:4px; }
.mt-2        { margin-top:8px; }
.mb-4        { margin-bottom:16px; }
.grid-2      { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.grid-3      { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.grid-4      { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
@media(max-width:900px) {
  .grid-4 { grid-template-columns:repeat(2,1fr); }
  .grid-3 { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:500px) {
  .grid-4,.grid-3,.grid-2 { grid-template-columns:1fr; }
}
.empty-state {
  text-align:center; padding:48px 24px;
  color:var(--muted);
}
.empty-state .empty-icon { font-size:2.5rem; margin-bottom:12px; }
.empty-state p { font-size:.88rem; }
