:root {
  --bg:#0b0d11; --bg-card:#13171d; --bg-card2:#1a1f28;
  --border:#21293a; --border-light:#2d3748;
  --accent:#3d8b3d; --accent-h:#4caf50;
  --danger:#c0392b; --danger-h:#e74c3c;
  --warning:#e67e22;
  --text:#c9d1d9; --text-dim:#8b949e; --text-head:#e6edf3;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--text);font:14px/1.6 'Segoe UI',system-ui,sans-serif;min-height:100vh}
a{color:var(--accent-h);text-decoration:none}
a:hover{text-decoration:underline}

/* Nav */
.cn-nav{display:flex;align-items:center;gap:6px;padding:0 20px;height:48px;background:var(--bg-card);border-bottom:1px solid var(--border);flex-wrap:wrap}
.cn-brand{font-weight:700;font-size:15px;color:var(--text-head);margin-right:10px;letter-spacing:.5px}
.cn-link{padding:5px 12px;border-radius:4px;font-size:13px;color:var(--text-dim);transition:background .15s,color .15s}
.cn-link:hover{background:var(--bg-card2);color:var(--text-head);text-decoration:none}
.cn-login-link{background:var(--accent);color:#fff!important}
.cn-login-link:hover{background:var(--accent-h)}
.cn-user{margin-left:auto;color:var(--text-dim);font-size:13px;padding:0 8px}

/* Wrap */
.cn-wrap{max-width:960px;margin:28px auto;padding:0 16px}

/* Cards */
.cn-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:20px}
.cn-card-head{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.cn-card-head h2{font-size:15px;font-weight:600;color:var(--text-head)}
.cn-card-body{padding:20px}

/* Table */
.cn-table{width:100%;border-collapse:collapse;font-size:13px}
.cn-table th{text-align:left;padding:8px 12px;color:var(--text-dim);border-bottom:1px solid var(--border);font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.5px}
.cn-table td{padding:9px 12px;border-bottom:1px solid var(--border);vertical-align:middle}
.cn-table tr:last-child td{border-bottom:none}
.cn-table tr:hover td{background:var(--bg-card2)}

/* Badge */
.badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}
.badge-leader{background:#2d4739;color:#7ed8a0}
.badge-member{background:#1e2a3a;color:#7abaed}
.badge-applicant{background:#3a2a1e;color:#edba7a}

/* Buttons */
.btn{display:inline-block;padding:5px 14px;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;border:none;transition:background .15s;text-align:center}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-h);text-decoration:none;color:#fff}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{background:var(--danger-h);text-decoration:none;color:#fff}
.btn-secondary{background:var(--bg-card2);color:var(--text);border:1px solid var(--border-light)}
.btn-secondary:hover{background:var(--border);text-decoration:none;color:var(--text-head)}
.btn-sm{padding:3px 10px;font-size:11px}

/* Forms */
.cn-form label{display:block;margin-bottom:4px;color:var(--text-dim);font-size:12px;font-weight:500}
.cn-form input[type=text],.cn-form input[type=password],.cn-form input[type=number],.cn-form textarea,.cn-form select{width:100%;padding:8px 10px;background:var(--bg-card2);border:1px solid var(--border-light);border-radius:4px;color:var(--text);font-size:13px;outline:none}
.cn-form input:focus,.cn-form textarea:focus,.cn-form select:focus{border-color:var(--accent)}
.cn-form .row{margin-bottom:14px}
.cn-form .hint{font-size:11px;color:var(--text-dim);margin-top:3px}

/* Flash */
.cn-flash{padding:10px 16px;border-radius:5px;margin-bottom:16px;font-size:13px}
.cn-flash.error{background:#2d1a1a;border:1px solid var(--danger);color:#f5a0a0}
.cn-flash.success{background:#1a2d1a;border:1px solid var(--accent);color:#a0f5a0}
.cn-flash.info{background:#1a1e2d;border:1px solid #3a6ea8;color:#a0c8f5}

/* Login modal card */
.login-card{max-width:380px;margin:60px auto}

/* Clan tag chip */
.cn-tag{display:inline-block;padding:1px 8px;background:var(--bg-card2);border:1px solid var(--border-light);border-radius:4px;font-size:12px;color:var(--text-dim);font-family:monospace}

/* Empty state */
.cn-empty{padding:32px;text-align:center;color:var(--text-dim);font-size:13px}

/* Clan description */
.cn-desc{color:var(--text-dim);font-size:13px;line-height:1.7;white-space:pre-wrap}

/* Section heading */
.cn-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-dim);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}

/* Confirm dialog overlay */
.cn-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:100;align-items:center;justify-content:center}
.cn-overlay.open{display:flex}
.cn-dialog{background:var(--bg-card);border:1px solid var(--border-light);border-radius:8px;padding:28px;min-width:320px;max-width:420px}
.cn-dialog h3{color:var(--text-head);font-size:15px;margin-bottom:10px}
.cn-dialog p{color:var(--text-dim);font-size:13px;margin-bottom:20px}
.cn-dialog-btns{display:flex;gap:8px;justify-content:flex-end}
