.app{display:flex;flex-direction:column;height:100dvh;max-width:480px;margin:0 auto;background:var(--surface-0);position:relative;overflow:hidden}.app-content{flex:1;min-height:0;position:relative}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100dvh;gap:16px;background:var(--purple-950)}.loading-sigil{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.sigil-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:1px solid;animation:spin-slow linear infinite}.sigil-ring-1{animation-duration:6s;border-color:#7b3fc480}.sigil-ring-2{top:8px;right:8px;bottom:8px;left:8px;animation-duration:4s;animation-direction:reverse;border-color:#d4a03066}.sigil-glyph{font-size:28px;filter:drop-shadow(0 0 8px var(--analtena-glow));animation:float 2s ease-in-out infinite}.loading-text{font-size:22px;color:var(--gold-400);letter-spacing:.2em;text-shadow:0 0 20px var(--gold-glow)}.loading-sub{font-size:12px;color:var(--silver-400);font-style:italic}.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100dvh;gap:12px;padding:32px;text-align:center}.error-icon{font-size:40px}.error-screen .display{font-size:20px;color:var(--silver-200)}.error-msg{font-size:13px;color:var(--silver-400);max-width:280px}.retry-btn{margin-top:8px;padding:10px 28px;background:var(--purple-700);border:1px solid var(--border-gold);border-radius:8px;color:var(--gold-400);font-size:13px;letter-spacing:.1em}.navbar{display:flex;height:var(--nav-height);background:var(--purple-900);border-top:1px solid var(--border);padding-bottom:var(--safe-bottom);flex-shrink:0}.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;color:var(--silver-400);position:relative;transition:color .2s var(--ease-out-expo);letter-spacing:.05em}.nav-btn.active{color:var(--gold-400)}.nav-icon{font-size:20px;transition:transform .2s var(--ease-spring)}.nav-btn.active .nav-icon{transform:scale(1.15);filter:drop-shadow(0 0 6px var(--gold-glow))}.nav-label{font-size:9px;letter-spacing:.15em;text-transform:uppercase;font-family:var(--font-display)}.nav-indicator{position:absolute;top:0;left:50%;transform:translate(-50%);width:32px;height:2px;background:linear-gradient(90deg,transparent,var(--analtena),transparent);border-radius:0 0 2px 2px}.boss-orb-wrap{position:relative;width:160px;height:160px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px}.boss-orb-wrap.has-image{width:220px;height:220px}.ring{position:absolute;border-radius:50%;border:1px solid;animation:spin-slow linear infinite;transition:border-color .8s ease}.ring-1{width:160px;height:160px;animation-duration:12s}.ring-2{width:130px;height:130px;animation-duration:8s;animation-direction:reverse}.ring-3{width:200px;height:200px;animation-duration:20s;border-style:dashed}.boss-orb-wrap.has-image .ring-1{width:220px;height:220px}.boss-orb-wrap.has-image .ring-2{width:180px;height:180px}.boss-orb-wrap.has-image .ring-3{width:260px;height:260px}.boss-image-wrap{position:relative;z-index:2;width:160px;height:160px;border-radius:50%;overflow:hidden;border:1px solid rgba(212,160,48,.3);transition:box-shadow .8s ease;animation:float 4s ease-in-out infinite,arcane-pulse 3s ease-in-out infinite}.boss-orb-wrap.has-image .boss-image-wrap{width:200px;height:200px}.boss-image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center top}.boss-image-prev{z-index:1;opacity:1}.boss-image-current{z-index:2;opacity:1;transition:opacity 0s}.boss-image-current.fading-in{opacity:0;animation:phase-fade-in .6s ease-out .08s forwards}@keyframes phase-fade-in{0%{opacity:0;filter:brightness(1.8) saturate(.3)}40%{filter:brightness(1.4) saturate(.7)}to{opacity:1;filter:brightness(1) saturate(1)}}.boss-orb-wrap.striking .boss-image-current{animation:damage-flash .3s ease-out}.boss-image-vignette{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;border-radius:50%;background:radial-gradient(circle at center,transparent 40%,rgba(4,7,18,.5) 70%,rgba(4,7,18,.85) 100%);pointer-events:none}.phase-label{position:absolute;bottom:12px;left:50%;transform:translate(-50%);z-index:4;font-family:Cinzel,serif;font-size:11px;letter-spacing:.2em;text-transform:uppercase;text-shadow:0 0 8px currentColor;animation:phase-label-pop .7s ease-out forwards;white-space:nowrap}@keyframes phase-label-pop{0%{opacity:0;transform:translate(-50%) translateY(4px)}30%{opacity:1;transform:translate(-50%) translateY(0)}70%{opacity:1}to{opacity:0}}.boss-sigil{position:relative;z-index:2;width:100px;height:100px;background:radial-gradient(circle,#151e38,#0a0e1a);border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid rgba(212,160,48,.3);box-shadow:0 0 30px #7b3fc466,inset 0 0 20px #00000080;animation:float 4s ease-in-out infinite,arcane-pulse 3s ease-in-out infinite}.boss-glyph{font-size:48px;filter:drop-shadow(0 0 8px rgba(240,192,96,.5))}.phase-dots{display:flex;gap:6px;position:absolute;bottom:-18px;left:50%;transform:translate(-50%)}.phase-dot{width:6px;height:6px;border-radius:50%;background:#151e38;border:1px solid rgba(100,120,180,.2);transition:background .4s ease,box-shadow .4s ease}.phase-dot.active{background:#606880}.boss-orb-wrap.has-image{width:100%;height:280px}.boss-orb-wrap.has-image .boss-image-wrap,.boss-orb-wrap.has-image .ring-1{width:100%;height:280px;border-radius:16px}.boss-orb-wrap.has-image .ring-2{width:95%;height:260px;border-radius:16px}.boss-orb-wrap.has-image .ring-3{width:105%;height:300px;border-radius:16px}.boss-image-vignette{border-radius:16px!important}.raid-screen{display:flex;flex-direction:column;height:100%;padding:16px 16px 0;gap:12px;animation:fadeUp .4s var(--ease-out-expo)}.boss-header{text-align:center}.boss-name{font-size:clamp(18px,5vw,26px);color:var(--gold-400);text-shadow:0 0 24px var(--gold-glow);margin-bottom:10px}.hp-bar-track{position:relative;height:10px;background:var(--purple-700);border-radius:5px;margin:8px 0 4px;border:1px solid var(--border)}.hp-bar-fill{height:100%;border-radius:5px;transition:width .6s var(--ease-out-expo);box-shadow:0 0 8px currentColor}.hp-bar-label{position:absolute;right:0;top:-20px;font-size:11px;color:var(--silver-300);font-family:var(--font-display)}.hp-phase{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--silver-400);font-family:var(--font-display);margin-top:4px}.boss-arena{flex:1;position:relative;display:flex;align-items:center;justify-content:center;min-height:0}.boss-arena.shake{animation:shake .4s var(--ease-out-expo)}.strike-result{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10;text-align:center;pointer-events:none;animation:fadeUp .2s var(--ease-spring);background:#0d0514eb;border-radius:16px;padding:14px 24px;min-width:180px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.strike-result.crit{border:1px solid var(--gold-400);box-shadow:0 0 32px var(--gold-glow)}.strike-result.hit{border:1px solid var(--analtena-light);box-shadow:0 0 24px var(--analtena-glow)}.strike-result.miss{border:1px solid var(--silver-400)}.strike-roll{display:flex;align-items:center;gap:4px;justify-content:center;font-size:12px;color:var(--silver-300);font-family:var(--font-display);margin-bottom:6px}.roll-label{opacity:.6}.roll-value{font-size:16px;font-weight:700;color:var(--silver-100)}.roll-bonus{color:var(--stem-green);font-size:11px}.roll-eq{color:var(--silver-200)}.crit-label{display:block;font-size:12px;letter-spacing:.15em;color:var(--gold-400);font-family:var(--font-display);text-transform:uppercase;margin-bottom:2px}.damage-value{display:block;font-size:32px;font-weight:700;font-family:var(--font-display);color:var(--gold-400);text-shadow:0 0 16px var(--gold-glow);line-height:1}.weapon-label{display:block;font-size:11px;color:var(--silver-400);margin-top:2px}.miss-label{font-size:22px;font-family:var(--font-display);color:var(--silver-400);letter-spacing:.1em}.special-effect{font-size:11px;color:var(--analtena-light);margin-top:4px}.boss-stats-row{display:flex;justify-content:center;gap:24px;padding:8px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.boss-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.stat-icon{font-size:14px}.stat-val{font-family:var(--font-display);font-size:15px;font-weight:700}.stat-lbl{font-size:8px;letter-spacing:.2em;text-transform:uppercase;color:var(--silver-400);font-family:var(--font-display)}.narrator-box{position:relative;padding:10px 14px 10px 36px;background:var(--purple-800);border-left:2px solid var(--analtena);border-radius:0 8px 8px 0}.narrator-owl{position:absolute;left:10px;top:10px;font-size:16px;animation:owl-blink 4s ease-in-out infinite}.narrator-text{font-style:italic;font-size:13px;color:var(--silver-300);line-height:1.5}.strike-section{padding-bottom:8px;display:flex;flex-direction:column;align-items:center;gap:8px}.strike-btn{width:100%;height:56px;border-radius:12px;background:linear-gradient(135deg,#1c1030,#3d2070,#1c1030);border:1px solid rgba(212,160,48,.4);color:var(--gold-400);font-size:15px;letter-spacing:.15em;display:flex;align-items:center;justify-content:center;gap:10px;animation:pulse-gold 3s ease-in-out infinite}.strike-btn:not(:disabled):hover{background:linear-gradient(135deg,#2a1648,#5a2ea0,#2a1648);box-shadow:0 0 40px var(--analtena-glow)}.strike-btn:disabled{opacity:.6;animation:none;cursor:not-allowed}.btn-icon{font-size:20px}.btn-text{font-family:var(--font-display)}.btn-spinner{width:20px;height:20px;border:2px solid var(--purple-600);border-top-color:var(--analtena-light);border-radius:50%;animation:spin-slow .7s linear infinite}.player-hint{font-size:11px;color:var(--silver-400);font-family:var(--font-display);letter-spacing:.05em}.defeated-banner{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--silver-400);font-family:var(--font-display)}.raid-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px;text-align:center;padding:32px}.raid-empty h2{color:var(--silver-200);font-size:20px}.muted-hint{font-size:13px;color:var(--silver-400);font-style:italic}.cooldown-btn-wrap{display:flex;flex-direction:column;align-items:center;gap:8px}.strike-btn.cooling{position:relative;overflow:hidden;opacity:.85;cursor:not-allowed}.cooldown-fill{position:absolute;left:0;top:0;bottom:0;background:#ffffff26;transition:width .1s linear;border-radius:inherit}.no-stamina{font-size:12px;color:#f59e0b;font-style:italic;animation:fadeInOut 1.2s ease forwards}@keyframes fadeInOut{0%{opacity:0;transform:translateY(-4px)}20%{opacity:1;transform:translateY(0)}80%{opacity:1}to{opacity:0}}.strike-btn.cooling{min-width:100%;width:100%}.cooldown-btn-wrap{width:100%}.boss-arena{width:100%;padding:0}.profile-screen{padding:16px;display:flex;flex-direction:column;gap:12px;height:100%;animation:fadeUp .4s var(--ease-out-expo)}.profile-header{display:flex;align-items:center;gap:16px;padding:8px 0}.avatar{position:relative;width:72px;height:72px;flex-shrink:0}.avatar-icon{font-size:36px;position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--purple-700);border-radius:50%;border:2px solid var(--cls-color, var(--analtena));box-shadow:0 0 20px color-mix(in srgb,var(--cls-color, var(--analtena)) 40%,transparent)}.avatar-ring{position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;border-radius:50%;border:1px dashed var(--cls-color, var(--analtena));opacity:.4;animation:spin-slow 10s linear infinite}.profile-name{font-size:clamp(16px,4vw,22px);color:var(--silver-100)}.class-badge{font-family:var(--font-display);font-size:12px;letter-spacing:.12em;text-transform:uppercase;display:block}.class-desc{font-size:11px;color:var(--silver-400);font-style:italic;display:block;margin-top:2px}.stats-block{display:flex;flex-direction:column;gap:10px}.stat-row{display:grid;grid-template-columns:20px 56px 1fr 28px;align-items:center;gap:8px}.stat-icon-sm{font-size:14px}.stat-name{font-size:11px;letter-spacing:.08em;text-transform:uppercase;font-family:var(--font-display);color:var(--silver-300)}.stat-track{height:6px;background:var(--purple-700);border-radius:3px;overflow:hidden}.stat-fill{height:100%;background:linear-gradient(90deg,var(--analtena),var(--analtena-light));border-radius:3px;transition:width .8s var(--ease-out-expo);box-shadow:0 0 6px var(--analtena-glow)}.stat-num{font-family:var(--font-display);font-size:13px;font-weight:600;text-align:right}.equip-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.equip-slot{background:var(--purple-800);border:1px solid var(--border);border-radius:10px;padding:12px 8px;display:flex;flex-direction:column;align-items:center;gap:4px;transition:border-color .2s}.equip-slot.filled{border-color:var(--border-gold);box-shadow:0 0 12px var(--gold-glow)}.equip-icon{font-size:20px}.equip-label{font-size:9px;letter-spacing:.15em;text-transform:uppercase;font-family:var(--font-display);color:var(--silver-300)}.equip-status{font-size:8px;color:var(--silver-400)}.equip-slot.filled .equip-status{color:var(--gold-500)}.x1-card{display:flex;flex-direction:column;gap:8px}.x1-header{display:flex;align-items:center;gap:8px}.x1-logo{font-size:20px;color:var(--x1-cyan)}.x1-label{font-family:var(--font-display);font-size:12px;letter-spacing:.1em}.x1-desc{font-size:12px;color:var(--silver-300);line-height:1.5}.x1-desc strong{color:var(--x1-cyan)}.wallet-row{display:flex;align-items:center;gap:8px;padding-top:6px;border-top:1px solid var(--border);font-size:12px}.wallet-text{flex:1;color:var(--silver-300);font-family:monospace;font-size:11px}.wallet-status{font-size:10px;font-family:var(--font-display)}.eggplant-tip{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:var(--purple-800);border:1px solid rgba(92,24,128,.4);border-radius:10px;font-size:12px;color:var(--silver-300);margin-bottom:8px}.egg-icon{font-size:18px;flex-shrink:0}.eggplant-tip em{color:var(--analtena-light)}.profile-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px;text-align:center;padding:32px}.empty-owl{font-size:52px;animation:float 3s ease-in-out infinite}.empty-hint{font-size:12px;color:var(--silver-400);font-style:italic}.rank-screen{display:flex;flex-direction:column;height:100%;padding:16px;gap:10px;animation:fadeUp .4s var(--ease-out-expo)}.rank-header{text-align:center}.rank-owl{font-size:28px;animation:owl-blink 4s ease-in-out infinite;margin-bottom:4px}.rank-title{font-size:clamp(17px,4vw,22px);color:var(--gold-400);text-shadow:0 0 20px var(--gold-glow)}.rank-boss-name{font-size:12px;margin-top:4px}.rank-list{flex:1;display:flex;flex-direction:column;gap:6px;min-height:0}.rank-row{display:flex;align-items:center;gap:10px;padding:9px 12px;background:var(--purple-800);border:1px solid var(--border);border-radius:10px;animation:fadeUp .3s var(--ease-out-expo) both}.rank-row.medal-row{border-color:var(--border-gold);background:linear-gradient(135deg,var(--purple-800),var(--purple-700))}.rank-row.is-me{border-color:var(--analtena);box-shadow:0 0 12px var(--analtena-glow)}.rank-pos{font-family:var(--font-display);font-size:12px;color:var(--silver-400);min-width:22px;text-align:center}.rank-pos.medal{font-size:18px}.rank-info{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}.rank-name{font-family:var(--font-display);font-size:13px;color:var(--silver-100);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rank-clan{font-size:10px;color:var(--gold-500)}.rank-stats{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.rank-damage{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--gold-400)}.rank-meta{display:flex;gap:8px;font-size:10px;color:var(--silver-400)}.rank-crit{color:var(--analtena-light)}.rank-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px;color:var(--silver-400);font-size:13px;font-style:italic}.loading-orb{width:28px;height:28px;border:2px solid var(--purple-600);border-top-color:var(--analtena-light);border-radius:50%;animation:spin-slow .8s linear infinite}.rank-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px;text-align:center}.rank-empty-hint{font-size:12px;color:var(--silver-400);font-style:italic}.refresh-btn{width:100%;height:40px;background:var(--purple-700);border:1px solid var(--border);border-radius:8px;color:var(--silver-300);font-size:12px;letter-spacing:.1em;transition:all .15s}.refresh-btn:hover:not(:disabled){border-color:var(--border-gold);color:var(--gold-400)}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}:root{--purple-950: #0d0514;--purple-900: #130920;--purple-800: #1c1030;--purple-700: #2a1648;--purple-600: #3d2070;--purple-500: #5a2ea0;--analtena: #7b3fc4;--analtena-light: #a060e0;--analtena-glow: rgba(123, 63, 196, .4);--gold-400: #f0c060;--gold-500: #d4a030;--gold-600: #a87820;--gold-glow: rgba(212, 160, 48, .35);--eggplant: #4a1060;--eggplant-suit: #5c1880;--stem-green: #4a8c30;--silver-100: #ede8f5;--silver-200: #c8b8e0;--silver-300: #9080b0;--silver-400: #604878;--cosmic-blue: #1a2060;--x1-cyan: #40c8e0;--x1-glow: rgba(64, 200, 224, .2);--blood-400: #e05050;--green-400: #4ade80;--surface-0: var(--purple-950);--surface-1: var(--purple-900);--surface-2: var(--purple-800);--surface-3: var(--purple-700);--border: rgba(160, 96, 224, .15);--border-gold: rgba(212, 160, 48, .3);--border-x1: rgba(64, 200, 224, .2);--font-display: "Cinzel", "Georgia", serif;--font-body: "Crimson Pro", "Georgia", serif;--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--nav-height: 64px;--safe-bottom: env(safe-area-inset-bottom, 0px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;width:100%;overflow:hidden}body{background:var(--surface-0);color:var(--silver-100);font-family:var(--font-body);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}.scroll-area{overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none}.scroll-area::-webkit-scrollbar{display:none}.text-gold{color:var(--gold-400)}.text-silver{color:var(--silver-200)}.text-muted{color:var(--silver-400)}.text-purple{color:var(--analtena-light)}.text-x1{color:var(--x1-cyan)}h1,h2,h3,.display{font-family:var(--font-display);letter-spacing:.05em;line-height:1.2}.divider{display:flex;align-items:center;gap:12px;color:var(--silver-400);font-size:10px;letter-spacing:.2em;text-transform:uppercase;font-family:var(--font-display)}.divider:before,.divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--border-gold),transparent)}.card{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:16px}.card-purple{border-color:#7b3fc466;box-shadow:0 0 24px var(--analtena-glow)}.card-gold{border-color:var(--border-gold);box-shadow:0 0 24px var(--gold-glow)}button{cursor:pointer;border:none;font-family:var(--font-display);font-size:13px;letter-spacing:.1em;text-transform:uppercase;transition:all .15s var(--ease-out-expo)}button:active{transform:scale(.97)}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-purple{0%,to{box-shadow:0 0 20px var(--analtena-glow)}50%{box-shadow:0 0 40px var(--analtena-glow),0 0 60px var(--analtena-glow)}}@keyframes pulse-gold{0%,to{box-shadow:0 0 20px var(--gold-glow)}50%{box-shadow:0 0 40px var(--gold-glow),0 0 60px var(--gold-glow)}}@keyframes x1-pulse{0%,to{box-shadow:0 0 16px var(--x1-glow)}50%{box-shadow:0 0 32px var(--x1-glow),0 0 48px var(--x1-glow)}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@keyframes damage-flash{0%{filter:brightness(1)}30%{filter:brightness(2.5) hue-rotate(280deg) saturate(2)}to{filter:brightness(1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes owl-blink{0%,90%,to{transform:scaleY(1)}95%{transform:scaleY(.1)}}
