/* soloAR — v3 Stylesheet */
:root {
  --bg:#06090f; --bg-panel:#090e1a; --bg-panel2:#0c1220;
  --accent:#00d4ff; --accent-dim:rgba(0,212,255,0.12); --accent-glow:0 0 24px rgba(0,212,255,0.35);
  --danger:#ff3434; --danger-dim:rgba(255,52,52,0.15);
  --warn:#ffaa00; --success:#00ff88;
  --text:#b8cfe0; --text-bright:#d8eeff; --text-dim:#3a5a7a;
  --border:rgba(0,212,255,0.18); --border-dim:rgba(0,212,255,0.07);
  --str:#ff6535; --vit:#ff3d8a; --agi:#35ff8a; --int:#a06aff; --per:#ffd700;
  --font-mono:'JetBrains Mono',monospace; --font-serif:'DM Serif Display',serif;
  --clip:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,12px 100%,0 calc(100% - 12px));
  --clip-sm:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px));
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:var(--font-mono);font-size:13px;min-height:100vh;overflow-x:hidden;line-height:1.6}
input,button,select{font-family:var(--font-mono)}
button{cursor:pointer;border:none;background:none}
a{text-decoration:none;color:inherit}
.scanlines{position:fixed;inset:0;pointer-events:none;z-index:9999;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,0.04) 2px,rgba(0,0,0,0.04) 4px)}
.hidden{display:none!important}
.accent{color:var(--accent)}
.screen{min-height:100vh;display:none}
.screen.active{display:flex}
#auth-screen{flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden}
#penalty-screen{flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,rgba(255,52,52,0.08) 0%,var(--bg) 70%)}
#app-screen{flex-direction:column}

/* HEX */
.hex-outer{position:relative;display:inline-flex;align-items:center;justify-content:center;width:76px;height:76px;background:var(--accent);clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);filter:drop-shadow(0 0 10px rgba(0,212,255,0.5));animation:hex-pulse 3s ease-in-out infinite;flex-shrink:0}
.hex-outer.small{width:30px;height:30px;animation:none;filter:drop-shadow(0 0 5px rgba(0,212,255,0.4))}
.hex-outer.med{width:68px;height:68px}
.auth-hex-logo{width:68px;height:68px;clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);background:var(--bg-panel);display:flex;align-items:center;justify-content:center}
.topbar-hex{width:24px;height:24px;clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);background:var(--bg-panel);display:flex;align-items:center;justify-content:center}
.char-avatar-hex{width:60px;height:60px;clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);background:linear-gradient(135deg,var(--bg-panel2),rgba(0,212,255,0.15));display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-size:26px;color:var(--accent)}
.hex-text{font-family:var(--font-serif);color:var(--accent);font-size:20px;letter-spacing:2px}
.topbar-hex span{font-size:7px;letter-spacing:1px;color:var(--accent)}
@keyframes hex-pulse{0%,100%{filter:drop-shadow(0 0 8px rgba(0,212,255,0.4))}50%{filter:drop-shadow(0 0 22px rgba(0,212,255,0.85))}}

/* AUTH */
.auth-bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 50% 50%,rgba(0,212,255,0.06) 0%,transparent 70%)}
.auth-grid-lines{position:absolute;inset:0;background-image:linear-gradient(rgba(0,212,255,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(0,212,255,0.04) 1px,transparent 1px);background-size:40px 40px;animation:grid-scroll 20s linear infinite}
@keyframes grid-scroll{to{background-position:40px 40px}}
.auth-container{position:relative;z-index:1;width:100%;max-width:420px;padding:24px 20px}
.auth-logo-wrap{text-align:center;margin-bottom:28px}
.auth-title{font-family:var(--font-serif);font-size:36px;color:var(--text-bright);letter-spacing:6px;margin-top:12px}
.auth-title .accent{text-shadow:0 0 20px rgba(0,212,255,0.8)}
.auth-subtitle{font-size:10px;letter-spacing:4px;color:var(--text-dim);margin-top:6px}
.auth-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:22px}
.tab-btn{flex:1;padding:10px;font-size:11px;letter-spacing:3px;color:var(--text-dim);border-bottom:2px solid transparent;transition:all .2s}
.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}
.tab-btn:hover{color:var(--text)}
.form-group{margin-bottom:14px}
.form-label{display:block;font-size:9px;letter-spacing:3px;color:var(--text-dim);margin-bottom:5px}
.form-input{width:100%;background:var(--bg-panel2);border:1px solid var(--border-dim);clip-path:var(--clip-sm);padding:10px 14px;color:var(--text-bright);font-size:13px;outline:none;transition:border-color .2s}
.form-input:focus{border-color:var(--accent);box-shadow:0 0 10px rgba(0,212,255,0.12)}
.form-input::placeholder{color:var(--text-dim)}
select.form-input{appearance:none;-webkit-appearance:none;cursor:pointer}
.auth-error{color:var(--danger);font-size:11px;margin-top:8px;min-height:16px}

/* BUTTONS */
.btn-primary{width:100%;padding:12px 20px;background:transparent;border:1px solid var(--accent);clip-path:var(--clip-sm);color:var(--accent);font-size:11px;letter-spacing:3px;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .25s;position:relative;overflow:hidden;margin-top:4px}
.btn-primary::before{content:'';position:absolute;inset:0;background:var(--accent);transform:translateX(-100%);transition:transform .3s ease;z-index:0}
.btn-primary>*{position:relative;z-index:1}
.btn-primary:hover::before{transform:translateX(0)}
.btn-primary:hover{color:var(--bg);box-shadow:var(--accent-glow)}
.btn-primary:disabled{opacity:.3;pointer-events:none;border-color:var(--text-dim);color:var(--text-dim)}
.btn-danger{width:100%;padding:12px 20px;background:var(--danger-dim);border:1px solid var(--danger);clip-path:var(--clip-sm);color:var(--danger);font-size:11px;letter-spacing:3px;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}
.btn-danger:hover{background:var(--danger);color:#fff;box-shadow:0 0 20px rgba(255,52,52,0.5)}
.btn-icon{width:36px;height:36px;border:1px solid var(--border-dim);clip-path:var(--clip-sm);color:var(--text-dim);display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s}
.btn-icon:hover{color:var(--accent);border-color:var(--accent)}
.btn-sm{padding:6px 12px;font-size:10px;letter-spacing:2px;width:auto;margin-top:0}
.btn-icon-small{width:26px;height:26px;border:1px solid var(--border-dim);color:var(--text-dim);display:flex;align-items:center;justify-content:center;font-size:13px;transition:all .2s;clip-path:var(--clip-sm);cursor:pointer;background:var(--bg-panel2)}
.btn-icon-small:hover{color:var(--accent);border-color:var(--accent)}
.btn-icon-small:disabled{opacity:.3;cursor:not-allowed}

/* PENALTY */
.penalty-container{max-width:480px;width:100%;padding:28px 20px;text-align:center}
.penalty-glow-ring{width:120px;height:120px;border:2px solid var(--danger);border-radius:50%;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;animation:ring-pulse 1.5s ease-in-out infinite}
@keyframes ring-pulse{0%,100%{box-shadow:0 0 20px rgba(255,52,52,0.4)}50%{box-shadow:0 0 60px rgba(255,52,52,0.8)}}
.penalty-symbol{font-family:var(--font-serif);font-size:52px;color:var(--danger);text-shadow:0 0 30px rgba(255,52,52,0.9);line-height:1}
.penalty-bracket{font-size:18px;letter-spacing:4px;color:var(--danger);margin-bottom:14px;animation:glitch 3s infinite}
@keyframes glitch{0%,90%,100%{transform:none;text-shadow:0 0 20px rgba(255,52,52,0.6)}92%{transform:translateX(-2px) skewX(-2deg);text-shadow:-2px 0 #ff3434,2px 0 rgba(0,212,255,0.5)}94%{transform:translateX(2px) skewX(2deg)}}
.penalty-msg{color:var(--text);margin-bottom:14px;line-height:1.8}
.penalty-days{font-size:11px;letter-spacing:2px;color:var(--warn);margin-bottom:12px}
.penalty-stat-list{background:var(--bg-panel);border:1px solid rgba(255,52,52,0.3);clip-path:var(--clip);padding:12px;margin-bottom:14px;display:flex;flex-direction:column;gap:8px}
.penalty-stat-row{display:flex;justify-content:space-between;font-size:12px}
.penalty-stat-row .stat-loss{color:var(--danger);font-weight:700}
.penalty-warning-bar{background:var(--danger-dim);border:1px solid rgba(255,52,52,0.3);padding:8px 14px;font-size:10px;letter-spacing:1px;color:var(--danger);margin-bottom:16px}

/* TOPBAR */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:0 12px;height:52px;background:rgba(6,9,15,0.97);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;backdrop-filter:blur(8px);flex-shrink:0}
.topbar-brand{display:flex;align-items:center;gap:8px}
.topbar-title{font-family:var(--font-serif);font-size:16px;color:var(--text-bright);letter-spacing:4px}
.topbar-nav{display:flex;gap:1px}
.nav-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:4px 8px;min-width:52px;color:var(--text-dim);border-bottom:2px solid transparent;transition:all .2s}
.nav-btn i{font-size:16px}
.nav-btn span{font-size:7px;letter-spacing:1.5px}
.nav-btn.active{color:var(--accent);border-bottom-color:var(--accent);text-shadow:0 0 10px rgba(0,212,255,0.5)}
.nav-btn:hover{color:var(--text)}
.topbar-right{display:flex;align-items:center;gap:8px}
.topbar-level-badge{display:flex;flex-direction:column;align-items:center;background:var(--accent-dim);border:1px solid var(--border);clip-path:var(--clip-sm);padding:2px 10px}
.lv-label{font-size:7px;letter-spacing:2px;color:var(--text-dim)}
.lv-num{font-size:14px;font-weight:700;color:var(--accent);line-height:1.2}

/* PANEL */
.panel{background:var(--bg-panel);border:1px solid var(--border);clip-path:var(--clip);padding:16px;position:relative;overflow:hidden}
.panel::after{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.4}
.panel-tag{font-size:9px;letter-spacing:3px;color:var(--accent);border-bottom:1px solid var(--border);padding-bottom:10px;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:6px}
.panel-tag-btn{font-size:9px;letter-spacing:2px;color:var(--text-dim);transition:color .2s}
.panel-tag-btn:hover{color:var(--accent)}
.ap-tag{background:rgba(0,212,255,0.1);border:1px solid rgba(0,212,255,0.3);color:var(--accent);padding:2px 8px;font-size:9px;letter-spacing:2px;clip-path:var(--clip-sm)}
.timer-tag{display:flex;align-items:center;gap:4px;background:rgba(255,170,0,0.1);border:1px solid rgba(255,170,0,0.3);color:var(--warn);padding:2px 8px;font-size:10px;letter-spacing:1px;clip-path:var(--clip-sm)}
.bonus-tag{background:rgba(0,255,136,0.1);border:1px solid rgba(0,255,136,0.3);color:var(--success);padding:2px 8px;font-size:9px;letter-spacing:2px;clip-path:var(--clip-sm)}

/* VIEWS */
.view{display:none;padding:14px;flex:1}
.view.active{display:block}
.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;max-width:1000px;margin:0 auto}
@media(max-width:700px){.dashboard-grid{grid-template-columns:1fr}}

/* CHARACTER */
.character-card{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.char-avatar-wrap{position:relative;flex-shrink:0}
.char-rank-badge{position:absolute;bottom:-4px;right:-4px;width:22px;height:22px;background:var(--bg);border:1px solid var(--accent);clip-path:var(--clip-sm);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:var(--accent)}
.char-info{flex:1;min-width:90px}
.char-name{font-family:var(--font-serif);font-size:18px;color:var(--text-bright);letter-spacing:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.char-title-tag{font-size:9px;color:var(--accent);letter-spacing:2px;margin-top:2px;text-shadow:0 0 8px rgba(0,212,255,0.4)}
.char-job{font-size:10px;color:var(--text-dim);margin-top:4px}
.char-level-display{text-align:center;flex-shrink:0}
.lv-big-label{display:block;font-size:8px;letter-spacing:2px;color:var(--text-dim)}
.lv-big-num{display:block;font-family:var(--font-serif);font-size:38px;color:var(--accent);line-height:1;text-shadow:0 0 20px rgba(0,212,255,0.7)}
.xp-wrap{margin-bottom:10px}
.xp-header{display:flex;justify-content:space-between;font-size:9px;letter-spacing:2px;color:var(--text-dim);margin-bottom:4px}
.xp-bar-track{height:6px;background:var(--bg-panel2);border:1px solid var(--border-dim)}
.xp-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),rgba(0,212,255,0.4));box-shadow:0 0 8px rgba(0,212,255,0.5);transition:width .6s ease;width:0%}
.bars-section{margin-bottom:10px;display:flex;flex-direction:column;gap:6px}
.bar-row{display:flex;align-items:center;gap:8px}
.bar-icon{font-size:10px;width:38px;flex-shrink:0;display:flex;align-items:center;gap:3px}
.hp-color{color:var(--vit)} .mp-color{color:var(--int)}
.bar-track{flex:1;height:5px;background:var(--bg-panel2);border:1px solid var(--border-dim)}
.bar-fill{height:100%;transition:width .5s ease}
.hp-fill{background:var(--vit);box-shadow:0 0 5px rgba(255,61,138,0.5)}
.mp-fill{background:var(--int);box-shadow:0 0 5px rgba(160,106,255,0.5)}
.bar-val{font-size:10px;color:var(--text-dim);white-space:nowrap;width:70px;text-align:right}
.streak-row{font-size:11px;color:var(--text-dim);display:flex;align-items:center;gap:6px}

/* STATS */
.stats-list{display:flex;flex-direction:column;gap:10px}
.stat-row{display:flex;align-items:center;gap:8px}
.stat-icon-box{width:26px;height:26px;display:flex;align-items:center;justify-content:center;font-size:14px;border:1px solid rgba(255,255,255,0.08);clip-path:var(--clip-sm);flex-shrink:0}
.str-color{color:var(--str);background:rgba(255,101,53,0.1)} .vit-color{color:var(--vit);background:rgba(255,61,138,0.1)}
.agi-color{color:var(--agi);background:rgba(53,255,138,0.1)} .int-color{color:var(--int);background:rgba(160,106,255,0.1)} .per-color{color:var(--per);background:rgba(255,215,0,0.1)}
.stat-name{font-size:10px;letter-spacing:2px;width:28px;flex-shrink:0}
.stat-bar-track{flex:1;height:4px;background:var(--bg-panel2);border:1px solid var(--border-dim)}
.stat-bar-fill{height:100%;transition:width .5s ease}
.str-color-fill{background:var(--str);box-shadow:0 0 5px rgba(255,101,53,0.4)}
.vit-color-fill{background:var(--vit);box-shadow:0 0 5px rgba(255,61,138,0.4)}
.agi-color-fill{background:var(--agi);box-shadow:0 0 5px rgba(53,255,138,0.4)}
.int-color-fill{background:var(--int);box-shadow:0 0 5px rgba(160,106,255,0.4)}
.per-color-fill{background:var(--per);box-shadow:0 0 5px rgba(255,215,0,0.4)}
.stat-val{font-size:14px;font-weight:700;width:30px;text-align:right;color:var(--text-bright)}
.stat-plus{width:22px;height:22px;border:1px solid var(--warn);color:var(--warn);font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.stat-plus:hover{background:var(--warn);color:var(--bg)}

/* CHART */
.chart-wrap{display:flex;align-items:center;justify-content:center;padding:4px}
.chart-wrap canvas{max-width:100%;max-height:200px}

/* MINI LEADERBOARD */
.mini-rank-list{display:flex;flex-direction:column;gap:7px}
.mini-rank-row{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--bg-panel2);border:1px solid var(--border-dim);clip-path:var(--clip-sm)}
.mini-rank-row.is-me{border-color:var(--accent);background:var(--accent-dim)}
.mini-rank-pos{font-size:11px;color:var(--text-dim);width:18px;text-align:center}
.rank-pos-1{color:#ffd700} .rank-pos-2{color:#c0c0c0} .rank-pos-3{color:#cd7f32}
.mini-rank-name{flex:1;font-size:12px;color:var(--text-bright);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mini-rank-lv{font-size:11px;color:var(--accent)}
.mini-rank-badge{font-size:9px;padding:1px 5px;border:1px solid;clip-path:var(--clip-sm)}
.loading-row{font-size:10px;letter-spacing:3px;color:var(--text-dim);padding:12px;text-align:center;animation:blink 1.5s infinite}
@keyframes blink{50%{opacity:.3}}

/* QUESTS */
.quests-outer{max-width:660px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.date-tag{font-size:9px;color:var(--text-dim);letter-spacing:1px}
.quest-notification-bar{display:flex;align-items:center;gap:8px;background:var(--accent-dim);border:1px solid rgba(0,212,255,0.2);padding:8px 12px;font-size:11px;color:var(--text);margin-bottom:14px;clip-path:var(--clip-sm)}
.quest-section-label{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:10px;letter-spacing:3px;padding:6px 0;margin-bottom:10px;border-bottom:1px solid var(--border-dim)}
.quest-section-label>div{display:flex;align-items:center;gap:6px}
.str-label{color:var(--str)} .int-label{color:var(--int);margin-top:16px}
.reroll-counter{font-size:10px;letter-spacing:1px;color:var(--text-dim)}
.quest-list,.knowledge-list{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.quest-item{background:var(--bg-panel2);border:1px solid var(--border-dim);clip-path:var(--clip);padding:12px 14px;transition:border-color .3s}
.quest-item.completed{border-color:var(--success)}
.quest-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.quest-item-name{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-bright)}
.quest-item-name i{font-size:15px;color:var(--accent)}
.quest-item-header-right{display:flex;align-items:center;gap:8px}
.quest-item-target{font-size:12px;color:var(--text-dim)}
.quest-item-target.done{color:var(--success)}
.quest-track{height:5px;background:var(--bg);border:1px solid var(--border-dim);margin-bottom:8px}
.quest-track-fill{height:100%;background:linear-gradient(90deg,var(--accent),rgba(0,212,255,0.3));box-shadow:0 0 5px rgba(0,212,255,0.4);transition:width .4s ease}
.quest-item.completed .quest-track-fill{background:linear-gradient(90deg,var(--success),rgba(0,255,136,0.3))}
.quest-input-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.quest-input-label{font-size:10px;color:var(--text-dim)}
.quest-input{width:80px;background:var(--bg);border:1px solid var(--border);clip-path:var(--clip-sm);padding:5px 8px;color:var(--accent);font-size:14px;font-weight:700;text-align:center;outline:none}
.quest-input:focus{border-color:var(--accent)}
.quest-stat-tag{font-size:9px;letter-spacing:2px;padding:2px 6px;border:1px solid;clip-path:var(--clip-sm)}
.quest-checkmark{font-size:16px;color:var(--success)}
.knowledge-item{background:var(--bg-panel2);border:1px solid var(--border-dim);clip-path:var(--clip);padding:14px;transition:border-color .3s}
.knowledge-item.correct{border-color:var(--success)} .knowledge-item.wrong{border-color:var(--danger)}
.knowledge-q{font-size:13px;color:var(--text-bright);margin-bottom:12px;line-height:1.6}
.knowledge-opts{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.knowledge-opt{padding:8px 10px;background:var(--bg);border:1px solid var(--border-dim);clip-path:var(--clip-sm);font-size:11px;color:var(--text);text-align:left;cursor:pointer;transition:all .2s;letter-spacing:.5px;line-height:1.4}
.knowledge-opt:hover:not(.disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}
.knowledge-opt.selected-correct{border-color:var(--success);color:var(--success);background:rgba(0,255,136,0.1)}
.knowledge-opt.selected-wrong{border-color:var(--danger);color:var(--danger);background:rgba(255,52,52,0.1)}
.knowledge-opt.reveal-correct{border-color:var(--success);color:var(--success)}
.knowledge-opt.disabled{pointer-events:none;opacity:.7}
.knowledge-result{font-size:10px;letter-spacing:2px;margin-top:8px}
.knowledge-result.ok{color:var(--success)} .knowledge-result.bad{color:var(--danger)}
.quest-danger-bar{background:rgba(255,52,52,0.08);border:1px solid rgba(255,52,52,0.25);clip-path:var(--clip-sm);padding:10px 14px;font-size:11px;color:var(--text);margin-bottom:12px;line-height:1.7}
.danger-sense-bar{background:rgba(255,52,52,0.12);border:1px solid rgba(255,52,52,0.4);clip-path:var(--clip-sm);padding:10px 14px;font-size:11px;color:var(--danger);margin-bottom:12px;animation:pulse-red 2s infinite}
@keyframes pulse-red{0%,100%{box-shadow:0 0 0 rgba(255,52,52,0)}50%{box-shadow:0 0 12px rgba(255,52,52,0.3)}}
.penalty-word{color:var(--danger);font-weight:700}
.warn-icon{color:var(--warn);margin-right:4px}
.quest-done-msg{text-align:center;color:var(--success);font-size:12px;letter-spacing:2px;margin-top:10px}

/* ACTIVE SKILLS IN QUESTS */
.active-skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;margin-top:4px}
.active-skill-card{background:var(--bg-panel2);border:1px solid var(--border-dim);clip-path:var(--clip-sm);padding:12px;display:flex;flex-direction:column;gap:6px;transition:border-color .2s}
.active-skill-card:hover{border-color:var(--border)}
.active-skill-name{font-size:12px;color:var(--text-bright);font-weight:700}
.active-skill-desc{font-size:10px;color:var(--text-dim);line-height:1.5;flex:1}
.active-skill-cost{font-size:10px;letter-spacing:1px}
.skill-use-msg{text-align:center;font-size:11px;letter-spacing:2px;margin-top:10px;color:var(--accent)}

/* EXTRA TRAINING */
.extra-training-panel{}
.extra-form{display:flex;flex-direction:column;gap:10px}
.extra-toast{text-align:center;font-size:12px;letter-spacing:2px;padding:10px;background:rgba(0,255,136,0.08);border:1px solid rgba(0,255,136,0.3);clip-path:var(--clip-sm);color:var(--success);margin-top:10px}

/* REWARDS */
.rewards-got{text-align:center;font-size:12px;color:var(--text-dim);margin-bottom:14px}
.rewards-list{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.reward-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg-panel2);border:1px solid var(--border);clip-path:var(--clip-sm)}
.reward-num{color:var(--text-dim);font-size:12px;width:16px}
.reward-icon{font-size:18px;color:var(--warn)}
.reward-text{font-size:13px;color:var(--text-bright)}

/* SKILLS VIEW */
.skills-outer{max-width:800px;margin:0 auto}
.skills-intro{font-size:11px;color:var(--text-dim);letter-spacing:1px;line-height:1.7;margin-bottom:18px}
.skills-stat-tabs{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.skill-tab-btn{padding:8px 14px;background:var(--bg-panel2);border:1px solid var(--border-dim);clip-path:var(--clip-sm);font-size:10px;letter-spacing:2px;color:var(--text-dim);display:flex;align-items:center;gap:6px;transition:all .2s}
.skill-tab-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}
.skill-tab-btn:hover{color:var(--text);border-color:var(--border)}
.skills-grid{display:flex;flex-direction:column;gap:12px}
.skill-card{background:var(--bg-panel2);border:1px solid var(--border-dim);clip-path:var(--clip);padding:14px;display:flex;align-items:flex-start;gap:14px;transition:all .2s}
.skill-card.unlocked{border-color:var(--success)}
.skill-card.locked{opacity:.6}
.skill-card.available{border-color:var(--border);cursor:default}
.skill-icon-box{width:40px;height:40px;clip-path:var(--clip-sm);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;border:1px solid var(--border-dim)}
.skill-info{flex:1;min-width:0}
.skill-name-row{display:flex;align-items:center;gap:8px;margin-bottom:4px;flex-wrap:wrap}
.skill-name{font-size:13px;color:var(--text-bright);font-weight:700}
.skill-type-tag{font-size:8px;letter-spacing:2px;padding:2px 6px;border:1px solid;clip-path:var(--clip-sm)}
.type-passive{color:var(--agi);border-color:var(--agi)}
.type-active{color:var(--warn);border-color:var(--warn)}
.skill-desc{font-size:11px;color:var(--text-dim);line-height:1.6;margin-bottom:8px}
.skill-req{font-size:9px;color:var(--text-dim);letter-spacing:1px;margin-bottom:8px}
.skill-cost-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:6px}
.skill-cost{font-size:11px;color:var(--warn)}
.skill-unlocked-badge{font-size:10px;color:var(--success);letter-spacing:2px}
.skill-unlock-msg{text-align:center;font-size:11px;letter-spacing:2px;margin-top:12px;min-height:16px;color:var(--accent)}

/* RANKING */
.ranking-panel{max-width:700px;margin:0 auto;position:relative;overflow:visible}
.rank-subtitle{font-size:10px;letter-spacing:2px;color:var(--text-dim);margin-bottom:16px}
.ranking-list{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.rank-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-panel2);border:1px solid var(--border-dim);clip-path:var(--clip);transition:border-color .2s}
.rank-row.is-me{border-color:var(--accent);background:var(--accent-dim);box-shadow:0 0 20px rgba(0,212,255,0.08)}
.rank-position{font-family:var(--font-serif);font-size:20px;width:32px;text-align:center;flex-shrink:0}
.pos-1{color:#ffd700;text-shadow:0 0 12px rgba(255,215,0,0.6)} .pos-2{color:#c0c0c0} .pos-3{color:#cd7f32} .pos-other{font-size:13px;color:var(--text-dim);font-family:var(--font-mono)}
.rank-avatar{width:34px;height:34px;clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);background:var(--accent-dim);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-size:15px;color:var(--accent);flex-shrink:0}
.rank-name-col{flex:1;min-width:0}
.rank-hunter-name{font-size:13px;color:var(--text-bright);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rank-hunter-title{font-size:9px;letter-spacing:2px;color:var(--text-dim)}
.rank-stats{display:flex;align-items:center;gap:8px;flex-shrink:0}
.rank-lv{font-size:18px;font-weight:700;color:var(--accent)}
.rank-lv-label{font-size:8px;color:var(--text-dim);letter-spacing:1px}
.rank-badge{font-size:10px;padding:2px 6px;border:1px solid;clip-path:var(--clip-sm);letter-spacing:2px;white-space:nowrap}
.badge-E{color:#888;border-color:#888} .badge-D{color:#66d9ff;border-color:#66d9ff} .badge-C{color:#66ff99;border-color:#66ff99}
.badge-B{color:#ffaa33;border-color:#ffaa33} .badge-A{color:#ff6666;border-color:#ff6666} .badge-S{color:var(--per);border-color:var(--per)}
.badge-N{color:#ff3d8a;border-color:#ff3d8a} .badge-SM{color:var(--accent);border-color:var(--accent)}
.my-rank-row{text-align:center;font-size:11px;color:var(--text-dim);letter-spacing:2px;padding:8px}

/* LEVEL UP */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,0.9);display:flex;align-items:center;justify-content:center;z-index:9000;backdrop-filter:blur(4px)}
.levelup-box{text-align:center;padding:32px 24px;max-width:360px;width:100%;position:relative}
.levelup-ring{width:160px;height:160px;border:2px solid var(--accent);border-radius:50%;margin:0 auto 20px;animation:spin 3s linear infinite,hex-pulse 1.5s ease-in-out infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.levelup-center{position:absolute;top:52px;left:50%;transform:translateX(-50%);width:140px}
.levelup-announce{font-size:10px;letter-spacing:6px;color:var(--accent);text-shadow:0 0 15px rgba(0,212,255,0.8);margin-bottom:4px}
.levelup-num{font-family:var(--font-serif);font-size:64px;color:var(--accent);text-shadow:0 0 40px rgba(0,212,255,0.9);line-height:1}
.levelup-title-gained{font-size:11px;letter-spacing:3px;color:var(--warn);margin-bottom:14px}
.levelup-gains{display:flex;flex-wrap:wrap;justify-content:center;gap:6px;margin-bottom:20px}
.gain-chip{padding:4px 10px;border:1px solid var(--border);clip-path:var(--clip-sm);font-size:11px;color:var(--success)}

/* SL POPUPS */
.sl-popup{position:relative;background:linear-gradient(135deg,#0a1628 0%,#0d1f3e 50%,#0a1628 100%);border:1px solid rgba(0,212,255,0.4);padding:32px 28px;max-width:380px;width:90%;text-align:center;box-shadow:0 0 60px rgba(0,212,255,0.15);animation:popup-appear .4s cubic-bezier(0.16,1,0.3,1)}
@keyframes popup-appear{from{opacity:0;transform:scale(0.85)}to{opacity:1;transform:scale(1)}}
.slc{position:absolute;width:20px;height:20px;border-color:var(--accent);border-style:solid;opacity:.8}
.slc-tl{top:8px;left:8px;border-width:2px 0 0 2px} .slc-tr{top:8px;right:8px;border-width:2px 2px 0 0}
.slc-bl{bottom:8px;left:8px;border-width:0 0 2px 2px} .slc-br{bottom:8px;right:8px;border-width:0 2px 2px 0}
.sl-popup-ornament{color:rgba(0,212,255,0.4);font-size:12px;letter-spacing:8px;margin-bottom:14px}
.sl-popup-header{font-size:13px;letter-spacing:4px;color:var(--accent);margin-bottom:20px;display:flex;align-items:center;justify-content:center;gap:8px}
.sl-popup-header i{font-size:18px;color:var(--warn)}
.sl-popup-body{font-family:var(--font-serif);font-size:26px;color:var(--text-bright);letter-spacing:2px;margin-bottom:12px}
.sl-bracket{color:var(--accent);opacity:.7}
.sl-name{color:#00ff88;text-shadow:0 0 15px rgba(0,255,136,0.7)}
.sl-popup-sub{font-size:11px;color:var(--text-dim);letter-spacing:1.5px;line-height:1.8;margin-bottom:22px}
.sl-btn{margin-top:0}
.quest-info-popup{max-width:420px}
.qi-title{font-size:14px;font-weight:700;color:var(--text-bright);letter-spacing:1px;margin-bottom:20px;line-height:1.5}
.qi-goals-label{font-size:12px;letter-spacing:4px;color:#00ff88;text-shadow:0 0 12px rgba(0,255,136,0.6);margin-bottom:14px}
.qi-goals{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;text-align:left}
.qi-goal-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--text);padding:4px 0;border-bottom:1px solid var(--border-dim)}
.qi-goal-row:last-child{border-bottom:none}
.qi-goal-target{color:var(--accent);font-weight:700}
.qi-caution{font-size:11px;color:var(--text);letter-spacing:.5px;line-height:1.8;margin-bottom:16px;padding:10px;background:rgba(255,52,52,0.06);border:1px solid rgba(255,52,52,0.2)}
.qi-caution-word{color:var(--danger);font-weight:700;letter-spacing:1px}
.qi-timer-icon{font-size:28px;color:var(--accent);margin-bottom:16px;opacity:.6}

/* LOADING OVERLAY */
.loading-overlay{position:fixed;inset:0;background:rgba(6,9,15,0.92);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:99999;gap:16px;backdrop-filter:blur(4px)}
.loading-overlay.hidden{display:none!important}
.loading-spinner{width:48px;height:48px;border:3px solid rgba(0,212,255,0.15);border-top-color:#00d4ff;border-radius:50%;animation:spin 0.8s linear infinite}
.loading-text{font-size:11px;letter-spacing:4px;color:var(--accent)}
.footer{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--border-dim);margin-top:16px}
.footer-copy{font-size:10px;letter-spacing:2px;color:var(--text-dim)}
.icons{display:flex;gap:10px;align-items:center}
.icon{width:34px;height:34px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--text-dim);transition:all .3s}
.icon:hover{animation:shake .4s ease}
@keyframes shake{0%,100%{transform:rotate(0)}20%{transform:rotate(-10deg)}40%{transform:rotate(10deg)}60%{transform:rotate(-6deg)}80%{transform:rotate(6deg)}}
.icon--instagram:hover{color:#e1306c;border-color:#e1306c;box-shadow:0 0 12px rgba(225,48,108,0.4);background:rgba(225,48,108,0.1)}
.icon--email:hover{color:var(--accent);border-color:var(--accent);box-shadow:0 0 12px rgba(0,212,255,0.4);background:var(--accent-dim)}

/* RESPONSIVE */
@media(max-width:480px){
  .topbar{padding:0 8px}
  .topbar-title{font-size:13px;letter-spacing:2px}
  .nav-btn{padding:4px 5px;min-width:44px}
  .nav-btn span{font-size:6px}
  .auth-title{font-size:26px}
  .hex-outer{width:60px;height:60px}
  .auth-hex-logo{width:54px;height:54px}
  .knowledge-opts{grid-template-columns:1fr}
  .char-name{font-size:15px}
  .lv-big-num{font-size:30px}
  .sl-popup{padding:20px 16px}
  .sl-popup-body{font-size:20px}
  .active-skills-grid{grid-template-columns:1fr}
}

/* ── BADGES ── */
.user-badge {
  display:inline-flex;align-items:center;gap:4px;
  font-size:9px;letter-spacing:2px;padding:2px 8px;
  border:1px solid;clip-path:polygon(0 0,calc(100% - 6px) 0,100% 6px,100% 100%,6px 100%,0 calc(100% - 6px));
  font-weight:700;
}
.char-badges { display:flex;flex-wrap:wrap;gap:6px;margin-top:6px; }
.rank-badges { display:flex;flex-wrap:wrap;gap:4px;margin-top:4px; }
 
/* ── OFFLINE BANNER ── */
.offline-banner {
  position:fixed;top:0;left:0;right:0;z-index:9999;
  background:var(--danger);color:#fff;
  font-size:11px;letter-spacing:1px;padding:8px 16px;
  display:flex;align-items:center;gap:8px;justify-content:center;
  animation:slideDown .3s ease;
}
@keyframes slideDown { from{transform:translateY(-100%)} to{transform:translateY(0)} }

/* ── FORGOT PASSWORD / LINK BUTTON ── */
.auth-forgot { margin-top:10px;text-align:center; }
.link-btn {
  background:none;border:none;color:var(--accent);
  font-size:11px;letter-spacing:1px;cursor:pointer;
  text-decoration:underline;padding:0;font-family:inherit;
  opacity:.7;transition:opacity .2s;
}
.link-btn:hover { opacity:1; }
.btn-secondary {
  display:flex;align-items:center;gap:6px;
  background:transparent;border:1px solid var(--border);
  color:var(--text);padding:10px 18px;cursor:pointer;
  font-family:var(--font-mono);font-size:12px;letter-spacing:2px;
  clip-path:var(--clip);transition:border-color .2s;
}
.btn-secondary:hover { border-color:var(--text); }

/* ── DANGER LINK (delete account) ── */
.danger-link {
  color: var(--danger) !important;
  opacity: .45;
  font-size: 10px;
  letter-spacing: 1px;
  margin-top: 6px;
  display: block;
  text-align: center;
}
.danger-link:hover { opacity: .9; }

/* ═══════════════════════════════════════
   v3.1 — JOB CLASSES + RENAME
═══════════════════════════════════════ */

/* char name row with rename button */
.char-name-row { display:flex; align-items:center; gap:8px; }

/* job select button under char-job */
#job-select-btn {
  margin-top:6px; font-size:9px; letter-spacing:1.5px;
  padding:5px 12px; width:auto; justify-content:center; gap:6px;
}

/* job class overlay */
.job-popup { max-width:500px; }
.job-grid  { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin:4px 0 8px; }
@media(max-width:480px) { .job-grid { grid-template-columns:1fr; } }

.job-card {
  background:var(--bg-panel2); border:1px solid var(--border-dim);
  clip-path:var(--clip-sm); padding:12px 14px; text-align:left;
  cursor:pointer; transition:border-color .2s, background .2s;
  display:flex; flex-direction:column; gap:5px;
}
.job-card:hover   { border-color:var(--border); background:rgba(0,212,255,0.04); }
.job-card.selected{ border-color:var(--accent); background:var(--accent-dim); }

.job-card-header { display:flex; align-items:center; gap:8px; }
.job-card-icon   { font-size:18px; }
.job-card-name   { font-size:12px; font-weight:700; letter-spacing:2px; }
.job-card-bonus  {
  font-size:9px; letter-spacing:1px; color:var(--accent);
  padding:2px 7px; border:1px solid rgba(0,212,255,0.3);
  clip-path:var(--clip-sm); display:inline-block; width:fit-content;
}
.job-card-desc { font-size:10px; color:var(--text-dim); line-height:1.5; }

.job-confirm-bar {
  background:rgba(0,212,255,0.05); border:1px solid rgba(0,212,255,0.25);
  clip-path:var(--clip-sm); padding:10px 14px; margin-top:8px;
  display:flex; align-items:center; justify-content:space-between;
  gap:10px; flex-wrap:wrap;
}
#job-confirm-text { font-size:11px; color:var(--text-bright); letter-spacing:1px; flex:1; }
.job-confirm-btns { display:flex; gap:8px; align-items:center; }
#job-back-btn { padding:6px 12px; font-size:10px; letter-spacing:1px; width:auto; }
