/* 6Degrees - app.css — minimal, no external dependencies */
:root {
  --bg:       #0d1117;
  --bg2:      #161b22;
  --bg3:      #21262d;
  --border:   #30363d;
  --text:     #e6edf3;
  --text2:    #8b949e;
  --accent:   #58a6ff;
  --accent2:  #3fb950;
  --danger:   #f85149;
  --warn:     #d29922;
  --radius:   8px;
  --shadow:   0 2px 12px rgba(0,0,0,.4);
}

*,*::before,*::after { box-sizing: border-box; margin:0; padding:0; }

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

body {
  background: var(--bg);
  color: var(--text);
  font-family: system-ui, -apple-system, sans-serif;
  line-height: 1.6;
  min-height: 100vh;
}

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

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

/* ── Header ─────────────────────────────────────────── */
.site-header {
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
  position: sticky; top:0; z-index:100;
}
.header-inner {
  max-width: 1100px; margin: 0 auto;
  padding: .75rem 1rem;
  display: flex; align-items:center; justify-content:space-between;
  flex-wrap: wrap; gap:.5rem;
}
.logo {
  font-size: 1.3rem; font-weight:700; color: var(--accent);
  letter-spacing: -.5px;
}
.main-nav { display:flex; align-items:center; gap:.5rem; flex-wrap:wrap; }
.main-nav a {
  color: var(--text2); padding:.3rem .6rem; border-radius:var(--radius);
  font-size:.9rem; transition: color .2s, background .2s;
}
.main-nav a:hover { color:var(--text); background:var(--bg3); text-decoration:none; }
.btn-primary {
  background: var(--accent); color:#000 !important;
  padding:.35rem .9rem !important; border-radius:var(--radius) !important;
  font-weight:600;
}
.btn-logout { color: var(--danger) !important; }
.notif-link { position:relative; }
.badge {
  background: var(--danger); color:#fff; font-size:.7rem;
  padding:1px 5px; border-radius:99px; margin-left:3px;
}

/* ── Layout ─────────────────────────────────────────── */
.main-content { max-width:1100px; margin:0 auto; padding:1.5rem 1rem; }
.page-wrap { max-width:680px; margin:0 auto; }
.card {
  background: var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius); padding:1.25rem;
  box-shadow: var(--shadow);
}
.card + .card { margin-top:1rem; }
.card-title { font-size:1.1rem; font-weight:600; margin-bottom:1rem; }
.row { display:flex; gap:1rem; flex-wrap:wrap; }
.col { flex:1; min-width:240px; }

/* ── Forms ──────────────────────────────────────────── */
.form-group { margin-bottom:1rem; }
.form-group label { display:block; font-size:.875rem; color:var(--text2); margin-bottom:.35rem; }
.form-group input,
.form-group select,
.form-group textarea {
  width:100%; background:var(--bg3); border:1px solid var(--border);
  color:var(--text); border-radius:var(--radius); padding:.55rem .75rem;
  font-size:.95rem; transition: border-color .2s;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline:none; border-color:var(--accent);
}
.form-group textarea { resize:vertical; min-height:90px; }
.form-hint { font-size:.8rem; color:var(--text2); margin-top:.25rem; }

/* ── Buttons ─────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.5rem 1.1rem; border-radius:var(--radius);
  font-size:.9rem; font-weight:600; cursor:pointer;
  border:none; transition: opacity .2s, transform .1s; text-decoration:none;
}
.btn:hover { opacity:.85; text-decoration:none; }
.btn:active { transform:scale(.97); }
.btn-accent  { background:var(--accent);  color:#000; }
.btn-green   { background:var(--accent2); color:#000; }
.btn-danger  { background:var(--danger);  color:#fff; }
.btn-ghost   { background:transparent; border:1px solid var(--border); color:var(--text); }
.btn-sm      { padding:.3rem .7rem; font-size:.82rem; }
.btn-block   { width:100%; justify-content:center; }
.btn-wa      { background:#25D366; color:#fff; }

/* ── Alerts ─────────────────────────────────────────── */
.alert {
  padding:.75rem 1rem; border-radius:var(--radius); margin-bottom:1rem;
  font-size:.9rem; border-left:3px solid;
}
.alert-success { background:#0d2c1e; border-color:var(--accent2); color:var(--accent2); }
.alert-error   { background:#2c0d0d; border-color:var(--danger);  color:var(--danger); }
.alert-info    { background:#0d1c2c; border-color:var(--accent);  color:var(--accent); }
.alert-warn    { background:#2c200d; border-color:var(--warn);    color:var(--warn); }

/* ── Profile image ───────────────────────────────────── */
.avatar { border-radius:50%; object-fit:cover; }
.avatar-lg { width:80px; height:80px; }
.avatar-md { width:48px; height:48px; }
.avatar-sm { width:36px; height:36px; }
.avatar-tiny { width:28px; height:28px; }

/* ── User card ───────────────────────────────────────── */
.user-row {
  display:flex; align-items:center; gap:.75rem;
  padding:.6rem 0; border-bottom:1px solid var(--border);
}
.user-row:last-child { border-bottom:none; }
.user-info { flex:1; }
.user-name { font-weight:600; font-size:.95rem; }
.user-meta { font-size:.8rem; color:var(--text2); }
.user-actions { display:flex; gap:.4rem; }

/* ── Network canvas ──────────────────────────────────── */
#network-canvas {
  width:100%; height:500px; border-radius:var(--radius);
  background: radial-gradient(ellipse at center, #1a2035 0%, #0d1117 100%);
  border:1px solid var(--border); cursor:grab; display:block;
}
#network-canvas:active { cursor:grabbing; }

/* ── Node popup ──────────────────────────────────────── */
.node-popup {
  position:fixed; top:50%; left:50%; transform:translate(-50%,-50%);
  background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius); padding:1.5rem; width:min(340px,90vw);
  z-index:500; box-shadow:0 8px 40px rgba(0,0,0,.7);
}
.node-popup .popup-avatar { width:90px; height:90px; border-radius:50%; display:block; margin:0 auto .75rem; }
.node-popup h3 { text-align:center; margin-bottom:.25rem; }
.node-popup .popup-meta { text-align:center; color:var(--text2); font-size:.85rem; margin-bottom:1rem; }
.popup-overlay { position:fixed; inset:0; background:rgba(0,0,0,.5); z-index:499; }
.popup-close { position:absolute; top:.75rem; right:.75rem; background:none; border:none; color:var(--text2); font-size:1.2rem; cursor:pointer; }

/* ── Updates ────────────────────────────────────────── */
.update-card {
  background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius); padding:1rem; margin-bottom:1rem;
}
.update-header { display:flex; align-items:center; gap:.6rem; margin-bottom:.75rem; }
.update-body img { width:100%; border-radius:calc(var(--radius) - 2px); margin-bottom:.5rem; }
.update-actions { display:flex; gap:.5rem; margin-top:.75rem; align-items:center; }
.update-stat { font-size:.82rem; color:var(--text2); }
.yt-embed { position:relative; padding-bottom:56.25%; height:0; overflow:hidden; border-radius:var(--radius); }
.yt-embed iframe { position:absolute; top:0; left:0; width:100%; height:100%; }

/* ── Footer ─────────────────────────────────────────── */
.site-footer {
  background:var(--bg2); border-top:1px solid var(--border);
  margin-top:2rem; padding:1rem;
}
.footer-inner { max-width:1100px; margin:0 auto; text-align:center; font-size:.85rem; color:var(--text2); }

/* ── Admin ───────────────────────────────────────────── */
.admin-grid { display:grid; grid-template-columns:220px 1fr; gap:1rem; }
.admin-sidebar {
  background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius); padding:1rem; height:fit-content;
}
.admin-sidebar a {
  display:block; padding:.45rem .75rem; border-radius:var(--radius);
  color:var(--text2); font-size:.9rem; margin-bottom:.1rem;
}
.admin-sidebar a:hover, .admin-sidebar a.active { background:var(--bg3); color:var(--text); text-decoration:none; }
.admin-main { min-width:0; }
.stat-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:.75rem; margin-bottom:1rem; }
.stat-box { background:var(--bg3); border-radius:var(--radius); padding:1rem; text-align:center; }
.stat-num { font-size:1.8rem; font-weight:700; color:var(--accent); }
.stat-label { font-size:.8rem; color:var(--text2); }

/* ── Tabs ────────────────────────────────────────────── */
.tabs { display:flex; gap:.25rem; border-bottom:1px solid var(--border); margin-bottom:1rem; }
.tab-btn {
  padding:.5rem 1rem; background:none; border:none; color:var(--text2);
  cursor:pointer; border-bottom:2px solid transparent; font-size:.9rem;
}
.tab-btn.active { color:var(--accent); border-bottom-color:var(--accent); }
.tab-panel { display:none; }
.tab-panel.active { display:block; }

/* ── Table ───────────────────────────────────────────── */
.data-table { width:100%; border-collapse:collapse; font-size:.875rem; }
.data-table th, .data-table td { padding:.55rem .75rem; border-bottom:1px solid var(--border); text-align:left; }
.data-table th { color:var(--text2); font-weight:600; }
.data-table tr:hover td { background:var(--bg3); }

/* ── Toggle ──────────────────────────────────────────── */
.toggle { display:flex; align-items:center; gap:.6rem; cursor:pointer; }
.toggle-switch {
  width:40px; height:22px; background:var(--bg3); border-radius:99px;
  position:relative; transition:background .2s; border:1px solid var(--border);
}
.toggle input { display:none; }
.toggle input:checked + .toggle-switch { background:var(--accent2); }
.toggle-switch::after {
  content:''; position:absolute; top:2px; left:2px;
  width:16px; height:16px; background:#fff; border-radius:50%;
  transition:transform .2s;
}
.toggle input:checked + .toggle-switch::after { transform:translateX(18px); }

/* ── Voucher ─────────────────────────────────────────── */
.voucher-code {
  font-family:monospace; font-size:1.1rem; letter-spacing:2px;
  background:var(--bg3); padding:.4rem .8rem; border-radius:var(--radius);
  border:1px dashed var(--border);
}

/* ── Credits ─────────────────────────────────────────── */
.credits-badge {
  background: linear-gradient(135deg,#f5a623,#e8810a);
  color:#000; font-weight:700; padding:.2rem .6rem; border-radius:99px; font-size:.8rem;
}

/* ── Page hero ───────────────────────────────────────── */
.page-hero { text-align:center; padding:2rem 1rem; }
.page-hero h1 { font-size:2rem; margin-bottom:.5rem; }
.page-hero p { color:var(--text2); max-width:520px; margin:0 auto; }

/* ── Invite banner ───────────────────────────────────── */
.invite-banner {
  background: linear-gradient(135deg,var(--bg2),var(--bg3));
  border:1px solid var(--accent); border-radius:var(--radius);
  padding:1rem; margin-bottom:1rem; display:flex; align-items:center; gap:1rem;
}
.invite-text { flex:1; font-size:.9rem; }
.invite-link { font-family:monospace; font-size:.85rem; color:var(--accent); word-break:break-all; }

/* ── Mobile ──────────────────────────────────────────── */
@media (max-width:640px) {
  .admin-grid { grid-template-columns:1fr; }
  #network-canvas { height:360px; }
  .page-hero h1 { font-size:1.5rem; }
  .row { flex-direction:column; }
}

/* ── Loading spinner ─────────────────────────────────── */
.spinner { display:inline-block; width:20px; height:20px; border:2px solid var(--border); border-top-color:var(--accent); border-radius:50%; animation:spin .7s linear infinite; }
@keyframes spin { to { transform:rotate(360deg); } }

/* ── Ad placeholders ─────────────────────────────────── */
.ad-top, .ad-footer { text-align:center; padding:.5rem; }
