/* styles.css — SetQuest UI (extracted from index.html) */
/* offline — system fonts used */

/* Portrait frames */
.portrait-wrap{position:relative;display:inline-block;}
.portrait-frame{position:absolute;inset:-6px;border-radius:50%;pointer-events:none;}
.frame-none{}
.frame-gold{box-shadow:0 0 0 3px var(--gold),0 0 16px rgba(201,168,76,.4);}
.frame-fire{box-shadow:0 0 0 3px #e74c3c,0 0 16px rgba(231,76,60,.4);}
.frame-arcane{box-shadow:0 0 0 3px #9b59b6,0 0 16px rgba(155,89,182,.4);}
.frame-nature{box-shadow:0 0 0 3px #27ae60,0 0 16px rgba(39,174,96,.4);}
.frame-ice{box-shadow:0 0 0 3px #3498db,0 0 16px rgba(52,152,219,.4);}
.frame-shadow{box-shadow:0 0 0 3px #2c3e50,0 0 16px rgba(44,62,80,.6);}
/* Title badge */
.hero-title-badge{display:inline-block;font-size:.6rem;letter-spacing:.12em;padding:2px 8px;border-radius:3px;margin-top:3px;font-family:'Cinzel',serif;}
/* Heatmap */
.heatmap-wrap{display:flex;gap:12px;justify-content:center;padding:8px 0;}
.heatmap-label{font-size:.6rem;color:var(--text-faint);text-anchor:middle;}
/* AI suggestion panel */
.ai-suggest{background:rgba(155,89,182,.06);border:1px solid rgba(155,89,182,.3);border-radius:8px;padding:14px;margin-bottom:12px;}
.ai-suggest .ai-title{font-family:'Cinzel',serif;font-size:.78rem;color:var(--purple-light);letter-spacing:.08em;margin-bottom:8px;display:flex;align-items:center;gap:6px;}
.ai-suggest .ai-body{font-size:.8rem;color:var(--text-dim);line-height:1.7;}
.ai-suggest .ai-loading{color:var(--text-faint);font-style:italic;font-size:.78rem;}
/* Avatar customizer */
.avatar-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px;}
.avatar-opt{border:1px solid var(--border);border-radius:6px;padding:8px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg3);}
.avatar-opt:hover{border-color:var(--border-strong);}
.avatar-opt.selected{border-color:var(--gold);background:rgba(201,168,76,.06);}
.avatar-opt .ao-label{font-size:.6rem;color:var(--text-faint);margin-top:4px;letter-spacing:.06em;}
.title-opt{border:1px solid var(--border);border-radius:4px;padding:5px 8px;cursor:pointer;font-size:.7rem;color:var(--text-dim);transition:all .2s;background:var(--bg3);}
.title-opt:hover{border-color:var(--border-strong);color:var(--text);}
.title-opt.selected{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,.06);}

:root {
  --gold:#c9a84c;--gold-light:#f0d080;--gold-dark:#8a6a20;
  --bg:#0d0a06;--bg2:#16120a;--bg3:#1e1810;--bg4:#252015;
  --red:#c0392b;--red-light:#e74c3c;
  --green:#27ae60;--green-light:#2ecc71;
  --blue:#2980b9;--blue-light:#3498db;
  --purple:#8e44ad;--purple-light:#9b59b6;
  --teal:#1abc9c;--teal-light:#48d1bb;
  --pink:#e91e8c;--pink-light:#ff5ab5;
  --cyan:#00bcd4;--cyan-light:#4dd0e1;
  --border:rgba(201,168,76,0.25);--border-strong:rgba(201,168,76,0.6);
  --text:#e8d5a3;--text-dim:#9a8660;--text-faint:#5a4e36;
  --wis-color:#9b59b6;--int-color:#00bcd4;
  --str-color:#e67e22;--end-color:#27ae60;--agi-color:#3498db;
  --monk-color:#f39c12;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{background:var(--bg);color:var(--text);font-family:'Crimson Pro',Georgia,serif;font-size:17px;min-height:100vh;overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 40px,rgba(201,168,76,.012) 40px,rgba(201,168,76,.012) 41px),repeating-linear-gradient(90deg,transparent,transparent 40px,rgba(201,168,76,.012) 40px,rgba(201,168,76,.012) 41px);pointer-events:none;z-index:0}
.app{position:relative;z-index:1;max-width:900px;margin:0 auto;padding:0 0 80px}
.site-header{text-align:center;padding:24px 16px 14px;border-bottom:1px solid var(--border);margin-bottom:14px}
.site-header h1{font-family:'Cinzel',serif;font-size:1.9rem;font-weight:900;color:var(--gold);letter-spacing:.12em;text-shadow:0 0 40px rgba(201,168,76,.4)}
.site-header .tagline{font-size:.82rem;color:var(--text-dim);letter-spacing:.15em;margin-top:2px;font-style:italic}
.status-bar{font-size:.72rem;color:var(--text-faint);margin-top:5px;letter-spacing:.05em}
.nav{display:flex;gap:4px;padding:0 10px 10px;flex-wrap:wrap;justify-content:center}
.subnav{display:flex;gap:4px;padding:4px 10px 10px;flex-wrap:wrap;justify-content:center;border-top:1px solid var(--border);margin-top:-2px;background:rgba(0,0,0,.15)}
.nav button{font-family:'Cinzel',serif;font-size:.68rem;letter-spacing:.07em;padding:6px 11px;border:1px solid var(--border);border-radius:3px;background:transparent;color:var(--text-dim);cursor:pointer;transition:all .2s;position:relative}
.tab-badge{position:absolute;top:-5px;right:-5px;background:#e74c3c;color:#fff;font-size:.55rem;font-family:sans-serif;min-width:14px;height:14px;border-radius:7px;display:flex;align-items:center;justify-content:center;padding:0 3px;font-weight:700;box-shadow:0 1px 3px rgba(0,0,0,.4)}
.nav button:hover{border-color:var(--border-strong);color:var(--text)}
.nav button.active{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,.08);text-shadow:0 0 12px rgba(201,168,76,.5)}
.subnav button{font-family:'Cinzel',serif;font-size:.62rem;letter-spacing:.07em;padding:5px 10px;border:1px solid var(--border);border-radius:3px;background:transparent;color:var(--text-faint);cursor:pointer;transition:all .2s;position:relative}
.subnav button:hover{border-color:var(--border-strong);color:var(--text-dim)}
.subnav button.active{border-color:rgba(201,168,76,.6);color:var(--gold-light);background:rgba(201,168,76,.06)}
.page{display:none;padding:0 12px;animation:fadeIn .3s ease}.page.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.card{background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:16px;margin-bottom:12px;position:relative;overflow:hidden}
.card::before{content:'';position:absolute;inset:0;border-radius:6px;background:linear-gradient(135deg,rgba(201,168,76,.04) 0%,transparent 60%);pointer-events:none}
.card-title{font-family:'Cinzel',serif;font-size:.82rem;color:var(--gold);letter-spacing:.1em;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.card-title::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,var(--border-strong),transparent)}
.hero-panel{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
@media(max-width:600px){.hero-panel{grid-template-columns:1fr}}
.character-card{background:var(--bg2);border:1px solid var(--border-strong);border-radius:6px;padding:16px;position:relative;overflow:hidden}
.character-card::before{content:'';position:absolute;top:-40px;right:-40px;width:120px;height:120px;background:radial-gradient(circle,rgba(201,168,76,.08) 0%,transparent 70%);pointer-events:none}
.char-name{font-family:'Cinzel',serif;font-size:1.25rem;color:var(--gold-light);font-weight:600}
.char-class{font-size:.78rem;color:var(--text-dim);letter-spacing:.08em;font-style:italic;margin-bottom:10px}
.char-level{font-family:'Cinzel',serif;font-size:2.2rem;font-weight:900;color:var(--gold);line-height:1}
.char-level-label{font-size:.68rem;color:var(--text-dim);letter-spacing:.15em}
/* class-tinted borders */
.class-warrior .character-card{border-color:rgba(230,126,34,.7)}
.class-thief .character-card{border-color:rgba(52,152,219,.7)}
.class-necromancer .character-card{border-color:rgba(0,188,212,.7)}
.class-psionicist .character-card{border-color:rgba(155,89,182,.7)}
.class-monk .character-card{border-color:rgba(243,156,18,.7)}
.class-druid .character-card{border-color:rgba(39,174,96,.7)}
.stat-row{margin-bottom:7px}
.stat-label{display:flex;justify-content:space-between;font-size:.73rem;color:var(--text-dim);margin-bottom:3px;letter-spacing:.04em}
.stat-label span:last-child{color:var(--text);font-weight:600}
.bar-track{height:6px;background:rgba(255,255,255,.05);border-radius:4px;overflow:hidden;border:1px solid rgba(255,255,255,.06)}
.bar-fill{height:100%;border-radius:4px;transition:width .6s cubic-bezier(.4,0,.2,1)}
.bar-xp{background:linear-gradient(90deg,#c9902c,#f0d080)}
.bar-hp{background:linear-gradient(90deg,#c0392b,#e74c3c)}
.bar-str{background:linear-gradient(90deg,#c0581a,#e67e22)}
.bar-end{background:linear-gradient(90deg,#1a8a40,#27ae60)}
.bar-agi{background:linear-gradient(90deg,#1a6aa0,#3498db)}
.bar-wis{background:linear-gradient(90deg,#6a2a8a,#9b59b6)}
.bar-int{background:linear-gradient(90deg,#007b99,#00bcd4)}
.bar-mana{background:linear-gradient(90deg,#4a1580,#9b59b6)}
.bar-stamina{background:linear-gradient(90deg,#b8860b,#f0c040)}
.stamina-glow{text-shadow:0 0 6px rgba(240,192,64,.5)}
.enemy-card{background:var(--bg3);border:1px solid rgba(192,57,43,.4);border-radius:6px;padding:16px;position:relative;overflow:hidden}
.enemy-card::before{content:'';position:absolute;top:-30px;left:-30px;width:100px;height:100px;background:radial-gradient(circle,rgba(192,57,43,.12) 0%,transparent 70%);pointer-events:none}
.enemy-name{font-family:'Cinzel',serif;font-size:1.05rem;color:var(--red-light);font-weight:600}
.enemy-type{font-size:.73rem;color:var(--text-dim);font-style:italic;margin-bottom:8px}
.enemy-art{font-size:3.2rem;text-align:center;margin:6px 0;filter:drop-shadow(0 0 12px rgba(192,57,43,.5))}
/* magic enemy variant */
.enemy-magic{border-color:rgba(155,89,182,.5)}
.enemy-magic::before{background:radial-gradient(circle,rgba(155,89,182,.12) 0%,transparent 70%)}
.enemy-magic .enemy-name{color:var(--purple-light)}
.enemy-psi{border-color:rgba(0,188,212,.4)}
.enemy-psi::before{background:radial-gradient(circle,rgba(0,188,212,.1) 0%,transparent 70%)}
.enemy-psi .enemy-name{color:var(--cyan-light)}
.combat-log{background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:10px;font-size:.8rem;color:var(--text-dim);min-height:60px;max-height:220px;overflow-y:auto;font-style:italic;line-height:1.65;scrollbar-width:thin;scrollbar-color:var(--gold-dark) var(--bg3)}
.combat-log>div{padding:3px 6px;margin:1px 0;border-radius:3px;border-left:2px solid transparent;transition:background-color .15s}
.combat-log>div:has(.crit){border-left-color:var(--gold);background:rgba(201,168,76,.04)}
.combat-log>div:has(.level){border-left-color:#9b59b6;background:rgba(155,89,182,.06)}
.combat-log>div:has(.loot){border-left-color:var(--gold-dark)}
.combat-log>div:has(.heal){border-left-color:#27ae60}
.combat-log::-webkit-scrollbar{width:5px}
.combat-log::-webkit-scrollbar-track{background:var(--bg3);border-radius:3px}
.combat-log::-webkit-scrollbar-thumb{background:var(--gold-dark);border-radius:3px}
.combat-log::-webkit-scrollbar-thumb:hover{background:var(--gold)}
.chronicle-scroll::-webkit-scrollbar{width:6px}
.chronicle-scroll::-webkit-scrollbar-track{background:rgba(0,0,0,.2);border-radius:3px}
.chronicle-scroll::-webkit-scrollbar-thumb{background:var(--gold-dark);border-radius:3px}
.chronicle-scroll::-webkit-scrollbar-thumb:hover{background:var(--gold)}
.combat-log .hit{color:#e74c3c}.combat-log .crit{color:#f39c12;font-weight:600}.combat-log .magic{color:#9b59b6;font-weight:600}.combat-log .psi{color:#00bcd4;font-weight:600}.combat-log .shadow{color:#3498db}.combat-log .heal{color:#27ae60}.combat-log .loot{color:var(--gold)}.combat-log .level{color:#9b59b6;font-weight:600}.combat-log .wisdom{color:#e91e8c}
/* active workout */
.am-header{background:linear-gradient(135deg,#1a0f00,#2a1a08);border:1px solid var(--border-strong);border-radius:6px 6px 0 0;padding:16px;display:flex;justify-content:space-between;align-items:flex-start}
.am-ex-title{font-family:'Cinzel',serif;font-size:1.15rem;color:var(--gold-light);font-weight:600}
.am-ex-sub{font-size:.76rem;color:var(--text-dim);margin-bottom:4px;letter-spacing:.04em}
.am-elapsed{font-family:'Cinzel',serif;font-size:1.5rem;color:var(--gold);font-weight:600;text-align:right}
.am-body{background:var(--bg2);border:1px solid var(--border);border-top:none;border-radius:0 0 6px 6px;margin-bottom:12px}
.am-section{padding:13px 16px;border-bottom:1px solid var(--border)}.am-section:last-child{border-bottom:none}
.am-label{font-family:'Cinzel',serif;font-size:.68rem;color:var(--gold-dark);letter-spacing:.1em;margin-bottom:9px}
.big-inputs{display:flex;gap:10px;align-items:flex-end}
.bi{flex:1}.bi label{display:block;font-size:.7rem;color:var(--text-dim);margin-bottom:4px;letter-spacing:.04em}
.bi input{width:100%;font-family:'Cinzel',serif;font-size:2.1rem;font-weight:600;color:var(--gold-light);background:transparent;border:none;border-bottom:2px solid var(--gold-dark);padding-bottom:3px;text-align:center}
.bi input:focus{outline:none;border-bottom-color:var(--gold)}
.bi.hr input{border-bottom-color:rgba(192,57,43,.6);color:#e74c3c}
.log-set-btn{width:52px;height:52px;border-radius:50%;background:var(--gold-dark);border:2px solid var(--gold);color:var(--bg);font-size:1.1rem;cursor:pointer;font-family:'Cinzel',serif;font-weight:600;flex-shrink:0;transition:all .15s}
.log-set-btn:active{transform:scale(.94)}
.last-ref{display:flex;justify-content:space-between;align-items:center;background:rgba(201,168,76,.05);border:1px solid var(--border);border-radius:4px;padding:7px 11px;margin-bottom:9px}
.last-ref .lr-label{font-size:.7rem;color:var(--text-faint)}.last-ref .lr-val{font-size:.86rem;color:var(--gold);font-weight:600}
.set-chips{display:flex;gap:5px;margin-top:7px}
.set-chip{flex:1;padding:6px 3px;border-radius:4px;text-align:center;border:1px solid var(--border);background:var(--bg3);font-size:.68rem;color:var(--text-faint)}
.set-chip.done{background:rgba(201,168,76,.1);border-color:var(--gold-dark);color:var(--gold)}
.set-chip.current{background:rgba(201,168,76,.15);border:2px solid var(--gold);color:var(--gold-light)}
.set-chip .cv{font-size:.76rem;font-weight:600;margin-top:2px}
.rest-row{display:flex;align-items:center;gap:12px;padding:11px 16px;border-bottom:1px solid var(--border)}
.rest-val{font-family:'Cinzel',serif;font-size:1.35rem;color:var(--gold);min-width:48px}
.rest-track{flex:1;height:5px;background:rgba(255,255,255,.05);border-radius:3px;overflow:hidden}
.rest-fill{height:5px;background:linear-gradient(90deg,var(--gold-dark),var(--gold));border-radius:3px;transition:width .5s linear}
.progress-pips{display:flex;gap:5px;justify-content:center;padding:9px 0}
.pip{width:7px;height:7px;border-radius:50%;background:var(--bg4);border:1px solid var(--border)}
.pip.done{background:var(--gold-dark);border-color:var(--gold)}
.pip.current{background:var(--gold);border-color:var(--gold-light);width:18px;border-radius:4px}
.ex-nav{display:flex;gap:7px;padding:11px 16px}
.enb{flex:1;padding:9px 7px;border:1px solid var(--border);border-radius:4px;text-align:center;cursor:pointer;background:var(--bg3);transition:all .15s}
.enb:hover{border-color:var(--border-strong)}.enb.nxt{border-color:var(--gold-dark);background:rgba(201,168,76,.08)}.enb.nxt:hover{border-color:var(--gold)}
.enb .nd{font-size:.63rem;color:var(--text-faint);letter-spacing:.04em}.enb.nxt .nd{color:var(--gold-dark)}
.enb .nn{font-size:.8rem;color:var(--text);margin-top:2px;font-weight:600}.enb.nxt .nn{color:var(--gold-light)}
.btn-primary{font-family:'Cinzel',serif;font-size:.8rem;letter-spacing:.09em;padding:10px 20px;border:1px solid var(--gold);border-radius:4px;background:rgba(201,168,76,.12);color:var(--gold-light);cursor:pointer;transition:all .2s}
.btn-primary:hover{background:rgba(201,168,76,.2);box-shadow:0 0 20px rgba(201,168,76,.2)}.btn-primary:active{transform:scale(.97)}
.btn-magic{font-family:'Cinzel',serif;font-size:.78rem;letter-spacing:.08em;padding:10px 18px;border:1px solid rgba(155,89,182,.6);border-radius:4px;background:rgba(155,89,182,.1);color:var(--purple-light);cursor:pointer;transition:all .2s}
.btn-magic:hover{background:rgba(155,89,182,.2)}.btn-magic:active{transform:scale(.97)}
.btn-psi{font-family:'Cinzel',serif;font-size:.78rem;letter-spacing:.08em;padding:10px 18px;border:1px solid rgba(0,188,212,.5);border-radius:4px;background:rgba(0,188,212,.08);color:var(--cyan-light);cursor:pointer;transition:all .2s}
.btn-psi:hover{background:rgba(0,188,212,.18)}.btn-psi:active{transform:scale(.97)}
.btn-thief{font-family:'Cinzel',serif;font-size:.78rem;letter-spacing:.08em;padding:10px 18px;border:1px solid rgba(52,152,219,.5);border-radius:4px;background:rgba(52,152,219,.08);color:var(--blue-light);cursor:pointer;transition:all .2s}
.btn-thief:hover{background:rgba(52,152,219,.18)}.btn-thief:active{transform:scale(.97)}
.btn-danger{font-family:'Cinzel',serif;font-size:.8rem;letter-spacing:.07em;padding:8px 16px;border:1px solid rgba(192,57,43,.5);border-radius:4px;background:rgba(192,57,43,.1);color:var(--red-light);cursor:pointer;transition:all .2s}
.btn-sm{font-size:.7rem;padding:4px 10px;border:1px solid var(--border);border-radius:3px;background:transparent;color:var(--text-dim);cursor:pointer;transition:all .15s}
.btn-sm:hover{border-color:var(--border-strong);color:var(--text)}
.btn-ghost{font-size:.76rem;padding:6px 11px;border:1px solid var(--border);border-radius:3px;background:transparent;color:var(--text-dim);cursor:pointer;transition:all .15s}
.btn-ghost.sel{border-color:var(--gold-dark);color:var(--gold);background:rgba(201,168,76,.08)}
.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;margin-bottom:14px}
.day-pill{border:1px solid var(--border);border-radius:4px;padding:7px 3px;text-align:center;cursor:pointer;background:var(--bg3);transition:all .15s}
.day-pill:hover{border-color:var(--border-strong)}.day-pill .dn{font-size:.63rem;color:var(--text-faint)}.day-pill .dt{font-size:.7rem;font-weight:600;margin-top:3px}
.day-pill.strength .dt{color:var(--str-color)}.day-pill.cardio .dt{color:var(--end-color)}.day-pill.rest .dt{color:var(--text-faint)}.day-pill.today-p{border-color:var(--gold-dark);background:rgba(201,168,76,.08)}
.log-entry{display:flex;align-items:flex-start;gap:10px;padding:9px 0;border-bottom:1px solid var(--border)}.log-entry:last-child{border-bottom:none}
.badge{display:inline-block;font-size:.62rem;padding:2px 7px;border-radius:3px;letter-spacing:.04em;font-family:'Cinzel',serif}
.badge-s{background:rgba(230,126,34,.15);border:1px solid rgba(230,126,34,.3);color:#e67e22}
.badge-c{background:rgba(39,174,96,.15);border:1px solid rgba(39,174,96,.3);color:var(--green-light)}
.badge-m{background:rgba(155,89,182,.15);border:1px solid rgba(155,89,182,.3);color:var(--purple-light)}
.badge-p{background:rgba(0,188,212,.12);border:1px solid rgba(0,188,212,.3);color:var(--cyan-light)}
.badge-t{background:rgba(52,152,219,.12);border:1px solid rgba(52,152,219,.3);color:var(--blue-light)}
.badge-r{background:rgba(127,140,141,.1);border:1px solid rgba(127,140,141,.2);color:#7f8c8d}
.badge-xp{background:rgba(241,196,15,.12);border:1px solid rgba(241,196,15,.3);color:#f1c40f}
.badge-hr{background:rgba(192,57,43,.12);border:1px solid rgba(192,57,43,.3);color:var(--red-light)}
/* class select on onboarding */
.class-pick-row{display:flex;gap:10px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.class-pick-row::-webkit-scrollbar{height:5px}.class-pick-row::-webkit-scrollbar-track{background:var(--bg3);border-radius:3px}.class-pick-row::-webkit-scrollbar-thumb{background:var(--gold-dark);border-radius:3px}.class-pick-row::-webkit-scrollbar-thumb:hover{background:var(--gold)}
.class-pick{min-width:240px;max-width:260px;flex-shrink:0;scroll-snap-align:center;border:1px solid var(--border);border-radius:8px;padding:16px;cursor:pointer;background:var(--bg3);transition:all .2s;text-align:left}
.class-pick:hover{border-color:var(--border-strong)}
.class-pick.sel{border-width:2px}
.class-pick.warrior.sel{border-color:var(--str-color);background:rgba(230,126,34,.07)}
.class-pick.thief.sel{border-color:var(--agi-color);background:rgba(52,152,219,.07)}
.class-pick.necromancer.sel{border-color:var(--int-color);background:rgba(0,188,212,.07)}
.class-pick.psionicist.sel{border-color:var(--wis-color);background:rgba(155,89,182,.07)}
.class-pick.monk.sel{border-color:var(--monk-color);background:rgba(243,156,18,.07)}
.class-pick.druid.sel{border-color:var(--green-light);background:rgba(39,174,96,.07)}
.class-pick .cp-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.class-pick .ci{font-size:2rem;line-height:1}
.class-pick .cn{font-family:'Cinzel',serif;font-size:.9rem;font-weight:600;letter-spacing:.06em}
.class-pick.warrior .cn{color:var(--str-color)}.class-pick.thief .cn{color:var(--agi-color)}.class-pick.necromancer .cn{color:var(--int-color)}.class-pick.psionicist .cn{color:var(--wis-color)}.class-pick.monk .cn{color:var(--monk-color)}.class-pick.druid .cn{color:var(--green-light)}
.class-pick .cp-stats{font-size:.68rem;letter-spacing:.08em;color:var(--text-faint);margin-bottom:6px}
.class-pick .cp-source{font-size:.72rem;color:var(--text-dim);margin-bottom:8px;line-height:1.4}
.class-pick .cp-desc{font-size:.75rem;color:var(--text);line-height:1.5;font-style:italic}
/* activity log types */
.activity-section{background:var(--bg3);border:1px solid var(--border);border-radius:5px;padding:12px;margin-bottom:10px}
.activity-title{font-family:'Cinzel',serif;font-size:.78rem;letter-spacing:.08em;margin-bottom:8px}
.activity-title.magic{color:var(--purple-light)}.activity-title.psi{color:var(--cyan-light)}.activity-title.thief{color:var(--blue-light)}.activity-title.warrior{color:var(--str-color)}.activity-title.cardio{color:var(--end-color)}
/* achievements */
.achievement{display:flex;align-items:center;gap:10px;padding:9px 11px;background:var(--bg3);border:1px solid var(--border);border-radius:5px;margin-bottom:5px}
.achievement.unlocked{border-color:var(--gold-dark);background:rgba(201,168,76,.06)}
.ach-icon{font-size:1.5rem;opacity:.35}.achievement.unlocked .ach-icon{opacity:1}
.ach-name{font-size:.83rem;color:var(--text-dim)}.achievement.unlocked .ach-name{color:var(--text)}
.ach-desc{font-size:.7rem;color:var(--text-faint);margin-top:1px}
/* inventory */
.inv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(115px,1fr));gap:7px}
.inv-item{background:var(--bg3);border:1px solid var(--border);border-radius:5px;padding:9px 7px;text-align:center;cursor:pointer;transition:all .15s}
.inv-item:hover{border-color:var(--border-strong)}.inv-item .ii-icon{font-size:1.7rem;margin-bottom:3px}.inv-item .ii-name{font-size:.7rem;color:var(--text)}.inv-item .ii-stat{font-size:.63rem;color:var(--gold);margin-top:2px}
.inv-item.rare{border-color:rgba(155,89,182,.4)}.inv-item.legendary{border-color:rgba(201,168,76,.6)}
.rarity-junk{color:#5a4e36;font-style:italic}
.pr-flash{animation:prPulse 1.4s ease-out;}
@keyframes prPulse{0%{box-shadow:0 0 0 0 rgba(201,168,76,.8)}70%{box-shadow:0 0 0 14px rgba(201,168,76,0)}100%{box-shadow:0 0 0 0 rgba(201,168,76,0)}}
.nemesis-card{border-color:rgba(192,57,43,.8)!important;box-shadow:0 0 24px rgba(192,57,43,.25);}
.nemesis-card::before{background:linear-gradient(135deg,rgba(192,57,43,.08) 0%,transparent 60%)!important;}
.fatigue-banner{background:rgba(230,126,34,.08);border:1px solid rgba(230,126,34,.4);border-radius:6px;padding:10px 14px;margin-bottom:12px;font-size:.78rem;color:#e67e22;display:flex;align-items:center;gap:8px;}
.weekly-recap{background:var(--bg2);border:1px solid var(--gold-dark);border-radius:8px;padding:16px;margin-bottom:12px;}
.weekly-recap .wr-title{font-family:'Cinzel',serif;font-size:.8rem;color:var(--gold);letter-spacing:.1em;margin-bottom:12px;display:flex;align-items:center;gap:8px;}
.weekly-recap .wr-title::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,var(--gold-dark),transparent);}
.weekly-recap .wr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:10px;}
.weekly-recap .wr-stat{text-align:center;}
.weekly-recap .wr-val{font-family:'Cinzel',serif;font-size:1.1rem;font-weight:700;color:var(--gold);}
.weekly-recap .wr-lbl{font-size:.55rem;color:var(--text-faint);letter-spacing:.08em;}
.weekly-recap .wr-pr{font-size:.72rem;color:var(--green-light);padding:3px 0;border-bottom:1px solid var(--border);}
.weekly-recap .wr-pr:last-child{border-bottom:none;}.rarity-common{color:#7f8c8d}.rarity-uncommon{color:#27ae60}.rarity-rare{color:#2980b9}.rarity-epic{color:#8e44ad}.rarity-legendary{color:var(--gold);text-shadow:0 0 8px rgba(201,168,76,.6)}
.mgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(85px,1fr));gap:8px;margin-bottom:12px}
.metric{background:var(--bg3);border:1px solid var(--border);border-radius:5px;padding:9px 7px;text-align:center;overflow:hidden;min-width:0}
.metric .mv{font-family:'Cinzel',serif;font-size:1.2rem;font-weight:600;color:var(--gold-light);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.metric .ml{font-size:.58rem;color:var(--text-faint);letter-spacing:.06em;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.chart-wrap{position:relative;width:100%;overflow:hidden;box-sizing:border-box}
#toasts{position:fixed;top:14px;right:14px;z-index:9999;pointer-events:none;width:255px}
.toast{background:var(--bg2);border:1px solid var(--gold);border-radius:5px;padding:11px 14px;margin-bottom:7px;font-size:.82rem;color:var(--text);max-width:255px;animation:toastIn .3s ease,toastOut .3s ease 3.7s forwards;box-shadow:0 4px 20px rgba(0,0,0,.6),0 0 20px rgba(201,168,76,.1)}
.toast.loot{border-color:var(--purple-light)}.toast.level{border-color:var(--gold-light);box-shadow:0 0 30px rgba(201,168,76,.3)}.toast.magic{border-color:var(--purple-light);background:rgba(155,89,182,.12)}.toast.psi{border-color:var(--cyan-light);background:rgba(0,188,212,.08)}
@keyframes toastIn{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}
@keyframes toastOut{from{opacity:1}to{opacity:0}}
/* mana bar under hp */
.mana-glow{text-shadow:0 0 8px rgba(155,89,182,.8)}
.int-glow{text-shadow:0 0 8px rgba(0,188,212,.8)}
.c25k-phase{font-family:'Cinzel',serif;font-size:.88rem;letter-spacing:.2em}.c25k-phase.run{color:var(--green-light)}.c25k-phase.walk{color:var(--blue-light)}
.c25k-countdown{font-family:'Cinzel',serif;font-size:4.2rem;font-weight:900;color:var(--gold-light);line-height:1;text-shadow:0 0 30px rgba(201,168,76,.3)}
textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:4px;color:var(--text);font-family:'Crimson Pro',serif;font-size:.86rem;padding:7px 10px;resize:vertical;min-height:44px}
textarea:focus{outline:none;border-color:var(--border-strong)}
hr.divider{border:none;border-top:1px solid var(--border);margin:10px 0}
input[type=number]{-moz-appearance:textfield}
input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none}
.switch-row{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-bottom:10px}
.ex-row{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}.ex-row:last-child{border-bottom:none}
.stat-box{background:var(--bg3);border:1px solid var(--border);border-radius:5px;padding:9px 7px;text-align:center}
.stat-box .sv{font-family:'Cinzel',serif;font-size:1.4rem;font-weight:600;color:var(--gold-light)}.stat-box .sl{font-size:.63rem;color:var(--text-dim);letter-spacing:.07em;margin-top:2px}
.streak-dot{width:24px;height:24px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.6rem;color:var(--text-faint)}
.streak-dot.done{background:#185FA5;border-color:#185FA5;color:#fff}.streak-dot.today{border:2px solid var(--gold);color:var(--gold);font-weight:600}
/* onboarding overlay */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:5000;display:flex;align-items:center;justify-content:center;padding:20px}
.overlay-box{background:var(--bg2);border:1px solid var(--border-strong);border-radius:8px;padding:24px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--gold-dark) var(--bg3)}
.overlay-box::-webkit-scrollbar{width:5px}.overlay-box::-webkit-scrollbar-track{background:var(--bg3);border-radius:3px}.overlay-box::-webkit-scrollbar-thumb{background:var(--gold-dark);border-radius:3px}.overlay-box::-webkit-scrollbar-thumb:hover{background:var(--gold)}
.overlay-box h2{font-family:'Cinzel',serif;font-size:1.3rem;color:var(--gold);text-align:center;margin-bottom:6px}
.overlay-box p{font-size:.88rem;color:var(--text-dim);text-align:center;margin-bottom:18px;line-height:1.6}

.quest-card{background:var(--bg3);border:1px solid var(--border);border-radius:5px;padding:13px;margin-bottom:8px}
.quest-card.done{opacity:.5;border-color:rgba(39,174,96,.4)}
.quest-card.active-q{border-color:var(--gold-dark);background:rgba(201,168,76,.06)}
.quest-tier{font-size:.6rem;letter-spacing:.12em;font-family:'Cinzel',serif;margin-bottom:4px}
.quest-tier.daily{color:var(--end-color)}.quest-tier.weekly{color:var(--blue-light)}.quest-tier.epic{color:var(--purple-light)}.quest-tier.legendary{color:var(--gold)}
.quest-title{font-size:.9rem;color:var(--text);font-weight:600;margin-bottom:3px}
.quest-desc{font-size:.75rem;color:var(--text-dim);line-height:1.5;margin-bottom:7px}
.quest-reward{font-size:.72rem;color:var(--gold);font-family:'Cinzel',serif}
.quest-prog{height:4px;background:rgba(255,255,255,.05);border-radius:2px;margin-top:7px;overflow:hidden}
.quest-prog-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--gold-dark),var(--gold))}
.floor-card{background:var(--bg3);border:1px solid rgba(192,57,43,.3);border-radius:6px;padding:14px;margin-bottom:9px}
.floor-card.cleared{border-color:rgba(39,174,96,.4);background:rgba(39,174,96,.04)}
.floor-num{font-family:'Cinzel',serif;font-size:.65rem;color:var(--red-light);letter-spacing:.12em;margin-bottom:5px}
.floor-card.cleared .floor-num{color:var(--green-light)}
.floor-boss{font-family:'Cinzel',serif;font-size:1rem;color:var(--text);font-weight:600}
.bw-entry{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}.bw-entry:last-child{border-bottom:none}
.bw-date{font-size:.72rem;color:var(--text-faint);min-width:78px}
.bw-val{font-family:'Cinzel',serif;font-size:1.05rem;color:var(--gold-light);font-weight:600}
.bw-delta{font-size:.75rem;margin-left:4px}.bw-delta.up{color:var(--red-light)}.bw-delta.down{color:var(--green-light)}.bw-delta.same{color:var(--text-faint)}
.mc-badge{display:inline-block;font-size:.6rem;padding:2px 7px;border-radius:3px;letter-spacing:.05em;font-family:'Cinzel',serif;background:rgba(201,168,76,.12);border:1px solid var(--gold-dark);color:var(--gold)}
.rec-weight{background:rgba(201,168,76,.07);border:1px solid var(--gold-dark);border-radius:4px;padding:6px 10px;font-size:.78rem;color:var(--gold);display:inline-flex;align-items:center;gap:6px;margin-bottom:7px}
.extra-ex-row{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid var(--border)}.extra-ex-row:last-child{border-bottom:none}

.gate-overlay{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px}
.gate-box{background:var(--bg2);border:1px solid var(--border-strong);border-radius:8px;padding:32px 28px;max-width:380px;width:100%;text-align:center}
.gate-box h2{font-family:'Cinzel',serif;font-size:1.4rem;color:var(--gold);margin-bottom:6px;letter-spacing:.12em}
.gate-box p{font-size:.86rem;color:var(--text-dim);margin-bottom:22px;line-height:1.6}
.gate-input{width:100%;font-family:'Cinzel',serif;font-size:1.1rem;letter-spacing:.2em;text-align:center;padding:11px 14px;background:var(--bg3);border:1px solid var(--border-strong);border-radius:4px;color:var(--gold-light);margin-bottom:12px;text-transform:uppercase}
.gate-input:focus{outline:none;border-color:var(--gold)}
.gate-error{font-size:.78rem;color:var(--red-light);margin-bottom:10px;min-height:1.2em}

@keyframes gateShake{0%{transform:translateX(0)}20%{transform:translateX(-8px)}40%{transform:translateX(8px)}60%{transform:translateX(-5px)}80%{transform:translateX(5px)}100%{transform:translateX(0)}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.3)}}
@keyframes onboard-pulse{0%,100%{box-shadow:0 0 12px rgba(201,168,76,.4)}50%{box-shadow:0 0 28px rgba(201,168,76,.7)}}
/* Notification badge */
.nav-badge{position:absolute;top:-2px;right:-2px;background:#e74c3c;color:#fff;font-size:.5rem;font-weight:700;min-width:14px;height:14px;line-height:14px;text-align:center;border-radius:7px;padding:0 3px;pointer-events:none}

/* Community page */
.comm-hero{position:relative;text-align:center;padding:28px 16px 20px;overflow:hidden;border-radius:8px;margin-bottom:12px;background:linear-gradient(135deg,#0f1923 0%,#162234 40%,#1a2a3e 70%,#0d1520 100%);border:1px solid var(--border-strong)}
.comm-hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='30' height='30' fill='%23ffffff05'/%3E%3Crect x='30' y='30' width='30' height='30' fill='%23ffffff05'/%3E%3C/svg%3E");opacity:.4}
.comm-hero>*{position:relative}
.comm-feat{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.comm-feat-card{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:12px;text-align:center;position:relative;overflow:hidden;transition:transform .2s}
.comm-feat-card:active{transform:scale(.97)}
.comm-feat-card .cfc-icon{font-size:1.6rem;margin-bottom:4px}
.comm-feat-card .cfc-title{font-size:.72rem;font-weight:600;color:var(--text);margin-bottom:2px}
.comm-feat-card .cfc-desc{font-size:.6rem;color:var(--text-faint);line-height:1.5}
.comm-tile{position:absolute;opacity:.06;font-size:2rem;pointer-events:none}
.comm-road{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:12px 14px;margin-bottom:6px;display:flex;align-items:center;gap:10px}
.comm-road .cr-dot{width:10px;height:10px;border-radius:50%;border:2px solid var(--gold-dark);flex-shrink:0}
.comm-road .cr-dot.done{background:var(--gold);border-color:var(--gold)}
.comm-road .cr-text{font-size:.75rem;color:var(--text-dim);flex:1}
.comm-road .cr-badge{font-size:.58rem;padding:2px 6px;border-radius:3px;background:rgba(201,168,76,.1);color:var(--gold-dark);letter-spacing:.06em}

/* Tour overlay */
.tour-container{position:fixed;inset:0;z-index:8000;pointer-events:none}
.tour-spotlight{position:fixed;border-radius:8px;box-shadow:0 0 0 9999px rgba(0,0,0,.7);z-index:8000;pointer-events:none;transition:all .3s ease;animation:tour-pulse 2s infinite}
@keyframes tour-pulse{0%,100%{box-shadow:0 0 0 9999px rgba(0,0,0,.7),0 0 0 3px rgba(201,168,76,.6)}50%{box-shadow:0 0 0 9999px rgba(0,0,0,.7),0 0 0 6px rgba(201,168,76,.3)}}
.tour-fullscreen{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:8000;pointer-events:none}
.tour-tooltip{position:fixed;z-index:8001;background:var(--bg2);border:2px solid var(--gold);border-radius:10px;padding:16px;max-width:300px;width:calc(100vw - 32px);pointer-events:auto;box-shadow:0 8px 32px rgba(0,0,0,.5);box-sizing:border-box}
.tour-tooltip .tour-step{font-size:.6rem;color:var(--gold-dark);letter-spacing:.1em;margin-bottom:3px}
.tour-tooltip .tour-title{font-family:'Cinzel',serif;font-size:.95rem;color:var(--gold);margin-bottom:6px}
.tour-tooltip .tour-text{font-size:.78rem;color:var(--text-dim);line-height:1.6;margin-bottom:12px}
.tour-tooltip .tour-nav{display:flex;flex-direction:column;gap:8px}
.tour-tooltip .tour-nav-btns{display:flex;gap:6px;justify-content:stretch}
.tour-tooltip .tour-nav-btns button{flex:1;font-size:.72rem;padding:8px 6px;min-height:36px}
.tour-tooltip .tour-dots{display:flex;gap:3px;justify-content:center}.tour-tooltip .tour-dot{width:5px;height:5px;border-radius:50%;background:var(--border)}.tour-tooltip .tour-dot.active{background:var(--gold)}
#chat-messages::-webkit-scrollbar{width:5px}#chat-messages::-webkit-scrollbar-track{background:var(--bg3);border-radius:3px}#chat-messages::-webkit-scrollbar-thumb{background:var(--gold-dark);border-radius:3px}#chat-messages::-webkit-scrollbar-thumb:hover{background:var(--gold)}
/* Twemoji — sized inline with surrounding text, vertically centered */
img.emoji{height:1em;width:1em;margin:0 .05em 0 .1em;vertical-align:-0.15em;display:inline-block}
/* Lucide SVG icons — used for UI chrome (buttons, badges). Inherits color via currentColor. */
.lucide-icon{display:inline-block;vertical-align:-0.15em;width:1em;height:1em;stroke-width:2;stroke:currentColor;fill:none;stroke-linecap:round;stroke-linejoin:round}
.lucide-icon.lucide-lg{width:1.3em;height:1.3em}
#settings-btn.settings-active{border-color:var(--gold)!important;color:var(--gold)!important}

/* ──────────────────────────────────────────────────────────────────
   Combat polish v20260419l — floating damage numbers, enemy hit
   reactions, level-up celebration, chronicle entry animations.
   All effects are additive and pointer-events:none so they never
   interfere with interaction. Auto-cleanup handled by JS.
   ────────────────────────────────────────────────────────────────── */

/* Enemy banner needs position:relative so absolute-positioned damage
   numbers can anchor to it. We hook via .enemy-banner-slot (existing
   class used on every workout page's banner). */
.enemy-banner-slot{position:relative;overflow:visible}

/* Floating damage numbers. Three variants: normal (white), crit (gold),
   ultimate (red). Each rises and fades with a slight horizontal jitter. */
.dmg-float{position:absolute;pointer-events:none;z-index:50;font-family:'Cinzel',serif;font-weight:900;text-shadow:0 2px 4px rgba(0,0,0,.9),0 0 8px rgba(0,0,0,.6);user-select:none;will-change:transform,opacity}
.dmg-float.normal{color:#fff;font-size:1.15rem;animation:dmgFloat 900ms cubic-bezier(.25,.8,.3,1) forwards}
.dmg-float.crit{color:var(--gold-light);font-size:1.6rem;text-shadow:0 2px 4px rgba(0,0,0,.9),0 0 16px rgba(240,208,128,.7);animation:dmgFloatCrit 1200ms cubic-bezier(.25,.8,.3,1) forwards}
.dmg-float.ultimate{color:#ff5a3a;font-size:2rem;text-shadow:0 2px 6px rgba(0,0,0,1),0 0 20px rgba(255,90,58,.9);animation:dmgFloatCrit 1400ms cubic-bezier(.25,.8,.3,1) forwards}
.dmg-float.heal{color:#4ade80;font-size:1.1rem;text-shadow:0 2px 4px rgba(0,0,0,.9),0 0 12px rgba(74,222,128,.6)}
.dmg-float.heal{animation:dmgFloat 1000ms cubic-bezier(.25,.8,.3,1) forwards}

@keyframes dmgFloat{
  0%{opacity:0;transform:translate(-50%,0) scale(.6)}
  15%{opacity:1;transform:translate(-50%,-6px) scale(1.15)}
  30%{transform:translate(-50%,-14px) scale(1)}
  100%{opacity:0;transform:translate(-50%,-52px) scale(.95)}
}
@keyframes dmgFloatCrit{
  0%{opacity:0;transform:translate(-50%,0) scale(.4) rotate(-6deg)}
  12%{opacity:1;transform:translate(-50%,-8px) scale(1.35) rotate(3deg)}
  25%{transform:translate(-50%,-18px) scale(1.1) rotate(-2deg)}
  45%{transform:translate(-50%,-28px) scale(1.05) rotate(0deg)}
  100%{opacity:0;transform:translate(-50%,-68px) scale(.95) rotate(0deg)}
}

/* Enemy hit-reaction — banner briefly shakes and flashes red. Applied
   as a class that JS removes after 400ms. */
.enemy-hit-shake{animation:enemyHitShake .22s ease-in-out both}
@keyframes enemyHitShake{
  0%{transform:translateX(0)}
  20%{transform:translateX(-5px)}
  40%{transform:translateX(5px)}
  60%{transform:translateX(-3px)}
  80%{transform:translateX(2px)}
  100%{transform:translateX(0)}
}
.enemy-hit-flash::before{
  content:'';position:absolute;inset:0;background:radial-gradient(circle at center,rgba(231,76,60,.35),transparent 70%);
  pointer-events:none;animation:enemyHitFlash .4s ease-out both;border-radius:inherit;z-index:2
}
@keyframes enemyHitFlash{
  0%{opacity:0}20%{opacity:1}100%{opacity:0}
}

/* Enemy defeat — portrait scales and fades before next enemy spawns. */
.enemy-defeat-anim{animation:enemyDefeat .55s ease-out forwards}
@keyframes enemyDefeat{
  0%{transform:scale(1);opacity:1;filter:brightness(1)}
  40%{transform:scale(1.2);opacity:.85;filter:brightness(1.6) saturate(1.4)}
  100%{transform:scale(.4);opacity:0;filter:brightness(0) blur(3px)}
}

/* Level-up radial pulse — applied to hero portrait or a body overlay. */
.levelup-pulse{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:9000;width:10px;height:10px;border-radius:50%;background:radial-gradient(circle,rgba(240,208,128,.9) 0%,rgba(201,168,76,.6) 30%,transparent 70%);animation:levelupPulse 1.4s ease-out forwards}
@keyframes levelupPulse{
  0%{width:10px;height:10px;opacity:.9}
  50%{opacity:.7}
  100%{width:900px;height:900px;opacity:0}
}

/* Floating stat-gain text for level-ups — fly out radially from center. */
.stat-gain-float{position:fixed;top:50%;left:50%;pointer-events:none;z-index:9001;font-family:'Cinzel',serif;font-weight:700;font-size:1.1rem;color:var(--gold-light);text-shadow:0 2px 6px rgba(0,0,0,.9),0 0 14px rgba(240,208,128,.7);white-space:nowrap;will-change:transform,opacity;user-select:none}
.stat-gain-float.sg0{animation:statFly0 1.6s cubic-bezier(.2,.8,.3,1) forwards}
.stat-gain-float.sg1{animation:statFly1 1.6s cubic-bezier(.2,.8,.3,1) forwards}
.stat-gain-float.sg2{animation:statFly2 1.6s cubic-bezier(.2,.8,.3,1) forwards}
.stat-gain-float.sg3{animation:statFly3 1.6s cubic-bezier(.2,.8,.3,1) forwards}
.stat-gain-float.sg4{animation:statFly4 1.6s cubic-bezier(.2,.8,.3,1) forwards}
@keyframes statFly0{0%{transform:translate(-50%,-50%) scale(.6);opacity:0}15%{opacity:1;transform:translate(-50%,-50%) scale(1.15)}100%{transform:translate(-50%,calc(-50% - 110px)) scale(1);opacity:0}}
@keyframes statFly1{0%{transform:translate(-50%,-50%) scale(.6);opacity:0}15%{opacity:1;transform:translate(-50%,-50%) scale(1.15)}100%{transform:translate(calc(-50% + 120px),calc(-50% - 70px)) scale(1);opacity:0}}
@keyframes statFly2{0%{transform:translate(-50%,-50%) scale(.6);opacity:0}15%{opacity:1;transform:translate(-50%,-50%) scale(1.15)}100%{transform:translate(calc(-50% + 120px),calc(-50% + 70px)) scale(1);opacity:0}}
@keyframes statFly3{0%{transform:translate(-50%,-50%) scale(.6);opacity:0}15%{opacity:1;transform:translate(-50%,-50%) scale(1.15)}100%{transform:translate(-50%,calc(-50% + 110px)) scale(1);opacity:0}}
@keyframes statFly4{0%{transform:translate(-50%,-50%) scale(.6);opacity:0}15%{opacity:1;transform:translate(-50%,-50%) scale(1.15)}100%{transform:translate(calc(-50% - 130px),calc(-50% - 20px)) scale(1);opacity:0}}

/* Combat log (chronicle) entries animate in and criticals/level-ups
   get a distinct left-border + background. */
.combat-log>div{animation:logEntryIn .25s ease-out both}
@keyframes logEntryIn{from{opacity:0;transform:translateX(-6px)}to{opacity:1;transform:translateX(0)}}
