/* Swarm & Bee App — CCIR Dashboard */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#08080a;--surface:#111113;--surface-2:#18181b;--surface-3:#1e1e22;
  --border:#222225;--border-light:#2a2a2e;
  --glow:#f59e0b;--glow-dim:#b8860b;--glow-soft:rgba(245,158,11,.08);
  --green:#22c55e;--red:#ef4444;--blue:#3b82f6;
  --text:#f0f0f0;--text-2:#8a8a8e;--text-3:#55555a;
  --sidebar-w:240px;
  --font:'Inter',system-ui,-apple-system,sans-serif;
  --mono:'JetBrains Mono',monospace;
}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
::selection{background:var(--glow);color:#050505}

/* ── LAYOUT ── */
.app-layout{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:50}
.main{margin-left:var(--sidebar-w);flex:1;min-height:100vh}
.main-content{max-width:900px;padding:32px 40px}
.topbar{display:none}

/* ── SIDEBAR ── */
.sidebar-brand{padding:20px 20px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
.sidebar-logo{font-weight:700;font-size:1rem;letter-spacing:-.03em}
.sidebar-logo span{color:var(--glow)}
.sidebar-tag{font-family:var(--mono);font-size:.6rem;background:var(--glow-soft);color:var(--glow);padding:2px 6px;border-radius:3px;letter-spacing:.06em}

.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:2px}
.sidebar-nav a{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;font-size:.85rem;color:var(--text-2);transition:all .15s}
.sidebar-nav a:hover{background:var(--surface-2);color:var(--text)}
.sidebar-nav a.active{background:var(--glow-soft);color:var(--glow);font-weight:500}
.nav-icon{font-size:.9rem;width:20px;text-align:center;flex-shrink:0}

.sidebar-support{padding:12px 16px;border-top:1px solid var(--border)}
.sidebar-support a{display:block;font-size:.75rem;color:var(--glow);margin-bottom:6px;transition:color .15s}
.sidebar-support a:hover{color:#fbbf24}
.sidebar-support-links{display:flex;gap:12px}
.sidebar-support-links a{font-size:.7rem;color:var(--text-3);margin-bottom:0}.sidebar-support-links a:hover{color:var(--text)}
.sidebar-footer{padding:16px;border-top:1px solid var(--border)}
.sidebar-user{display:flex;align-items:center;gap:10px}
.user-avatar{width:32px;height:32px;background:var(--glow);color:#050505;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.82rem;flex-shrink:0}
.user-info{min-width:0}
.user-email{font-size:.75rem;color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}
.user-logout{font-size:.7rem;color:var(--text-3)}.user-logout:hover{color:var(--red)}

/* ── HEADER ── */
.page-header{margin-bottom:32px}
.page-header h1{font-size:1.5rem;font-weight:700;letter-spacing:-.03em;margin-bottom:4px}
.page-header p{font-size:.88rem;color:var(--text-2)}

/* ── CARDS ── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px;margin-bottom:16px}
.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.card-title{font-size:.92rem;font-weight:600}
.card-action{font-size:.78rem;color:var(--glow);cursor:pointer}.card-action:hover{color:#fbbf24}

/* ── STAT GRID ── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:20px}
.stat-value{font-family:var(--mono);font-size:1.5rem;font-weight:600;margin-bottom:2px}
.stat-label{font-size:.75rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em}
.stat-card.glow .stat-value{color:var(--glow)}
.stat-card.green .stat-value{color:var(--green)}
.stat-card.blue .stat-value{color:var(--blue)}

/* ── TABLE ── */
.table{width:100%;border-collapse:collapse}
.table th{text-align:left;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);padding:10px 0;border-bottom:1px solid var(--border)}
.table td{font-size:.85rem;padding:12px 0;border-bottom:1px solid var(--border);color:var(--text-2)}
.table td:first-child{color:var(--text)}
.table tr:hover td{background:var(--surface-2)}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:8px;font-family:var(--font);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s;border:none}
.btn-primary{background:var(--glow);color:#050505}.btn-primary:hover{background:#fbbf24}
.btn-sm{padding:6px 14px;font-size:.78rem;border-radius:6px}
.btn-ghost{background:transparent;color:var(--text-2);border:1px solid var(--border)}.btn-ghost:hover{color:var(--text);border-color:var(--text-3)}
.btn-danger{background:rgba(239,68,68,.1);color:var(--red);border:1px solid rgba(239,68,68,.2)}.btn-danger:hover{background:rgba(239,68,68,.2)}

/* ── FORMS ── */
.form-group{margin-bottom:16px}
.form-label{font-size:.78rem;font-weight:500;margin-bottom:6px;display:block;color:var(--text-2)}
.form-input{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:8px;font-family:var(--font);font-size:.88rem;background:var(--surface-2);color:var(--text);outline:none;transition:border-color .15s}
.form-input:focus{border-color:var(--glow)}
.form-input::placeholder{color:var(--text-3)}
.form-help{font-size:.72rem;color:var(--text-3);margin-top:4px}

/* ── KEY DISPLAY ── */
.key-display{font-family:var(--mono);font-size:.82rem;background:var(--bg);padding:12px 16px;border-radius:8px;border:1px solid var(--border);color:var(--glow);word-break:break-all;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.key-display:hover{border-color:var(--glow)}
.key-copy{font-size:.7rem;color:var(--text-3);flex-shrink:0;margin-left:12px}

/* ── BADGES ── */
.badge{font-family:var(--mono);font-size:.65rem;padding:3px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.06em}
.badge-active{background:rgba(34,197,94,.12);color:var(--green)}
.badge-trial{background:rgba(245,158,11,.12);color:var(--glow)}
.badge-expired{background:rgba(239,68,68,.12);color:var(--red)}
.badge-live{background:rgba(34,197,94,.12);color:var(--green)}

/* ── CONTACT MODAL ── */
.contact-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);z-index:200;display:none;align-items:center;justify-content:center}
.contact-overlay.show{display:flex}
.contact-box{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:32px;max-width:480px;width:90%;max-height:90vh;overflow-y:auto}

/* ── TOAST ── */
.toast{position:fixed;bottom:24px;right:24px;padding:12px 20px;border-radius:8px;font-size:.85rem;background:var(--surface);border:1px solid var(--border);color:var(--text);opacity:0;transform:translateY(10px);transition:all .3s;z-index:9999}
.toast.show{opacity:1;transform:translateY(0)}
.toast-success{border-color:var(--green);color:var(--green)}
.toast-error{border-color:var(--red);color:var(--red)}

/* ── CODE BLOCK ── */
.code-block{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:16px;font-family:var(--mono);font-size:.8rem;color:var(--text-2);overflow-x:auto;line-height:1.6;margin:12px 0}
.code-block .key{color:var(--glow)}
.code-block .str{color:var(--green)}
.code-block .comment{color:var(--text-3)}

/* ── EMPTY STATE ── */
.empty{text-align:center;padding:48px 24px;color:var(--text-3)}
.empty h3{font-size:1rem;color:var(--text-2);margin-bottom:8px}
.empty p{font-size:.85rem;margin-bottom:20px}

/* ── AUTH PAGES ── */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}
.auth-box{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:48px 40px;max-width:420px;width:90%}
.auth-logo{text-align:center;margin-bottom:24px}
.auth-logo a{font-size:1.1rem;font-weight:700;letter-spacing:-.03em}
.auth-logo a span{color:var(--glow)}
.auth-logo .auth-tag{font-family:var(--mono);font-size:.65rem;color:var(--text-3);display:block;margin-top:4px}
.auth-box h1{font-size:1.3rem;font-weight:700;text-align:center;margin-bottom:4px}
.auth-box .auth-sub{font-size:.85rem;color:var(--text-2);text-align:center;margin-bottom:28px}
.auth-error{font-size:.82rem;color:var(--red);text-align:center;margin-top:8px;min-height:1.2em}
.auth-footer{font-size:.82rem;color:var(--text-3);text-align:center;margin-top:20px}
.auth-footer a{color:var(--glow)}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .sidebar{display:none;position:fixed;width:280px;z-index:100}
  .sidebar.open{display:flex}
  .main{margin-left:0}
  .topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border);background:var(--surface)}
  .topbar-menu{background:none;border:none;color:var(--text);font-size:1.4rem;cursor:pointer}
  .topbar-logo{font-weight:700;font-size:1rem}.topbar-logo span{color:var(--glow)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .main-content{padding:20px 16px}
}
