/* ============================================================
   P2P THEME — Core Variables & Utilities
   Colors: Emerald Green #0B6B3A | Gold #FFC72C | Dark #0d1b2a
   ============================================================ */

/* Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

:root {
  /* Brand Colors */
  --p2p-green:        #0B6B3A;
  --p2p-green-dark:   #085230;
  --p2p-green-medium: #0d7f46;
  --p2p-green-light:  #e8f5ee;
  --p2p-green-muted:  rgba(11,107,58,0.12);

  --p2p-gold:         #FFC72C;
  --p2p-gold-dark:    #e6b000;
  --p2p-gold-light:   #fff8e1;
  --p2p-gold-muted:   rgba(255,199,44,0.15);

  --p2p-dark:         #0d1b2a;
  --p2p-dark-2:       #1a2d3d;
  --p2p-dark-3:       #243447;

  /* Semantic */
  --p2p-success:      #10b981;
  --p2p-danger:       #ef4444;
  --p2p-warning:      #f59e0b;
  --p2p-info:         #3b82f6;

  /* Backgrounds */
  --p2p-bg:           #f4fbf7;
  --p2p-bg-card:      #ffffff;
  --p2p-bg-muted:     #f0f9f4;

  /* Text */
  --p2p-text:         #0d1b2a;
  --p2p-text-muted:   #52687a;
  --p2p-text-light:   #8a9bb0;

  /* Borders */
  --p2p-border:       #d4eade;
  --p2p-border-light: #e8f5ee;

  /* Shadows */
  --p2p-shadow-sm:    0 1px 3px rgba(11,107,58,.08);
  --p2p-shadow:       0 4px 12px rgba(11,107,58,.10);
  --p2p-shadow-md:    0 8px 24px rgba(11,107,58,.12);
  --p2p-shadow-lg:    0 16px 40px rgba(11,107,58,.15);
  --p2p-shadow-gold:  0 4px 20px rgba(255,199,44,.30);

  /* Typography */
  --p2p-font:         'Plus Jakarta Sans', 'Inter', sans-serif;
  --p2p-font-mono:    'JetBrains Mono', monospace;

  /* Border Radius */
  --p2p-radius-sm:    6px;
  --p2p-radius:       10px;
  --p2p-radius-md:    14px;
  --p2p-radius-lg:    20px;
  --p2p-radius-xl:    28px;
  --p2p-radius-full:  9999px;

  /* Transitions */
  --p2p-transition:   all 0.25s ease;

  /* Sidebar */
  --sidebar-width:    260px;
  --sidebar-mini:     72px;
  --topbar-height:    64px;
}

/* Dark mode overrides */
body.dark-mode {
  --p2p-bg:           #0a1628;
  --p2p-bg-card:      #0d1f35;
  --p2p-bg-muted:     #112240;
  --p2p-text:         #e2efea;
  --p2p-text-muted:   #8ab4c4;
  --p2p-text-light:   #5a8a9a;
  --p2p-border:       #1e3a5f;
  --p2p-border-light: #162d4a;
  --p2p-shadow-sm:    0 1px 3px rgba(0,0,0,0.3);
  --p2p-shadow:       0 4px 12px rgba(0,0,0,0.4);
  --p2p-shadow-md:    0 8px 24px rgba(0,0,0,0.5);
}

/* ============ RESET & BASE ============ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

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

body {
  font-family: var(--p2p-font);
  color: var(--p2p-text);
  background: var(--p2p-bg);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

a { text-decoration: none; color: inherit; transition: var(--p2p-transition); }
a:hover { color: var(--p2p-green); }

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

/* ============ TYPOGRAPHY ============ */
h1,h2,h3,h4,h5,h6 {
  font-weight: 700;
  line-height: 1.3;
  color: var(--p2p-text);
}

.text-green   { color: var(--p2p-green) !important; }
.text-gold    { color: var(--p2p-gold-dark) !important; }
.text-muted-p { color: var(--p2p-text-muted) !important; }
.text-light-p { color: var(--p2p-text-light) !important; }

/* ============ BUTTONS ============ */
.btn-p2p {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 24px;
  border-radius: var(--p2p-radius-full);
  font-weight: 600;
  font-size: 0.9rem;
  letter-spacing: 0.02em;
  border: none;
  cursor: pointer;
  transition: var(--p2p-transition);
  white-space: nowrap;
}

.btn-p2p-primary {
  background: var(--p2p-green);
  color: #fff;
  box-shadow: 0 4px 14px rgba(11,107,58,.30);
}
.btn-p2p-primary:hover {
  background: var(--p2p-green-dark);
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(11,107,58,.40);
}

.btn-p2p-gold {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 9px 22px;
  border-radius: var(--p2p-radius-full);
  font-weight: 700;
  font-size: 0.875rem;
  letter-spacing: 0.02em;
  border: none;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition: var(--p2p-transition);
  background: var(--p2p-gold);
  color: var(--p2p-dark);
  box-shadow: var(--p2p-shadow-gold);
  line-height: 1;
}
.btn-p2p-gold:hover {
  background: var(--p2p-gold-dark);
  color: var(--p2p-dark);
  transform: translateY(-1px);
  box-shadow: 0 6px 24px rgba(255,199,44,.45);
}

.btn-p2p-outline {
  background: transparent;
  color: var(--p2p-green);
  border: 2px solid var(--p2p-green);
}
.btn-p2p-outline:hover {
  background: var(--p2p-green);
  color: #fff;
}

.btn-p2p-outline-green {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 9px 22px;
  border-radius: var(--p2p-radius-full);
  font-size: 0.875rem;
  font-weight: 600;
  background: transparent;
  color: var(--p2p-green);
  border: 2px solid var(--p2p-green);
  text-decoration: none;
  transition: var(--p2p-transition);
  cursor: pointer;
  line-height: 1;
}
.btn-p2p-outline-green:hover {
  background: var(--p2p-green);
  color: #fff;
}

.btn-p2p-ghost {
  background: var(--p2p-green-muted);
  color: var(--p2p-green);
}
.btn-p2p-ghost:hover {
  background: var(--p2p-green);
  color: #fff;
}

.btn-p2p-danger { background: #fef2f2; color: #dc2626; }
.btn-p2p-danger:hover { background: #dc2626; color:#fff; }

/* ============ CARDS ============ */
.p2p-card {
  background: var(--p2p-bg-card);
  border: 1px solid var(--p2p-border-light);
  border-radius: var(--p2p-radius-md);
  padding: 1.5rem;
  box-shadow: var(--p2p-shadow-sm);
  transition: var(--p2p-transition);
}
.p2p-card:hover {
  box-shadow: var(--p2p-shadow);
  transform: translateY(-2px);
  border-color: var(--p2p-border);
}
.p2p-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.25rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--p2p-border-light);
}
.p2p-card-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--p2p-text);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 8px;
}
.p2p-card-title i {
  color: var(--p2p-green);
  font-size: 1.1rem;
}

/* ============ STAT CARDS ============ */
.stat-card {
  background: var(--p2p-bg-card);
  border-radius: var(--p2p-radius-md);
  padding: 1.5rem;
  border: 1px solid var(--p2p-border-light);
  box-shadow: var(--p2p-shadow-sm);
  transition: var(--p2p-transition);
  position: relative;
  overflow: hidden;
}
.stat-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--p2p-green), var(--p2p-gold));
}
.stat-card:hover {
  box-shadow: var(--p2p-shadow-md);
  transform: translateY(-3px);
  border-color: var(--p2p-green-light);
}
.stat-card .stat-icon {
  width: 52px; height: 52px;
  border-radius: var(--p2p-radius);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem;
  margin-bottom: 1rem;
}
.stat-card .stat-icon.green  { background: var(--p2p-green-muted); color: var(--p2p-green); }
.stat-card .stat-icon.gold   { background: var(--p2p-gold-muted);  color: var(--p2p-gold-dark); }
.stat-card .stat-icon.blue   { background: rgba(59,130,246,.12);  color: #3b82f6; }
.stat-card .stat-icon.red    { background: rgba(239,68,68,.12);   color: #ef4444; }
.stat-card .stat-icon.teal   { background: rgba(20,184,166,.12);  color: #14b8a6; }

.stat-card .stat-label {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--p2p-text-muted);
  margin-bottom: 6px;
}
.stat-card .stat-value {
  font-size: 2rem;
  font-weight: 800;
  color: var(--p2p-text);
  line-height: 1.1;
  margin-bottom: 8px;
}
.stat-card .stat-sub {
  font-size: 0.8rem;
  color: var(--p2p-text-muted);
  display: flex;
  align-items: center;
  gap: 4px;
}
.stat-card .stat-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 3px 8px;
  border-radius: var(--p2p-radius-full);
  font-size: 0.72rem;
  font-weight: 600;
}
.stat-badge.up   { background: rgba(16,185,129,.12); color: #059669; }
.stat-badge.down { background: rgba(239,68,68,.12);  color: #dc2626; }

/* ============ BADGES ============ */
.badge-p2p {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 10px;
  border-radius: var(--p2p-radius-full);
  font-size: 0.72rem;
  font-weight: 600;
}
.badge-green  { background: var(--p2p-green-muted);      color: var(--p2p-green); }
.badge-gold   { background: var(--p2p-gold-muted);        color: #92610a; }
.badge-red    { background: rgba(239,68,68,.12);           color: #dc2626; }
.badge-blue   { background: rgba(59,130,246,.12);          color: #2563eb; }
.badge-gray   { background: rgba(107,114,128,.12);         color: #4b5563; }
.badge-teal   { background: rgba(20,184,166,.12);          color: #0f766e; }

/* ============ TABLES ============ */
.p2p-table { width: 100%; border-collapse: separate; border-spacing: 0; }
.p2p-table thead th {
  background: var(--p2p-bg-muted);
  color: var(--p2p-text-muted);
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 12px 16px;
  border-bottom: 2px solid var(--p2p-border);
  white-space: nowrap;
}
.p2p-table thead th:first-child { border-radius: 10px 0 0 0; }
.p2p-table thead th:last-child  { border-radius: 0 10px 0 0; }
.p2p-table tbody tr {
  transition: var(--p2p-transition);
}
.p2p-table tbody tr:hover { background: var(--p2p-bg-muted); }
.p2p-table tbody td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--p2p-border-light);
  color: var(--p2p-text);
  font-size: 0.875rem;
  vertical-align: middle;
}
.p2p-table tbody tr:last-child td { border-bottom: none; }

/* ============ FORMS ============ */
.p2p-form-group { margin-bottom: 1.25rem; }
.p2p-label {
  display: block;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--p2p-text);
  margin-bottom: 6px;
  letter-spacing: 0.02em;
}
.p2p-input {
  width: 100%;
  padding: 11px 16px;
  border: 1.5px solid var(--p2p-border);
  border-radius: var(--p2p-radius);
  font-family: var(--p2p-font);
  font-size: 0.9rem;
  color: var(--p2p-text);
  background: var(--p2p-bg-card);
  transition: var(--p2p-transition);
  outline: none;
}
.p2p-input:focus {
  border-color: var(--p2p-green);
  box-shadow: 0 0 0 3px var(--p2p-green-muted);
}
.p2p-input::placeholder { color: var(--p2p-text-light); }

select.p2p-input { cursor: pointer; }

textarea.p2p-input { resize: vertical; min-height: 100px; }

/* ============ ALERTS ============ */
.p2p-alert {
  padding: 14px 18px;
  border-radius: var(--p2p-radius);
  font-size: 0.875rem;
  font-weight: 500;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 1rem;
}
.p2p-alert-success { background: var(--p2p-green-muted); color: var(--p2p-green); border: 1px solid rgba(11,107,58,.2); }
.p2p-alert-warning { background: var(--p2p-gold-muted);  color: #92610a; border: 1px solid rgba(255,199,44,.3); }
.p2p-alert-danger  { background: rgba(239,68,68,.1);     color: #dc2626; border: 1px solid rgba(239,68,68,.2); }
.p2p-alert-info    { background: rgba(59,130,246,.1);    color: #2563eb; border: 1px solid rgba(59,130,246,.2); }

/* ============ LOADER ============ */
#p2p-loader {
  position: fixed; inset: 0;
  background: var(--p2p-green);
  display: flex; align-items: center; justify-content: center;
  z-index: 99999;
  transition: opacity 0.4s ease, visibility 0.4s ease;
}
#p2p-loader.hidden { opacity: 0; visibility: hidden; }
.p2p-loader-ring {
  width: 54px; height: 54px;
  border: 4px solid rgba(255,255,255,0.25);
  border-top-color: var(--p2p-gold);
  border-radius: 50%;
  animation: spin 0.9s linear infinite;
}
.p2p-loader-logo {
  position: absolute;
  display: flex; flex-direction: column; align-items: center; gap: 16px;
}
.p2p-loader-text { color: rgba(255,255,255,.85); font-size: 0.9rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; }

@keyframes spin { to { transform: rotate(360deg); } }

/* ============ AVATAR ============ */
.p2p-avatar {
  border-radius: 50%;
  object-fit: cover;
  display: inline-block;
  border: 2px solid var(--p2p-border);
}
.p2p-avatar-sm  { width:  36px; height:  36px; }
.p2p-avatar-md  { width:  48px; height:  48px; }
.p2p-avatar-lg  { width:  64px; height:  64px; }
.p2p-avatar-xl  { width:  80px; height:  80px; }

/* Status dots */
.online-dot {
  position: absolute;
  bottom: 2px; right: 2px;
  width: 10px; height: 10px;
  background: #22c55e;
  border-radius: 50%;
  border: 2px solid white;
}

/* ============ PROGRESS BARS ============ */
.p2p-progress-bar {
  height: 8px;
  background: var(--p2p-border-light);
  border-radius: var(--p2p-radius-full);
  overflow: hidden;
  margin-top: 8px;
}
.p2p-progress-fill {
  height: 100%;
  border-radius: var(--p2p-radius-full);
  background: linear-gradient(90deg, var(--p2p-green), var(--p2p-gold));
  transition: width 0.8s ease;
}

/* ============ COUNTDOWN ============ */
.p2p-countdown {
  display: flex; gap: 10px; justify-content: center;
}
.p2p-countdown-item {
  background: var(--p2p-green-muted);
  border: 1px solid var(--p2p-border);
  border-radius: var(--p2p-radius);
  padding: 12px 16px;
  text-align: center;
  min-width: 64px;
}
.p2p-countdown-item .num {
  display: block;
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--p2p-green);
  line-height: 1;
}
.p2p-countdown-item .label {
  display: block;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--p2p-text-muted);
  margin-top: 4px;
}

/* ============ EMPTY STATE ============ */
.p2p-empty {
  text-align: center;
  padding: 3rem 1.5rem;
}
.p2p-empty i { font-size: 3rem; color: var(--p2p-border); margin-bottom: 1rem; }
.p2p-empty h5 { font-size: 1rem; color: var(--p2p-text); margin-bottom: 0.5rem; }
.p2p-empty p  { font-size: 0.875rem; color: var(--p2p-text-muted); }

/* ============ UTILITIES ============ */
.rounded-p2p { border-radius: var(--p2p-radius); }
.shadow-p2p  { box-shadow: var(--p2p-shadow); }

.p2p-divider {
  height: 1px;
  background: var(--p2p-border-light);
  margin: 1.25rem 0;
}

.gold-accent-line {
  width: 40px; height: 3px;
  background: var(--p2p-gold);
  border-radius: var(--p2p-radius-full);
  margin-bottom: 0.75rem;
}

/* Scroll bar */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--p2p-border); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: var(--p2p-green); }

/* Flash messages integration */
.alert { border-radius: var(--p2p-radius); border: none; }
