
:root {
  --bg: #060608;
  --bg2: #0d0d12;
  --card: rgba(255,255,255,0.04);
  --card-hover: rgba(255,255,255,0.07);
  --solid: #111116;
  --amber: #f59e0b;
  --amber2: #fbbf24;
  --amber-dim: rgba(245,158,11,0.12);
  --amber-glow: rgba(245,158,11,0.25);
  --red: #f43f5e;
  --red-dim: rgba(244,63,94,0.12);
  --green: #10b981;
  --green-dim: rgba(16,185,129,0.12);
  --purple: #8b5cf6;
  --text: #f8fafc;
  --text2: #94a3b8;
  --text3: #475569;
  --border: rgba(255,255,255,0.06);
  --border2: rgba(255,255,255,0.12);
  --grad: linear-gradient(135deg,#f59e0b,#f97316);
  --grad-soft: linear-gradient(135deg,rgba(245,158,11,0.15),rgba(249,115,22,0.08));
  --r4: 4px; --r8: 8px; --r12: 12px; --r16: 16px; --r20: 20px; --r999: 999px;
  --shadow: 0 4px 24px rgba(0,0,0,0.4);
  --shadow-lg: 0 8px 40px rgba(0,0,0,0.5);
  --shadow-amber: 0 4px 20px rgba(245,158,11,0.2);
  --blur: blur(20px) saturate(160%);
  --fret-metal: #6a6880;
  --wood: #1e1810; --wood-dark: #0e0a06;
  --nut: #c8b890; --string1: #d8d0a8; --string6: #908050;
}

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

body {
  background:var(--bg);
  color:var(--text);
  font-family:'DM Mono','Space Mono',monospace;
  min-height:100vh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:20px;
  overflow-x:hidden;
}

/* 배경 오로라 */
body::before {
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse 80% 50% at 15% 5%,rgba(139,92,246,0.06) 0%,transparent 55%),
    radial-gradient(ellipse 60% 40% at 85% 95%,rgba(245,158,11,0.05) 0%,transparent 55%),
    radial-gradient(ellipse 50% 60% at 50% 50%,rgba(6,182,212,0.02) 0%,transparent 65%);
}

.screen{display:none;flex-direction:column;align-items:center;width:100%;max-width:820px;position:relative;z-index:1;}
.screen.active{display:flex;animation:up .38s cubic-bezier(.22,1,.36,1);}
@keyframes up{from{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:none}}

/* ── 타이포 ── */
.logo{font-family:'Bebas Neue',sans-serif;font-size:clamp(3rem,9vw,5.5rem);letter-spacing:.18em;line-height:.92;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center;filter:drop-shadow(0 0 40px rgba(245,158,11,.25));}
.logo-sub{font-family:'Bebas Neue',sans-serif;font-size:clamp(1rem,3vw,1.4rem);letter-spacing:.35em;color:var(--text2);margin-top:4px;text-align:center;}
h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(1.6rem,5vw,2.4rem);letter-spacing:.12em;color:var(--text);margin-bottom:6px;}
.sub{font-size:.7rem;color:var(--text2);letter-spacing:.12em;text-transform:uppercase;margin-bottom:24px;}
.divider{width:40px;height:2px;background:var(--grad);border-radius:2px;opacity:.5;margin:18px auto;}

/* ── 입력 ── */
.text-input{
  background:rgba(255,255,255,.05);border:1px solid var(--border2);border-radius:var(--r12);
  color:var(--text);font-family:'DM Mono','Space Mono',monospace;font-size:1.1rem;
  padding:14px 20px;width:280px;text-align:center;outline:none;
  transition:all .2s;letter-spacing:.06em;backdrop-filter:blur(10px);
}
.text-input:focus{border-color:var(--amber);box-shadow:0 0 0 3px var(--amber-dim),var(--shadow-amber);}
.text-input.error{border-color:var(--red);box-shadow:0 0 0 3px var(--red-dim);}

/* ── 버튼 ── */
.btn{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r8);
  color:var(--text2);font-family:'Bebas Neue',sans-serif;font-size:1.1rem;letter-spacing:.12em;
  padding:11px 26px;cursor:pointer;transition:all .2s;backdrop-filter:blur(8px);
}
.btn:hover{border-color:var(--amber);color:var(--amber);background:var(--amber-dim);transform:translateY(-1px);}
.btn.selected{border-color:transparent;color:#000;background:var(--grad);box-shadow:var(--shadow-amber);}

.btn-cta{
  background:var(--grad);border:none;border-radius:var(--r12);color:#000;
  font-family:'Bebas Neue',sans-serif;font-size:1.4rem;letter-spacing:.18em;
  padding:15px 52px;cursor:pointer;transition:all .2s;margin-top:18px;
  box-shadow:0 4px 24px rgba(245,158,11,.35);position:relative;overflow:hidden;
}
.btn-cta::after{content:'';position:absolute;inset:0;background:linear-gradient(rgba(255,255,255,.15),transparent);border-radius:inherit;}
.btn-cta:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(245,158,11,.45);}
.btn-cta:active{transform:none;}

.btn-ghost{
  background:transparent;border:1px solid var(--border);border-radius:var(--r8);
  color:var(--text2);font-family:'DM Mono','Space Mono',monospace;font-size:.72rem;
  letter-spacing:.1em;padding:8px 20px;cursor:pointer;transition:all .2s;margin-top:10px;
}
.btn-ghost:hover{border-color:var(--border2);color:var(--text);background:var(--card);}
.btn-group{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;}

/* ── 모드 카드 ── */
.mode-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r20);
  color:var(--text2);padding:32px 36px;width:220px;cursor:pointer;
  transition:all .3s cubic-bezier(.22,1,.36,1);text-align:center;
  backdrop-filter:var(--blur);position:relative;overflow:hidden;
}
.mode-card::before{content:'';position:absolute;inset:0;background:var(--grad-soft);opacity:0;transition:opacity .3s;border-radius:inherit;}
.mode-card:hover{border-color:rgba(245,158,11,.4);color:var(--amber);transform:translateY(-5px);box-shadow:var(--shadow-amber),var(--shadow-lg);}
.mode-card:hover::before{opacity:1;}
.mode-card .mode-icon{font-family:'Bebas Neue',sans-serif;font-size:3rem;letter-spacing:.1em;display:block;line-height:1;}
.mode-card .mode-title{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;letter-spacing:.12em;margin-top:10px;}
.mode-card .mode-desc{font-size:.82rem;letter-spacing:.04em;margin-top:8px;line-height:1.8;font-family:'DM Mono','Space Mono',monospace;color:var(--text2);}

/* ── 줄 버튼 ── */
.string-btn{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r8);
  color:var(--text2);font-family:'DM Mono','Space Mono',monospace;font-size:.78rem;font-weight:700;
  padding:12px 16px;cursor:pointer;transition:all .2s;white-space:nowrap;
}
.string-btn:hover{border-color:rgba(245,158,11,.4);color:var(--amber);transform:translateY(-1px);}
.string-btn.selected{border-color:transparent;color:#000;background:var(--grad);box-shadow:0 2px 14px rgba(245,158,11,.3);}

/* ── 스탯바 ── */
.stats-bar{
  display:flex;width:100%;
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-radius:var(--r12) var(--r12) 0 0;
  overflow:hidden;backdrop-filter:var(--blur);
}
.stat-cell{flex:1;padding:12px 6px 10px;text-align:center;border-right:1px solid var(--border);}
.stat-cell:last-child{border-right:none;}
.stat-label{font-size:.6rem;letter-spacing:.1em;color:var(--text2);text-transform:uppercase;}
.stat-value{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;color:var(--amber);letter-spacing:.05em;line-height:1.1;}

/* ── 도트/타이머 ── */
.q-dots{display:flex;gap:8px;justify-content:center;padding:12px 0 8px;}
.q-dot{width:9px;height:9px;border-radius:50%;background:var(--border2);transition:all .25s;}
.q-dot.ok{background:var(--green);box-shadow:0 0 8px rgba(16,185,129,.5);}
.q-dot.ng{background:var(--red);box-shadow:0 0 8px rgba(244,63,94,.5);}
.q-dot.cur{background:var(--amber);animation:blink 1s infinite;box-shadow:0 0 8px var(--amber-glow);}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}

.timer-track{width:100%;height:3px;background:rgba(255,255,255,.05);}
.timer-fill{height:100%;background:var(--grad);transition:width .12s linear,background .4s;border-radius:0 2px 2px 0;}

/* ── 프렛보드 ── */
.fretboard-wrap{
  width:100%;background:var(--wood-dark);
  border:1px solid rgba(255,255,255,.05);border-top:none;
  padding:14px 8px 32px;
  box-shadow:0 16px 48px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.03);
  position:relative;border-radius:0 0 var(--r16) var(--r16);
}
.string-info{font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:.18em;color:var(--text2);text-align:center;margin-bottom:8px;}
#fb-svg{width:100%;height:auto;display:block;}
.fret-label{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;letter-spacing:.18em;color:var(--amber);text-align:center;margin-top:8px;padding:10px 0;border-top:1px solid var(--border);min-height:46px;}
.note-section{width:100%;display:flex;flex-direction:column;gap:10px;padding:18px 0 16px;}
.note-row{display:flex;gap:5px;justify-content:center;}
.note-row-label{font-size:.55rem;color:var(--text2);letter-spacing:.1em;text-transform:uppercase;text-align:center;margin-bottom:2px;}

/* ── 노트 버튼 ── */
.note-btn{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r8);
  color:var(--text);font-family:'DM Mono','Space Mono',monospace;font-size:1.1rem;font-weight:700;
  width:78px;padding:15px 2px;cursor:pointer;text-align:center;transition:all .15s;
  line-height:1.3;white-space:nowrap;
}
.note-btn.sharp{font-size:.9rem;color:var(--text2);background:var(--card);border-style:dashed;}
.note-btn:hover:not(:disabled){border-color:rgba(245,158,11,.5);color:var(--amber);background:var(--amber-dim);transform:translateY(-2px);box-shadow:0 4px 16px rgba(245,158,11,.15);}
.note-btn:disabled{cursor:default;}
.note-btn.ok{background:var(--green-dim);border-color:var(--green);color:#6ee7b7;animation:pop .3s ease;box-shadow:0 0 20px rgba(16,185,129,.2);}
.note-btn.ng{background:var(--red-dim);border-color:var(--red);color:#fda4af;animation:shake .28s ease;}
@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.1) translateY(-2px)}100%{transform:scale(1)}}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-6px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}

.btn-hint{background:transparent;border:1px dashed var(--text3);border-radius:var(--r8);color:var(--text2);font-family:'DM Mono','Space Mono',monospace;font-size:.65rem;letter-spacing:.08em;padding:6px 14px;cursor:pointer;transition:all .18s;white-space:nowrap;}
.btn-hint:hover{border-color:var(--amber);color:var(--amber);}
.btn-hint.counting{color:var(--red);border-color:var(--red);cursor:default;}
.feedback{min-height:28px;text-align:center;margin:4px 0;font-family:'Bebas Neue',sans-serif;font-size:1.4rem;letter-spacing:.1em;opacity:0;transition:opacity .2s;}
.feedback.show{opacity:1;}

/* ── 랭크 뱃지 ── */
.rank-badge{font-family:'Bebas Neue',sans-serif;font-size:2rem;letter-spacing:.2em;padding:14px 42px;border:2px solid;margin:16px 0;border-radius:var(--r12);}
.rank-pro{border-color:#fbbf24;color:#fbbf24;background:rgba(251,191,36,.06);box-shadow:0 0 28px rgba(251,191,36,.12);}
.rank-mid{border-color:var(--purple);color:#c4b5fd;background:rgba(139,92,246,.06);}
.rank-beg{border-color:var(--text3);color:var(--text2);background:rgba(71,85,105,.06);}
.rank-nope{border-color:var(--red);color:#fda4af;background:var(--red-dim);}

/* ── 오답 ── */
.wrong-note-section{width:100%;max-width:500px;background:var(--card);border:1px solid var(--border);border-radius:var(--r16);padding:20px;margin:10px 0;backdrop-filter:var(--blur);}
.wn-header{font-family:'Bebas Neue',sans-serif;font-size:1.1rem;letter-spacing:.18em;color:var(--red);margin-bottom:14px;text-align:center;}
.wn-cols{display:flex;gap:24px;}
.wn-col{flex:1;}
.wn-title{font-family:'Bebas Neue',sans-serif;font-size:.9rem;letter-spacing:.14em;color:var(--text2);margin-bottom:8px;border-bottom:1px solid var(--border);padding-bottom:4px;}
.wn-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;}
.wn-note{font-family:'DM Mono','Space Mono',monospace;font-size:.72rem;font-weight:700;color:var(--red);width:58px;flex-shrink:0;}
.wn-bar{flex:1;height:5px;background:rgba(255,255,255,.06);border-radius:3px;overflow:hidden;}
.wn-fill{display:block;height:100%;background:linear-gradient(90deg,var(--red),#fb7185);transition:width .5s ease;border-radius:3px;}
.wn-cnt{font-family:'DM Mono','Space Mono',monospace;font-size:.62rem;color:var(--text2);width:26px;text-align:right;flex-shrink:0;}

/* ── 결과 ── */
.result-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;width:100%;max-width:420px;margin:14px 0;}
.result-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r16);padding:22px 10px;text-align:center;backdrop-filter:var(--blur);transition:transform .2s;}
.result-card:hover{transform:translateY(-2px);}
.result-big{font-family:'Bebas Neue',sans-serif;font-size:2.2rem;color:var(--amber);line-height:1;}
.result-lbl{font-size:.72rem;color:var(--text2);letter-spacing:.1em;text-transform:uppercase;margin-top:6px;}

@media(max-width:580px){
  .note-btn{width:80px;font-size:1rem;padding:14px 2px;}
  .mode-card{width:155px;padding:22px 14px;}
  .stat-value{font-size:1.3rem;}
}

/* ── 공지 ── */
.notice-btn{position:fixed;top:14px;right:16px;background:var(--card);border:1px solid var(--border);border-radius:var(--r8);color:var(--text2);font-family:'Bebas Neue',sans-serif;font-size:.9rem;letter-spacing:.12em;padding:7px 16px;cursor:pointer;z-index:500;transition:all .2s;backdrop-filter:blur(10px);}
.notice-btn:hover{border-color:rgba(245,158,11,.4);color:var(--amber);}
.notice-btn .badge{display:inline-block;background:var(--red);color:#fff;font-family:'DM Mono','Space Mono',monospace;font-size:.55rem;border-radius:50%;width:14px;height:14px;line-height:14px;text-align:center;margin-left:4px;vertical-align:middle;}
.notice-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);z-index:1000;align-items:flex-start;justify-content:center;padding-top:60px;}
.notice-modal.open{display:flex;animation:up .3s ease;}
.notice-box{background:var(--surface-solid);border:1px solid var(--border);border-radius:var(--r20);width:90%;max-width:480px;max-height:70vh;overflow-y:auto;padding:28px 24px;box-shadow:var(--shadow-lg);}
.notice-header{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;letter-spacing:.15em;color:var(--amber);margin-bottom:16px;border-bottom:1px solid var(--border);padding-bottom:10px;display:flex;justify-content:space-between;align-items:center;}
.notice-close{background:transparent;border:none;color:var(--text2);font-size:1.2rem;cursor:pointer;transition:color .15s;}
.notice-close:hover{color:var(--text);}
.notice-item{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border);}
.notice-item:last-child{border-bottom:none;margin-bottom:0;}
.notice-version{font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:.12em;color:var(--amber);}
.notice-date{font-size:.6rem;color:var(--text2);letter-spacing:.08em;margin-left:8px;}
.notice-content{font-size:.72rem;color:var(--text);line-height:1.9;margin-top:8px;letter-spacing:.04em;}

/* ── 시즌 배지 ── */
.season-badge{display:inline-block;background:var(--grad);color:#000;font-family:'Bebas Neue',sans-serif;font-size:.7rem;letter-spacing:.12em;padding:3px 10px;margin-bottom:6px;border-radius:var(--r4);}
.season-end-bar{background:var(--card);border:1px solid var(--border);border-left:3px solid var(--amber);border-radius:0 var(--r8) var(--r8) 0;padding:10px 14px;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between;}
.season-end-lbl{font-size:.6rem;color:var(--text2);letter-spacing:.1em;}
.season-end-val{font-family:'Bebas Neue',sans-serif;font-size:1.1rem;color:var(--amber);letter-spacing:.08em;}
.season-reward-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.88);backdrop-filter:blur(12px);z-index:2000;align-items:center;justify-content:center;}
.season-reward-modal.open{display:flex;animation:up .4s ease;}
.season-reward-box{background:rgba(13,13,18,.98);border:1px solid rgba(245,158,11,.3);border-radius:var(--r20);width:88%;max-width:380px;padding:40px 28px;text-align:center;box-shadow:var(--shadow-amber),var(--shadow-lg);}
.season-reward-title{font-family:'Bebas Neue',sans-serif;font-size:2rem;letter-spacing:.18em;color:var(--amber);margin-bottom:4px;}
.season-reward-sub{font-size:.65rem;color:var(--text2);letter-spacing:.1em;margin-bottom:20px;}
.season-reward-rank{font-family:'Bebas Neue',sans-serif;font-size:3.5rem;color:var(--text);letter-spacing:.05em;line-height:1;}
.season-reward-pts{font-family:'Bebas Neue',sans-serif;font-size:2.2rem;color:var(--amber);letter-spacing:.08em;margin:8px 0 20px;}
.season-reward-btn{background:var(--grad);border:none;border-radius:var(--r8);color:#000;font-family:'Bebas Neue',sans-serif;font-size:1.1rem;letter-spacing:.18em;padding:13px 36px;cursor:pointer;box-shadow:var(--shadow-amber);transition:all .2s;}
.season-reward-btn:hover{transform:translateY(-1px);}

/* ── 메뉴 ── */
.menu-btn{position:fixed;top:14px;left:16px;background:var(--card);border:1px solid var(--border);border-radius:var(--r8);color:var(--text2);width:40px;height:40px;cursor:pointer;z-index:500;transition:all .2s;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px);}
.menu-btn:hover{border-color:rgba(245,158,11,.4);color:var(--amber);}
.menu-drawer{display:none;position:fixed;inset:0;z-index:900;}
.menu-drawer.open{display:block;}
.menu-overlay{position:absolute;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);}
.menu-panel{position:absolute;left:0;top:0;bottom:0;width:268px;background:var(--surface-solid);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:0;animation:slideIn .25s cubic-bezier(.22,1,.36,1);overflow:hidden;}
@keyframes slideIn{from{transform:translateX(-100%)}to{transform:none}}
.menu-title{font-family:'Bebas Neue',sans-serif;font-size:1.4rem;letter-spacing:.18em;color:var(--amber);padding:18px 22px;border-bottom:1px solid var(--border);}
.menu-item{display:flex;align-items:center;gap:14px;padding:14px 22px;cursor:pointer;transition:all .15s;border:none;background:transparent;width:100%;text-align:left;color:var(--text2);font-family:'DM Mono','Space Mono',monospace;font-size:.78rem;letter-spacing:.06em;}
.menu-item:hover{background:var(--amber-dim);color:var(--amber);padding-left:26px;}
.menu-item-icon{font-size:1.1rem;width:22px;text-align:center;opacity:.8;}
.menu-item-badge{margin-left:auto;background:var(--red);color:#fff;font-size:.55rem;border-radius:var(--r999);padding:2px 7px;}
.menu-sub{padding-left:44px !important;font-size:.72rem !important;background:rgba(255,255,255,.02);}
.menu-toggle-arrow{margin-left:auto;transition:transform .2s;display:inline-block;font-size:1rem;}
.menu-toggle-arrow.open{transform:rotate(90deg);}
.menu-group{overflow:hidden;}

/* ── 메뉴 프로필 ── */
.menu-profile-header{display:flex;align-items:center;gap:12px;padding:18px 20px;border-bottom:1px solid var(--border);cursor:pointer;transition:all .15s;}
.menu-profile-header:hover{background:var(--amber-dim);}
.menu-avatar{width:44px;height:44px;border-radius:50%;border:2px solid var(--amber);background:var(--solid);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;box-shadow:0 0 14px var(--amber-dim);}
.menu-profile-info{flex:1;min-width:0;}
.menu-profile-name{font-family:'Bebas Neue',sans-serif;font-size:1.1rem;letter-spacing:.1em;color:var(--text);line-height:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.menu-profile-title{font-size:.58rem;color:var(--amber);letter-spacing:.06em;margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.menu-profile-pts{font-family:'Bebas Neue',sans-serif;font-size:.85rem;color:var(--text2);letter-spacing:.08em;margin-top:1px;}

/* ── 포인트 ── */
.points-display{position:fixed;top:14px;left:66px;background:var(--card);border:1px solid var(--border);border-radius:var(--r8);color:var(--amber);font-family:'Bebas Neue',sans-serif;font-size:.95rem;letter-spacing:.1em;padding:7px 14px;z-index:500;pointer-events:none;backdrop-filter:blur(10px);}
.streak-display{position:fixed;top:14px;left:160px;background:var(--card);border:1px solid var(--border);border-radius:var(--r8);color:var(--text2);font-family:'Bebas Neue',sans-serif;font-size:.95rem;letter-spacing:.1em;padding:7px 14px;z-index:500;pointer-events:none;backdrop-filter:blur(10px);}
.point-toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:var(--grad);color:#000;font-family:'Bebas Neue',sans-serif;font-size:1.1rem;letter-spacing:.15em;padding:11px 28px;border-radius:var(--r999);z-index:9999;opacity:0;transition:opacity .3s;pointer-events:none;box-shadow:0 4px 24px rgba(245,158,11,.4);}
.point-toast.show{opacity:1;}

/* ── 출석 ── */
.attend-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);z-index:1100;align-items:center;justify-content:center;}
.attend-modal.open{display:flex;animation:up .3s ease;}
.attend-box{background:var(--surface-solid);border:1px solid var(--border);border-radius:var(--r20);width:90%;max-width:400px;padding:28px 22px;box-shadow:var(--shadow-lg);}
.attend-header{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;letter-spacing:.15em;color:var(--amber);margin-bottom:6px;display:flex;justify-content:space-between;align-items:center;}
.attend-streak{font-family:'Bebas Neue',sans-serif;font-size:3rem;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center;line-height:1;margin:16px 0 4px;}
.attend-streak-label{font-size:.82rem;color:var(--text2);letter-spacing:.1em;text-align:center;margin-bottom:20px;}
.attend-calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:16px;}
.attend-cal-header{text-align:center;font-family:'DM Mono','Space Mono',monospace;font-size:.7rem;color:var(--text2);padding:2px 0 6px;letter-spacing:.04em;}
.attend-cal-month{font-family:'Bebas Neue',sans-serif;font-size:1.1rem;letter-spacing:.12em;color:var(--text2);text-align:center;margin-bottom:8px;}
.attend-day{aspect-ratio:1;border-radius:var(--r8);display:flex;align-items:center;justify-content:center;font-family:'DM Mono','Space Mono',monospace;font-size:.68rem;color:var(--text2);background:var(--card);border:1px solid var(--border);transition:all .15s;}
.attend-day.empty{background:transparent;border-color:transparent;}
.attend-day.done{background:var(--green-dim);border-color:rgba(16,185,129,.35);color:#6ee7b7;}
.attend-day.today{border-color:rgba(245,158,11,.5);color:var(--amber);box-shadow:0 0 10px var(--amber-dim);}
.attend-day.today.done{background:var(--amber-dim);border-color:rgba(245,158,11,.5);color:var(--amber2);}
.attend-rewards{display:flex;gap:8px;margin-bottom:20px;}
.attend-reward{flex:1;background:var(--card);border:1px solid var(--border);border-radius:var(--r12);padding:14px 8px;text-align:center;transition:all .2s;}
.attend-reward.unlocked{border-color:rgba(16,185,129,.4);background:var(--green-dim);box-shadow:0 0 14px rgba(16,185,129,.1);}
.attend-reward-pts{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;color:var(--amber);letter-spacing:.1em;line-height:1;}
.attend-reward-cond{font-size:.72rem;color:var(--text2);margin-top:5px;letter-spacing:.06em;line-height:1.5;}
.attend-reward.unlocked .attend-reward-cond{color:var(--green);}
.attend-check-btn{width:100%;background:var(--grad);border:none;border-radius:var(--r12);color:#000;font-family:'Bebas Neue',sans-serif;font-size:1.3rem;letter-spacing:.18em;padding:14px;cursor:pointer;transition:all .2s;box-shadow:0 4px 20px rgba(245,158,11,.3);}
.attend-check-btn:disabled{background:rgba(255,255,255,.08);color:var(--text2);cursor:default;box-shadow:none;}
.attend-check-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 24px rgba(245,158,11,.4);}

/* ── 상점 ── */
.shop-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);z-index:1100;align-items:flex-start;justify-content:center;padding-top:50px;}
.shop-modal.open{display:flex;animation:up .3s ease;}
.shop-box{background:var(--surface-solid);border:1px solid var(--border);border-radius:var(--r20);width:92%;max-width:500px;max-height:75vh;overflow-y:auto;padding:24px 20px;box-shadow:var(--shadow-lg);}
.shop-header{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;letter-spacing:.15em;color:var(--amber);margin-bottom:4px;display:flex;justify-content:space-between;align-items:center;}
.shop-balance{font-family:'DM Mono','Space Mono',monospace;font-size:.72rem;color:var(--text2);margin-bottom:16px;letter-spacing:.06em;}
.shop-balance span{color:var(--amber);font-weight:700;}
.shop-tabs{display:flex;gap:6px;margin-bottom:16px;border-bottom:1px solid var(--border);padding-bottom:12px;flex-wrap:wrap;}
.shop-tab{background:transparent;border:1px solid var(--border);border-radius:var(--r999);color:var(--text2);font-family:'DM Mono','Space Mono',monospace;font-size:.65rem;letter-spacing:.08em;padding:6px 16px;cursor:pointer;transition:all .15s;}
.shop-tab.active{border-color:transparent;color:#000;background:var(--grad);}
.shop-tab:hover:not(.active){border-color:var(--border2);color:var(--text);}
.shop-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.shop-item{background:var(--card);border:1px solid var(--border);border-radius:var(--r16);padding:16px 10px;text-align:center;transition:all .2s;}
.shop-item:hover{transform:translateY(-2px);box-shadow:var(--shadow);}
.shop-item.owned{border-color:rgba(16,185,129,.35);}
.shop-item.equipped{border-color:rgba(245,158,11,.4);background:var(--amber-dim);box-shadow:var(--shadow-amber);}
.shop-item-preview{margin-bottom:8px;line-height:1;display:flex;justify-content:center;align-items:center;}
.shop-item-name{font-family:'Bebas Neue',sans-serif;font-size:.9rem;letter-spacing:.1em;color:var(--text);margin-bottom:4px;}
.shop-item-price{font-family:'DM Mono','Space Mono',monospace;font-size:.65rem;color:var(--amber);margin-bottom:8px;}
.shop-item-btn{width:100%;background:var(--grad);border:none;border-radius:var(--r8);color:#000;font-family:'Bebas Neue',sans-serif;font-size:.85rem;letter-spacing:.1em;padding:8px;cursor:pointer;transition:all .15s;box-shadow:0 2px 12px rgba(245,158,11,.2);}
.shop-item-btn:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(245,158,11,.3);}
.shop-item-btn.owned-btn{background:linear-gradient(135deg,var(--green),#059669);color:#fff;}
.shop-item-btn.equipped-btn{background:transparent;color:var(--amber);border:1px solid rgba(245,158,11,.4);box-shadow:none;}
.gtype-btn{background:transparent;border:1px solid var(--border);border-radius:var(--r999);color:var(--text2);font-family:'Bebas Neue',sans-serif;font-size:.85rem;letter-spacing:.1em;padding:5px 14px;cursor:pointer;transition:all .15s;}
.gtype-btn:hover{border-color:rgba(245,158,11,.4);color:var(--amber);}
.gtype-btn.active{background:var(--grad);border-color:transparent;color:#000;}
.prof-toggle-btn{width:100%;background:var(--card);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--r8) var(--r8);color:var(--text2);font-family:'DM Mono','Space Mono',monospace;font-size:.82rem;letter-spacing:.08em;padding:10px 12px;cursor:pointer;transition:all .15s;display:flex;align-items:center;}
.prof-toggle-btn:hover{color:var(--amber);}
.prof-toggle-arrow{margin-left:auto;transition:transform .2s;display:inline-block;}
.prof-toggle-arrow.open{transform:rotate(90deg);}

/* ── 업적 ── */
.ach-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r12);padding:12px 10px 10px;display:flex;flex-direction:column;gap:4px;transition:all .2s;}
.ach-card:hover{transform:translateY(-1px);box-shadow:var(--shadow);}
.ach-card.unlocked{border-color:rgba(245,158,11,.4);background:var(--amber-dim);box-shadow:var(--shadow-amber);}
.ach-card.locked{opacity:.35;}
.ach-top{display:flex;align-items:center;gap:7px;}
.ach-icon{font-size:1.4rem;line-height:1;flex-shrink:0;}
.ach-name{font-family:'Bebas Neue',sans-serif;font-size:.95rem;letter-spacing:.1em;color:var(--text);line-height:1.2;}
.ach-card.unlocked .ach-name{color:var(--amber);}
.ach-desc{font-family:'DM Mono','Space Mono',monospace;font-size:.58rem;color:var(--text2);letter-spacing:.04em;line-height:1.5;}
.ach-reward{font-family:'Bebas Neue',sans-serif;font-size:.78rem;color:var(--green);letter-spacing:.08em;margin-top:2px;}
.ach-card.unlocked .ach-reward{color:var(--amber);}

/* ── 프로필 ── */
.profile-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(10px);z-index:1100;align-items:flex-start;justify-content:center;padding:12px 0;overflow-y:auto;}
.profile-modal.open{display:flex;animation:up .3s ease;}
.profile-box{background:var(--surface-solid);border:1px solid var(--border);border-radius:var(--r20);width:92%;max-width:420px;overflow:hidden;margin:auto;box-shadow:var(--shadow-lg);}
.profile-banner{width:100%;height:72px;position:relative;display:flex;align-items:flex-end;padding:0 18px;background:linear-gradient(135deg,rgba(139,92,246,.2),var(--amber-dim));border-bottom:1px solid var(--border);}
.profile-banner-glow{position:absolute;inset:0;opacity:.35;background:radial-gradient(ellipse 80% 100% at 50% 0%,rgba(245,158,11,.3) 0%,transparent 70%);pointer-events:none;}
.profile-avatar{width:54px;height:54px;border-radius:50%;background:var(--solid);border:2px solid var(--amber);display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:1.4rem;color:var(--amber);transform:translateY(26px);flex-shrink:0;box-shadow:0 0 24px var(--amber-glow);position:relative;z-index:1;overflow:hidden;}
.profile-header-close{position:absolute;top:10px;right:12px;background:rgba(255,255,255,.08);border:1px solid var(--border);border-radius:50%;color:var(--text);font-size:.9rem;cursor:pointer;z-index:2;width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:all .15s;}
.profile-header-close:hover{background:rgba(255,255,255,.15);color:var(--amber);}
.profile-body{padding:32px 18px 18px;position:relative;}
.profile-name{font-family:'Bebas Neue',sans-serif;font-size:2rem;letter-spacing:.12em;color:var(--text);line-height:1;}
.profile-title-badge{display:inline-block;margin-top:6px;}
.profile-divider{width:100%;height:1px;background:var(--border);margin:14px 0;}
.profile-section-label{font-family:'Bebas Neue',sans-serif;font-size:.9rem;letter-spacing:.2em;color:var(--text2);margin-bottom:8px;text-transform:uppercase;}
.profile-equip-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:5px;}
.profile-equip-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r8);padding:6px 3px;display:flex;flex-direction:column;align-items:center;gap:3px;overflow:hidden;transition:all .15s;}
.profile-equip-card:hover{border-color:var(--border2);}
.profile-equip-label{font-size:.6rem;letter-spacing:.04em;color:var(--text2);text-transform:uppercase;}
.profile-equip-name{font-family:'Bebas Neue',sans-serif;font-size:.7rem;letter-spacing:.05em;color:var(--text);text-align:center;line-height:1.2;word-break:break-all;}
.profile-equip-card svg{max-width:100%;height:auto;display:block;}
.profile-points-row{display:flex;align-items:center;justify-content:space-between;margin-top:8px;}
.profile-points-val{font-family:'Bebas Neue',sans-serif;font-size:2.2rem;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.08em;line-height:1;}
.profile-points-label{font-size:.82rem;color:var(--text2);letter-spacing:.1em;text-transform:uppercase;margin-top:2px;}
.profile-streak-val{font-family:'Bebas Neue',sans-serif;font-size:2.2rem;color:var(--text);letter-spacing:.08em;line-height:1;text-align:right;}

/* ── 프로필 인삿말/경력 ── */
.prof-bio-section{margin-bottom:4px;}
.prof-bio-label{font-size:.6rem;color:var(--text2);letter-spacing:.1em;text-transform:uppercase;margin-bottom:3px;}
.prof-bio-input{width:100%;background:var(--card);border:1px solid var(--border);border-radius:var(--r8);color:var(--text);font-family:'DM Mono','Space Mono',monospace;font-size:.75rem;padding:8px 12px;outline:none;letter-spacing:.04em;resize:none;transition:all .2s;}
.prof-bio-input:focus{border-color:rgba(245,158,11,.5);box-shadow:0 0 0 2px var(--amber-dim);}
.prof-career-row{display:flex;align-items:center;gap:8px;}
.prof-career-input{width:60px;background:var(--card);border:1px solid var(--border);border-radius:var(--r8);color:var(--text);font-family:'Bebas Neue',sans-serif;font-size:1.2rem;padding:7px 8px;outline:none;text-align:center;transition:all .2s;}
.prof-career-input:focus{border-color:rgba(245,158,11,.5);}

/* ── 트라이어드 ── */
.triad-modal{display:none;position:fixed;inset:0;background:var(--bg);z-index:1100;align-items:flex-start;justify-content:center;overflow-y:auto;}
.triad-modal.open{display:flex;}
.triad-box{background:var(--bg);width:100%;max-width:820px;min-height:100vh;}
.tr-setup{padding:0 0 24px;}
.tr-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.4rem,7vw,3.5rem);letter-spacing:.18em;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center;line-height:.95;padding-top:16px;}
.tr-subtitle{font-family:'Bebas Neue',sans-serif;font-size:clamp(.9rem,2.5vw,1.2rem);letter-spacing:.3em;color:var(--text2);text-align:center;margin-top:4px;}
.tr-setup-divider{width:44px;height:2px;background:var(--grad);border-radius:2px;opacity:.5;margin:14px auto 20px;}
.tr-mode-hint{font-size:.62rem;color:var(--text2);letter-spacing:.1em;text-align:center;margin-bottom:14px;}
.tr-mode-cards{display:flex;gap:12px;justify-content:center;padding:0 16px;margin-bottom:20px;}
.tr-mode-card{flex:1;max-width:200px;background:var(--card);border:1px solid var(--border);border-radius:var(--r20);padding:24px 12px;cursor:pointer;transition:all .25s cubic-bezier(.22,1,.36,1);text-align:center;backdrop-filter:var(--blur);}
.tr-mode-card:hover{border-color:rgba(245,158,11,.4);background:var(--amber-dim);transform:translateY(-4px);box-shadow:var(--shadow-amber),var(--shadow-lg);}
.tr-mode-card.selected{border-color:rgba(245,158,11,.4);background:var(--amber-dim);}
.tr-mode-icon{font-family:'Bebas Neue',sans-serif;font-size:1.8rem;letter-spacing:.06em;color:var(--amber);line-height:1;margin-bottom:8px;}
.tr-mode-name{font-family:'Bebas Neue',sans-serif;font-size:1.8rem;letter-spacing:.1em;color:var(--text);margin-bottom:8px;}
.tr-mode-desc{font-family:'DM Mono','Space Mono',monospace;font-size:.78rem;color:var(--text2);line-height:1.8;}
.tr-filter-label{font-size:.62rem;color:var(--text2);letter-spacing:.1em;text-align:center;margin-bottom:10px;}
.tr-filter-btns{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;padding:0 16px;margin-bottom:20px;}
.tr-filter-btn{background:transparent;border:1px solid var(--border);border-radius:var(--r999);color:var(--text2);font-family:'Bebas Neue',sans-serif;font-size:.85rem;letter-spacing:.12em;padding:9px 20px;cursor:pointer;transition:all .15s;}
.tr-filter-btn:hover{border-color:rgba(245,158,11,.4);color:var(--amber);}
.tr-filter-btn.selected{border-color:transparent;color:#000;background:var(--grad);box-shadow:0 2px 14px rgba(245,158,11,.3);}
.tr-back-btn{background:transparent;border:1px solid var(--border);border-radius:var(--r8);color:var(--text2);font-family:'Bebas Neue',sans-serif;font-size:.9rem;letter-spacing:.12em;padding:10px 22px;cursor:pointer;transition:all .15s;display:block;margin:0 16px;}
.tr-back-btn:hover{border-color:var(--border2);color:var(--text);}
.tr-start-btn{background:var(--grad);border:none;border-radius:var(--r16);color:#000;font-family:'Bebas Neue',sans-serif;font-size:1.3rem;letter-spacing:.18em;padding:15px;cursor:pointer;transition:all .2s;width:calc(100% - 32px);margin:0 16px;display:block;box-shadow:0 4px 24px rgba(245,158,11,.3);}
.tr-start-btn:hover{transform:translateY(-2px);box-shadow:0 6px 28px rgba(245,158,11,.4);}
.tr-game{display:none;padding:0 0 20px;}
.tr-stats-bar{display:flex;background:var(--card);border:1px solid var(--border);border-bottom:none;margin:0;}
.tr-stat-cell{flex:1;padding:10px 4px 8px;text-align:center;border-right:1px solid var(--border);}
.tr-stat-cell:last-child{border-right:none;}
.tr-stat-label{font-size:.6rem;letter-spacing:.1em;color:var(--text2);text-transform:uppercase;}
.tr-stat-value{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;color:var(--amber);letter-spacing:.05em;line-height:1.1;}
.tr-prog-dots{display:flex;gap:8px;justify-content:center;padding:10px 0 7px;background:var(--card);border:1px solid var(--border);}
.tr-prog-dot{width:10px;height:10px;border-radius:50%;background:var(--border2);transition:all .25s;}
.tr-prog-dot.done-ok{background:var(--green);box-shadow:0 0 8px rgba(16,185,129,.4);}
.tr-prog-dot.done-ng{background:var(--red);box-shadow:0 0 8px rgba(244,63,94,.4);}
.tr-prog-dot.cur{background:var(--amber);animation:blink 1s infinite;box-shadow:0 0 8px var(--amber-glow);}
.tr-qbox{background:var(--card);border:1px solid var(--border);border-top:none;padding:22px 12px 24px;min-height:100px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;}
.tr-qbox-hint{font-size:.62rem;color:var(--text2);letter-spacing:.1em;}
.tr-notes-display{display:flex;align-items:center;gap:5px;flex-wrap:wrap;justify-content:center;}
.tr-note-chip{font-family:'Bebas Neue',sans-serif;font-size:1.7rem;letter-spacing:.04em;color:var(--amber);background:var(--card);border:1px solid var(--border);border-radius:var(--r8);padding:4px 12px;line-height:1.2;}
.tr-note-sep{font-size:1.2rem;color:var(--text2);}
.tr-chord-root{font-family:'Bebas Neue',sans-serif;font-size:3rem;letter-spacing:.1em;color:var(--amber);line-height:1;}
.tr-chord-type-lbl{font-family:'DM Mono','Space Mono',monospace;font-size:.85rem;color:var(--text2);letter-spacing:.08em;}
.tr-ans-grid-6{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:10px 12px 4px;}
.tr-ans-grid-combo{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:10px 12px 4px;}
.tr-ans-btn{background:var(--card);border:1px solid var(--border);border-radius:var(--r8);color:var(--text);font-family:'DM Mono','Space Mono',monospace;font-size:.88rem;font-weight:700;letter-spacing:.04em;padding:12px 4px;cursor:pointer;transition:all .15s;text-align:center;line-height:1.3;}
.tr-ans-btn:hover:not(:disabled){border-color:rgba(245,158,11,.4);color:var(--amber);background:var(--amber-dim);transform:translateY(-1px);}
.tr-ans-btn:disabled{cursor:default;}
.tr-ans-btn.tr-ok{background:var(--green-dim);border-color:rgba(16,185,129,.4);color:#6ee7b7;box-shadow:0 0 12px rgba(16,185,129,.15);}
.tr-ans-btn.tr-ng{background:var(--red-dim);border-color:rgba(244,63,94,.4);color:#fda4af;}
.tr-game-bottom{display:flex;gap:8px;padding:8px 12px 4px;justify-content:center;}
.tr-show-ans-btn{background:transparent;border:1px dashed var(--text3);border-radius:var(--r8);color:var(--text2);font-family:'Bebas Neue',sans-serif;font-size:.9rem;letter-spacing:.1em;padding:8px 18px;cursor:pointer;transition:all .15s;}
.tr-show-ans-btn:hover{border-color:var(--amber);color:var(--amber);}
.tr-reset-btn{background:transparent;border:1px solid var(--border);border-radius:var(--r8);color:var(--text2);font-family:'Bebas Neue',sans-serif;font-size:.9rem;letter-spacing:.1em;padding:8px 18px;cursor:pointer;transition:all .15s;}
.tr-reset-btn:hover{border-color:var(--border2);color:var(--text);}
.tr-game-feedback{text-align:center;font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:.1em;min-height:20px;padding:3px 0 0;color:var(--text2);}
.tr-results{display:none;padding:16px 16px 24px;}
.tr-result-title{font-family:'Bebas Neue',sans-serif;font-size:1.4rem;letter-spacing:.18em;color:var(--amber);text-align:center;margin-bottom:14px;}
.tr-result-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:14px;}
.tr-result-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r16);padding:18px 6px;text-align:center;transition:transform .2s;}
.tr-result-card:hover{transform:translateY(-1px);}
.tr-result-big{font-family:'Bebas Neue',sans-serif;font-size:2rem;color:var(--amber);line-height:1;}
.tr-result-lbl{font-size:.62rem;color:var(--text2);letter-spacing:.08em;margin-top:4px;text-transform:uppercase;}
.tr-result-wrong{width:100%;background:var(--card);border:1px solid var(--border);border-radius:var(--r16);padding:14px 16px;margin-bottom:10px;}
.tr-result-wrong-hd{font-family:'Bebas Neue',sans-serif;font-size:.9rem;letter-spacing:.15em;color:var(--red);margin-bottom:8px;}
.tr-result-wrong-item{display:flex;gap:10px;align-items:center;padding:6px 0;border-bottom:1px solid var(--border);font-size:.68rem;}
.tr-result-wrong-item:last-child{border-bottom:none;}
.tr-result-wrong-q{color:var(--text2);flex:1;}
.tr-result-wrong-yours{color:var(--red);font-family:'DM Mono','Space Mono',monospace;}
.tr-result-wrong-correct{color:var(--green);font-family:'DM Mono','Space Mono',monospace;}
.tr-result-btns{display:flex;gap:8px;}
.tr-result-again{flex:1;background:var(--grad);border:none;border-radius:var(--r8);color:#000;font-family:'Bebas Neue',sans-serif;font-size:1.2rem;letter-spacing:.15em;padding:13px;cursor:pointer;box-shadow:0 4px 18px rgba(245,158,11,.3);transition:all .2s;}
.tr-result-again:hover{transform:translateY(-1px);}
.tr-result-home{flex:1;background:transparent;border:1px solid var(--border);border-radius:var(--r8);color:var(--text2);font-family:'Bebas Neue',sans-serif;font-size:1.2rem;letter-spacing:.15em;padding:13px;cursor:pointer;transition:all .2s;}
.tr-result-home:hover{border-color:var(--border2);color:var(--text);}

/* ── 장착 패널 ── */
.etp-panel{min-width:200px;display:none;position:absolute;left:0;right:0;margin:0 4px;background:rgba(9,9,14,.98);border:1px solid rgba(245,158,11,.25);border-radius:var(--r16);padding:12px 10px 10px;z-index:300;box-shadow:var(--shadow-amber),var(--shadow-lg);max-height:260px;overflow-y:auto;backdrop-filter:var(--blur);}
.etp-panel-header{font-family:'Bebas Neue',sans-serif;font-size:.9rem;letter-spacing:.15em;color:var(--amber);margin-bottom:8px;display:flex;justify-content:space-between;align-items:center;}
.etp-panel-close{background:transparent;border:none;color:var(--text2);cursor:pointer;font-size:.9rem;padding:0;transition:color .15s;}
.etp-panel-close:hover{color:var(--text);}
.etp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;}
.etp-cell{cursor:pointer;border:1px solid var(--border);border-radius:var(--r8);padding:4px;transition:all .15s;display:flex;flex-direction:column;align-items:center;gap:3px;}
.etp-cell:hover{border-color:rgba(245,158,11,.4);background:var(--amber-dim);transform:translateY(-1px);}
.etp-cell.etp-equipped{border-color:rgba(245,158,11,.5);background:var(--amber-dim);box-shadow:var(--shadow-amber);}
.etp-cell-name{font-family:'DM Mono','Space Mono',monospace;font-size:.52rem;color:var(--text2);text-align:center;line-height:1.3;}

/* ── Google 연동 ── */
.gs-login-wrap{display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:16px;}
.gs-btn{display:flex;align-items:center;gap:10px;background:#fff;border:none;border-radius:var(--r12);color:#1a1a1a;font-family:'DM Mono','Space Mono',monospace;font-size:.78rem;letter-spacing:.04em;padding:12px 24px;cursor:pointer;transition:all .2s;min-width:220px;justify-content:center;box-shadow:0 4px 20px rgba(255,255,255,.1);}
.gs-btn:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,255,255,.18);}
.gs-btn svg{width:18px;height:18px;flex-shrink:0;}
.gs-guest-btn{background:transparent;border:1px solid var(--border);border-radius:var(--r8);color:var(--text2);font-family:'DM Mono','Space Mono',monospace;font-size:.62rem;letter-spacing:.08em;padding:8px 20px;cursor:pointer;transition:all .2s;}
.gs-guest-btn:hover{border-color:var(--border2);color:var(--text);}
.gs-status-bar{display:none!important;}
.gs-status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.gs-status-dot.synced{background:var(--green);box-shadow:0 0 6px rgba(16,185,129,.5);}
.gs-status-dot.syncing{background:var(--amber);animation:blink 1s infinite;}
.gs-status-dot.offline{background:var(--text3);}
.gs-status-dot.error{background:var(--red);}
.gs-status-txt{color:var(--text2);flex:1;}
.gs-logout-btn{background:transparent;border:none;color:var(--text2);font-family:'DM Mono','Space Mono',monospace;font-size:.58rem;cursor:pointer;padding:2px 6px;transition:color .15s;}
.gs-logout-btn:hover{color:var(--text);}
.gs-user-info{display:flex;align-items:center;gap:6px;}
.gs-user-avatar{width:18px;height:18px;border-radius:50%;object-fit:cover;}
.gs-sync-badge{position:fixed;top:60px;right:16px;background:var(--card);border:1px solid var(--border);border-radius:var(--r8);color:var(--text2);font-family:'DM Mono','Space Mono',monospace;font-size:.55rem;letter-spacing:.06em;padding:4px 10px;z-index:400;display:none;}

/* ── 랭킹전 ── */
.rank-modal{display:none;position:fixed;inset:0;background:var(--bg);z-index:1100;flex-direction:column;overflow-y:auto;}
.rank-modal.open{display:flex;}
.rank-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 0;flex-shrink:0;}
.rank-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(1.6rem,5vw,2.4rem);letter-spacing:.18em;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.rank-close-btn{background:var(--card);border:1px solid var(--border);border-radius:var(--r8);color:var(--text2);font-family:'DM Mono','Space Mono',monospace;font-size:.65rem;padding:7px 16px;cursor:pointer;transition:all .15s;}
.rank-close-btn:hover{border-color:var(--border2);color:var(--text);}
.rank-tabs{display:flex;border-bottom:1px solid var(--border);margin:14px 20px 0;flex-shrink:0;gap:4px;}
.rank-tab{background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text2);font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:.15em;padding:8px 18px;cursor:pointer;transition:all .15s;margin-bottom:-1px;}
.rank-tab.active{border-bottom-color:var(--amber);color:var(--amber);}
.rank-panel{display:none;padding:16px 20px;flex:1;}
.rank-panel.active{display:block;}

/* ── 랭킹 게임 ── */
.rg-stats{display:flex;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--r12) var(--r12) 0 0;border-bottom:none;overflow:hidden;backdrop-filter:var(--blur);width:100%;}
.rg-stat{flex:1;padding:10px 4px 8px;text-align:center;border-right:1px solid var(--border);}
.rg-stat:last-child{border-right:none;}
.rg-stat-lbl{font-size:.58rem;letter-spacing:.1em;color:var(--text2);text-transform:uppercase;}
.rg-stat-val{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;color:var(--amber);letter-spacing:.05em;line-height:1.1;}
.rg-stage-info{background:var(--card);border:1px solid var(--border);border-radius:var(--r12);padding:14px 18px;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between;}
.rg-stage-badge{font-family:'Bebas Neue',sans-serif;font-size:2rem;color:var(--amber);letter-spacing:.1em;line-height:1;}
.rg-stage-meta{text-align:right;}
.rg-stage-pts{font-family:'Bebas Neue',sans-serif;font-size:1rem;color:var(--green);letter-spacing:.1em;}
.rg-stage-time{font-family:'Bebas Neue',sans-serif;font-size:.85rem;color:var(--text2);letter-spacing:.08em;}
.rg-timer-track{width:100%;height:3px;background:rgba(255,255,255,.05);margin-bottom:0;}
.rg-timer-fill{height:100%;background:var(--grad);transition:width .1s linear,background .3s;border-radius:2px;}
.rg-qbox{background:var(--card);border:1px solid var(--border);border-radius:var(--r12);padding:22px 14px;text-align:center;margin-bottom:10px;min-height:80px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;}
.rg-qhint{font-size:.62rem;color:var(--text2);letter-spacing:.08em;}
.rg-ans-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:8px;}
.rg-ans-btn{background:var(--card);border:1px solid var(--border);border-radius:var(--r8);color:var(--text);font-family:'Bebas Neue',sans-serif;font-size:.95rem;letter-spacing:.06em;padding:12px 4px;cursor:pointer;transition:all .15s;text-align:center;}
.rg-ans-btn:hover:not(:disabled){border-color:rgba(245,158,11,.4);color:var(--amber);background:var(--amber-dim);transform:translateY(-1px);}
.rg-ans-btn:disabled{cursor:default;}
.rg-ans-btn.rg-ok{background:var(--green-dim);border-color:rgba(16,185,129,.4);color:#6ee7b7;box-shadow:0 0 12px rgba(16,185,129,.15);}
.rg-ans-btn.rg-ng{background:var(--red-dim);border-color:rgba(244,63,94,.4);color:#fda4af;animation:shake .28s ease;}
.rg-feedback{text-align:center;font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:.1em;min-height:20px;padding:2px 0 6px;}
.rg-penalty{color:var(--red);font-family:'Bebas Neue',sans-serif;font-size:.9rem;letter-spacing:.1em;text-align:center;min-height:18px;}
.rg-result{display:none;padding:20px;flex:1;}
.rg-result-title{font-family:'Bebas Neue',sans-serif;font-size:2rem;letter-spacing:.2em;color:var(--amber);text-align:center;margin-bottom:16px;}
.rg-result-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px;}
.rg-result-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r16);padding:20px 8px;text-align:center;transition:transform .2s;}
.rg-result-card:hover{transform:translateY(-2px);}
.rg-result-big{font-family:'Bebas Neue',sans-serif;font-size:2.2rem;color:var(--amber);line-height:1;}
.rg-result-lbl{font-size:.62rem;color:var(--text2);letter-spacing:.08em;margin-top:4px;text-transform:uppercase;}
.rg-result-btns{display:flex;gap:8px;margin-bottom:16px;}
.rg-retry-btn{flex:1;background:var(--grad);border:none;border-radius:var(--r8);color:#000;font-family:'Bebas Neue',sans-serif;font-size:1.2rem;letter-spacing:.15em;padding:13px;cursor:pointer;box-shadow:0 4px 18px rgba(245,158,11,.3);transition:all .2s;}
.rg-retry-btn:hover{transform:translateY(-1px);}
.rg-board-btn{flex:1;background:transparent;border:1px solid var(--border);border-radius:var(--r8);color:var(--text2);font-family:'Bebas Neue',sans-serif;font-size:1.2rem;letter-spacing:.15em;padding:13px;cursor:pointer;transition:all .2s;}
.rg-board-btn:hover{border-color:var(--border2);color:var(--text);}

/* ★★★ 리더보드 ★★★ */
.rg-board{margin-top:6px;display:flex;flex-direction:column;gap:4px;}
.rg-board-loading{text-align:center;padding:36px;font-size:.65rem;color:var(--text2);letter-spacing:.1em;}
.rg-board-row{
  display:flex;align-items:center;gap:10px;
  padding:12px 16px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-radius:var(--r12);
  font-family:'DM Mono','Space Mono',monospace;font-size:.72rem;
  transition:all .2s;
}
.rg-board-row:hover{background:rgba(255,255,255,.06);transform:translateX(2px);}
.rg-board-row.rg-me{
  background:var(--amber-dim);
  border-color:rgba(245,158,11,.3);
  box-shadow:0 0 16px var(--amber-dim);
}
.rg-board-rank{
  width:32px;font-family:'Bebas Neue',sans-serif;font-size:1.2rem;
  color:var(--text2);text-align:center;flex-shrink:0;
}
.rg-board-rank.gold{color:#fbbf24;text-shadow:0 0 12px rgba(251,191,36,.5);}
.rg-board-rank.silver{color:#cbd5e1;}
.rg-board-rank.bronze{color:#c8804a;}
.rg-board-nick{flex:1;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.rg-board-score{
  font-family:'Bebas Neue',sans-serif;font-size:1.1rem;
  color:var(--amber);letter-spacing:.08em;flex-shrink:0;
  background:var(--amber-dim);padding:3px 10px;border-radius:var(--r999);
}
.rg-board-row.rg-me .rg-board-score{background:rgba(245,158,11,.2);}
.rg-my-rank-bar{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(245,158,11,.25);
  border-radius:var(--r16);
  padding:14px 18px;margin-top:12px;
  align-items:center;justify-content:space-between;gap:10px;
  box-shadow:0 0 20px var(--amber-dim);
}
.rg-my-rank-lbl{font-size:.6rem;color:var(--text2);letter-spacing:.1em;}
.rg-my-rank-val{font-family:'Bebas Neue',sans-serif;font-size:1.4rem;color:var(--amber);letter-spacing:.1em;}

/* ── 유저 카드 ── */
.ucard-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(10px);z-index:1600;align-items:center;justify-content:center;}
.ucard-modal.open{display:flex;animation:up .3s ease;}
.ucard-box{background:var(--surface-solid);border:1px solid var(--border);border-radius:var(--r20);width:92%;max-width:420px;overflow:hidden;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);}
.ucard-header{background:linear-gradient(135deg,rgba(139,92,246,.15),rgba(245,158,11,.1));border-bottom:1px solid var(--border);padding:18px 16px 14px;display:flex;align-items:center;gap:14px;position:relative;}
.ucard-avatar{width:52px;height:52px;border-radius:50%;border:2px solid var(--amber);background:var(--solid);display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:1.3rem;color:var(--amber);flex-shrink:0;overflow:hidden;box-shadow:0 0 18px var(--amber-dim);}
.ucard-info{flex:1;min-width:0;}
.ucard-nick{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;letter-spacing:.1em;color:var(--text);line-height:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ucard-career{font-size:.62rem;color:var(--text2);letter-spacing:.08em;margin-top:3px;}
.ucard-close{position:absolute;top:10px;right:12px;background:rgba(255,255,255,.08);border:none;border-radius:50%;color:var(--text2);font-size:1rem;cursor:pointer;width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:all .15s;}
.ucard-close:hover{background:rgba(255,255,255,.15);color:var(--text);}
.ucard-body{padding:16px 18px;}
.ucard-greeting{background:rgba(255,255,255,.04);border-left:3px solid var(--amber);border-radius:0 var(--r8) var(--r8) 0;padding:10px 14px;font-size:.72rem;color:var(--text);line-height:1.7;letter-spacing:.04em;margin-bottom:14px;min-height:40px;}
.ucard-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;}
.ucard-stat{background:var(--card);border:1px solid var(--border);border-radius:var(--r12);padding:10px 4px;text-align:center;transition:transform .2s;}
.ucard-stat:hover{transform:translateY(-1px);}
.ucard-stat-val{font-family:'Bebas Neue',sans-serif;font-size:1.3rem;color:var(--amber);letter-spacing:.05em;line-height:1;}
.ucard-stat-lbl{font-size:.58rem;color:var(--text2);letter-spacing:.06em;margin-top:2px;}
.ucard-greeting{background:rgba(255,255,255,.04);border-left:3px solid var(--amber);border-radius:0 var(--r8) var(--r8) 0;padding:10px 14px;font-size:.72rem;color:var(--text);line-height:1.7;letter-spacing:.04em;margin-bottom:14px;min-height:40px;}
.rg-board-avatar{width:26px;height:26px;border-radius:50%;border:1px solid var(--border);background:rgba(255,255,255,.05);display:inline-flex;align-items:center;justify-content:center;overflow:hidden;cursor:pointer;flex-shrink:0;transition:all .15s;}
.rg-board-avatar:hover{border-color:rgba(245,158,11,.4);box-shadow:0 0 8px var(--amber-dim);}

/* ── 문의하기 ── */
.inquiry-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);z-index:1400;align-items:center;justify-content:center;}
.inquiry-modal.open{display:flex;animation:up .3s ease;}
.inquiry-box{background:var(--surface-solid);border:1px solid var(--border);border-radius:var(--r20);width:90%;max-width:440px;padding:28px 24px;box-shadow:var(--shadow-lg);}
.inquiry-title{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;letter-spacing:.15em;color:var(--amber);margin-bottom:16px;border-bottom:1px solid var(--border);padding-bottom:10px;display:flex;justify-content:space-between;align-items:center;}
.inquiry-label{font-size:.6rem;color:var(--text2);letter-spacing:.12em;text-transform:uppercase;margin-bottom:4px;margin-top:12px;}
.inquiry-input{width:100%;background:var(--card);border:1px solid var(--border);border-radius:var(--r8);color:var(--text);font-family:'DM Mono','Space Mono',monospace;font-size:.78rem;padding:10px 12px;outline:none;letter-spacing:.04em;transition:all .2s;}
.inquiry-input:focus{border-color:rgba(245,158,11,.5);box-shadow:0 0 0 2px var(--amber-dim);}
.inquiry-textarea{width:100%;background:var(--card);border:1px solid var(--border);border-radius:var(--r8);color:var(--text);font-family:'DM Mono','Space Mono',monospace;font-size:.75rem;padding:10px 12px;outline:none;letter-spacing:.04em;resize:vertical;min-height:100px;transition:all .2s;}
.inquiry-textarea:focus{border-color:rgba(245,158,11,.5);box-shadow:0 0 0 2px var(--amber-dim);}
.inquiry-submit{width:100%;margin-top:16px;background:var(--grad);border:none;border-radius:var(--r8);color:#000;font-family:'Bebas Neue',sans-serif;font-size:1.1rem;letter-spacing:.15em;padding:13px;cursor:pointer;transition:all .2s;box-shadow:0 4px 18px rgba(245,158,11,.3);}
.inquiry-submit:hover{transform:translateY(-1px);box-shadow:0 6px 22px rgba(245,158,11,.4);}
.inquiry-submit:disabled{opacity:.4;cursor:default;transform:none;}

/* ══════════════════════════════════
   랭킹 보상 카드
══════════════════════════════════ */
.reward-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--r16);
  overflow: hidden;
  margin-bottom: 16px;
  animation: up .4s cubic-bezier(.22,1,.36,1);
}
.reward-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px 12px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  background: rgba(255,255,255,.03);
}
.reward-card-title {
  font-family: 'Rajdhani', 'Bebas Neue', sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: .08em;
  color: var(--amber);
}
.reward-card-sub {
  font-family: 'DM Mono', monospace;
  font-size: .62rem;
  color: var(--text2);
  letter-spacing: .06em;
}
.reward-list { padding: 8px 12px 10px; display: flex; flex-direction: column; gap: 4px; }

.reward-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: var(--r8);
  border: 1px solid transparent;
  transition: all .2s;
  animation: slideRight .4s cubic-bezier(.22,1,.36,1) both;
}
.reward-row:nth-child(1){animation-delay:.05s}
.reward-row:nth-child(2){animation-delay:.1s}
.reward-row:nth-child(3){animation-delay:.15s}
.reward-row:nth-child(4){animation-delay:.2s}
.reward-row:nth-child(5){animation-delay:.25s}
.reward-row:nth-child(6){animation-delay:.3s}
@keyframes slideRight {
  from{opacity:0;transform:translateX(-12px)}
  to{opacity:1;transform:none}
}
.reward-row:hover { transform: translateX(3px); }

.reward-gold   { background:rgba(251,191,36,.07); border-color:rgba(251,191,36,.2); }
.reward-silver { background:rgba(203,213,225,.06); border-color:rgba(203,213,225,.15); }
.reward-bronze { background:rgba(180,83,9,.08); border-color:rgba(180,83,9,.2); }
.reward-normal { background:rgba(255,255,255,.03); border-color:rgba(255,255,255,.06); }

.reward-rank-badge {
  width: 60px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1px;
}
.reward-laurel { font-size: 1.5rem; line-height: 1; }
.reward-rank-num {
  font-family: 'Rajdhani', sans-serif;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .06em;
}
.gold   .reward-rank-num { color: #fbbf24; }
.silver .reward-rank-num { color: #cbd5e1; }
.bronze .reward-rank-num { color: #c8804a; }
.normal .reward-rank-num { color: var(--text2); }

.reward-items { display: flex; gap: 8px; flex-wrap: wrap; flex: 1; }
.reward-item {
  display: flex;
  align-items: center;
  gap: 5px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: var(--r8);
  padding: 5px 10px;
}
.reward-icon { font-size: .95rem; }
.reward-amount {
  font-family: 'Rajdhani', sans-serif;
  font-size: .85rem;
  font-weight: 600;
  color: var(--text);
  letter-spacing: .04em;
}
.reward-gold   .reward-amount strong { color: #fbbf24; }
.reward-silver .reward-amount strong { color: #cbd5e1; }
.reward-bronze .reward-amount strong { color: #c8804a; }
.reward-normal .reward-amount strong { color: var(--amber); }

/* ── 새 탭 스타일 ── */
.lb-tabs {
  display: flex;
  gap: 6px;
  margin-bottom: 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: var(--r12);
  padding: 4px;
}
.lb-tab {
  flex: 1;
  background: transparent;
  border: none;
  border-radius: var(--r8);
  color: var(--text2);
  font-family: 'Rajdhani', 'Bebas Neue', sans-serif;
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: .1em;
  padding: 9px;
  cursor: pointer;
  transition: all .2s;
}
.lb-tab.lb-tab-active {
  background: var(--grad);
  color: #000;
  font-weight: 700;
  box-shadow: 0 2px 12px rgba(245,158,11,.3);
}
.lb-tab:hover:not(.lb-tab-active) { color: var(--text); background: rgba(255,255,255,.05); }

/* ══════════════════════════════════
   폰트/굵기 강조
══════════════════════════════════ */
.stat-label { font-family: 'Rajdhani', sans-serif; font-size: .72rem; font-weight: 600; }
.rg-board-nick strong, .rg-board-row.rg-me .rg-board-nick { font-weight: 700; color: var(--amber2); }
.result-lbl { font-family: 'Rajdhani', sans-serif; font-weight: 600; font-size: .8rem; }
.rg-stat-lbl { font-family: 'Rajdhani', sans-serif; font-weight: 600; }
.tr-stat-label { font-family: 'Rajdhani', sans-serif; font-weight: 600; }
.notice-content strong { color: var(--amber); }
.notice-content em { color: var(--text); font-style: normal; font-weight: 700; }

/* ══════════════════════════════════
   애니메이션 강화
══════════════════════════════════ */
/* 스탯값 카운트업 효과용 */
.stat-value, .rg-stat-val, .tr-stat-value {
  transition: color .3s, opacity .2s;
}

/* 노트 버튼 등장 */
.note-btn {
  animation: noteIn .3s cubic-bezier(.22,1,.36,1) both;
}
@keyframes noteIn {
  from{opacity:0;transform:scale(.9) translateY(4px)}
  to{opacity:1;transform:none}
}

/* 리더보드 행 등장 */
.rg-board-row {
  animation: rowIn .35s cubic-bezier(.22,1,.36,1) both;
}
@keyframes rowIn {
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:none}
}

/* 모달 등장 강화 */
.rank-modal.open > * { animation: up .4s cubic-bezier(.22,1,.36,1) both; }

/* 결과 카드 */
.result-card { animation: cardIn .4s cubic-bezier(.22,1,.36,1) both; }
.result-card:nth-child(1){animation-delay:.05s}
.result-card:nth-child(2){animation-delay:.12s}
.result-card:nth-child(3){animation-delay:.19s}
@keyframes cardIn {
  from{opacity:0;transform:translateY(16px) scale(.96)}
  to{opacity:1;transform:none}
}

/* 호버 pulse */
.btn-cta:hover::before { animation: pulse 1.5s infinite; }
@keyframes pulse {
  0%,100%{opacity:.15} 50%{opacity:.3}
}

/* 랭킹 1~3위 뱃지 shine */
.rg-board-rank.gold { animation: goldShine 2.5s infinite; }
@keyframes goldShine {
  0%,100%{text-shadow:0 0 8px rgba(251,191,36,.4)}
  50%{text-shadow:0 0 18px rgba(251,191,36,.8),0 0 32px rgba(251,191,36,.3)}
}

/* rBoardTab 탭 전환 시 active 클래스 */
.lb-tab { position: relative; overflow: hidden; }
.lb-tab::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,.1);
  transform: translateX(-100%);
  transition: transform .3s;
}
.lb-tab:active::after { transform: none; }

/* ══ 미션 모달 ══ */
.mission-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);z-index:1400;align-items:flex-start;justify-content:center;padding-top:50px;}
.mission-modal.open{display:flex;animation:up .3s ease;}
.mission-box{background:var(--surface-solid);border:1px solid var(--border);border-radius:var(--r20);width:92%;max-width:480px;max-height:78vh;overflow-y:auto;box-shadow:var(--shadow-lg);}
.mission-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px;border-bottom:1px solid var(--border);}
.mission-section{background:var(--card);border:1px solid var(--border);border-radius:var(--r12);margin:0 4px;}
.mission-sec-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px 6px;}
.mission-sec-title{font-family:'Bebas Neue',sans-serif;font-size:1.2rem;letter-spacing:.15em;color:var(--amber);}
.mission-sec-timer{font-family:'DM Mono',monospace;font-size:.72rem;color:var(--text2);letter-spacing:.06em;}
.mission-list{display:flex;flex-direction:column;gap:6px;padding:4px 10px 12px;}
.mission-row{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;border-radius:var(--r8);
  background:rgba(255,255,255,.03);border:1px solid var(--border);
  transition:all .2s;animation:rowIn .3s ease both;
}
.mission-row.mission-done{background:var(--amber-dim);border-color:rgba(245,158,11,.3);}
.mission-icon{font-size:1.4rem;flex-shrink:0;width:26px;text-align:center;}
.mission-label{flex:1;font-size:.92rem;color:var(--text);letter-spacing:.03em;}
.mission-row.mission-done .mission-label{color:var(--text2);text-decoration:line-through;}
.mission-pts{font-family:'Bebas Neue',sans-serif;font-size:1.05rem;color:var(--amber);letter-spacing:.08em;flex-shrink:0;background:var(--amber-dim);padding:4px 10px;border-radius:var(--r999);}
.mission-pts-done{color:var(--green);background:var(--green-dim);}
.mission-progress-bar{height:6px;background:rgba(255,255,255,.08);border-radius:3px;margin:4px 10px 4px;overflow:hidden;}
.mission-progress-fill{height:100%;background:var(--grad);border-radius:3px;transition:width .5s ease;}
.mission-progress-label{font-family:'DM Mono',monospace;font-size:.72rem;color:var(--text2);text-align:center;padding-bottom:12px;letter-spacing:.08em;}

/* ── 모든 모드 공통 fretboard 레이아웃 ── */
.rg-stats { width:100%; }
.rg-stat-lbl { font-family:'Rajdhani',sans-serif; font-weight:600; font-size:.65rem; letter-spacing:.1em; color:var(--text2); text-transform:uppercase; }
.rg-stat-val { font-family:'Bebas Neue',sans-serif; font-size:1.6rem; color:var(--amber); letter-spacing:.05em; line-height:1.1; }
.rg-timer-fill { height:100%; background:var(--grad); transition:width .1s linear,background .3s; }
.rg-stage-info { background:var(--card); border:1px solid var(--border); border-top:none; padding:10px 16px; margin-bottom:0; display:flex; align-items:center; justify-content:space-between; }

.rg-board-empty{opacity:.45;}
.rg-board-reward{font-family:'Bebas Neue',sans-serif;font-size:.9rem;letter-spacing:.06em;flex-shrink:0;width:80px;text-align:right;}

/* ══════════════════════════════
   🏆 시상대 - EPIC EDITION
══════════════════════════════ */
.rg-podium{
  position:relative;
  display:flex;align-items:flex-end;justify-content:center;
  gap:0;padding:28px 0 0;margin-bottom:8px;
  background:radial-gradient(ellipse 80% 60% at 50% 100%, rgba(245,158,11,.06) 0%, transparent 70%);
}

/* 1위 중앙 */
.rg-podium-col{
  display:flex;flex-direction:column;align-items:center;
  gap:6px;flex:1;position:relative;
  animation:podiumIn .5s cubic-bezier(.22,1,.36,1) both;
}
.rg-podium-col:nth-child(1){animation-delay:.1s;}
.rg-podium-col:nth-child(2){animation-delay:.0s;}
.rg-podium-col:nth-child(3){animation-delay:.2s;}
@keyframes podiumIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* 왕관 (1위만) */
.rg-podium-crown{
  font-size:1.6rem;line-height:1;
  animation:crownFloat 2.5s ease-in-out infinite;
  filter:drop-shadow(0 0 8px rgba(251,191,36,.6));
}
@keyframes crownFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}

/* 아바타 */
.rg-podium-avatar{
  border-radius:50%;
  border:3px solid;
  background:var(--surface-solid);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;cursor:pointer;
  transition:all .25s;
  position:relative;
}
.rg-podium-avatar::after{
  content:'';position:absolute;inset:0;border-radius:50%;
  background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 60%);
  pointer-events:none;
}
.rg-podium-avatar:hover{transform:scale(1.1);}

/* 1위 아바타 크기 */
.rg-podium-first .rg-podium-avatar{
  width:72px;height:72px;
  border-color:#fbbf24;
  box-shadow:0 0 0 3px rgba(251,191,36,.2),0 0 24px rgba(251,191,36,.35),0 4px 16px rgba(0,0,0,.4);
}
/* 2위 */
.rg-podium-second .rg-podium-avatar{
  width:58px;height:58px;
  border-color:#cbd5e1;
  box-shadow:0 0 0 2px rgba(203,213,225,.2),0 0 16px rgba(203,213,225,.2),0 4px 12px rgba(0,0,0,.4);
}
/* 3위 */
.rg-podium-third .rg-podium-avatar{
  width:52px;height:52px;
  border-color:#c8804a;
  box-shadow:0 0 0 2px rgba(200,128,74,.2),0 0 14px rgba(200,128,74,.2),0 4px 12px rgba(0,0,0,.4);
}

/* 닉네임 */
.rg-podium-nick{
  font-family:'Bebas Neue',sans-serif;letter-spacing:.1em;
  text-align:center;max-width:110px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  text-shadow:0 2px 8px rgba(0,0,0,.4);
}
.rg-podium-first .rg-podium-nick{font-size:1.1rem;color:#fbbf24;}
.rg-podium-second .rg-podium-nick{font-size:.95rem;color:#f0f4ff;}
.rg-podium-third .rg-podium-nick{font-size:.9rem;color:#f0c090;}

/* 점수 */
.rg-podium-score{
  font-family:'DM Mono',monospace;font-size:.72rem;font-weight:700;
  text-align:center;opacity:.85;
}

/* 트로피 배지 */
.rg-podium-trophy{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:5px 10px;border-radius:var(--r8);
  font-family:'Bebas Neue',sans-serif;letter-spacing:.08em;
  border:1px solid;backdrop-filter:blur(4px);
}
.rg-podium-first .rg-podium-trophy{
  background:linear-gradient(135deg,rgba(251,191,36,.2),rgba(251,191,36,.05));
  border-color:rgba(251,191,36,.4);color:#fbbf24;font-size:.75rem;
}
.rg-podium-second .rg-podium-trophy{
  background:linear-gradient(135deg,rgba(203,213,225,.15),rgba(203,213,225,.04));
  border-color:rgba(203,213,225,.5);color:#e8edf5;font-size:.7rem;
}
.rg-podium-third .rg-podium-trophy{
  background:linear-gradient(135deg,rgba(200,128,74,.15),rgba(200,128,74,.04));
  border-color:rgba(200,128,74,.5);color:#e0a87a;font-size:.68rem;
}

/* 받침대 */
.rg-podium-stand{
  width:100%;border-radius:var(--r8) var(--r8) 0 0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:8px 4px;position:relative;overflow:hidden;
  border:1px solid;border-bottom:none;
}
.rg-podium-stand::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);
}
.rg-podium-first .rg-podium-stand{
  height:90px;
  background:linear-gradient(180deg,rgba(251,191,36,.18) 0%,rgba(251,191,36,.06) 100%);
  border-color:rgba(251,191,36,.35);
  box-shadow:inset 0 1px 0 rgba(251,191,36,.3);
}
.rg-podium-second .rg-podium-stand{
  height:60px;
  background:linear-gradient(180deg,rgba(203,213,225,.14) 0%,rgba(203,213,225,.04) 100%);
  border-color:rgba(203,213,225,.3);
}
.rg-podium-third .rg-podium-stand{
  height:44px;
  background:linear-gradient(180deg,rgba(200,128,74,.14) 0%,rgba(200,128,74,.04) 100%);
  border-color:rgba(200,128,74,.3);
}
.rg-podium-stand-rank{
  font-family:'Bebas Neue',sans-serif;font-size:2rem;letter-spacing:.05em;line-height:1;
}
.rg-podium-first .rg-podium-stand-rank{color:#fbbf24;text-shadow:0 0 16px rgba(251,191,36,.5);}
.rg-podium-second .rg-podium-stand-rank{color:#cbd5e1;font-size:1.6rem;}
.rg-podium-third .rg-podium-stand-rank{color:#c8804a;font-size:1.4rem;}
.rg-podium-stand-pts{
  font-family:'DM Mono',monospace;font-size:.6rem;font-weight:700;opacity:.8;
}

/* ══ 친구 ══ */
.friend-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);z-index:1400;align-items:flex-start;justify-content:center;padding-top:40px;}
.friend-modal.open{display:flex;animation:up .3s ease;}
.friend-box{background:var(--surface-solid);border:1px solid var(--border);border-radius:var(--r20);width:92%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);}
.friend-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px;border-bottom:1px solid var(--border);flex-shrink:0;}
.friend-tabs{display:flex;gap:4px;padding:8px 12px;border-bottom:1px solid var(--border);flex-shrink:0;}
.friend-tab{flex:1;background:transparent;border:1px solid var(--border);border-radius:var(--r8);color:var(--text2);font-family:'Bebas Neue',sans-serif;font-size:.85rem;letter-spacing:.1em;padding:7px;cursor:pointer;transition:all .2s;}
.friend-tab.friend-tab-active{background:var(--grad);border-color:transparent;color:#000;}
.friend-panel{display:none;overflow-y:auto;flex:1;}
.friend-panel.friend-panel-active{display:block;}
.friend-loading{text-align:center;padding:32px;font-size:.72rem;color:var(--text2);}
.friend-row{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid rgba(255,255,255,.04);transition:background .15s;cursor:pointer;}
.friend-row:hover{background:var(--card);}
.friend-avatar{width:40px;height:40px;border-radius:50%;border:2px solid var(--border);background:var(--card);display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:1.1rem;color:var(--amber);flex-shrink:0;position:relative;overflow:hidden;}
.friend-online-dot{width:10px;height:10px;border-radius:50%;border:2px solid var(--surface-solid);position:absolute;bottom:0;right:0;}
.friend-online-dot.online{background:#22c55e;box-shadow:0 0 6px #22c55e;}
.friend-online-dot.offline{background:var(--text3);}
.friend-info{flex:1;min-width:0;}
.friend-nick{font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:.08em;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.friend-status-txt{font-size:.62rem;color:var(--text2);margin-top:1px;}
.friend-actions{display:flex;gap:6px;flex-shrink:0;}
.friend-btn{background:var(--card);border:1px solid var(--border);border-radius:var(--r8);color:var(--text2);font-family:'Bebas Neue',sans-serif;font-size:.75rem;letter-spacing:.1em;padding:5px 10px;cursor:pointer;transition:all .2s;}
.friend-btn:hover{border-color:var(--amber);color:var(--amber);}
.friend-btn.danger:hover{border-color:var(--red);color:var(--red);}
.friend-btn.primary{background:var(--grad);border-color:transparent;color:#000;}

/* ══ 채팅 ══ */
.chat-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(8px);z-index:1700;align-items:flex-end;justify-content:center;}
.chat-modal.open{display:flex;animation:up .3s ease;}
.chat-box{background:var(--surface-solid);border:1px solid var(--border);border-radius:var(--r20) var(--r20) 0 0;width:100%;max-width:500px;height:75vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);}
.chat-header{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0;}
.chat-online-dot{width:10px;height:10px;border-radius:50%;}
.chat-online-dot.online{background:#22c55e;box-shadow:0 0 6px #22c55e;}
.chat-online-dot.offline{background:var(--text3);}
.chat-messages{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:8px;}
.chat-bubble{max-width:72%;padding:9px 14px;border-radius:18px;font-size:.82rem;line-height:1.5;word-break:break-word;}
.chat-bubble.mine{align-self:flex-end;background:var(--grad);color:#000;border-radius:18px 18px 4px 18px;}
.chat-bubble.theirs{align-self:flex-start;background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:18px 18px 18px 4px;}
.chat-bubble-time{font-size:.56rem;opacity:.6;margin-top:3px;text-align:right;}
.chat-input-bar{display:flex;gap:8px;padding:10px 14px;border-top:1px solid var(--border);flex-shrink:0;}

.shop-item.ach-only{opacity:.75;}
.shop-item.ach-only .shop-item-preview{filter:sepia(.3) saturate(1.5) hue-rotate(10deg);}
