:root{
  --bg:#12121e; --card:#1a1a2e; --input:#0f0f1a; --border:#2a2a45;
  --purple:#7c4dff; --purple-glow:#9c6dff; --text:#e8e8f0; --muted:#6b6b8a;
  --green:#4caf50; --red:#f44336;
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:-apple-system,"Segoe UI",Roboto,"Helvetica Neue",sans-serif;min-height:100vh;display:flex;flex-direction:column}
a{color:var(--purple-glow);text-decoration:none}
a:hover{color:var(--purple)}

.nav{display:flex;align-items:center;gap:28px;padding:16px 28px;background:#0d0d1a;border-bottom:1px solid var(--border)}
.brand{font-weight:800;font-size:20px;color:var(--text)}
.nav .menu{display:flex;align-items:center;gap:22px}
.nav .menu a{color:var(--text);font-weight:600;font-size:15px}
.nav .menu a:hover{color:var(--purple-glow)}
.nav .acct{display:flex;align-items:center;gap:16px;margin-left:auto}
.who{color:var(--muted);font-size:14px}

.wrap{flex:1;width:100%;max-width:880px;margin:0 auto;padding:40px 24px}
.foot{display:flex;justify-content:space-between;padding:18px 28px;color:var(--muted);font-size:12px;border-top:1px solid var(--border)}

.btn{display:inline-block;background:var(--purple);color:#fff;padding:11px 20px;border-radius:10px;font-weight:700;border:none;cursor:pointer;font-size:15px}
.btn:hover{background:var(--purple-glow);color:#fff}
.btn-ghost{color:var(--muted)}
.btn-block{display:block;width:100%;text-align:center}

.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:28px;margin-bottom:22px}
.card h2{font-size:18px;margin-bottom:16px}
.card h3{font-size:15px;color:var(--muted);margin-bottom:10px;font-weight:600}

.hero{text-align:center;padding:48px 0 36px}
.hero h1{font-size:40px;letter-spacing:-1px;margin-bottom:14px}
.hero p{color:var(--muted);font-size:17px;margin-bottom:28px}

label{display:block;font-size:13px;color:var(--muted);margin:14px 0 6px}
input,select,textarea{width:100%;background:var(--input);border:1px solid var(--border);border-radius:10px;padding:12px 14px;color:var(--text);font-size:15px;font-family:inherit;resize:vertical}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--purple)}
form .btn{margin-top:20px}
label.check{display:flex;align-items:center;gap:8px;color:var(--text);margin-top:16px}
label.check input{width:auto}

/* 로그인 첫 화면 */
.login-hero{max-width:400px;margin:24px auto;text-align:center}
.login-hero h1{font-size:30px;margin:6px 0 2px}
.login-card{margin-top:22px;text-align:left}
.logo-big{font-size:52px;line-height:1}

/* 페이지 헤더 */
.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.admin-tabs{display:flex;gap:6px}
.admin-tabs a{padding:7px 14px;border-radius:8px;font-size:14px;color:var(--muted)}
.admin-tabs a.active{background:var(--card);color:var(--text);border:1px solid var(--border)}

/* 통계 카드 */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.stat{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px;text-align:center}
.stat.accent{border-color:var(--purple)}
.stat-num{font-size:30px;font-weight:800;color:var(--text)}
.stat.accent .stat-num{color:var(--purple-glow)}
.stat-lbl{font-size:13px;color:var(--muted);margin-top:4px}

/* 활동 로그 구분 태그 */
.lg{font-size:12px;font-weight:700;padding:3px 10px;border-radius:20px;white-space:nowrap}
.lg-app{background:rgba(124,77,255,.18);color:var(--purple-glow)}
.lg-site{background:rgba(110,110,138,.2);color:var(--muted)}
.lg-fs{background:rgba(76,175,80,.16);color:var(--green)}
.lg-fe{background:rgba(244,67,54,.16);color:var(--red)}

/* 공지 목록 */
.notice-list{list-style:none}
.notice-list li{border-bottom:1px solid var(--border)}
.notice-list li:last-child{border-bottom:none}
.notice-list a{display:flex;align-items:center;gap:10px;padding:14px 4px;color:var(--text)}
.notice-list a:hover{color:var(--purple-glow)}
.notice-list .nt{flex:1;font-weight:600}
.notice-list .nd{font-size:13px}
.pin{color:var(--purple-glow)}
.notice-head{display:flex;align-items:baseline;justify-content:space-between;gap:14px;margin-bottom:16px;border-bottom:1px solid var(--border);padding-bottom:14px}
.notice-body{white-space:pre-wrap;line-height:1.8;color:var(--text)}

.msg{padding:11px 14px;border-radius:10px;font-size:14px;margin-bottom:14px}
.msg.ok{background:rgba(76,175,80,.12);color:var(--green);border:1px solid rgba(76,175,80,.3)}
.msg.err{background:rgba(244,67,54,.12);color:var(--red);border:1px solid rgba(244,67,54,.3)}

table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border)}
th{color:var(--muted);font-weight:600}
.tag{font-size:12px;padding:3px 9px;border-radius:20px;font-weight:700}
.tag.yes{background:rgba(76,175,80,.15);color:var(--green)}
.tag.no{background:rgba(244,67,54,.15);color:var(--red)}

.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:18px 0}
.plan{background:var(--input);border:1px solid var(--border);border-radius:12px;padding:18px;text-align:center}
.plan .price{font-size:24px;font-weight:800;margin:8px 0}
.plan .price small{font-size:13px;color:var(--muted);font-weight:400}

.pay-amount{font-size:32px;font-weight:800;color:var(--purple-glow);text-align:center;margin:8px 0}
.copyrow{display:flex;justify-content:space-between;background:var(--input);border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin:8px 0}
.copyrow b{color:var(--text)}
.note{font-size:13px;color:var(--muted);line-height:1.7;margin-top:10px}
.center{text-align:center}
.muted{color:var(--muted)}
code{background:var(--input);padding:2px 8px;border-radius:6px;font-family:ui-monospace,monospace}
