.chat-dock{width:min(360px,34vw);max-height:46%;transition:max-height .15s ease}.chat-dock.collapsed{max-height:none}.chat-dock .dock-head{align-items:center;gap:6px}.dock-tabs{display:flex;gap:4px;flex:1;min-width:0}.dock-tabs button{font-family:var(--display);font-size:var(--fs-sm);padding:3px 10px;border-radius:var(--radius-sm);background:var(--wash);color:var(--muted);box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.dock-tabs button.on{background:var(--wash-on);color:var(--text);box-shadow:inset 0 0 0 1px var(--accent-dim)}.dock-icon{padding:2px 7px;font-size:var(--fs-sm);background:none;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;opacity:.7}.dock-icon:hover,.dock-icon.on{opacity:1}.dock-sub{font-size:var(--fs-xs);margin:-2px 0 2px}.chat-from-btn{background:none;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;padding:0;color:var(--accent);font-family:var(--display);font-size:var(--fs-sm);cursor:pointer}.chat-from-btn:disabled{cursor:default;opacity:1}.chat-from-btn:not(:disabled):hover{text-decoration:underline}.chat-menu{display:inline-flex;gap:4px;margin-left:6px}.chat-menu button{font-size:var(--fs-xs);padding:1px 7px;background:var(--wash);color:var(--lapis);box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.chat-menu button:hover{color:var(--accent)}.dock-dms{display:flex;flex-direction:column;min-height:0;flex:1;gap:6px}.dock-dms .dm-head{display:flex;align-items:center;gap:8px}.dm-back{margin-left:0}.dock-dms .dm-partners{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}.dock-dms .dm-partners .social-user{cursor:pointer;padding:4px 6px;border-radius:var(--radius-sm)}.dock-dms .dm-partners .social-user:hover{background:var(--wash)}.dock-dms .dock-log{flex:1}.social-title{margin:0 0 12px;font-family:var(--display);font-size:var(--fs-lg);color:var(--accent)}.avatar-actions{display:flex;flex-direction:column;align-items:center;gap:3px;pointer-events:none}.avatar-act{pointer-events:auto;font-size:var(--fs-xs);padding:2px 9px}.guide-npc{position:absolute;display:flex;flex-direction:column;align-items:center;z-index:5;pointer-events:none;filter:drop-shadow(0 0 9px rgba(168,130,255,.45)) drop-shadow(0 8px 8px rgba(0,0,0,.55));transition:left 1s ease-in-out,top 1s ease-in-out;animation:guide-walk .5s ease-in-out infinite}.guide-name{margin-top:-6px;font-size:var(--fs-xs);color:#e9defc;text-shadow:var(--halo);white-space:nowrap;background:#3a1e6099;padding:1px 8px;border-radius:8px}.guide-arrow{font-size:22px;line-height:1;color:#ffd75e;text-shadow:0 0 6px rgba(255,215,94,.7);animation:guide-bob 1.1s ease-in-out infinite}@keyframes guide-bob{0%,to{translate:0 0}50%{translate:0 -5px}}@keyframes guide-walk{0%,to{transform:translate(-50%,-100%)}50%{transform:translate(-50%,-103%)}}@media(prefers-reduced-motion:reduce){.guide-arrow{animation:none}.guide-npc{animation:none;transition:none;transform:translate(-50%,-100%)}}.minimap{position:fixed;right:14px;bottom:58px;z-index:55;width:168px;padding:9px 10px 7px;background:var(--glass-strong);border-radius:var(--radius-sm);box-shadow:var(--edge),var(--shadow-soft);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);pointer-events:none;-webkit-user-select:none;user-select:none}.minimap-title{font-family:var(--display);font-variant:small-caps;letter-spacing:1px;font-size:var(--fs-xs);color:var(--muted);text-align:center;margin-bottom:5px}.minimap-svg{display:block;width:100%;height:auto;overflow:visible}.minimap-link{stroke:var(--hair);stroke-width:3}.minimap-dot{fill:var(--wash-2);stroke:#ffffff29;stroke-width:2}.minimap-label{fill:var(--muted);font-family:Georgia,serif;font-size:17px;opacity:.72}.minimap-cell.here .minimap-dot{fill:var(--accent);stroke:var(--accent-soft);filter:drop-shadow(0 0 6px var(--accent-dim));animation:minimap-pulse 1.8s ease-in-out infinite}.minimap-cell.here .minimap-label{fill:var(--accent-soft);opacity:1}@keyframes minimap-pulse{0%,to{opacity:1}50%{opacity:.7}}@media(prefers-reduced-motion:reduce){.minimap-cell.here .minimap-dot{animation:none}}.sb-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:60;padding:24px}.sb-book{position:relative;width:min(1180px,96vw);height:min(760px,92vh);display:flex;flex-direction:column;border-radius:16px;background:linear-gradient(180deg,#241f33,#181423);box-shadow:var(--shadow),var(--edge),inset 0 0 0 1px #ffffff0f;overflow:hidden}.sb-close{position:absolute;top:14px;right:16px;z-index:5;width:38px;height:38px;padding:0;display:flex;align-items:center;justify-content:center;font-size:var(--fs-md);line-height:1;border-radius:50%}.sb-spread{flex:1;min-height:0;display:grid;grid-template-columns:minmax(360px,1fr) minmax(360px,1fr);gap:0;background:linear-gradient(90deg,transparent calc(50% - 2px),rgba(0,0,0,.5) 50%,transparent calc(50% + 2px))}.sb-stage{position:relative;display:flex;flex-direction:column;padding:30px;min-height:0}.sb-preview{flex:1;min-height:280px;border-radius:var(--radius);overflow:hidden;background:radial-gradient(circle at 50% 42%,#1f2547,#0c0f20);box-shadow:var(--edge),inset 0 0 60px #00000073}.sb-preview canvas{display:block;width:100%;height:100%}.sb-incant{margin-top:18px;text-align:center;font-family:var(--display);font-size:var(--fs-lg);letter-spacing:3px;text-transform:capitalize;color:var(--accent)}.sb-detail{display:flex;flex-direction:column;gap:16px;padding:30px 34px;overflow-y:auto}.sb-title{display:flex;align-items:center;gap:14px}.sb-sigil{font-size:var(--fs-2xl);line-height:1}.sb-name{font-family:var(--display);font-size:var(--fs-2xl);line-height:1.05;letter-spacing:1px}.sb-meta{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.sb-badge{font-family:var(--display);font-size:var(--fs-xs);letter-spacing:1px;padding:4px 12px;border-radius:999px;background:var(--wash);box-shadow:inset 0 0 0 1px #ffffff1a}.sb-badge.tier{color:var(--accent);background:var(--wash-on);box-shadow:inset 0 0 0 1.5px var(--accent-dim)}.sb-badge.school{font-variant:small-caps;font-weight:700}.sb-badge.role{color:var(--muted)}.sb-desc{margin:0;font-size:var(--fs-md);line-height:1.6;color:var(--text)}.sb-stats{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}.sb-stats th,.sb-stats td{padding:8px 4px;border-bottom:1px dotted var(--hair);text-align:left}.sb-stats th{color:var(--muted);font-weight:400;font-variant:small-caps;letter-spacing:1px;width:44%}.sb-stats td{color:var(--text);text-align:right;text-transform:capitalize}.sb-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto;padding-top:8px}.sb-tags .sb-tag{font-size:var(--fs-xs);color:var(--muted);background:var(--wash);border-radius:999px;padding:3px 11px;text-transform:capitalize}.sb-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 22px;border-top:1px solid var(--hair)}.sb-folio{font-family:var(--display);color:var(--muted);letter-spacing:1px}.sb-hint{font-size:var(--fs-xs);color:var(--muted);opacity:.7}@media(max-width:820px){.sb-book{height:auto;max-height:92vh}.sb-spread{grid-template-columns:1fr;overflow-y:auto;background:none}.sb-preview{min-height:240px}}.duel-setup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;display:flex;align-items:center;justify-content:center;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.duel-setup{width:min(420px,92vw);padding:28px 28px 24px;border-radius:var(--radius);text-align:center;background:var(--glass-strong);box-shadow:var(--shadow),var(--edge),var(--lift);animation:victory-pop .4s cubic-bezier(.2,1.3,.4,1)}.duel-setup-title{font-family:var(--display);font-size:32px;margin:0 0 4px;letter-spacing:1px}.duel-setup-sub{color:var(--muted);font-size:var(--fs-sm);margin:0 0 18px}.duel-setup-difficulty{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.difficulty-pick{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding:10px 14px;border-radius:var(--radius-sm);background:var(--wash);box-shadow:var(--edge);color:var(--text);cursor:pointer;transition:background .15s,box-shadow .15s,color .15s}.difficulty-pick:hover{background:var(--wash-on)}.difficulty-pick.on{background:var(--wash-on);box-shadow:inset 0 0 0 1px var(--accent);color:var(--accent)}.difficulty-name{font-family:var(--display);font-size:var(--fs-lg)}.difficulty-stat{font-size:var(--fs-xs);color:var(--muted)}.difficulty-pick.on .difficulty-stat{color:var(--accent-dim)}.duel-setup-start{min-width:140px}.char-row{justify-content:flex-start}.char-preview{flex:0 0 auto;display:flex;align-items:flex-end;justify-content:center;width:56px;height:64px;border-radius:10px;background:#0c090580;box-shadow:inset 0 0 0 1px #e2d7a024;overflow:hidden}.char-row .char-meta-block{flex:1 1 auto;min-width:0}.char-row-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.char-row-actions{flex:0 0 auto;display:flex;align-items:center;gap:8px}.char-btn-sm{padding:9px 14px;font-size:14px}.char-delete{color:#e7c3b6;border-color:#d68a7473}.char-delete:hover{color:#fff;border-color:#d68a74;background:#7830268c}.char-confirm{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.char-confirm-text{font-size:12px;color:#e7c3b6}.char-confirm-row{display:flex;gap:8px}.char-confirm-row .char-btn-sm.danger{background:linear-gradient(180deg,#c0533d,#9c3f2d);color:#1b1610;border-color:transparent}.char-confirm-row .char-btn-sm.danger:hover{background:linear-gradient(180deg,#d8654c,#c0533d)}.char-empty{display:flex;flex-direction:column;align-items:center;gap:10px;padding:28px 16px;margin-bottom:16px;text-align:center;border:1px dashed rgba(226,215,160,.28);border-radius:12px;background:#241e1366}.char-empty-title{font-weight:700;color:#f0e6b8}.char-empty-sub{font-size:13px;color:#b8ae93;max-width:320px}.menu-panel.create{width:min(980px,96vw)}.char-create{display:flex;flex-direction:column;gap:16px}.char-create .onboard-name{margin-bottom:0}.char-create .mb{padding-left:0;padding-right:0;max-width:100%}.tutorial-choice{display:flex;flex-direction:column;gap:10px;width:100%;max-width:360px;margin:0 auto}.tutorial-choice .hint{text-align:center;font-size:13px;color:#b8ae93;margin:0}.onboard-actions.stacked{flex-direction:column;align-items:stretch;gap:10px;width:100%;max-width:360px;margin-left:auto;margin-right:auto}.onboard-actions.stacked .ghost{background:none;color:#c9bf9f;box-shadow:inset 0 0 0 1px #e2d7a066}.onboard-actions.stacked .ghost:hover:not(:disabled){color:#f0e6b8}.menu-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;padding:24px;color:#f3ecd6}.menu-plate{text-align:center;padding:26px 40px 22px;background:radial-gradient(120% 130% at 50% 0%,#261f12a8,#100d0899);border:1px solid rgba(226,215,160,.22);border-radius:18px;box-shadow:0 18px 60px #00000073,inset 0 1px #fff8d614;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:menu-rise .5s ease both}.menu-eyebrow{margin:0;font-size:clamp(13px,1.6vw,16px);font-weight:600;letter-spacing:.42em;text-transform:uppercase;color:#d8c88c;opacity:.85}.menu-title{display:flex;align-items:baseline;justify-content:center;flex-wrap:wrap;gap:.28em;margin:6px 0 0;font-size:clamp(34px,6vw,60px);font-weight:700;line-height:1.02;letter-spacing:.015em;color:#f3e9bd;text-shadow:0 2px 22px rgba(0,0,0,.65),0 0 36px rgba(201,162,39,.18)}.menu-title-of{font-size:.46em;font-weight:500;font-style:italic;letter-spacing:.06em;color:#cbbf92}.menu-rule{width:64%;height:1px;margin:16px auto 0;background:linear-gradient(90deg,transparent,rgba(226,215,160,.55),transparent)}.menu-sub{margin:12px 0 0;color:#ccc3a6;letter-spacing:.01em}.menu-who{color:#f0e6b8;font-weight:600}@keyframes menu-rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}@media(prefers-reduced-motion:reduce){.menu-plate{animation:none}}.menu-nav{display:flex;flex-direction:column;gap:12px;width:min(320px,90vw)}.menu-btn{padding:13px 18px;font-size:15px;font-weight:600;color:#f3ecd6;background:#1e1910e6;border:1px solid rgba(226,215,160,.4);border-radius:10px;cursor:pointer;transition:border-color .15s,background .15s}.menu-btn:hover{border-color:#e2d7a0;background:#2e2617f2}.menu-btn.primary{background:linear-gradient(180deg,#c9a227,#a6841d);color:#1b1610;border-color:transparent}.menu-btn.primary:hover{background:linear-gradient(180deg,#e2b34a,#c9a227)}.menu-btn:disabled{opacity:.5;cursor:default}.menu-panel{width:min(440px,92vw);max-height:84vh;overflow:auto;padding:22px 24px;background:#14100af0;border:1px solid rgba(226,215,160,.4);border-radius:14px;box-shadow:0 16px 48px #00000080}.menu-panel.wide{width:min(560px,94vw)}.menu-panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.menu-panel-head h2{margin:0;color:#f0e6b8}.menu-back{background:none;border:none;color:#c9bf9f;cursor:pointer;font-size:14px}.menu-back:hover{color:#f0e6b8}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0;border-top:1px solid rgba(226,215,160,.16)}.settings-label{color:#cfc6a8;font-weight:600}.settings-row-stack{flex-direction:column;align-items:stretch;gap:8px}.settings-name{display:flex;gap:8px}.settings-name input{flex:1;min-width:0;padding:11px 13px;font:inherit;color:#f3ecd6;background:#0c0a0699;border:1px solid rgba(226,215,160,.3);border-radius:10px}.settings-name input:focus{outline:none;border-color:#e2d7a0}.settings-name .menu-btn{flex:0 0 auto}.char-list{list-style:none;margin:0 0 16px;padding:0;display:flex;flex-direction:column;gap:10px}.char-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 14px;background:#241e13b3;border:1px solid rgba(226,215,160,.2);border-radius:10px}.char-meta-block{display:flex;flex-direction:column;gap:3px}.char-row-name{font-weight:700;color:#f0e6b8}.char-row-sub{font-size:12px;color:#b8ae93}.new-char{width:100%}.char-create .onboard-name{display:block;margin-bottom:14px}.charsheet{width:min(680px,92vw);display:flex;flex-direction:column;gap:0}.charsheet .lobby-card{margin:0;box-shadow:none;background:transparent;padding:4px 6px 6px}.charsheet .char-head{display:flex;gap:16px;align-items:center;margin:4px 0 14px}.charsheet .char-id{flex:1;display:flex;flex-direction:column;gap:8px}.charsheet .row{display:flex;gap:10px;align-items:center}.charsheet .char-sub{color:var(--muted);font-size:var(--fs-xs)}.charsheet .char-title{font-family:var(--display);font-size:var(--fs-sm);color:var(--accent);letter-spacing:.04em}.charsheet .char-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.charsheet .marks-chip{display:inline-flex;align-items:center;gap:5px;background:var(--wash-on);border-radius:999px;padding:2px 10px;font-size:var(--fs-xs);color:var(--text);box-shadow:var(--edge)}.charsheet .marks-chip .marks-coin{color:var(--accent)}.charsheet .title-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:2px}.charsheet .title-chip{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:var(--wash);color:var(--muted);border-radius:999px;padding:4px 12px;font-family:inherit;font-size:var(--fs-sm);cursor:pointer;box-shadow:var(--edge)}.charsheet .title-chip:hover{color:var(--text)}.charsheet .title-chip.on{background:var(--wash-on);color:var(--accent)}.charsheet .char-portrait{flex:none;width:96px;height:96px;border-radius:var(--radius-sm);background:radial-gradient(circle at 50% 36%,#1c2140,#0d1022);box-shadow:var(--edge),var(--shadow-soft);display:flex;align-items:center;justify-content:center;overflow:hidden}.charsheet .char-field{display:flex;flex-direction:column;gap:4px}.charsheet .char-field-label{font-size:var(--fs-xs);color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.charsheet input[type=text],.charsheet input:not([type]){background:var(--glass-strong);color:var(--text);border:none;border-radius:var(--radius-sm);padding:8px 10px;font-family:inherit;flex:1;box-shadow:var(--edge),var(--shadow-soft)}.charsheet-tabs{display:flex;gap:4px;border-bottom:1px solid var(--hair);margin-bottom:14px}.charsheet-tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;color:var(--muted);font-family:var(--display);font-size:var(--fs-md);padding:8px 14px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;border-radius:0}.charsheet-tab:hover{color:var(--text)}.charsheet-tab.on{color:var(--text);border-bottom-color:var(--accent)}.charsheet-body{min-height:0}.mastery-head{display:flex;justify-content:space-between;align-items:baseline;margin:2px 0 4px}.mastery-head .level{color:var(--accent);font-family:var(--display);font-size:var(--fs-lg)}.school-mastery{display:flex;flex-direction:column;gap:12px;margin-top:12px}.school-block{display:flex;flex-direction:column;gap:6px}.school-block .school-name{font-family:var(--display);font-size:var(--fs-sm);text-transform:uppercase;letter-spacing:.06em}.spell-mastery-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:10px}.spell-mastery-row .spell-name{font-size:var(--fs-sm);color:var(--text)}.spell-mastery-row .spell-pct{font-size:var(--fs-xs);color:var(--muted);min-width:34px;text-align:right}.mastery-track{grid-column:1 / -1;height:5px;border-radius:999px;background:var(--wash);box-shadow:var(--edge);overflow:hidden}.mastery-fill{height:100%;border-radius:999px}.passive-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.passive-chip{background:var(--wash-on);border-radius:999px;padding:3px 10px;font-size:var(--fs-sm);color:var(--accent)}.appearance-tab{display:flex;flex-direction:column;align-items:center;gap:12px}.appearance-tab .figure-stage{background:radial-gradient(circle at 50% 38%,#1c2140,#0d1022);border-radius:var(--radius-sm);padding:8px 0;display:flex;justify-content:center}.appearance-tab .mb-actions{display:flex;gap:10px}.appearance-tab .mb{display:flex;flex-direction:column;gap:16px;padding:0;width:100%}.appearance-tab .mb-stage{position:static;width:100%}.section-label{color:var(--muted);font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.06em;margin:14px 0 6px}.cinematic{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none}.cinematic .canvas-host{position:absolute;top:0;right:0;bottom:0;left:0}.cinematic-page{position:fixed;background:radial-gradient(120% 90% at 50% 0%,#1b2740,#0c1020 70%,#070a14)}.cinematic-title{position:absolute;left:0;right:0;top:clamp(28px,7vh,80px);display:flex;justify-content:center;text-align:center}.cinematic-title-main{font-size:clamp(20px,3.4vw,40px);font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:#e2d7a0eb;text-shadow:0 2px 18px rgba(150,180,255,.35),0 1px 2px rgba(0,0,0,.6)}:root{--tut-gold: #e2d7a0;--tut-gold-bright: #f0e6b8;--tut-ink: #1b1610;--tut-panel: rgba(24, 20, 14, .92);--tut-panel-edge: rgba(226, 215, 160, .45)}.guide-dialog{position:fixed;left:50%;bottom:24px;transform:translate(-50%);z-index:70;display:flex;gap:14px;align-items:flex-start;width:min(620px,calc(100vw - 40px));padding:16px 18px;background:var(--tut-panel);border:1px solid var(--tut-panel-edge);border-radius:12px;box-shadow:0 10px 36px #00000080;color:#f3ecd6;animation:guide-rise .22s ease-out}@keyframes guide-rise{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}.guide-portrait{flex:none;width:60px;height:60px;display:grid;place-items:center;overflow:hidden;background:radial-gradient(circle at 50% 35%,#3a3221,#211b12);border:1px solid var(--tut-panel-edge);border-radius:10px}.guide-body{flex:1;min-width:0}.guide-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:6px}.guide-name{font-size:12px;letter-spacing:.08em;text-transform:uppercase;font-weight:700;color:var(--tut-gold)}.guide-progress{display:inline-flex;align-items:center;gap:10px;flex:none;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:#b8ae93}.guide-skip{background:none;border:none;color:#8f876f;font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;cursor:pointer;padding:0}.guide-skip:hover{color:var(--tut-gold-bright)}.guide-line{margin:0 0 12px;line-height:1.5;font-size:14.5px}.guide-objective{margin:2px 0 0;line-height:1.45;font-size:14.5px;color:#f3ecd6}.guide-obj-label{display:inline-block;margin-right:8px;padding:1px 8px;border-radius:999px;background:var(--tut-gold);color:var(--tut-ink);font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;vertical-align:middle}.guide-skipstep{margin-left:auto;background:none;border:1px solid var(--tut-panel-edge);color:#c9bf9f;border-radius:6px;padding:4px 10px;font-size:11px;cursor:pointer}.guide-skipstep:hover{color:var(--tut-gold-bright);border-color:var(--tut-gold)}.guide-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}.guide-dots{display:inline-flex;gap:5px}.guide-dots .dot{width:6px;height:6px;border-radius:50%;background:#e2d7a04d}.guide-dots .dot.on{background:var(--tut-gold)}.guide-next{margin-left:auto;background:linear-gradient(180deg,#c9a227,#a6841d);color:var(--tut-ink);border:none;border-radius:8px;padding:7px 18px;font-weight:700;font-size:13px;cursor:pointer}.guide-next:hover{background:linear-gradient(180deg,#e2b34a,#c9a227)}.reward-toast{position:fixed;left:50%;top:18px;transform:translate(-50%);z-index:80;min-width:220px;padding:12px 18px;text-align:center;background:linear-gradient(180deg,#302818f5,#1c170ef5);border:1px solid var(--tut-gold);border-radius:10px;box-shadow:0 10px 30px #00000080,0 0 22px #e2d7a02e;color:#f3ecd6;cursor:pointer;animation:reward-pop .28s cubic-bezier(.2,1.3,.5,1)}@keyframes reward-pop{0%{opacity:0;transform:translate(-50%,-8px) scale(.96)}to{opacity:1;transform:translate(-50%) scale(1)}}.rt-head{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--tut-gold);margin-bottom:3px}.rt-body{font-weight:700;font-size:14px;color:var(--tut-gold-bright)}.audio-dock{position:fixed;right:14px;bottom:12px;z-index:60;pointer-events:none}.audio-dock>.audio-control{pointer-events:auto}.audio-control{display:inline-flex;align-items:center;gap:8px;padding:5px 9px;background:var(--glass-strong);border-radius:var(--radius-sm);box-shadow:var(--edge),var(--shadow-soft)}.audio-toggle{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text);font-size:15px;line-height:1;cursor:pointer;transition:background .12s ease,transform .12s ease}.audio-toggle:hover{background:#ffffff14}.audio-toggle:active{transform:scale(.92)}.audio-toggle[aria-pressed=true]{color:var(--muted)}.audio-slider{width:84px;accent-color:var(--accent);cursor:pointer}@font-face{font-family:MedievalSharp;src:url(/fonts/MedievalSharp.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}:root{color-scheme:dark;font-family:Georgia,Palatino Linotype,Palatino,serif;--display: "MedievalSharp", "Palatino Linotype", Georgia, serif;--fs-xs: .8rem;--fs-sm: .9rem;--fs-base: 1rem;--fs-md: 1.15rem;--fs-lg: 1.4rem;--fs-xl: 1.8rem;--fs-2xl: 2.3rem;--fs-huge: 6rem;--ink: #e9ecfb;--text: #e9ecfb;--muted: #99a0c4;--accent: #ffd76a;--accent-soft: #ffe9a8;--accent-dim: rgba(255, 215, 106, .42);--rubric: #ff6f61;--lapis: #82a8ff;--glass: rgba(28, 31, 52, .52);--glass-strong: rgba(20, 22, 40, .82);--wash: rgba(255, 255, 255, .07);--wash-2: rgba(255, 255, 255, .13);--wash-on: rgba(255, 215, 106, .18);--well: rgba(0, 0, 0, .38);--hair: rgba(170, 180, 235, .16);--edge: inset 0 0 0 1px rgba(255, 255, 255, .09);--lift: inset 0 1px 0 rgba(255, 255, 255, .12);--blur: blur(16px) saturate(1.2);--radius: 18px;--radius-sm: 11px;--shadow: 0 16px 38px rgba(0, 0, 0, .5);--shadow-soft: 0 7px 20px rgba(0, 0, 0, .38);--halo: 0 1px 4px rgba(0, 0, 0, .7)}*{box-sizing:border-box}html{font-size:18px;background:#0e1018}body{margin:0;color:var(--text);font-size:var(--fs-base);background:transparent;min-height:100vh}svg.ambient{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}.battle-platforms{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none}.platform{position:absolute;transform:translate(-50%,-50%);border-radius:50%;background:radial-gradient(ellipse at 50% 38%,#96b4ff80,#6e82cd3d 56%,#6e82cd00 74%)}.platform:after{content:"";position:absolute;left:9%;right:9%;top:16%;bottom:16%;border-radius:50%;border:2px solid rgba(150,180,255,.6);box-shadow:0 0 20px #96b4ff80,inset 0 0 16px #96b4ff59;animation:platform-pulse 3.6s ease-in-out infinite}.platform-player{left:22%;top:80%;width:27vw;height:8.2vw}.platform-enemy{left:78%;top:42%;width:18.5vw;height:5.6vw}@keyframes platform-pulse{0%,to{opacity:.65}50%{opacity:1}}@media(prefers-reduced-motion:reduce){.platform:after{animation:none}}button{font:inherit;background:var(--wash);color:var(--text);border:none;border-radius:var(--radius-sm);padding:7px 15px;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--shadow-soft),var(--edge),var(--lift);transition:background .14s ease,color .14s ease,box-shadow .14s ease,transform 90ms ease}button:hover:not(:disabled){background:var(--wash-2);box-shadow:var(--shadow),var(--edge),var(--lift)}button:active:not(:disabled){transform:translateY(1px)}button:disabled{opacity:.4;cursor:default}button.active{background:var(--wash-on);color:var(--accent);box-shadow:inset 0 0 0 1.5px var(--accent-dim)}button:focus-visible,select:focus-visible,input:focus-visible{outline:none;box-shadow:0 0 0 3px #ffd76a59}select,input[type=text]{font:inherit;background:var(--glass-strong);color:var(--text);border:none;border-radius:var(--radius-sm);padding:8px 11px;box-shadow:var(--edge),var(--shadow-soft);transition:box-shadow .14s ease}input[type=range],input[type=radio]{accent-color:var(--accent)}.app{position:relative;z-index:1;display:flex;flex-direction:column;height:100vh}.topbar{display:flex;align-items:center;justify-content:flex-end;padding:14px 26px;position:relative;z-index:10}.topbar strong{display:none}.topbar nav{display:flex;gap:4px}.topbar nav button{background:none;border:none;border-radius:999px;padding:7px 16px;color:var(--text);font-family:var(--display);font-size:var(--fs-md);letter-spacing:.5px;text-shadow:var(--halo);-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none}.topbar nav button:hover:not(:disabled){background:var(--glass);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);box-shadow:var(--edge)}.topbar nav button.active{background:var(--glass-strong);color:var(--accent);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);box-shadow:var(--shadow-soft),var(--edge),var(--lift)}.lab{flex:1;display:grid;grid-template-columns:1fr 360px;min-height:0}.lab-stage{position:relative;display:flex;flex-direction:column;min-height:0}.canvas-host{flex:1;min-height:0}.canvas-host canvas{display:block}.focus-sink{position:absolute;opacity:0;width:2px;height:2px;bottom:8px;left:8px;pointer-events:none}.hint{padding:8px 16px;margin:0;font-size:var(--fs-sm);color:var(--muted);text-shadow:var(--halo)}.lab-side{overflow-y:auto;padding:16px 18px;display:flex;flex-direction:column;gap:18px;margin:12px 12px 12px 0;border-radius:var(--radius);background:var(--glass);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);box-shadow:var(--shadow),var(--edge),var(--lift)}.panel{position:relative;background:var(--glass);border-radius:var(--radius);padding:18px 20px;-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);box-shadow:var(--shadow),var(--edge),var(--lift)}.panel h2{margin:0 0 12px;font-variant:small-caps;font-size:var(--fs-md);font-weight:700;letter-spacing:2px;color:var(--accent);padding-bottom:7px;border-bottom:1px solid var(--hair)}.panel h3{margin:14px 0 6px;font-variant:small-caps;font-size:var(--fs-sm);font-weight:700;letter-spacing:2px;color:var(--muted)}.lab-side .panel{background:none;border-radius:0;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;padding:0 0 16px;border-bottom:1px solid var(--hair)}.lab-side .panel:last-child{border-bottom:none;padding-bottom:0}.muted{color:var(--muted);font-size:var(--fs-sm)}.help{cursor:help;text-decoration:underline dotted;text-underline-offset:3px}.field{display:flex;flex-direction:column;gap:4px;margin-bottom:12px;font-size:var(--fs-sm)}.field>span,.field legend{color:var(--accent);font-variant:small-caps;font-weight:700;font-size:var(--fs-sm);letter-spacing:1px}.radio{display:flex;align-items:center;gap:6px;margin:2px 0;color:var(--text)}fieldset.field{border:none;background:var(--wash);border-radius:var(--radius-sm);padding:8px 12px;box-shadow:var(--edge)}.prompt-preview{font-family:var(--display);font-size:var(--fs-xl);letter-spacing:2px;padding:8px 0;color:var(--accent)}.bar-row{display:grid;grid-template-columns:100px 1fr 44px;align-items:center;gap:8px;margin:6px 0;font-size:var(--fs-sm)}.bar-label{color:var(--muted)}.bar-track{height:9px;background:var(--well);border-radius:999px;overflow:hidden}.bar-fill{height:100%}.bar-val{text-align:right}.derives{margin:8px 0 2px;padding-top:6px;border-top:1px solid var(--hair);text-align:right;font-size:var(--fs-xs);color:var(--muted);cursor:help}.bar-row.quality{margin-top:2px;font-size:var(--fs-base)}.bar-row.quality .bar-label{color:var(--accent);font-weight:700;font-variant:small-caps}.bar-row.quality .bar-track{height:16px;box-shadow:inset 0 0 0 1px var(--accent-dim)}.bar-row.quality .bar-val{color:var(--accent);font-size:var(--fs-md)}.stats{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px;margin:12px 0 0}.stats div{display:flex;justify-content:space-between;font-size:var(--fs-sm);border-bottom:1px dotted var(--hair);padding-bottom:2px}.stats dt{color:var(--muted)}.stats dd{margin:0}.misfire{margin:12px 0 0;padding:10px 12px;border-radius:var(--radius-sm);background:#ff6f6124;color:#ffb4ab;font-size:var(--fs-sm)}.history .spark{display:flex;align-items:flex-end;gap:3px;height:60px;padding:4px;background:var(--well);border-radius:var(--radius-sm)}.spark-bar{flex:1;min-width:4px}.arena{position:relative;flex:1;min-height:0;overflow:hidden}.arena .canvas-host{position:absolute;top:0;right:0;bottom:0;left:0}.overlay{position:absolute;pointer-events:none;z-index:2}.field-stack{width:42%;height:76%;display:flex;flex-direction:column;gap:5px;transform:translateY(-50%);transition:opacity .16s ease}.field-player{top:38%;left:5%;align-items:flex-start;text-align:left}.field-enemy{top:62%;right:5%;align-items:flex-end;text-align:right}.field-enemy .alts{align-items:flex-end}.field-stack.dim{opacity:.5}.lab-stage .field-stack{height:94%}.lab-stage .field-player{top:50%}@keyframes field-shake{0%,to{transform:translateY(-50%)}20%{transform:translate(-7px,-50%)}40%{transform:translate(6px,-51%)}60%{transform:translate(-4px,-49%)}80%{transform:translate(3px,-50%)}}.field-stack.shake{animation:field-shake .4s ease-out}.alts{flex:1 1 0;min-height:0;display:flex;flex-direction:column;gap:2px;width:100%;align-items:flex-start}.field-stack>.alts:first-child{justify-content:flex-end}.field-stack>.alts:last-child{justify-content:flex-start}.alt{display:flex;align-items:center;gap:8px;max-height:28px;overflow:hidden;opacity:.9;transition:opacity .15s ease,max-height .2s ease,transform .15s ease}.alt.dropped{opacity:0;max-height:0;transform:translate(-8px)}.alt.unaffordable{opacity:.4}.alt-icon{font-size:var(--fs-sm);width:18px;text-align:center;flex:none}.alt-incant{font-size:var(--fs-md);letter-spacing:1px;text-shadow:var(--halo);white-space:pre}.alt-incant .typed{color:inherit;font-weight:700}.alt-incant .rest{color:inherit;opacity:.5}.alt-cost{font-size:var(--fs-xs);color:var(--muted);text-shadow:var(--halo)}.field-icon{flex:none;display:inline-flex;align-items:center;justify-content:center;width:32px;height:40px;margin-right:8px;font-size:var(--fs-lg);line-height:1}.cast-field{flex:none;display:flex;align-items:center;min-height:48px;padding:4px 2px;border-bottom:2px solid var(--accent-dim);font-size:var(--fs-2xl);line-height:1.15;letter-spacing:2px;text-shadow:var(--halo);white-space:pre}.cast-field .typed{color:var(--text)}.cast-field .rest{color:var(--muted);opacity:.6}.cast-field .committed{color:var(--accent);font-variant:small-caps}.field-caret{display:inline-block;width:2px;align-self:stretch;margin:4px 1px;background:var(--accent);animation:caret-blink 1s step-end infinite}.hud-corner{width:300px}.hud-corner.player{bottom:16px;left:18px}.hud-corner.enemy{top:16px;right:18px}.buffs{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}.buffs-right{justify-content:flex-end}.buff{position:relative;width:34px;height:34px;border:2px solid;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--fs-md);background:var(--glass-strong);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:var(--shadow-soft);overflow:hidden}.buff-glyph{line-height:1}.buff-bar{position:absolute;bottom:0;left:0;height:3px;opacity:.9;transition:width .12s linear}.arena-controls{top:12px;left:50%;transform:translate(-50%);pointer-events:auto;display:flex;align-items:center;gap:8px}.arena-log{bottom:14px;left:50%;transform:translate(-50%);width:min(440px,60%);text-align:center;font-size:var(--fs-sm);color:var(--muted);text-shadow:var(--halo)}.duel-hud{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;padding:12px 16px}.side-hud{display:flex;flex-direction:column;gap:5px;width:100%;max-width:320px}.side-hud.mirror{margin-left:auto;text-align:right}.side-name{font-variant:small-caps;font-weight:700;font-size:var(--fs-md);letter-spacing:1px;text-shadow:var(--halo)}.side-name em{color:var(--muted)}.meter{display:grid;grid-template-columns:78px 1fr;align-items:center;gap:8px;font-size:var(--fs-xs)}.side-hud.mirror .meter{grid-template-columns:1fr 78px}.side-hud.mirror .meter-label{order:2;text-align:left}.side-hud.mirror .meter-track{order:1}.meter-label{color:var(--muted);text-shadow:var(--halo)}.meter-track{height:9px;background:var(--well);border-radius:999px;overflow:hidden;box-shadow:var(--lift)}.meter-fill{height:100%}.tell{position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;padding:6px 14px;min-width:150px;text-shadow:var(--halo)}.tell.idle{color:var(--muted);font-size:var(--fs-sm)}.tell-school{font-weight:700;letter-spacing:3px;font-size:var(--fs-md)}.tell-pips{display:flex;gap:5px}.pip{width:8px;height:8px;transform:rotate(45deg);background:var(--well)}.pip.on{background:var(--accent)}.tell-progress{width:110px;height:5px;background:var(--well);border-radius:999px;overflow:hidden}.tell-progress-fill{display:block;height:100%;transition:width .12s linear}.tell-label{font-size:var(--fs-xs);letter-spacing:2px;color:var(--muted)}.duel-stage{position:relative;display:flex;flex-direction:column;min-height:0;overflow:hidden}.winner-banner{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:#0a0c16c7;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);font-family:var(--display);font-size:var(--fs-xl);color:var(--text)}.duel-spells{display:flex;gap:8px;padding:10px 16px;flex-wrap:wrap}.spell{display:flex;flex-direction:column;align-items:flex-start;gap:2px;min-width:124px;padding:8px 10px;text-align:left}.spell.active{box-shadow:inset 0 0 0 1.5px var(--accent-dim)}.spell-key{font-size:var(--fs-xs);color:var(--muted)}.spell-name{font-variant:small-caps;font-weight:700;letter-spacing:1px}.spell-meta{font-size:var(--fs-xs);color:var(--muted)}.candidates{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;width:100%}.candidate{display:flex;flex-direction:column;align-items:flex-start;gap:2px;min-width:132px;padding:8px 12px;border-radius:var(--radius-sm);background:var(--glass-strong);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);box-shadow:var(--shadow-soft),var(--edge),var(--lift);transition:opacity .12s ease,box-shadow .12s ease}.candidate.dropped{opacity:.3}.candidates.dim{opacity:.5}.candidate.unaffordable{opacity:.4}.candidate.unaffordable .candidate-incant .typed,.candidate.unaffordable .candidate-incant .rest{color:var(--muted)}.candidate-incant{font-size:var(--fs-lg);letter-spacing:1px}.candidate-incant .typed{color:var(--accent);font-weight:700}.candidate-incant .rest{color:var(--muted)}.candidate-name{font-variant:small-caps;letter-spacing:1px;color:var(--text)}.candidate-meta{font-size:var(--fs-xs);color:var(--muted)}.lab-stage .candidates{position:absolute;left:0;right:0;bottom:52px;padding:0 16px}.candidates-hint{padding:4px 0;margin:0}.spellbook-open{align-self:flex-start;margin-bottom:10px}.spellbook-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:50}.spellbook{width:min(680px,92vw);max-height:84vh;display:flex;flex-direction:column;background:var(--glass-strong);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border-radius:var(--radius);box-shadow:var(--shadow),var(--edge),var(--lift)}.spellbook-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--hair)}.spellbook-head h2{margin:0;font-family:var(--display);font-size:var(--fs-lg);letter-spacing:1px;color:var(--accent);flex:1}.spellbook-page{font-size:var(--fs-xs);color:var(--muted);margin-right:14px}.spellbook-page-body{display:grid;grid-template-columns:280px 1fr;gap:18px;padding:18px}.spellbook-preview{width:280px;height:200px;border-radius:var(--radius-sm);overflow:hidden;background:radial-gradient(circle at 50% 40%,#1c2140,#0d1022);box-shadow:var(--edge)}.spellbook-preview canvas{display:block}.spellbook-detail{display:flex;flex-direction:column}.spellbook-title{display:flex;align-items:baseline;gap:10px}.spellbook-sigil{font-size:var(--fs-lg)}.spellbook-name{font-family:var(--display);font-size:var(--fs-xl);letter-spacing:1px}.spellbook-incant{margin-top:6px;font-size:var(--fs-lg);letter-spacing:2px;text-transform:capitalize;color:var(--accent)}.spellbook-tags{font-size:var(--fs-xs);color:var(--muted);margin-top:6px}.spellbook-effect{margin:12px 0 0;color:var(--text);line-height:1.5}.spellbook-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 18px;border-top:1px solid var(--hair)}.spellbook-dots{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}.spellbook-dots .dot{width:9px;height:9px;min-width:0;padding:0;border-radius:50%;background:var(--well)}.spellbook-dots .dot.active{background:var(--accent)}.duel-foot{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:10px 16px}.duel-controls{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.toggle-group{display:flex;align-items:center;gap:6px}.field-inline{display:flex;align-items:center;gap:6px;font-size:var(--fs-sm)}.small{font-size:var(--fs-xs)}.duel-log{background:var(--glass);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border-radius:var(--radius-sm);padding:8px 12px;font-size:var(--fs-sm);overflow-y:auto;max-height:96px;box-shadow:var(--edge)}.log-line{color:var(--muted);padding:1px 0}.log-line.fresh{color:var(--text)}.lobby{position:relative;z-index:1;flex:1;overflow-y:auto;display:flex;justify-content:center;padding:44px 28px 64px}.lobby-shell{width:100%;max-width:1060px;display:flex;flex-direction:column;gap:26px}.lobby-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px}.lobby-head h1{font-family:var(--display);color:var(--accent);font-size:var(--fs-xl);line-height:1.05;margin:0}.lobby-head .sub{color:var(--muted);font-size:var(--fs-sm);margin-top:6px}.lobby-grid{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);gap:22px;align-items:start}.lobby-col{display:flex;flex-direction:column;gap:22px;min-width:0}@media(max-width:860px){.lobby-grid{grid-template-columns:1fr}}.lobby-card{background:var(--glass);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border-radius:var(--radius);padding:22px 24px;min-width:320px;max-width:440px;box-shadow:var(--shadow),var(--edge),var(--lift)}.lobby-grid .lobby-card{min-width:0;max-width:none;width:100%}.lobby-card h2,.lobby-card h3{font-family:var(--display);color:var(--accent);margin:0 0 10px}.lobby-card p{color:var(--muted);margin:6px 0 14px}.lobby .row{display:flex;gap:10px;align-items:center;margin:10px 0}.lobby .row.spread{justify-content:space-between}.lobby .check{color:var(--muted);font-size:var(--fs-sm);display:flex;align-items:center;gap:6px}.lobby input[type=text],.lobby input:not([type]){background:var(--glass-strong);color:var(--text);border:none;border-radius:var(--radius-sm);padding:8px 10px;font-family:inherit;flex:1;box-shadow:var(--edge),var(--shadow-soft)}.hint{color:var(--muted);font-size:var(--fs-sm)}.muted{color:var(--muted)}.link{background:none;color:var(--lapis);cursor:pointer;padding:2px 6px;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.link:hover{color:var(--accent);background:none;box-shadow:none}.lobby-error{color:var(--rubric);margin:8px 0;font-size:var(--fs-sm)}.auth-gate{position:relative;z-index:1;min-height:100vh;display:grid;place-items:center;padding:24px}.auth-card{width:min(400px,92vw);background:var(--glass-strong);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border-radius:var(--radius);box-shadow:var(--shadow),var(--edge),var(--lift);padding:36px 32px 30px;text-align:center}.auth-mark{margin:0;font-family:var(--display);font-size:var(--fs-2xl);font-weight:400;letter-spacing:1px;color:var(--accent);text-shadow:0 0 26px rgba(255,215,106,.3)}.auth-sub{margin:7px 0 22px;color:var(--muted);font-size:var(--fs-sm)}.signin{display:flex;flex-direction:column;gap:11px;text-align:left}.signin input{font:inherit;width:100%;background:var(--glass-strong);color:var(--text);border:none;border-radius:var(--radius-sm);padding:11px 13px;box-shadow:var(--edge),var(--shadow-soft);transition:box-shadow .14s ease}.signin input::placeholder{color:var(--muted)}.signin>button{width:100%;padding:11px 15px}.signin>button[type=submit]{margin-top:2px;font-family:var(--display);font-size:var(--fs-md);letter-spacing:1px;color:#1b1407;background:linear-gradient(180deg,var(--accent-soft),var(--accent));box-shadow:var(--shadow-soft),var(--lift)}.signin>button[type=submit]:hover:not(:disabled){background:linear-gradient(180deg,#fff1cc,var(--accent-soft));box-shadow:var(--shadow),var(--lift)}.signin .link{width:auto;align-self:center;font-size:var(--fs-sm)}.signin .or{display:flex;align-items:center;gap:12px;margin:3px 0;color:var(--muted);font-size:var(--fs-xs);font-variant:small-caps;letter-spacing:2px}.signin .or:before,.signin .or:after{content:"";flex:1;height:1px;background:var(--hair)}.signin .error{margin:0;color:var(--rubric);font-size:var(--fs-sm)}.signin .hint{padding:0}.social{display:flex;flex-direction:column;width:min(560px,92vw);height:min(70vh,620px)}.social-tabs{display:flex;gap:6px;margin-bottom:12px}.social-tabs button{font-family:var(--display);font-size:var(--fs-md);padding:6px 16px}.social-body{flex:1;min-height:0;display:flex;flex-direction:column;gap:8px;overflow:hidden}.social-search input{width:100%;background:var(--glass-strong);color:var(--text);border:none;border-radius:var(--radius-sm);padding:9px 12px;box-shadow:var(--edge)}.social-h{margin:8px 0 2px;font-variant:small-caps;letter-spacing:1px;color:var(--muted);font-size:var(--fs-sm)}.social-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:3px;overflow-y:auto}.social-user{display:flex;align-items:center;gap:8px;padding:5px 6px;border-radius:var(--radius-sm)}.social-user:hover{background:var(--wash)}.social-user>.link{margin-left:auto}.user-chip{display:flex;align-items:center;gap:8px;min-width:0}.user-ava{width:30px;height:38px;border-radius:8px;overflow:hidden;background:radial-gradient(circle at 50% 38%,#1c2140,#0d1022);display:grid;place-items:end center;flex:none}.user-ava svg{width:30px;height:auto}.user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.social-dot{width:8px;height:8px;border-radius:50%;flex:none}.social-dot.on{background:#5fd06a;box-shadow:0 0 8px #5fd06ab3}.social-dot.off{background:#aab4eb47}.chat-pane .dock-log,.dm-conv .dock-log{flex:1;min-height:0;overflow-y:auto;background:var(--well);border-radius:var(--radius-sm);padding:8px 10px}.dm-pane{flex-direction:row;gap:12px}.dm-partners{list-style:none;padding:0;margin:0;width:150px;overflow-y:auto;display:flex;flex-direction:column;gap:3px;border-right:1px solid var(--hair)}.dm-partners .social-user{cursor:pointer}.dm-partners .social-user.on{background:var(--wash-on);box-shadow:inset 0 0 0 1px var(--accent-dim)}.dm-conv{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}.dm-head{padding-bottom:6px;border-bottom:1px solid var(--hair)}.dm-msg{max-width:78%;padding:7px 11px;border-radius:12px;font-size:var(--fs-sm);overflow-wrap:anywhere}.dm-msg.mine{align-self:flex-end;background:var(--wash-on);box-shadow:inset 0 0 0 1px var(--accent-dim)}.dm-msg.theirs{align-self:flex-start;background:var(--wash)}.room-code{color:var(--muted);margin-bottom:14px}.room-code strong{color:var(--accent);letter-spacing:.08em;font-family:var(--display)}.roster{display:flex;align-items:center;gap:14px;margin:12px 0}.roster .vs{color:var(--rubric);font-family:var(--display)}.slot{flex:1;display:flex;align-items:center;gap:8px;border-radius:var(--radius-sm);padding:10px 12px;background:var(--wash);box-shadow:var(--edge),var(--lift)}.slot.ready{box-shadow:inset 0 0 0 1.5px var(--accent-dim),var(--lift)}.slot-name{flex:1}.slot-state{color:var(--muted);font-size:var(--fs-xs)}.dot{width:9px;height:9px;border-radius:50%}.dot.on{background:#5fd06a;box-shadow:0 0 8px #5fd06ab3}.dot.off{background:#aab4eb47}.play-actions{display:flex;align-items:center;gap:14px;margin:4px 0 16px}.join-row{display:flex;gap:10px}.join-row input{flex:1}.btn-primary{background:var(--accent);color:#2a2206;font-family:var(--display);font-size:var(--fs-md);padding:11px 22px;box-shadow:var(--shadow-soft),var(--lift)}.btn-primary:hover:not(:disabled){background:var(--accent-soft);color:#2a2206}.room-list{list-style:none;padding:0;margin:12px 0 0;display:flex;flex-direction:column;gap:8px}.room-list li{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--radius-sm);background:var(--wash);box-shadow:var(--edge),var(--lift);transition:background .14s ease}.room-list li:hover{background:var(--wash-2)}.room-host{flex:1;font-weight:500}.room-list .code{color:var(--muted);font-family:var(--display);letter-spacing:.06em;font-size:var(--fs-sm)}.empty-duels{display:flex;flex-direction:column;align-items:center;gap:8px;padding:30px 16px;color:var(--muted);text-align:center}.empty-duels .glyph{font-size:26px;color:var(--accent-dim)}.net-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#080a12b3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:30;pointer-events:auto}.net-card{background:var(--glass-strong);border-radius:var(--radius);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);box-shadow:var(--shadow),var(--edge),var(--lift);padding:24px 30px;color:var(--text);text-align:center;display:flex;flex-direction:column;gap:14px}.countdown{font-family:var(--display);font-size:var(--fs-huge);color:var(--accent);text-shadow:0 0 30px rgba(255,215,106,.5);animation:countpulse 1s ease-in-out infinite}@keyframes countpulse{0%,to{transform:scale(1);opacity:.85}50%{transform:scale(1.12);opacity:1}}.net-banner{top:14px;left:50%;transform:translate(-50%);background:#ff6f6124;color:#ffb4ab;box-shadow:inset 0 0 0 1px #ff6f6159;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-sm);padding:8px 14px;z-index:25}.winner-banner .row{display:flex;gap:10px;justify-content:center;margin-top:10px}.leaderboard .ladder{list-style:none;padding:0;margin:6px 0 0}.leaderboard .ladder li{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:var(--radius-sm);border-top:1px solid var(--hair)}.leaderboard .ladder li.me{background:var(--wash-on);box-shadow:inset 0 0 0 1px var(--accent-dim)}.leaderboard .rank{width:22px;text-align:right;color:var(--muted);font-variant-numeric:tabular-nums}.leaderboard .ava{width:24px;height:24px;border-radius:50%;object-fit:cover;box-shadow:var(--edge)}.leaderboard .ava.blank{background:var(--wash-2)}.leaderboard .ladder-name{flex:1}.leaderboard .wl{color:var(--muted);font-size:var(--fs-sm);font-variant-numeric:tabular-nums}.leaderboard .rating{color:var(--accent);font-variant-numeric:tabular-nums;min-width:42px;text-align:right}.character .char-head{display:flex;gap:16px;align-items:center;margin:8px 0 16px}.char-avatar{width:96px;height:96px;border-radius:var(--radius-sm);object-fit:cover;background:var(--wash);box-shadow:var(--edge),var(--lift)}.char-avatar.blank{background:repeating-linear-gradient(45deg,#ffffff0a,#ffffff0a 6px,#ffffff17 6px,#ffffff17 12px)}.char-id{flex:1;display:flex;flex-direction:column;gap:8px}.char-id input{background:var(--glass-strong);color:var(--text);border:none;border-radius:var(--radius-sm);padding:8px 10px;font-family:var(--display);font-size:var(--fs-md);flex:1;box-shadow:var(--edge),var(--shadow-soft)}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:8px 0 16px}.stat{background:var(--wash);border-radius:var(--radius-sm);padding:12px 8px;text-align:center;box-shadow:var(--edge),var(--lift)}.stat-value{font-family:var(--display);font-size:var(--fs-lg);color:var(--text)}.stat-value.accent{color:var(--accent)}.stat-label{color:var(--muted);font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.06em;margin-top:4px}.avatar-forge{display:flex;gap:14px;align-items:flex-start}.forge-controls{flex:1;display:flex;flex-direction:column;gap:8px}.talents{max-width:none;width:100%}.talents .arcana{color:var(--accent);font-family:var(--display)}.xp-bar{height:6px;border-radius:999px;background:var(--wash);box-shadow:var(--edge);overflow:hidden;margin:4px 0 2px}.xp-fill{height:100%;background:linear-gradient(90deg,var(--accent-dim),var(--accent));border-radius:999px;transition:width .3s ease}.pick-mastery{margin-left:6px;font-size:var(--fs-xs);color:var(--muted)}.pick.on .pick-mastery{color:var(--accent)}.talent-tree{display:grid;grid-template-columns:repeat(5,1fr);gap:12px 16px;align-items:start;margin:14px 0 20px}@media(max-width:820px){.talent-tree{grid-template-columns:repeat(2,1fr)}}.talent-line{display:flex;flex-direction:column;gap:6px}.line-label{color:var(--muted);font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.06em;text-align:center}.talent{display:grid;grid-template-columns:1fr auto;gap:2px 6px;text-align:left;background:var(--wash);border-radius:var(--radius-sm);padding:8px 10px;cursor:pointer;box-shadow:var(--edge),var(--lift)}.talent .talent-name{font-family:var(--display);color:var(--text)}.talent .talent-cost{color:var(--accent);font-size:var(--fs-sm)}.talent .talent-blurb{grid-column:1 / -1;color:var(--muted);font-size:var(--fs-xs)}.talent.owned{box-shadow:inset 0 0 0 1.5px var(--accent-dim),var(--lift)}.talent.owned .talent-cost{color:#5fd06a}.talent.open:hover{background:var(--wash-2)}.talent.locked{opacity:.5;cursor:not-allowed}.loadout-pick{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.pick{background:var(--wash);border-radius:999px;padding:5px 12px;cursor:pointer;color:var(--muted);box-shadow:var(--edge),var(--lift)}.pick.on{color:var(--accent);background:var(--wash-on);box-shadow:inset 0 0 0 1px var(--accent-dim)}.tavern{display:flex;gap:18px;padding:24px;height:calc(100vh - 60px);box-sizing:border-box}.tavern-main{flex:1;display:flex;flex-direction:column;background:var(--glass);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border-radius:var(--radius);padding:18px 20px;min-width:0;box-shadow:var(--shadow),var(--edge),var(--lift)}.tavern-main h2{font-family:var(--display);color:var(--accent);margin:0}.chat-log{flex:1;overflow-y:auto;margin:12px 0;display:flex;flex-direction:column;gap:7px;padding-right:6px}.chat-line{display:flex;align-items:baseline;gap:8px}.chat-ava{width:22px;height:22px;border-radius:50%;object-fit:cover;align-self:center;box-shadow:var(--edge)}.chat-ava.blank{background:var(--wash-2)}.chat-from{color:var(--accent);font-family:var(--display);font-size:var(--fs-sm);white-space:nowrap}.chat-text{color:var(--text);overflow-wrap:anywhere}.chat-input{gap:8px}.chat-input input{flex:1;background:var(--glass-strong);color:var(--text);border:none;border-radius:var(--radius-sm);padding:9px 11px;font-family:inherit;box-shadow:var(--edge),var(--shadow-soft)}.tavern-patrons{width:240px;align-self:flex-start}.patron-list{list-style:none;padding:0;margin:8px 0 0;display:flex;flex-direction:column;gap:8px}.patron-list li{display:flex;align-items:center;gap:8px}.patron-list li .patron-name{flex:1}.history-list{list-style:none;padding:0;margin:6px 0 0}.history-list li{display:flex;align-items:center;gap:10px;padding:7px 4px;border-top:1px solid var(--hair)}.history-list .result{font-family:var(--display);font-size:var(--fs-sm);width:46px}.history-list .result.win{color:#5fd06a}.history-list .result.loss{color:var(--rubric)}.history-list .result.draw{color:var(--muted)}.history-list .vs-name{flex:1}.history-list .when{color:var(--muted);font-size:var(--fs-xs)}.models{min-height:100vh;color:var(--text);padding:0 0 40px;position:relative;z-index:1}.models-bar{display:flex;align-items:baseline;gap:14px;padding:16px 24px;border-bottom:1px solid var(--hair)}.models-bar strong{font-family:var(--display);color:var(--accent);font-size:var(--fs-lg)}.models-grid{display:grid;grid-template-columns:320px 1fr;gap:20px;padding:24px;align-items:start}.model-stage{position:sticky;top:24px;background:var(--glass);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border-radius:var(--radius);padding:24px;display:flex;flex-direction:column;align-items:center;gap:14px;box-shadow:var(--shadow),var(--edge),var(--lift)}.model-stage svg{background:radial-gradient(circle at 50% 38%,#1c2140,#0d1022);border-radius:var(--radius-sm)}.mod-readout{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.mod-readout span{background:var(--wash-on);border-radius:999px;padding:3px 10px;font-size:var(--fs-sm);color:var(--accent)}.model-panel h3{font-family:var(--display);color:var(--accent);margin:14px 0 8px}.model-panel .slot-head{text-transform:capitalize;color:var(--muted);font-size:var(--fs-sm)}.model-row{display:flex;flex-wrap:wrap;gap:10px}.model-chip{display:flex;flex-direction:column;align-items:center;gap:4px;background:var(--wash);border-radius:var(--radius-sm);padding:8px;cursor:pointer;color:var(--muted);font-size:var(--fs-xs);box-shadow:var(--edge),var(--lift)}.model-chip svg{background:radial-gradient(circle at 50% 40%,#1c2140,#0d1022);border-radius:var(--radius-sm)}.model-chip.on{color:var(--accent);box-shadow:inset 0 0 0 1.5px var(--accent-dim)}.wizards{min-height:100vh;color:var(--text);padding:0 0 48px;position:relative;z-index:1}.wizards-bar{display:flex;align-items:baseline;gap:16px;flex-wrap:wrap;padding:16px 24px;border-bottom:1px solid var(--hair)}.wizards-bar strong{font-family:var(--display);color:var(--accent);font-size:var(--fs-lg)}.wizards-bar .hint{flex:1;min-width:240px;padding:0}.wizards-palettes{display:flex;gap:8px}.pal-chip{font-family:var(--display);font-size:var(--fs-sm);color:var(--muted);padding:5px 14px;border-radius:999px}.pal-chip.on{color:var(--accent);background:var(--wash-on);box-shadow:inset 0 0 0 1px var(--accent-dim)}.wizards-section{font-family:var(--display);color:var(--accent);font-size:var(--fs-lg);margin:26px 0 0;padding:0 24px;letter-spacing:.5px}.wizards-section small{display:block;font-family:var(--display);color:var(--muted);font-size:var(--fs-sm);letter-spacing:0;margin-top:2px}.wizards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px;padding:16px 24px 8px}.wcard{background:var(--glass);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow),var(--edge),var(--lift);display:flex;flex-direction:column;gap:12px}.wcard-head{display:flex;align-items:baseline;gap:10px}.wcard-head h3{font-family:var(--display);color:var(--accent);margin:0;font-size:var(--fs-md)}.wcard-head .num{color:var(--muted);font-size:var(--fs-xs);letter-spacing:.06em;text-transform:uppercase}.wcard-stage{display:flex;align-items:flex-end;justify-content:center;gap:16px;padding:16px;border-radius:var(--radius-sm);background:radial-gradient(circle at 50% 38%,#1c2140,#0d1022);box-shadow:var(--edge)}.wcard-stage>svg{filter:drop-shadow(0 8px 12px rgba(0,0,0,.45))}.wcard-sizes{display:flex;align-items:flex-end;gap:12px}.wcard-stage.art{padding:0;overflow:hidden}.wsprite{display:block;width:100%;max-height:360px;object-fit:contain;border-radius:var(--radius-sm)}.mb{display:grid;grid-template-columns:minmax(0,340px) minmax(0,1fr);gap:20px;padding:8px 24px;align-items:start}@media(max-width:760px){.mb{grid-template-columns:1fr}.mb-stage{position:static}}.mb-stage{position:sticky;top:16px;display:flex;flex-direction:column;align-items:center;gap:14px;background:var(--glass);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow),var(--edge),var(--lift)}.mb-stage>svg{background:radial-gradient(circle at 50% 38%,#1c2140,#0d1022);border-radius:var(--radius-sm)}.mb-sizes{display:flex;align-items:flex-end;gap:14px}.mb-sizes svg{background:radial-gradient(circle at 50% 38%,#1c2140,#0d1022);border-radius:var(--radius-sm)}.mb-actions{display:flex;gap:8px}.mb-controls{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px 18px}.mb-slot h4{margin:0 0 6px;font-family:var(--display);color:var(--accent);font-size:var(--fs-sm);font-variant:small-caps;letter-spacing:1px}.mb-chips{display:flex;flex-wrap:wrap;gap:5px}.mb-chip{font-size:var(--fs-xs);color:var(--muted);padding:4px 10px;border-radius:999px;background:var(--wash);box-shadow:var(--edge)}.mb-chip.on{color:var(--accent);background:var(--wash-on);box-shadow:inset 0 0 0 1px var(--accent-dim)}.mb-swatches{display:flex;flex-wrap:wrap;gap:6px}.mb-swatch{width:24px;height:24px;min-width:0;padding:0;border-radius:50%;box-shadow:var(--edge)}.mb-swatch.on{box-shadow:0 0 0 2px var(--accent),var(--edge)}.wcard-blurb{color:var(--text);font-size:var(--fs-sm);line-height:1.45;margin:0}.wcard-tags{display:flex;flex-wrap:wrap;gap:6px}.wcard-tags span{background:var(--wash);border-radius:999px;padding:2px 10px;font-size:var(--fs-xs);color:var(--muted);box-shadow:var(--edge)}.kit-body{display:flex;gap:18px;flex-wrap:wrap}.kit-figure{display:flex;flex-direction:column;align-items:center;gap:8px}.kit-figure svg{background:radial-gradient(circle at 50% 38%,#1c2140,#0d1022);border-radius:var(--radius-sm)}.kit-choices{flex:1;min-width:220px;display:flex;flex-direction:column;gap:8px}.kit-slot{display:flex;flex-direction:column;gap:4px}.fighter{z-index:5;pointer-events:none;filter:drop-shadow(0 8px 12px rgba(0,0,0,.5))}.fighter-player{left:22%;top:80%;bottom:auto;transform:translate(-50%,-88%)}.fighter-enemy{left:78%;top:42%;right:auto;transform:translate(-50%,-88%) scaleX(-1)}.scene-mote{transform-box:fill-box;transform-origin:center;opacity:.82;animation:scene-bob var(--dur, 6s) ease-in-out infinite;animation-delay:var(--delay, 0s)}.scene-spin{transform-box:fill-box;transform-origin:center;animation:scene-spin 16s linear infinite}.scene-cloud{transform-box:fill-box;animation:scene-drift linear infinite}@keyframes scene-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-16px)}}@keyframes scene-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes scene-drift{0%{transform:translate(-50px)}to{transform:translate(120px)}}@media(prefers-reduced-motion:reduce){.scene-mote,.scene-spin,.scene-cloud{animation:none}}.world{position:relative;flex:1;min-height:0;overflow:hidden}.room{position:absolute;top:0;right:0;bottom:0;left:0}.room-wall{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(var(--wall),color-mix(in srgb,var(--wall) 70%,#000))}.room-floor{position:absolute;left:4%;right:4%;top:22%;bottom:3%;background:radial-gradient(120% 90% at 50% 0%,color-mix(in srgb,#fff 16%,var(--floor)) 0%,var(--floor) 60%);border-radius:16px;box-shadow:inset 0 8px 26px #00000073,inset 0 -2px #ffffff0d,0 -10px 24px #0000004d}.room-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0}.room-scene{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.rs-prop{position:absolute;transform:translate(-50%,-50%);filter:drop-shadow(0 6px 6px rgba(0,0,0,.4))}.rs-prop svg{display:block;width:100%;height:100%;overflow:visible}.item{position:absolute;transform:translate(-50%,-50%);z-index:3;pointer-events:none;filter:drop-shadow(0 8px 7px rgba(0,0,0,.5))}.door{position:absolute;display:flex;align-items:center;justify-content:center;border-radius:8px;background:#82a8ff24;box-shadow:inset 0 0 0 1px #a0beff66,0 0 22px #82a8ff59}.door-label{font-family:var(--display);font-size:var(--fs-sm);color:var(--text);text-shadow:var(--halo);white-space:nowrap}.pad{position:absolute;transform:translate(-50%,-50%);width:14%;height:9%;border-radius:50%;background:radial-gradient(ellipse at 50% 50%,#ffd76a42,#ffd76a00 70%);box-shadow:inset 0 0 0 2px #ffd76a52;animation:platform-pulse 3s ease-in-out infinite}.pad.active{box-shadow:inset 0 0 0 2px var(--accent),0 0 26px #ffd76a80}.prop{position:absolute;transform:translate(-50%,-50%);border-radius:8px}.prop-sigil{width:11%;height:8%;border-radius:50%;background:radial-gradient(ellipse,rgba(130,168,255,.18),transparent 70%);box-shadow:inset 0 0 0 1.5px #96b4ff59}.prop-pillar{width:4.5%;height:18%;background:linear-gradient(90deg,#14121f,#2a2740 55%,#14121f);border-radius:6px;box-shadow:0 8px 14px #00000073}.prop-table{width:13%;height:9%;border-radius:50%;background:radial-gradient(ellipse at 50% 35%,#6e4a2a,#4a3018);box-shadow:0 8px 14px #0006,inset 0 0 0 2px #0003}.prop-desk{width:12%;height:6%;background:linear-gradient(#5a4630,#3e2f1d);box-shadow:0 8px 12px #0006}.prop-bar{transform:translate(-50%,-50%);background:linear-gradient(#5a4026,#3a2817);border-radius:10px;box-shadow:0 10px 18px #00000073,inset 0 2px #ffffff0f}.prop-hearth{width:12%;height:9%;background:radial-gradient(ellipse at 50% 70%,#ff8a3c,#7a2f12 60%,#2a1208);border-radius:8px;box-shadow:0 0 28px #ff8a3c80}.prop-board{transform:translate(-50%,-50%);background:#1a2a22;border:3px solid #5a4630;border-radius:6px;box-shadow:0 6px 12px #0006}.prop-lectern{width:5%;height:7%;background:linear-gradient(#5a4630,#3a2817);border-radius:4px 4px 6px 6px}.avatar{position:absolute;transform:translate(-50%,-100%);display:flex;flex-direction:column;align-items:center;pointer-events:none;filter:drop-shadow(0 8px 8px rgba(0,0,0,.55))}.avatar-name{margin-top:-6px;font-size:var(--fs-xs);color:var(--text);text-shadow:var(--halo);white-space:nowrap;background:#0a0c1680;padding:1px 8px;border-radius:8px}.avatar-me{z-index:6}.avatar-peer{z-index:5;animation:peer-idle 3.4s ease-in-out infinite}.avatar-peer.moving{transition:left .1s linear,top .1s linear}.creature{position:absolute;transform:translate(-50%,-100%);display:flex;flex-direction:column;align-items:center;z-index:5;pointer-events:none;filter:drop-shadow(0 7px 7px rgba(0,0,0,.5));transition:left .12s linear,top .12s linear}.creature-name{margin-top:-6px;font-size:var(--fs-xs);color:#ff9a8a;text-shadow:var(--halo);white-space:nowrap;background:#280c0e80;padding:1px 8px;border-radius:8px}.creature.near{filter:drop-shadow(0 0 10px rgba(255,110,90,.6)) drop-shadow(0 7px 7px rgba(0,0,0,.5))}.encounter-tag{color:#ff9a8a;font-family:var(--display);letter-spacing:.04em}@keyframes peer-idle{0%,to{transform:translate(-50%,-100%)}50%{transform:translate(-50%,-103%)}}.avatar-challenge{pointer-events:auto;margin-top:4px;font-size:var(--fs-xs);padding:2px 9px}@media(prefers-reduced-motion:reduce){.avatar-peer,.pad{animation:none}}.world-hud{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:8}.hud-room{position:absolute;top:14px;left:20px;font-family:var(--display);font-size:var(--fs-lg);color:var(--accent);text-shadow:var(--halo)}.hud-keys{position:absolute;bottom:16px;left:50%;transform:translate(-50%);padding:8px 16px;border-radius:999px;background:var(--glass-strong);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);box-shadow:var(--edge),var(--shadow-soft);font-size:var(--fs-sm);color:var(--muted);white-space:nowrap}.hud-keys b,.hud-prompt b{color:var(--accent)}.hud-prompt{color:var(--text)}.hud-actions{position:absolute;top:14px;right:20px;display:flex;gap:8px;pointer-events:auto}.hud-actions b{color:var(--accent);margin-right:4px}.tavern-dock{position:absolute;left:20px;bottom:70px;width:min(360px,34vw);max-height:44%;display:flex;flex-direction:column;gap:8px;padding:12px 14px;border-radius:var(--radius);background:var(--glass-strong);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);box-shadow:var(--shadow),var(--edge),var(--lift);pointer-events:auto;z-index:9}.tavern-dock.solo{bottom:70px}.dock-head{display:flex;align-items:baseline;gap:8px;font-family:var(--display)}.dock-head .link{margin-left:auto}.dock-log{flex:1;min-height:60px;overflow-y:auto;display:flex;flex-direction:column;gap:5px;font-size:var(--fs-sm)}.dock-input{display:flex;gap:8px}.dock-input input{flex:1;background:var(--glass-strong);color:var(--text);border:none;border-radius:var(--radius-sm);padding:8px 10px;box-shadow:var(--edge)}.leave-btn{top:14px;left:18px;pointer-events:auto;z-index:40}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:50}.modal-shell{position:relative;display:flex;flex-direction:column;width:min(840px,94vw);max-height:90vh;overflow:auto;padding:26px 28px;border-radius:var(--radius);background:var(--glass-strong);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);box-shadow:var(--shadow),var(--edge),var(--lift)}.modal-shell.modal-sm{width:min(600px,94vw)}.modal-shell.modal-md{width:min(840px,94vw)}.modal-shell.modal-lg{width:min(1060px,95vw)}.modal-shell .lobby-card{background:none;-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none;border-radius:0;padding:0;min-width:0;max-width:none;width:100%}.modal-close{position:absolute;top:14px;right:16px;z-index:2}.book{position:relative;width:min(980px,95vw);max-height:88vh;display:flex;flex-direction:column;border-radius:14px;background:linear-gradient(180deg,#241f33,#1a1626);box-shadow:var(--shadow),var(--edge),inset 0 0 0 1px #ffffff0f}.book-close{position:absolute;top:12px;right:14px;z-index:3}.book-spread{flex:1;min-height:0;display:grid;grid-template-columns:1fr 1fr;background:linear-gradient(90deg,transparent calc(50% - 2px),rgba(0,0,0,.5) 50%,transparent calc(50% + 2px))}.book-leaf{padding:26px 30px;overflow-y:auto}.book-leaf.left{display:flex;flex-direction:column;align-items:center;gap:16px}.book-leaf.right{display:flex;flex-direction:column;gap:14px}.plate{display:flex;align-items:center;gap:12px}.plate-sigil{font-size:var(--fs-xl)}.plate-name{font-family:var(--display);font-size:var(--fs-xl)}.plate-incant{font-family:var(--display);font-size:var(--fs-lg);letter-spacing:2px;color:var(--accent);text-transform:capitalize}.entry-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;border-bottom:1px solid var(--hair);padding-bottom:8px}.entry-role{font-family:var(--display);font-size:var(--fs-lg);color:var(--text)}.entry-school{font-variant:small-caps;font-weight:700;letter-spacing:1px}.entry-desc{margin:0;font-size:var(--fs-md);line-height:1.6;color:var(--text)}.entry-stats{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}.entry-stats th,.entry-stats td{padding:7px 4px;border-bottom:1px dotted var(--hair);text-align:left}.entry-stats th{color:var(--muted);font-weight:400;font-variant:small-caps;letter-spacing:1px;width:42%}.entry-stats td{color:var(--text);text-align:right;text-transform:capitalize}.entry-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.entry-tags .tag{font-size:var(--fs-xs);color:var(--muted);background:var(--wash);border-radius:999px;padding:3px 11px;text-transform:capitalize}.book-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 18px;border-top:1px solid var(--hair)}.book-folio{font-family:var(--display);color:var(--muted)}.onboard{position:relative;z-index:1;min-height:100vh;display:flex;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto}.onboard-card{background:var(--glass);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border-radius:var(--radius);box-shadow:var(--shadow),var(--edge),var(--lift);padding:28px;width:min(960px,100%)}.onboard-head{text-align:center;margin-bottom:8px}.onboard-head h1{font-family:var(--display);color:var(--accent);margin:0 0 6px}.onboard-head .hint{display:block;max-width:520px;margin:0 auto 16px}.onboard-name{display:inline-flex;align-items:center;gap:10px}.onboard-name span{font-family:var(--display);color:var(--accent);font-variant:small-caps;letter-spacing:1px}.onboard-name input{background:var(--glass-strong);color:var(--text);border:none;border-radius:var(--radius-sm);padding:10px 14px;font-family:inherit;box-shadow:var(--edge),var(--shadow-soft);min-width:240px;text-align:center}.onboard-actions{display:flex;justify-content:center;margin-top:18px}.primary{color:var(--accent);background:var(--wash-on);box-shadow:inset 0 0 0 1px var(--accent-dim),var(--edge);font-weight:600;padding:10px 22px}.primary:disabled{opacity:.5;cursor:default}.lesson-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:flex;align-items:center;justify-content:center;background:#0009;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);padding:24px}.lesson{position:relative;width:min(560px,95vw);background:var(--glass-strong);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border-radius:var(--radius);box-shadow:var(--shadow),var(--edge),var(--lift);padding:24px}.lesson-head{display:flex;gap:16px;align-items:center;margin-bottom:18px}.lesson-head svg{flex:none}.lesson-intro h3{font-family:var(--display);color:var(--accent);margin:0 0 6px}.teacher-line{color:var(--text);margin:0;font-size:var(--fs-md);line-height:1.5}.lesson-field{display:flex;align-items:center;justify-content:center;gap:2px;font-family:var(--display);font-size:30px;letter-spacing:2px;padding:18px;min-height:40px;border-radius:var(--radius-sm);background:var(--wash);box-shadow:var(--edge),inset 0 0 0 1.5px transparent;transition:box-shadow .18s,background .18s}.lesson-field .field-icon{font-size:24px;margin-right:10px}.lesson-field .typed{color:var(--text)}.lesson-field .rest{color:var(--muted);opacity:.5}.lesson-field .field-caret{width:2px;height:1em;background:var(--accent);display:inline-block;animation:caret-blink 1s steps(2) infinite}.lesson-field.good{background:color-mix(in srgb,#5fd06a 16%,var(--wash));box-shadow:var(--edge),inset 0 0 0 1.5px #5fd06a}.lesson-field.miss{background:color-mix(in srgb,var(--rubric) 16%,var(--wash));box-shadow:var(--edge),inset 0 0 0 1.5px var(--rubric)}.lesson-reps{display:flex;align-items:center;gap:8px;margin-top:16px;justify-content:center}.lesson-reps .rep{width:13px;height:13px;border-radius:50%;background:var(--wash);box-shadow:inset 0 0 0 1.5px var(--accent-dim)}.lesson-reps .rep.done{background:var(--accent);box-shadow:0 0 10px #ffd76a80}.lesson-count{margin-left:8px;color:var(--muted);font-size:var(--fs-sm)}@keyframes caret-blink{50%{opacity:0}}.victory-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;display:flex;align-items:center;justify-content:center;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.victory{width:min(440px,92vw);padding:28px 28px 22px;border-radius:var(--radius);text-align:center;background:var(--glass-strong);box-shadow:var(--shadow),var(--edge),var(--lift);animation:victory-pop .4s cubic-bezier(.2,1.3,.4,1)}.victory-title{font-family:var(--display);font-size:44px;margin:0 0 8px;letter-spacing:1px}.victory.win .victory-title{color:var(--accent);text-shadow:0 0 24px rgba(255,215,106,.5)}.victory.loss .victory-title{color:#c46b6b}.victory.draw .victory-title{color:var(--muted)}.victory-xp{display:flex;flex-direction:column;gap:2px;margin:6px 0 16px;opacity:0;transform:translateY(6px);transition:opacity .4s,transform .4s}.victory-xp.in{opacity:1;transform:none}.xp-amount{font-family:var(--display);font-size:22px;color:#7fd0a0}.levelup{color:var(--accent);font-weight:600}.level{color:var(--muted);font-size:var(--fs-sm)}.victory-mastery{text-align:left;margin:4px 0 18px}.vm-head{font-variant:small-caps;letter-spacing:1px;color:var(--muted);font-size:var(--fs-sm);margin-bottom:8px}.vm-row{display:grid;grid-template-columns:1fr 90px auto;align-items:center;gap:8px;margin:6px 0}.vm-name{font-size:var(--fs-sm);color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vm-bar{height:8px;border-radius:999px;background:var(--wash);box-shadow:var(--edge);overflow:hidden}.vm-fill{display:block;height:100%;border-radius:999px;transition:width .9s cubic-bezier(.2,.8,.2,1)}.vm-delta{font-size:var(--fs-xs);color:#7fd0a0;min-width:34px;text-align:right}.victory-actions{display:flex;gap:10px;justify-content:center;margin-top:6px}@keyframes victory-pop{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}
