:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}:root{--phone-frame-width:390px;--phone-frame-height:844px;--phone-art-position:center;--bg-0:#100f16;--bg-1:#1b1a27;--panel:#161620db;--panel-soft:#242232c7;--line:#ffffff1f;--text:#fffaf0;--text-strong:#fff7dc;--muted:#ded6c8;--gold:#ffe29a;--danger:#ff7a7a;--good:#78e0a6;--level:#9bc3ff}*{box-sizing:border-box}html,body,#root{min-height:100%;color:var(--text);background:radial-gradient(1200px 700px at 10% -10%, #2e2546 0%, transparent 55%), radial-gradient(1200px 700px at 90% -20%, #27304f 0%, transparent 50%), var(--bg-0);margin:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow-x:hidden}main{max-width:100vw;min-height:100vh;padding:12px;overflow-x:hidden}h1,h2,h3{color:var(--text-strong);letter-spacing:.02em;margin:0}p{margin:0}.mx-auto{width:100%;margin:0 auto}.space-y-5>*+*{margin-top:18px}header,.rpg-panel{border:1px solid var(--line);background:linear-gradient(180deg, #ffffff08, transparent), var(--panel);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:20px;padding:14px;box-shadow:0 20px 45px #00000059}.grid{gap:16px;display:grid}.top-grid,.bottom-grid{grid-template-columns:minmax(0,1fr)}.app-container,.top-grid,.bottom-grid,.battle-sheets,.inventory-grid,.rpg-stat-grid,.rpg-equipment-grid,.shop-item,.player-header-top{min-width:0}.rounded-2xl,.rounded-3xl,.rounded-xl{border-radius:14px}button{cursor:pointer;border:1px solid #0000;border-radius:12px;min-height:44px;font-weight:700;transition:transform .12s,filter .18s,border-color .18s}button:hover:enabled{filter:brightness(1.06);transform:translateY(-1px)}button:disabled{opacity:.45;cursor:not-allowed}.bg-amber-400{color:#231b12;background:linear-gradient(#ffe29a,#f1bd53)}.bg-white\/10{color:var(--text);background:#ffffff1a;border-color:#ffffff1f}input,select,textarea{width:100%;color:var(--text);background:#0a0b1280;border:1px solid #ffffff2e;border-radius:10px;min-height:44px;padding:10px 12px;font-size:16px}input:focus,select:focus,textarea:focus{border-color:var(--gold);outline:none;box-shadow:0 0 0 2px #ffe29a3d}input[readonly]{color:var(--muted);background:#ffffff0f}.text-white\/60,.text-white\/70,.text-white\/80{color:var(--muted)}.text-amber-200,.text-amber-300{color:var(--gold)}.page-menu{right:50%;bottom:max(12px, env(safe-area-inset-bottom));z-index:20;border:1px solid var(--line);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0c0c12eb;border-radius:18px;gap:8px;padding:8px;display:grid;position:fixed;left:auto;transform:translate(50%);box-shadow:0 18px 36px #00000061}.page-menu>button{min-width:128px;min-height:52px}.page-menu-list{gap:8px;min-width:178px;display:grid}.page-menu-list button{justify-content:center;width:100%}.page-hidden{display:none}.starter-hero-image{object-fit:contain;object-position:center;height:150px;min-height:0}.enemy-portrait{object-position:top center;height:150px}.starter-shell{padding:16px 10px 28px}.starter-card-photo{aspect-ratio:9/16;min-height:0}.starter-card-photo img,.starter-hero-image,.enemy-portrait{object-fit:cover;object-position:var(--phone-art-position);width:100%}.landing-screen{background:#020617;width:100%;min-height:100dvh;padding:0;display:grid;overflow:hidden}.landing-page-hero{background:#020617;min-height:100dvh;position:relative;overflow:hidden}.landing-page-hero img{object-fit:cover;object-position:var(--phone-art-position);width:100%;height:100%;min-height:100dvh;display:block}.landing-page-overlay{right:18px;bottom:max(120px, env(safe-area-inset-bottom));justify-items:center;padding:14px;display:grid;position:absolute;left:18px}.landing-page-overlay button{border:1px solid #ffe29a8c;width:min(100%,280px);min-height:48px;font-size:.95rem;box-shadow:0 16px 34px #00000075,0 0 24px #ffc6582e}.hero-intro{text-align:center}.hero-intro h1{font-size:clamp(2rem,10vw,3.2rem);line-height:1.08}.starter-title{color:#fff7dc;text-shadow:0 2px 18px #000000b3,0 0 22px #ffe29a47;display:block;transform:translateY(-6px)}.hero-intro p:last-child{max-width:34rem}.starter-footer{color:#fff7dcad;letter-spacing:.16em;text-align:center;text-transform:uppercase;margin-top:24px;font-size:.78rem;font-weight:800}.confirm-overlay{z-index:70;background:#030712b3;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.confirm-dialog{text-align:center;background:linear-gradient(#2d1d12f5,#0c0807f5);border:1px solid #ffe29a57;border-radius:18px;gap:14px;width:min(100%,420px);padding:18px;display:grid;box-shadow:0 24px 70px #00000094}.confirm-dialog h2{color:#fff7dc;font-size:1.35rem;font-weight:900}.confirm-dialog p{color:#ffffffb8;line-height:1.5}.confirm-actions{gap:10px;display:grid}.confirm-actions button{width:100%}.saved-campaign>div,.stat-strip,.flex-wrap{flex-wrap:wrap}.saved-campaign button,.hero-select-card{width:100%}.saved-campaign>div{grid-template-columns:1fr;display:grid}.hero-grid{grid-template-columns:minmax(0,1fr);width:100%;max-width:100%}.hero-select-card{max-width:100%;min-height:0;color:var(--text);border:1px solid #ffffff29;grid-template-columns:minmax(0,1fr);align-items:stretch;gap:12px;padding:10px;display:grid;overflow:hidden}.class-card-berserker{background:linear-gradient(145deg,#501218f0,#1d181af5 58%,#744a24e0),#2a1719;border-color:#ffc16f57;box-shadow:inset 0 1px #ffe29a14,0 18px 38px #00000057}.class-card-ranger{background:linear-gradient(145deg,#10493df2,#121c25f5 58%,#305f70e0),#102823;border-color:#ade5df57;box-shadow:inset 0 1px #cffbf614,0 18px 38px #00000057}.hero-select-card h2{color:#fffbe8;overflow-wrap:anywhere;font-size:1.25rem;line-height:1.05}.hero-select-card p{overflow-wrap:anywhere;margin-top:6px;font-size:.92rem;line-height:1.42}.starter-card-photo{background:#05080c47;border-color:#fffaf038;align-self:auto;min-width:0;box-shadow:inset 0 0 26px #00000057}.starter-card-copy{min-width:0}.starter-carousel{gap:14px;padding:14px 46px 16px;position:relative}.starter-carousel .starter-card-photo{height:220px}.starter-carousel .starter-hero-image{width:100%;height:100%}.starter-arrow{z-index:2;color:#fff7dc;background:#080a0cad;border:1px solid #ffe29a4d;border-radius:999px;place-items:center;width:34px;height:46px;font-size:1.7rem;font-weight:900;line-height:1;display:grid;position:absolute;top:50%;transform:translateY(-50%)}.starter-arrow-left{left:8px}.starter-arrow-right{right:8px}.starter-card-copy button{margin-top:14px}.training-card{border-top:3px solid #ffe29a8c;flex-direction:column;margin-block:6px 18px;display:flex;position:relative}.training-guild-motto{color:#f8df9f;text-align:center;font-size:.98rem;font-style:italic;font-weight:800;line-height:1.45}.weekly-challenges{background:linear-gradient(#573a2042,#100c0a94),#100c0a94;border:1px solid #ffe29a33;border-radius:18px;padding:14px}.weekly-challenges-heading{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.weekly-challenges-heading p,.weekly-challenges-heading span{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-size:.72rem;font-weight:900}.weekly-challenges-heading h3{color:var(--text-strong);font-size:1.1rem;font-weight:950}.weekly-challenge-list{gap:10px;display:grid}.weekly-challenge-card{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:14px;grid-template-columns:72px 1fr;align-items:center;gap:12px;padding:10px;display:grid}.weekly-challenge-card.is-complete{background:#ffe29a1f;border-color:#ffe29a61}.weekly-challenge-card.is-summary,.weekly-challenge-card.tavern-task-card{grid-template-columns:1fr}.tavern-claim-action{justify-content:flex-end;margin-top:10px;display:flex}.tavern-board{background:linear-gradient(#573a2042,#100c0a94),#100c0a94;border:1px solid #ffe29a33;border-radius:18px;padding:14px}.tavern-board-grid{gap:12px;display:grid}.tavern-board-card{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:14px;gap:8px;padding:12px;display:grid}.tavern-board-card-featured{background:#ffe29a1a;border-color:#ffe29a47}.tavern-board-card-image{object-fit:cover;object-position:center top;border:1px solid #ffe29a47;border-radius:10px;width:100%;height:180px;display:block;box-shadow:0 12px 24px #00000059}.tavern-board-card span{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-size:.72rem;font-weight:900}.tavern-board-card h4{color:var(--text-strong);font-size:1rem;font-weight:900}.tavern-board-card p,.tavern-board-card small{color:var(--muted);font-size:.8rem;line-height:1.35}.tavern-detail-overlay{z-index:85;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0307129e;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.tavern-detail-panel{width:min(100%,520px);max-height:min(82dvh,680px);margin:0;overflow:auto;box-shadow:0 24px 58px #00000085}.tavern-board-list{gap:8px;display:grid}.tavern-board-list button{width:100%;color:inherit;text-align:left;background:#00000029;border:1px solid #ffffff1a;border-radius:12px;gap:3px;padding:10px;display:grid}.tavern-board-list button:hover{background:#ffe29a14;border-color:#ffe29a4d}.tavern-board-list strong{color:var(--text-strong);font-size:.86rem}.tavern-conversation-overlay{z-index:90;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0307129e;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.tavern-conversation-panel{background:linear-gradient(#573a204d,#100c0aa8),#100c0aa8;border:1px solid #ffe29a38;border-radius:18px;gap:12px;width:min(100%,520px);max-height:min(82dvh,680px);padding:14px;display:grid;overflow:auto;box-shadow:0 24px 58px #00000085}.tavern-conversation-image{object-fit:cover;object-position:center top;border:1px solid #ffe29a52;border-radius:12px;width:100%;height:220px;display:block;box-shadow:0 14px 28px #0000006b}.tavern-conversation-copy{gap:8px;display:grid}.tavern-board-card img,.tavern-conversation-panel img{border-radius:12px;overflow:hidden;object-fit:cover!important;object-position:center top!important;width:100%!important;max-width:100%!important;height:180px!important;max-height:180px!important;display:block!important}.tavern-conversation-copy span{color:var(--gold);letter-spacing:.08em;text-transform:uppercase;font-size:.72rem;font-weight:900}.tavern-conversation-copy h3{color:var(--text-strong);font-size:1.1rem;font-weight:950}.tavern-conversation-copy p{color:#fff3cf;font-size:.96rem;font-weight:750;line-height:1.45}.weekly-challenge-card img{object-fit:cover;border-radius:10px;width:72px;height:72px}.weekly-challenge-card h4{color:var(--text-strong);font-size:.98rem;font-weight:900}.weekly-challenge-card p,.weekly-challenge-card small{color:var(--muted);margin-top:3px;font-size:.78rem;line-height:1.35;display:block}.weekly-challenge-card strong{color:var(--gold);margin-top:5px;font-size:.8rem;display:block}.weekly-stat-counters{grid-template-columns:1fr 1fr;gap:10px;display:grid}.weekly-stat-counters div{background:linear-gradient(#ffe29a1c,#28180d3d),#0c080675;border:1px solid #ffe29a2e;border-radius:14px;padding:10px}.weekly-stat-counters span{color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-size:.72rem;font-weight:900;display:block}.weekly-stat-counters strong{color:var(--text-strong);margin-top:3px;font-size:.92rem;display:block}.training-actions{justify-content:flex-end;margin-top:auto;padding-top:16px;display:flex}.training-actions button{width:100%}.reward-preview{color:var(--muted);background:#ffe29a14;border:1px solid #ffe29a2e;border-radius:12px;gap:4px;margin-top:14px;padding:10px;font-size:.86rem;display:grid}.reward-preview strong{color:var(--text-strong)}.reward-preview p{color:var(--muted);font-size:.8rem}.app-shell{min-height:0;padding:10px 10px 92px}.app-container{width:100%;max-width:none}.player-header{border-radius:16px;padding:8px 10px;position:static}.hero-status-card{border:1px solid var(--line);background:linear-gradient(180deg, #ffffff08, transparent), var(--panel);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:16px;padding:8px 10px;display:block;box-shadow:0 20px 45px #00000059;position:static!important}.player-header-top{gap:8px;display:grid}.hero-identity{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:9px;display:grid}.hero-identity h1{color:#fffbe8;font-size:1.16rem;line-height:1}.hero-identity p:first-child{letter-spacing:.08em;font-size:.56rem}.hero-identity p:last-child{margin-top:2px;font-size:.72rem;line-height:1.1}.attack-countdown{color:#ff5a4f;text-shadow:0 0 10px #b91c1ca6,0 1px #000000d9;font-weight:900}.character-avatar{width:46px;height:46px}.stat-strip{grid-template-columns:repeat(4,minmax(0,1fr));gap:5px;display:grid}.hero-stats{gap:5px;display:grid}.gear-strip{color:var(--muted);background:#ffffff12;border-radius:12px;gap:6px;padding:10px;font-size:.86rem;line-height:1.35;display:none}.gear-strip strong{color:var(--text-strong)}.milestone-overlay{z-index:60;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#03071294;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.milestone-banner{width:min(100%,560px);max-height:min(80vh,620px);color:var(--text-strong);white-space:pre-line;background:linear-gradient(135deg,#ffe29a29,#78e0a617),#161620eb;border:1px solid #ffe29a61;border-radius:18px;gap:12px;padding:14px;display:grid;overflow:auto;box-shadow:0 18px 42px #00000052,inset 0 1px #ffffff14}.milestone-kicker{color:var(--gold);letter-spacing:.02em;margin-bottom:4px;font-size:1.05rem;font-weight:900}.intro-overlay{z-index:80;background:#050308;place-items:center;padding:0;display:grid;position:fixed;inset:0;overflow:hidden}.intro-scene{background:#000;place-items:center;width:min(100vw,46.1538dvh);height:100dvh;display:grid;position:relative;overflow:hidden}.intro-scene img{object-fit:cover;object-position:var(--phone-art-position);filter:brightness(.74);width:100%;max-width:none;height:100%;max-height:none;display:block}.intro-dialogue{background:linear-gradient(#2d1d1280,#110c0a80),#0a060480;border:1px solid #ffe29a57;border-radius:18px;gap:14px;width:min(100% - 28px,560px);padding:16px;display:grid;position:absolute;inset:auto 50% 12% auto;transform:translate(50%);box-shadow:0 18px 46px #00000080}.intro-dialogue p{color:#fff3cf;font-size:1.05rem;font-weight:800;line-height:1.45}.intro-dialogue button{width:100%}.tab-prompt-actions{gap:10px;display:grid}.tab-prompt-dialogue{top:72%;bottom:auto;transform:translate(50%,-50%)}.weekly-achievement-dialogue{background:linear-gradient(#372312b8,#0c0806b8),#0a0604b8}.weekly-achievement-dialogue h2{color:#fff7dc;font-size:1.35rem;font-weight:950;line-height:1.1}.weekly-achievement-dialogue p{font-size:.98rem}.weekly-achievement-dialogue strong{color:var(--gold)}.weekly-achievement-kicker{letter-spacing:.12em;text-transform:uppercase;color:var(--gold)!important;font-size:.76rem!important}.victory-dialogue.is-top{top:max(18px, env(safe-area-inset-top));bottom:auto}.victory-dialogue.is-bottom{top:auto;bottom:max(18px, env(safe-area-inset-bottom))}.failure-retry-screen{z-index:90;color:#fff3cf;text-align:center;background:#000;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.failure-retry-screen section{gap:18px;width:min(100%,460px);display:grid}.failure-retry-screen p{font-size:1.35rem;font-weight:900;line-height:1.35}.failure-retry-screen button{width:100%}.stat-strip>div,.stat-pill{border-radius:10px;justify-content:space-between;gap:3px;min-width:0;padding:5px 6px;font-size:.68rem}.xp-track-wrap{background:#ffffff0d;border-radius:10px;margin-top:7px;padding:6px}.lift-row-header{padding-bottom:8px}.lift-row-header button{margin-left:12px}.pr-toggle{width:fit-content;min-height:34px;color:var(--muted);cursor:pointer;background:#ffffff12;border:1px solid #ffffff24;border-radius:999px;grid-template-columns:auto auto auto;align-items:center;gap:6px;padding:5px 10px 5px 7px;font-size:.82rem;display:inline-grid}.pr-toggle input{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.pr-toggle span{filter:grayscale();background:#ffffff1a;border-radius:999px;place-items:center;width:24px;height:24px;font-size:.9rem;display:grid}.pr-toggle strong{color:var(--text-strong);font-size:.82rem}.pr-toggle small{color:var(--gold);font-size:.72rem;font-weight:800}.pr-toggle.is-active{background:#ffe29a24;border-color:#ffe29a80}.pr-toggle.is-active span{filter:none;background:#ffe29a38}.add-lift-action{padding-block:12px}.add-lift-action button{width:100%}.xp-track-heading{color:var(--text-strong);letter-spacing:.02em;justify-content:space-between;gap:12px;margin-bottom:8px;font-size:.82rem;font-weight:800;display:flex}.xp-track{background:linear-gradient(90deg,#ffffff14 1px,#0000 1px) 0 0/20% 100%,#00000047;border:1px solid #ffffff1f;border-radius:999px;height:14px;position:relative;overflow:hidden;box-shadow:inset 0 2px 8px #00000073}.battle-prompt{min-height:112px;max-height:168px}.monster-reveal,.phone-battle{gap:12px;display:grid}.monster-reveal{background:linear-gradient(#4925162e,#0000005c),#0000003d;border:1px solid #ffe29a38;border-radius:18px;padding:12px}.monster-reveal-image{background:#050308;border:1px solid #ffffff24;border-radius:16px;overflow:hidden}.monster-reveal-image img{object-fit:cover;object-position:var(--phone-art-position);width:100%;height:min(72dvh,610px);display:block}.monster-reveal-copy{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.monster-reveal-copy p,.phone-monster-heading p,.hero-combat-bar p{color:var(--gold);letter-spacing:.08em;text-transform:uppercase;font-size:.72rem;font-weight:900}.monster-reveal-copy h3,.phone-monster-heading h3,.hero-combat-bar h3{color:var(--text-strong);font-size:1.35rem;font-weight:950;line-height:1.05}.monster-reveal-copy span,.phone-monster-heading strong{color:#fecaca;flex:none;font-size:.9rem;font-weight:900}.monster-reveal-ability,.monster-reveal-warning,.phone-monster-ability{color:var(--muted);font-size:.9rem;line-height:1.45}.monster-reveal-warning{background:#ffe29a14;border-left:3px solid #ffe29a8c;padding:9px 10px}.monster-reveal button{width:100%}.phone-monster-card,.hero-combat-bar{background:linear-gradient(#0f172af5,#0f172ab8);border:1px solid #ffffff1f;border-radius:18px;padding:12px}.phone-monster-heading{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.phone-hp-bar{background:#ffffff1a;border-radius:999px;height:10px;margin-top:10px;overflow:hidden}.phone-hp-bar>div{border-radius:inherit;height:100%;transition:width .22s ease-out}.monster-hp-bar>div{background:linear-gradient(90deg,#f87171,#fecaca)}.hero-hp-bar>div{background:linear-gradient(90deg,#78e0a6,#d9f99d)}.phone-battle-image{object-fit:cover;object-position:top center;border:1px solid #ffffff1f;border-radius:14px;width:100%;height:188px;margin-top:12px}.phone-monster-ability{margin-top:9px}.target-strip{grid-template-columns:minmax(0,1fr);gap:8px;display:grid}.target-strip button{width:100%;min-height:42px;font-size:.78rem}.hero-combat-bar{background:linear-gradient(#16201cf2,#0f172ac2)}.hero-combat-stats{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.hero-combat-stats span{color:var(--muted);background:#ffffff14;border:1px solid #ffffff1f;border-radius:999px;padding:5px 8px;font-size:.72rem;font-weight:800}.mobile-battle-screen{background:radial-gradient(circle at 50% 12%,#f8c45f24,#0000 32%),linear-gradient(#0e1420fa,#05080efa);border:1px solid #ffe29a38;border-radius:22px;grid-template-rows:minmax(390px,1fr) auto auto auto;gap:10px;min-height:calc(100dvh - 180px);padding:10px;display:grid;overflow:hidden}.mobile-battle-scene{background-image:var(--battle-bg);background-position:50%;background-size:cover;border:1px solid #ffffff14;border-radius:18px;min-height:390px;padding:8px;position:relative;overflow:hidden}.battlefield:before{content:"";pointer-events:none;background:linear-gradient(#02060e14,#02060e3d);position:absolute;inset:0}.battlefield:after{content:none}.battler-target{width:min(34%,128px);color:inherit;transform:translateY(-28%) scale(var(--slot-scale,1));transform-origin:bottom;background:0 0;border:0;padding:0;position:absolute}.enemy-side,.hero-side{transform-origin:bottom}.battler-target:disabled{opacity:.55}.battler-target.selected .mobile-battler{filter:drop-shadow(0 0 10px #f8c45feb)}.hero-slot{pointer-events:none}.battle-float-text{color:#fecaca;pointer-events:none;background:#080a10d1;border:1px solid #ffffff2e;border-radius:999px;max-width:132px;padding:5px 8px;font-size:.68rem;font-weight:950;line-height:1.1;animation:6.2s ease-out forwards battle-float;position:absolute;bottom:38%;right:-18px}.hero-slot .battle-float-text{color:#fde68a;left:58%;right:auto}.battle-float-text.heal{color:#bbf7d0}.mobile-battler{background:0 0;border:0;gap:5px;width:100%;min-width:0;padding:0;animation:2.6s ease-in-out infinite battle-idle;display:grid}.mobile-battler-figure{width:100%;position:relative}.mobile-battler img{object-fit:contain;object-position:center bottom;filter:drop-shadow(0 12px 15px #0000007a);pointer-events:none;width:100%;height:clamp(92px,17dvh,132px)}.battle-effect{transform-origin:50%;pointer-events:none;filter:drop-shadow(0 0 14px #ffffff2e);width:clamp(54px,16vw,90px);height:auto;animation:.52s ease-out forwards battle-effect-pop;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.battle-effect-arrow{width:clamp(74px,19vw,112px)}.battle-effect-poison,.battle-effect-magic{width:clamp(68px,18vw,102px)}.mobile-battler img.flip-x{transform:scaleX(-1)}.mobile-battler-name{background:#02060e94;border:1px solid #ffffff24;border-radius:10px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:6px;padding:3px 5px;font-size:.68rem;font-weight:900;display:grid}.mobile-battler-name span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.mobile-battler-name strong{color:#fecaca;font-size:.68rem}.mobile-battle-hp{background:#02060e9e;border-radius:999px;height:8px;overflow:hidden;box-shadow:0 0 0 1px #ffffff1f}.mobile-battle-hp>div{border-radius:inherit;background:linear-gradient(90deg,#f87171,#fbbf24);height:100%;transition:width .22s ease-out}.mobile-battler.hero .mobile-battle-hp>div{background:linear-gradient(90deg,#22c55e,#bef264)}.mobile-battle-log{background:#0000003d;border:1px solid #ffe29a24;border-radius:16px;min-height:44px;max-height:44px;padding:6px;overflow:auto}.mobile-battle-log.expanded{min-height:82px;max-height:132px;padding:8px 10px}.battle-log-toggle{width:100%;min-height:30px;color:var(--gold);background:#ffffff14;border:1px solid #ffe29a2e;border-radius:12px;font-size:.76rem;font-weight:950}.mobile-battle-log p{color:var(--muted);margin:0 0 5px;font-size:.8rem;line-height:1.35}.mobile-battle-actions{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.mobile-battle-actions button{color:#1b1208;background:linear-gradient(#f8c45f,#d99938);border:1px solid #ffe29a47;border-radius:14px;place-items:center;min-height:52px;font-size:.78rem;font-weight:950;line-height:1.1;display:grid}.mobile-battle-actions button:disabled{cursor:not-allowed;filter:grayscale(.5);opacity:.48}.mobile-battle-actions small{font-size:.62rem;font-weight:800}.mobile-ability-menu,.mobile-item-menu{background:#00000052;border:1px solid #ffe29a29;border-radius:14px;gap:8px;padding:8px;display:grid}.mobile-ability-menu button,.mobile-item-menu button{color:#fff7ed;text-align:left;background:#ffffff14;border:1px solid #ffffff24;border-radius:12px;gap:2px;min-height:46px;padding:8px 10px;font-size:.8rem;font-weight:900;display:grid}.mobile-ability-menu button:disabled,.mobile-item-menu button:disabled{cursor:not-allowed;opacity:.48}.mobile-ability-menu small,.mobile-item-menu small,.mobile-item-menu p{color:#ffffffad;margin:0;font-size:.68rem;font-weight:700;line-height:1.25}.mobile-battle-result{text-align:center;border-radius:14px;padding:9px 10px;font-size:.86rem;font-weight:950}.mobile-battle-result h3{margin:0 0 6px;font-size:1rem;font-weight:950}.mobile-battle-result.won{color:#bbf7d0;background:#22c55e2e}.mobile-battle-result.lost{color:#fecaca;background:#f871712e}.mobile-battle-rewards{color:#ffffffd1;gap:3px;margin:6px 0 10px;font-size:.8rem;font-weight:750;display:grid}.mobile-battle-rewards p,.mobile-battle-result-note{margin:0}.mobile-battle-result-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:8px;display:grid}.mobile-battle-result-actions button{min-height:44px;color:inherit;background:#00000047;border:1px solid #ffffff29;border-radius:12px;font-size:.78rem;font-weight:950}.mobile-battler.is-attack{animation:.42s ease-out battle-lunge}.mobile-battler.is-hurt{animation:.36s ease-out battle-hurt}.mobile-battler.is-dead{animation:.5s ease-out forwards battle-death}@keyframes battle-idle{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-3px)scale(1.01)}}@keyframes battle-lunge{0%,to{transform:translate(0)}45%{transform:translate(12px,-8px)}}.mobile-battler.enemy.is-attack{animation-name:battle-lunge-enemy}@keyframes battle-lunge-enemy{0%,to{transform:translate(0)}45%{transform:translate(-12px,8px)}}@keyframes battle-hurt{0%,to{transform:translate(0)}25%{transform:translate(-5px)}55%{transform:translate(5px)}}@keyframes battle-float{0%{opacity:0;transform:translateY(8px)scale(.94)}18%{opacity:1}to{opacity:0;transform:translateY(-18px)scale(1)}}@keyframes battle-effect-pop{0%{opacity:0;transform:translate(-50%,-50%)scale(.72)}20%{opacity:1;transform:translate(-50%,-50%)scale(1.04)}to{opacity:0;transform:translate(-50%,-50%)scale(1.16)}}@keyframes battle-death{to{opacity:.2;transform:translateY(12px)scale(.94)}}.battle-sheets{gap:14px;display:grid}.battle-sheet{background:linear-gradient(135deg,#0f172af0,#1e293bd1);border:1px solid #ffffff1f;border-radius:18px;padding:12px}.battle-sheet-heading{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:12px;display:grid}.battle-sheet-avatar{object-fit:cover;border:1px solid #ffffff2e;border-radius:14px;width:72px;height:72px}.battle-sheet-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:14px;display:grid}.battle-sheet-hero .battle-sheet-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.battle-sheet-gear{color:var(--muted);background:#ffffff12;border-radius:12px;gap:6px;margin-top:12px;padding:10px;font-size:.86rem;display:grid}.battle-sheet-gear strong{color:var(--text-strong)}.encounter-enemies{gap:12px;display:grid}.encounter-enemy{background:#00000029;border:1px solid #ffffff1a;border-radius:16px;padding:10px}.encounter-enemy .enemy-portrait{height:132px}.encounter-enemy.is-targeted{border-color:#ffe29a8c;box-shadow:0 0 0 1px #ffe29a1f}.ambush-label{color:var(--danger);letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px;font-size:.78rem;font-weight:900}.combat-actions{gap:12px}.combat-actions button{margin-bottom:4px}.battle-guide{color:var(--text-muted);background:linear-gradient(#573a2038,#120d0a94),#120d0ab8;border:1px solid #e8b9773d;border-radius:16px;padding:12px 14px}.battle-guide summary{cursor:pointer;color:#f8e2b8;font-weight:900;list-style-position:inside}.battle-guide-grid{gap:14px;margin-top:12px;display:grid}.battle-guide h4{color:var(--accent);letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px;font-size:.82rem;font-weight:900}.battle-guide ul{gap:7px;padding-left:18px;font-size:.92rem;line-height:1.5;display:grid}.battle-guide strong{color:var(--text-strong)}.battle-guide span{color:#f8d58e;font-weight:800}.test-actions{gap:10px;display:grid}.monster-combat-summary h3 span{color:#fecaca;white-space:nowrap;margin-left:6px;font-size:.9rem;display:inline-block}.hero-hp-inline{color:var(--text-strong);background:#ffffff14;border:1px solid #ffffff24;border-radius:999px;padding:6px 10px;font-size:.86rem;font-weight:800;display:inline-flex}.dungeon-depth-card{color:var(--muted)}.dungeon-depth-card h3{color:var(--text-strong)}.dungeon-level-title{font-size:1.65rem;line-height:1}.dungeon-level-picker{flex-wrap:wrap;gap:10px;display:flex}.dungeon-light-pill{color:var(--text-strong);white-space:nowrap;background:#ffe29a1a;border:1px solid #ffe29a3d;border-radius:999px;flex:none;padding:6px 10px;font-size:.78rem;font-weight:800}.rpg-panel{scroll-margin-top:120px}.rpg-panel>div:first-child{margin-bottom:12px}.rpg-panel h2{font-size:1.2rem}.rpg-panel h3{font-size:1rem}.battle-entry{border-left:3px solid #583a1f47}.battle-entry.is-good{background:#627f4829;border-left-color:#477b4d}.battle-entry.is-bad{background:#97433129;border-left-color:#a94735}.battle-entry.is-level{background:#4c678424;border-left-color:#587da8}.battle-entry.is-neutral{border-left-color:#583a1f47}.scroll-panel{background:linear-gradient(#573a2033,#1a120e80),#1f1714e0;border-color:#e8b97738}.scroll-panel h2{color:#f8e2b8}.scroll-paper{color:#2c1d13;background:linear-gradient(90deg,#603e1f1f,#0000 12% 88%,#603e1f1f),linear-gradient(#f1d6a3,#d9b476);border:1px solid #63432252;border-radius:16px;padding:12px;position:relative;box-shadow:inset 0 0 26px #4c2f143d}.scroll-paper:before,.scroll-paper:after{content:"";background:#5c371957;border-radius:999px;height:5px;position:absolute;left:14px;right:14px}.scroll-paper:before{top:5px}.scroll-paper:after{bottom:5px}.scroll-entry{z-index:1;color:#2c1d13;white-space:pre-line;background:#fff6da6b;border:1px solid #583a1f2e;line-height:1.45;position:relative}.journal-panel{background:radial-gradient(circle at 20% 0,#ffe29a1f,#0000 30%),linear-gradient(#36231661,#0f0a08b8),#16100deb}.today-journal-page{gap:12px;margin-bottom:16px;padding:14px;display:grid}.journal-page-ribbon{z-index:1;background:linear-gradient(90deg,#6f421438,#fff6da75 28%,#6f421429),#fff6da57;border:1px solid #6f421447;border-radius:14px;grid-template-columns:34px minmax(0,1fr) auto;align-items:center;gap:9px;padding:9px 10px;display:grid;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffff57,0 6px 14px #4c2f141f}.journal-page-ribbon:before,.journal-page-ribbon:after{content:"";pointer-events:none;background:linear-gradient(#4c2f142e,#0000 34%,#4c2f1429);width:18px;position:absolute;top:0;bottom:0}.journal-page-ribbon:before{left:0}.journal-page-ribbon:after{right:0}.journal-ribbon-seal{z-index:1;color:#fff4c8;background:radial-gradient(circle at 35% 25%,#fffadeb8,#0000 34%),linear-gradient(#b9873f,#6f4214);border:1px solid #583a1f47;border-radius:999px;place-items:center;width:30px;height:30px;font-size:.9rem;display:grid;position:relative;box-shadow:0 4px 10px #39210e2e}.journal-ribbon-copy{z-index:1;min-width:0;position:relative}.journal-ribbon-copy p{color:#6f4214;letter-spacing:.12em;text-transform:uppercase;font-size:.62rem;font-weight:950;line-height:1}.journal-ribbon-copy h3{color:#2a170d;margin-top:3px;font-size:1.02rem;font-weight:950;line-height:1.05}.journal-ribbon-count,.journal-reward-badges span{z-index:1;color:#6f4214;white-space:nowrap;background:#fff6da9e;border:1px solid #6f421438;border-radius:999px;padding:3px 7px;font-size:.66rem;font-weight:900;position:relative}.journal-entry-stack{z-index:1;gap:8px;display:grid;position:relative}.journal-entry{background:linear-gradient(#fff6da73,#fff6da73),url(/assets/training-log-bg-BiLJ1mG0.png) 50%/100% 100% no-repeat;border:1px solid #583a1f2e;border-radius:12px;grid-template-columns:30px minmax(0,1fr);gap:9px;padding:14px 12px;display:grid;box-shadow:inset 0 1px #ffffff3d}.logbook-entry.quest-scroll-entry.scroll-entry{background:linear-gradient(#fff6da73,#fff6da73),url(/assets/training-log-bg-BiLJ1mG0.png) 50%/100% 100% no-repeat;border:1px solid #583a1f2e;border-radius:12px;padding:14px 12px}.logbook-entry.quest-scroll-entry{width:100%;display:block}.logbook-entry.quest-scroll-entry>.journal-entry-rune{display:none}.logbook-entry.quest-scroll-entry>div:not(.journal-entry-rune){width:100%}.logbook-entry.quest-scroll-entry .logbook-entry-heading{min-height:0;padding-left:0}.journal-entry-rune,.battle-rune{color:#fff4c8;background:radial-gradient(circle at 35% 25%,#fffadeb3,#0000 34%),linear-gradient(#b9873f,#6f4214);border:1px solid #583a1f3d;border-radius:50%;place-items:center;width:28px;height:28px;font-size:.82rem;font-weight:900;display:grid;box-shadow:0 4px 10px #39210e2e}.journal-entry-rune{background:#2a180a2e;border-color:#6e431761;overflow:hidden;box-shadow:0 4px 10px #39210e2e,inset 0 0 7px #ffe29a38}.journal-entry-rune img{object-fit:cover;width:100%;height:100%;transform:scale(1.18)}.journal-entry-rune span{place-items:center;width:100%;height:100%;display:grid}.journal-entry-main{gap:4px;min-width:0;display:grid}.journal-entry-heading{gap:5px;display:grid}.journal-entry-heading>div:first-child{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.journal-entry-heading strong{color:#2a170d;font-size:.84rem}.journal-entry-heading span{color:#6f4214;white-space:nowrap;font-size:.66rem;font-weight:900}.journal-entry p{color:#5f442c;margin-top:0;font-size:.74rem;line-height:1.32}.journal-reward-badges{flex-wrap:wrap;gap:4px;display:flex}.journal-footer-note{z-index:1;color:#5f442c;background:#fff6da57;border:1px solid #6f42142e;border-radius:10px;gap:3px;padding:8px 10px;font-size:.72rem;line-height:1.32;display:grid;position:relative}.journal-footer-note strong{color:#4d2c14;font-size:.74rem}.quest-scroll-timeline{gap:16px;padding-left:0;display:grid;position:relative}.quest-scroll-timeline:before{content:none}.quest-scroll-day{width:100%;margin-left:0}.battle-chronicle-panel{background:radial-gradient(circle at 80% 0,#a9473524,#0000 28%),linear-gradient(#28181285,#07070ac2),#110d0cf0}.battle-scroll-list{gap:10px;display:grid}.battle-scroll-entry{grid-template-columns:34px minmax(0,1fr);align-items:start;gap:10px;padding:10px;display:grid}.battle-scroll-entry p{color:#3a2618;margin:0}.scroll-entry strong{color:#2a170d}.scroll-entry span,.scroll-entry p{color:#5f442c}.scroll-reward{color:#6f4214;font-weight:800}.scroll-empty{z-index:1;color:#5f442c;position:relative}.logbook-intro{color:var(--muted);margin-bottom:14px}.logbook-intro h3{color:var(--text-strong);font-size:1.15rem}.logbook-intro p{margin-top:4px;font-size:.9rem}.inventory-summary{gap:10px;margin-bottom:16px;display:grid}.inventory-summary>div{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:14px;padding:10px}.inventory-summary span{color:var(--muted);font-size:.75rem;font-weight:800;display:block}.inventory-summary strong{color:var(--text-strong)}.shop-list{gap:14px;display:grid}.shop-item{background:linear-gradient(#ffffff13,#ffffff09),#0a080757;border:1px solid #ffe29a2e;border-radius:16px;grid-template-columns:1fr;align-items:stretch;gap:14px;padding:14px;display:grid}.shop-item button{width:100%}.shop-item.is-locked{opacity:.68}.shop-item-main{min-width:0}.shop-item-head{border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:flex-start;gap:12px;padding-bottom:9px;display:flex}.shop-item-type{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-size:.72rem;font-weight:900}.shop-item h3{color:var(--text-strong);margin-top:2px;font-size:1.05rem;font-weight:900}.shop-item-cost{color:var(--gold);white-space:nowrap;background:#ffe29a1f;border:1px solid #ffe29a47;border-radius:999px;flex:none;padding:5px 9px;font-size:.8rem}.shop-item-description,.shop-item-effect,.shop-item-meta{margin-top:8px;font-size:.88rem;line-height:1.45}.shop-item-description{color:#ffffffb8}.shop-item-effect{color:#f8d58e;font-weight:800}.shop-upgrade-comparison{color:#ffffffc2;background:#ffe29a14;border:1px solid #ffe29a38;border-radius:12px;gap:5px;margin-top:10px;padding:9px 10px;font-size:.78rem;line-height:1.35;display:grid}.shop-upgrade-comparison span{color:#f8d58e;font-weight:900}.shop-item-meta{color:#fecaca;font-weight:800}.inventory-grid{gap:12px;display:grid}.inventory-items-bottom{margin-top:16px}.dungeon-triumphs{color:#2c1d13;background:linear-gradient(90deg,#fff5d6e0,#fff5d6b8),url(/assets/training-log-bg-BiLJ1mG0.png) 50%/100% 100% no-repeat;border:1px solid #63432252;border-radius:16px;gap:10px;padding:18px 16px;display:grid;position:relative;overflow:hidden;box-shadow:inset 0 0 18px #532d122e,0 10px 22px #00000038}.dungeon-triumphs>*{z-index:1;position:relative}.dungeon-triumphs:before{content:"";pointer-events:none;background:radial-gradient(circle,#fff8dd8c,#0000 62%),linear-gradient(#693b1614,#693b1624);position:absolute;inset:0}.dungeon-triumphs strong{color:#2a170d}.inventory-item{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:16px;padding:14px}.inventory-item-heading{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px;display:flex}.inventory-item-heading p,.inventory-item small{color:var(--muted);font-size:.78rem}.inventory-item-heading h3{color:var(--text-strong);margin-top:2px}.inventory-item-heading span{color:var(--gold);text-transform:capitalize;background:#ffe29a1a;border:1px solid #ffe29a3d;border-radius:999px;padding:4px 8px;font-size:.72rem;font-weight:900}.inventory-item>p{color:var(--muted);line-height:1.45}.rpg-character-sheet{color:#2c1d13;background:linear-gradient(90deg,#603e1f14,#0000 12% 88%,#603e1f14),linear-gradient(#f1d6a3f2,#c6975bf2);border:1px solid #e8b9774d;border-radius:18px;margin-top:18px;padding:14px;box-shadow:inset 0 0 28px #4c2f1433,0 16px 38px #00000038}.rpg-sheet-header{border-bottom:2px solid #5c371947;grid-template-columns:76px 1fr;align-items:center;gap:12px;padding-bottom:12px;display:grid}.rpg-sheet-header img{object-fit:cover;border:2px solid #5c371961;border-radius:12px;width:76px;height:76px}.rpg-sheet-header p,.rpg-sheet-header span,.rpg-sheet-xp span,.rpg-sheet-xp small,.rpg-stat-grid span,.rpg-equipment-grid span{color:#6a4323;letter-spacing:.08em;text-transform:uppercase;font-size:.72rem;font-weight:900}.rpg-sheet-header h3{color:#24140b;font-size:1.35rem;font-weight:950;line-height:1.05}.rpg-sheet-xp{gap:7px;margin-top:12px;display:grid}.rpg-sheet-xp>div:first-child{justify-content:space-between;gap:12px;display:flex}.rpg-sheet-xp strong,.rpg-stat-grid strong,.rpg-equipment-grid strong{color:#24140b}.rpg-stat-grid,.rpg-equipment-grid{gap:10px;margin-top:12px;display:grid}.rpg-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.rpg-stat-grid>div,.rpg-equipment-grid>div,.rpg-ability-list article{background:#fff6da5c;border:1px solid #5c371938;border-radius:12px;padding:10px}.rpg-stat-grid span,.rpg-equipment-grid span{margin-bottom:3px;display:block}.rpg-stat-grid strong{font-size:1.1rem}.rpg-equipment-grid p,.rpg-ability-list p{color:#5f442c;margin-top:5px;font-size:.84rem;line-height:1.4}.rpg-ability-list{gap:9px;margin-top:14px;display:grid}.rpg-ability-list h4{color:#2a170d;letter-spacing:.08em;text-transform:uppercase;font-size:.95rem;font-weight:950}.rpg-ability-list article{opacity:.48}.rpg-ability-list article.is-unlocked{opacity:1}.rpg-ability-list article>div{justify-content:space-between;align-items:center;gap:10px;display:flex}.rpg-ability-list strong{color:#24140b}.rpg-ability-list article>div span{color:#6a4323;text-transform:uppercase;background:#5c37191a;border:1px solid #5c371938;border-radius:999px;flex:none;padding:3px 7px;font-size:.68rem;font-weight:900}.logbook-days{gap:16px;display:grid}.logbook-day{gap:12px;display:grid}.logbook-day-heading,.logbook-entry-heading{z-index:1;justify-content:space-between;align-items:baseline;gap:12px;display:flex;position:relative}.logbook-day-heading h3{color:#2a170d;font-size:1.1rem}.logbook-day-heading span,.logbook-entry-heading span{color:#6f4214;white-space:nowrap;font-size:.78rem;font-weight:800}.logbook-entry-list{justify-items:center;gap:10px;width:100%;display:grid}.logbook-detail{margin-top:10px}.logbook-detail h4{color:#2a170d;margin:0 0 6px;font-size:.95rem}.logbook-metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.logbook-metric{background:#fff6da61;border:1px solid #583a1f24;border-radius:10px;padding:7px 8px}.logbook-metric span{color:#6f5a40;font-size:.72rem;font-weight:800;display:block}.logbook-metric strong{color:#2a170d;font-size:.9rem}.xp-fill{border-radius:inherit;background:linear-gradient(90deg,#f8c45f,#ffe08a 55%,#fff4bc);min-width:0;height:100%;transition:width .32s ease-out;box-shadow:0 0 14px #f8c45f9e}.enemy-hit{animation:.18s ease-out enemyHitFlash}.player-hit{animation:.18s ease-out playerHitFlash}.combat-float{text-align:center;letter-spacing:.2em;color:var(--gold);pointer-events:none;margin-top:8px;font-size:12px;font-weight:800;animation:.5s ease-out combatPop}@keyframes enemyHitFlash{0%{filter:brightness()}40%{filter:brightness(1.4)saturate(1.15)}to{filter:brightness()}}@keyframes playerHitFlash{0%{box-shadow:inset 0 0 #ff7a7a00}45%{box-shadow:inset 0 0 0 999px #ff7a7a24}to{box-shadow:inset 0 0 #ff7a7a00}}@keyframes combatPop{0%{opacity:0;transform:translateY(8px)scale(.85)}30%{opacity:1;transform:translateY(0)scale(1.05)}to{opacity:0;transform:translateY(-6px)scale(1)}}@media (width>=700px){main{padding:18px}.page-menu{top:auto;right:50%;bottom:max(12px, env(safe-area-inset-bottom));border-radius:14px;justify-items:center;width:fit-content;margin-inline:auto;position:fixed;left:auto;transform:translate(50%)}.page-menu>button{min-height:46px}.app-shell{padding:18px 18px 36px}.app-container{max-width:960px}.player-header{position:static}.player-header-top{grid-template-columns:minmax(0,1fr) auto;align-items:center}.stat-strip{grid-template-columns:repeat(4,auto)}.gear-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.shop-item{grid-template-columns:1fr auto;align-items:center}.shop-item button{width:auto}.inventory-summary{grid-template-columns:repeat(3,minmax(0,1fr))}.inventory-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.rpg-character-sheet{padding:18px}.rpg-sheet-header{grid-template-columns:96px 1fr}.rpg-sheet-header img{width:96px;height:96px}.rpg-stat-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.rpg-equipment-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.milestone-banner{grid-template-columns:minmax(0,1fr) auto;align-items:center}.intro-dialogue{width:min(560px,100% - 80px);padding:20px;inset:auto 50% 40px auto;transform:translate(50%)}.tab-prompt-dialogue{top:72%;bottom:auto;transform:translate(50%,-50%)}.intro-dialogue p{font-size:1.18rem}.victory-dialogue.is-top{top:40px;bottom:auto}.victory-dialogue.is-bottom{top:auto;bottom:40px}.battle-prompt{min-height:180px}.battle-sheets{grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);align-items:stretch}.character-avatar{width:128px;height:128px}.starter-shell{padding:32px 20px}.hero-intro{text-align:center}.saved-campaign>div{justify-content:center;display:flex}.saved-campaign button{width:auto}.hero-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch}.hero-select-card{grid-template-columns:minmax(0,1fr);align-items:stretch;gap:16px;padding:20px}.hero-select-card h2{font-size:2rem}.hero-select-card p{max-width:34rem;font-size:1rem;line-height:1.55}.starter-card-photo{aspect-ratio:9/16;align-self:auto;min-height:0}.starter-hero-image{height:100%;min-height:0}.enemy-portrait{height:180px}}@media (width>=1080px){.app-container{max-width:1180px}.top-grid,.bottom-grid{grid-template-columns:minmax(0,1fr)}}@media (width>=700px){body{background:radial-gradient(900px 520px at 50% 0,#4739626b,#0000 62%),linear-gradient(135deg,#09070d,#171522 48%,#09070d);padding:16px;display:block}main.app-shell,main.starter-shell{width:var(--phone-frame-width);scrollbar-width:thin;background:linear-gradient(#ffffff09,#0000 24%),radial-gradient(circle at top,#1e293b,#020617 58%);border:1px solid #ffffff29;border-radius:34px;max-width:calc(100vw - 32px);padding:14px 12px 96px;box-shadow:0 28px 90px #00000094,0 0 0 10px #03050cd1,inset 0 0 0 1px #ffffff0f}main.starter-shell{background:linear-gradient(#0a101cf5,#030712fa),#020617}.app-container,.starter-shell .mx-auto{width:100%;max-width:100%}.top-grid,.bottom-grid,.hero-grid,.battle-sheets,.inventory-grid,.rpg-stat-grid,.rpg-equipment-grid{grid-template-columns:minmax(0,1fr)!important}.player-header{padding:8px 10px;position:static}.player-header-top{grid-template-columns:minmax(0,1fr);align-items:stretch}.hero-identity{gap:9px}.character-avatar{width:46px;height:46px}.stat-strip{grid-template-columns:repeat(4,minmax(0,1fr))}.gear-strip{display:none}.page-menu{z-index:18;width:fit-content;margin:0 auto;position:fixed;inset:auto 50% max(18px,50dvh - 404px) auto;transform:translate(50%)}.page-menu>button{min-height:48px}.shop-item{grid-template-columns:minmax(0,1fr);align-items:stretch}.shop-item button{width:100%}.inventory-summary{grid-template-columns:repeat(3,minmax(0,1fr))}.battle-sheets{gap:12px}.battle-sheet{border-radius:16px;padding:12px}.battle-sheet-heading{gap:10px}.battle-sheet-avatar{width:72px;height:72px}.battle-sheet-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.enemy-portrait,.encounter-enemy .enemy-portrait{height:132px}.monster-reveal-image img{height:min(620px,100dvh - 224px)}.phone-battle-image{height:180px}.battle-prompt{min-height:112px;max-height:168px}.combat-actions{grid-template-columns:repeat(2,minmax(0,1fr));display:grid!important}.combat-actions button{width:100%}.intro-scene{width:var(--phone-frame-width);height:min(var(--phone-frame-height), calc(100dvh - 32px));border-radius:28px;max-width:calc(100vw - 32px)}.intro-dialogue{width:min(100% - 28px,340px);padding:16px}.intro-dialogue p{font-size:1.05rem}.starter-shell{text-align:center}.hero-select-card{grid-template-columns:minmax(0,1fr);padding:14px}.starter-hero-image{height:150px}}.training-guild-showcase{background:linear-gradient(180deg, #05080e6b, #05080ee6), var(--training-guild-bg);background-position:50%;background-size:cover;border:1px solid #ffe29a3d;border-radius:22px;gap:14px;padding:12px;display:grid;position:relative;overflow:hidden;box-shadow:inset 0 0 34px #00000061,0 18px 42px #00000038}.training-guild-showcase:before{content:"";pointer-events:none;background:radial-gradient(circle at 22% 6%,#f8c45f2e,#0000 28%),linear-gradient(90deg,#0003,#0000 35%,#00000047);position:absolute;inset:0}.training-guild-card-grid,.training-detail-panel{z-index:1;position:relative}.training-guild-card-grid{gap:12px;display:grid}.training-guild-card{color:#fff7ed;text-align:left;background:#080c14d1;border:1px solid #ffe29a57;border-radius:18px;grid-template-columns:42% minmax(0,1fr) auto;align-items:stretch;gap:0;width:100%;min-height:128px;padding:0;display:grid;position:relative;overflow:hidden;box-shadow:0 16px 34px #0000005c}.training-guild-card:after{content:"";pointer-events:none;background:linear-gradient(90deg,#0000 24%,#04070c1f 42%,#04070c5c);position:absolute;inset:0}.training-guild-card.is-available{border-color:#78e0a6f2;box-shadow:0 0 0 1px #78e0a661,0 0 24px #78e0a638,0 18px 36px #0000006b}.training-guild-card{isolation:isolate;color:#fff7ed;text-align:left;background:#080c14d1;border:1px solid #ffe29a57;border-radius:18px;grid-template-columns:minmax(0,1fr) auto;align-items:stretch;gap:0;width:100%;min-height:132px;padding:0;display:grid;position:relative;overflow:hidden;box-shadow:0 16px 34px #0000005c}.training-guild-card:before{content:"";background:linear-gradient(90deg, #02060e14, #02060e94 52%, #02060eeb), var(--training-card-image);z-index:-2;background-position:64%;background-repeat:no-repeat;background-size:118%;position:absolute;inset:0}.training-guild-card:after{content:"";pointer-events:none;z-index:-1;background:radial-gradient(circle at 26% 46%,#0000 0 32%,#00000052 76%);position:absolute;inset:0}.training-guild-card.is-selected{border-color:#f8c45fd6;box-shadow:0 0 0 1px #f8c45f4d,0 18px 36px #0000006b}.training-guild-card-blue,.training-guild-card-green,.training-guild-card-purple,.training-guild-card-gold{background:#080c14d1}.training-guild-card-art,.training-guild-card-art img{display:none}.training-guild-card-copy{z-index:1;text-shadow:0 2px 8px #000000e0;background:0 0;align-content:end;gap:5px;width:62%;min-width:0;margin-left:auto;padding:16px 10px 16px 0;display:grid;position:relative}.training-guild-card-copy h3{color:#fff7ed;margin:0;font-size:1.08rem;font-weight:950;line-height:1.05}.training-guild-card-copy p{color:#f8c45f;margin:0;font-size:.74rem;font-weight:850;line-height:1.25}.training-guild-card-copy small{color:#ffffffc7;font-size:.68rem;font-weight:700;line-height:1.25}.tavern-card-status{color:#d9ffe8;letter-spacing:.08em;text-transform:uppercase;background:#166534b8;border:1px solid #78e0a68c;border-radius:999px;width:fit-content;padding:3px 8px;font-size:.62rem;font-weight:950;line-height:1}.training-guild-card-arrow{z-index:1;color:#1b1208;z-index:1;background:linear-gradient(#f8c45f,#a96824);border:1px solid #ffe29a7a;border-radius:999px;align-self:center;place-items:center;width:30px;height:30px;margin-right:8px;font-size:1.45rem;font-weight:950;line-height:1;display:grid;position:relative;box-shadow:0 8px 16px #00000052}.training-detail-panel{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:radial-gradient(circle at 50% 0,#f8c45f1a,#0000 30%),#00000094;border:1px solid #ffe29a38;border-radius:18px;gap:12px;margin-top:0;padding:12px;display:grid}.training-detail-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.training-detail-header h3{color:#f8c45f;margin:0;font-size:1rem;font-weight:950}.training-detail-back{color:#fff7ed;background:#ffffff1a;border:1px solid #ffe29a42;border-radius:999px;padding:7px 10px;font-size:.78rem;font-weight:900}@media (width<=420px){.training-guild-showcase{padding:10px}.training-guild-card{grid-template-columns:minmax(0,1fr) 28px;min-height:118px}.training-guild-card-copy{width:66%;padding:12px 7px 12px 0}.training-guild-card-copy h3{font-size:.95rem}.training-guild-card-copy p{font-size:.68rem}.training-guild-card-copy small{font-size:.62rem}.training-guild-card-arrow{width:26px;height:26px;margin-right:6px;font-size:1.25rem}}.location-hero{background:linear-gradient(180deg, #07090d2e, #07090dc7), linear-gradient(90deg, #07090d80, #07090d33 50%, #07090d80), var(--location-hero-image);text-align:center;background-position:50%;background-size:cover;border:1px solid #ffe29a47;border-radius:24px;place-items:center;gap:14px;min-height:180px;padding:18px;display:grid;position:relative;overflow:hidden;box-shadow:inset 0 0 40px #00000073,0 18px 42px #00000047}.location-hero:before{content:"";pointer-events:none;background:radial-gradient(circle at 18% 12%,#ffd2703d,#0000 28%),linear-gradient(#ffe29a1f,#0000 42%);position:absolute;inset:0}.location-hero-copy,.location-hero-stats{z-index:1;position:relative}.location-hero-copy{text-shadow:0 3px 14px #000000b8;justify-items:center;width:100%;max-width:none;display:grid}.location-hero-copy span{color:#ffd980;letter-spacing:.12em;text-transform:uppercase;background:#0a08069e;border:1px solid #ffe29a57;border-radius:999px;margin-bottom:7px;padding:5px 10px;font-size:.72rem;font-weight:900;display:inline-flex}.location-hero-copy h2{color:#fff4d2;text-align:center;text-wrap:balance;width:100%;max-width:100%;font-size:clamp(1.75rem,8vw,3.1rem);font-weight:1000;line-height:1.02}.location-hero-copy p{color:#fff4d2e0;text-align:center;width:min(100%,30rem);margin-top:9px;font-size:.96rem;font-weight:750;line-height:1.4}.location-hero-stats{color:#fff4d2c7;text-align:center;background:#080706a3;border:1px solid #ffe29a33;border-radius:18px;justify-self:stretch;gap:5px;padding:10px 12px;font-size:.78rem;line-height:1.35;display:grid}.location-hero-stats strong{color:#ffe29a;font-size:.86rem}.location-hero-dungeon,.location-hero-shop{margin-bottom:14px}.location-hero-dungeon .location-hero-copy{width:100%;max-width:none}.location-hero-dungeon .location-hero-copy h2{text-wrap:balance;max-width:100%;font-size:clamp(1.45rem,6.6vw,2.65rem);line-height:1.05}.location-hero-shop{background-position:50% 42%;min-height:190px}.location-hero-shop .location-hero-copy h2{font-size:clamp(2rem,9vw,3.35rem)}@media (width>=760px){.location-hero{grid-template-columns:minmax(0,1fr);min-height:220px}}.journal-entry,.logbook-entry.quest-scroll-entry,.logbook-entry.scroll-entry{border:1px solid #6f421457;border-radius:18px;padding:18px 16px;position:relative;overflow:hidden;box-shadow:inset 0 0 18px #532d122e,0 10px 22px #00000038;background:linear-gradient(90deg,#fff5d6e0,#fff5d6b8),url(/assets/training-log-bg-BiLJ1mG0.png) 50%/100% 100% no-repeat!important}.journal-entry>*,.logbook-entry.quest-scroll-entry>*,.logbook-entry.scroll-entry>*{z-index:1;position:relative}.journal-entry:before,.logbook-entry.quest-scroll-entry:before,.logbook-entry.scroll-entry:before{content:"";pointer-events:none;background:radial-gradient(circle,#fff8dd8c,#0000 62%),linear-gradient(#693b1614,#693b1624);position:absolute;inset:0}.journal-entry p,.logbook-entry p,.scroll-entry p{color:#3f2818}.journal-entry-heading strong,.logbook-entry-heading strong,.scroll-entry strong{color:#24140b}.journal-entry-heading span,.logbook-entry-heading span,.scroll-entry span{color:#6f4214}.logbook-metric{background:#fff6da94}.hero-select-card .starter-card-photo{aspect-ratio:16/10;place-items:center;min-height:220px;display:grid;overflow:hidden}.hero-select-card .starter-hero-image{object-fit:contain;object-position:center;width:100%;height:100%;display:block}.class-selection-screen{isolation:isolate;min-height:100dvh;position:relative;overflow:hidden;background:linear-gradient(#04030214,#04030280),url(/assets/class-selection-bg-CgcE2m6H.png) top/cover no-repeat!important;padding:18px 12px 110px!important}.class-selection-screen:before{content:"";z-index:-1;pointer-events:none;background:linear-gradient(#0403020a,#04030275),url(/assets/class-selection-bg-CgcE2m6H.png) top/cover no-repeat;position:fixed;inset:0}.class-selection-screen .hero-intro,.class-selection-screen .starter-footer{display:none}.class-selection-screen .class-selection-content{align-content:end;min-height:calc(100dvh - 128px);display:grid}.class-selection-screen .starter-carousel.hero-select-card{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-color:#ffe29a52;margin-top:min(42dvh,360px);box-shadow:0 18px 38px #00000085,inset 0 1px #ffe29a1f;background:linear-gradient(#1a120cb8,#090706d6)!important}.class-selection-screen .hero-select-card .starter-card-photo{aspect-ratio:16/10;place-items:center;min-height:220px;display:grid;overflow:hidden}.class-selection-screen .hero-select-card .starter-hero-image{width:100%;height:100%;display:block;object-fit:contain!important;object-position:center!important}@media (height<=760px){.class-selection-screen .starter-carousel.hero-select-card{margin-top:240px}}.location-hero-tavern{background-position:50% 46%;min-height:240px}.tavern-card-grid{gap:12px;display:grid}.tavern-feature-card{background:linear-gradient(#573a2047,#100c0a9e),#100c0a9e;border:1px solid #ffe29a33;border-radius:18px;padding:14px;box-shadow:inset 0 1px #ffffff14}.tavern-feature-card span,.tavern-feature-card small{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-size:.72rem;font-weight:900}.tavern-feature-card h3{color:var(--text-strong);margin-top:4px;font-size:1.05rem;font-weight:950}.tavern-feature-card p{color:#fff4d2c2;margin-top:6px;font-size:.86rem;line-height:1.45}.tavern-feature-card small{color:#ffd980;background:#0a08066b;border:1px solid #ffe29a38;border-radius:999px;margin-top:12px;padding:4px 9px;display:inline-flex}@media (width>=760px){.tavern-card-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.tavern-board-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.tavern-board-card:last-child{grid-column:1/-1}}.class-selection-screen{height:auto;min-height:100dvh;overflow-y:auto;padding:18px 12px max(24px, env(safe-area-inset-bottom))!important}.class-selection-screen .class-selection-content{flex-direction:column;justify-content:flex-end;gap:12px;width:100%;max-width:390px;min-height:calc(100dvh - 42px);margin:0 auto;padding-top:min(18dvh,160px);display:flex}.class-selection-screen .starter-carousel.hero-select-card{width:100%;margin:0 auto min(12dvh,180px);padding:12px 42px 14px}.class-selection-screen .hero-select-card .starter-card-photo{min-height:180px;max-height:220px}.class-selection-screen .saved-campaign{width:min(100%,320px);margin:0 auto}.class-selection-screen .saved-campaign>div{grid-template-columns:1fr;gap:10px;display:grid}.class-selection-screen .saved-campaign button{white-space:nowrap;width:100%;min-height:48px}@media (height<=760px){.class-selection-screen .class-selection-content{padding-top:130px}.class-selection-screen .starter-carousel.hero-select-card{margin-top:0;margin-bottom:48px}.class-selection-screen .hero-select-card .starter-card-photo{min-height:150px;max-height:180px}}.class-selection-screen .class-selection-content{padding-bottom:max(18px, env(safe-area-inset-bottom))}.class-selection-screen .class-selection-actions{-webkit-backdrop-filter:blur(6px)!important;backdrop-filter:blur(6px)!important;background:#0a0807e0!important;border:1px solid #ffe29a52!important;border-radius:18px!important;gap:10px!important;width:min(100%,340px)!important;margin:0 auto!important;padding:12px!important;display:grid!important;position:static!important;box-shadow:0 18px 38px #0000007a!important}.class-selection-screen .class-selection-actions>div{grid-template-columns:1fr!important;gap:10px!important;width:100%!important;display:grid!important}.class-selection-screen .class-selection-actions button{white-space:nowrap!important;width:100%!important;min-height:48px!important}.tavern-board .tavern-board-card>img.tavern-board-card-image,.tavern-board .tavern-board-card img.tavern-board-card-image,.tavern-conversation-panel>img.tavern-conversation-image,.tavern-conversation-panel img.tavern-conversation-image{object-fit:cover!important;object-position:center top!important;border-radius:12px!important;width:100%!important;max-width:100%!important;height:160px!important;min-height:0!important;max-height:160px!important;display:block!important}.villager-snark-overlay{z-index:95;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#030712ad;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.villager-snark-card{background:linear-gradient(#573a2052,#100c0ad1),#100c0aeb;border:1px solid #ffe29a61;border-radius:20px;gap:0;width:min(100%,430px);max-height:min(86dvh,720px);display:grid;overflow:auto;box-shadow:0 24px 58px #0000008f}.villager-snark-image{object-fit:cover;object-position:center top;border-bottom:1px solid #ffe29a47;width:100%;height:300px;display:block}.villager-snark-copy{text-align:center;gap:10px;padding:16px;display:grid}.villager-snark-kicker{color:var(--gold);letter-spacing:.12em;text-transform:uppercase;font-size:.72rem;font-weight:900}.villager-snark-copy h2{color:var(--text-strong);font-size:1.35rem;font-weight:950}.villager-snark-line{color:#fff3cf;white-space:pre-line;font-size:1rem;font-weight:800;line-height:1.45}.villager-snark-copy button{width:100%;margin-top:4px}.app-page-shop .location-hero:before,.location-hero-shop:before{background:linear-gradient(#07090d2e,#0000 45%)!important}.app-page-shop .shop-item{background:linear-gradient(#ffffff0b,#ffffff05),#0a08076b!important}.app-page-map{background:#050608!important;padding:0!important}.app-page-map .app-container{width:100%!important;max-width:none!important;height:100dvh!important;min-height:100dvh!important;margin:0!important;padding:0!important}.app-page-map .top-grid,.app-page-map .bottom-grid{display:none!important}.village-map-screen{background:#050608;width:100%;height:100dvh;min-height:100dvh;position:relative;overflow:hidden}.village-map-image{object-fit:cover;object-position:center;width:100%;height:100%;min-height:100dvh;display:block}.village-map-hotspot{z-index:3;color:#fff0bf;text-align:center;text-shadow:0 1px 2px #000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0e0905c7;border:1px solid #ffe29ac7;border-radius:12px;gap:3px;width:128px;min-height:44px;padding:7px 8px;font-family:inherit;font-size:.7rem;font-weight:950;line-height:1;display:grid;position:absolute;box-shadow:0 8px 18px #0000006b,inset 0 1px #ffffff1a}.village-map-hotspot:hover:enabled{filter:brightness(1.08);transform:translateY(-1px)}.village-map-hotspot span,.village-map-hotspot small{display:block}.village-map-hotspot span{white-space:nowrap}.village-map-hotspot small{color:#ffefc2d1;font-size:.56rem;font-weight:800;line-height:1.15}.village-map-hotspot-training{top:31%;left:6%}.village-map-hotspot-gate{top:19%;left:50%;transform:translate(-50%)}.village-map-hotspot-gate:hover:enabled,.village-map-hotspot-logbook:hover:enabled{transform:translate(-50%)translateY(-1px)}.village-map-hotspot-tavern{top:34%;right:7%}.village-map-hotspot-shop{top:58%;left:8%}.village-map-hotspot-camp{top:60%;right:9%}.village-map-hotspot-logbook{top:47%;left:50%;transform:translate(-50%)}.village-map-hotspot-road{top:79%;right:6%}.village-map-hotspot.is-locked{opacity:.72;filter:grayscale(.35)}.app-page-map .page-menu{z-index:10}@media (width>=700px){.app-page-map .app-container,.village-map-screen{height:100%!important;min-height:100%!important}.village-map-image{min-height:100%!important}}.village-map-hotspot-title{left:5%;top:max(12px, env(safe-area-inset-top));background:#120b05d6;border-color:#ffe29aeb;width:154px}.village-map-hotspot-title span{white-space:normal;font-size:.76rem}.map-return-button{color:#fff0bf;text-shadow:0 1px 2px #000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0e0905d1;border:1px solid #ffe29ac7;border-radius:999px;justify-content:center;align-items:center;min-height:40px;margin-bottom:12px;padding:8px 12px;font-family:inherit;font-size:.82rem;font-weight:950;line-height:1;display:inline-flex;box-shadow:0 8px 18px #0000006b,inset 0 1px #ffffff1a}.timing-strike-mini{z-index:9;pointer-events:auto;width:128px;position:absolute;top:34%;left:10%;transform:translateY(-50%)}.timing-strike-panel{text-align:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:radial-gradient(circle at 50% 44%,#ffe29a2e,#0000 52%),#0c0807c7;border:1px solid #ffe29a80;border-radius:16px;justify-items:center;gap:4px;padding:8px 8px 9px;display:grid;position:relative;box-shadow:0 12px 30px #0000007a,0 0 22px #ffc5561f}.timing-strike-kicker{color:var(--gold);letter-spacing:.12em;text-transform:uppercase;font-size:.58rem;font-weight:950;line-height:1}.timing-strike-ability{color:#fff7dc;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:.62rem;font-weight:900;line-height:1.05;overflow:hidden}.timing-strike-instructions{color:#fff3cfd1;font-size:.58rem;font-weight:800;line-height:1.1}.timing-strike-button{color:#fff7dc;touch-action:manipulation;background:radial-gradient(circle,#ffe29a29 0 25%,#6339185c 26% 58%,#05080ec7 59% 100%);border:2px solid #ffe29ae0;border-radius:999px;place-items:center;width:82px;height:82px;min-height:0;display:grid;position:relative;overflow:hidden;box-shadow:0 0 18px #ffc55640,0 8px 18px #00000073,inset 0 0 18px #00000057}.timing-strike-button strong{z-index:5;color:#fff7dc;letter-spacing:.05em;text-shadow:0 2px 4px #000;text-transform:uppercase;background:#0906049e;border-radius:999px;padding:5px 8px;font-size:.64rem;font-weight:950;position:relative}.timing-strike-outer,.timing-strike-perfect-zone,.timing-strike-ring,.timing-strike-center-dot{pointer-events:none;border-radius:999px;position:absolute}.timing-strike-outer{border:1px solid #ffffff38;inset:8px}.timing-strike-perfect-zone{background:#78e0a614;border:2px solid #78e0a6eb;width:34%;height:34%;box-shadow:0 0 12px #78e0a657}.timing-strike-ring{border:3px solid #ffe29af5;animation:1.35s linear infinite timingStrikeShrink;inset:8px;box-shadow:0 0 14px #ffe29a8f}.timing-strike-center-dot{background:#fff7dc;width:7px;height:7px;box-shadow:0 0 12px #fff7dcd1}@keyframes timingStrikeShrink{0%{opacity:.95;transform:scale(1)}72%{opacity:1;transform:scale(.38)}84%{opacity:.75;transform:scale(.23)}to{opacity:.95;transform:scale(1)}}.defense-reaction-prompt{z-index:10;pointer-events:auto;width:142px;position:absolute;top:58%;left:31%;transform:translateY(-50%)}.defense-reaction-panel{text-align:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:radial-gradient(circle at 50% 42%,#9bc3ff33,#0000 54%),#080c14d1;border:1px solid #9bc3ffa3;border-radius:16px;justify-items:center;gap:5px;padding:9px 9px 10px;display:grid;position:relative;box-shadow:0 12px 30px #00000080,0 0 22px #9bc3ff29}.defense-reaction-kicker{color:var(--level);letter-spacing:.12em;text-transform:uppercase;font-size:.56rem;font-weight:950;line-height:1}.defense-reaction-enemy,.defense-reaction-ability{text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-weight:900;line-height:1.05;overflow:hidden}.defense-reaction-enemy{color:#fff7dc;font-size:.68rem}.defense-reaction-ability{color:#fff3cfdb;font-size:.58rem}.defense-reaction-instructions{color:#fff3cfd1;font-size:.56rem;font-weight:800;line-height:1.1}.defense-reaction-button{color:#fff7dc;touch-action:manipulation;background:radial-gradient(circle,#ffe29a38 0 23%,#9bc3ff33 24% 60%,#080c14e6 61% 100%);border:2px solid #9bc3ffeb;border-radius:999px;place-items:center;width:92px;height:92px;min-height:0;display:grid;position:relative;overflow:hidden;box-shadow:0 0 20px #9bc3ff47,0 8px 18px #00000075,inset 0 0 22px #00000052}.defense-reaction-button strong{z-index:5;color:#fff7dc;letter-spacing:.05em;text-shadow:0 2px 4px #000;text-transform:uppercase;background:#07080c94;border-radius:999px;padding:5px 8px;font-size:.62rem;font-weight:950;position:relative}.defense-shield-block-zone,.defense-shield-perfect-core,.defense-shield-timing-ring,.defense-shield-center{pointer-events:none;border-radius:999px;position:absolute}.defense-shield-block-zone{background:#9bc3ff14;border:3px solid #9bc3ffeb;inset:9px;box-shadow:0 0 16px #9bc3ff6b,inset 0 0 14px #9bc3ff1f}.defense-shield-perfect-core{background:#ffe29a33;border:3px solid #ffe29afa;width:36%;height:36%;animation:.72s ease-in-out infinite defensePerfectCorePulse;box-shadow:0 0 18px #ffe29a9e,inset 0 0 10px #ffe29a2e}.defense-shield-timing-ring{animation:defenseShieldShrink var(--defense-duration,.76s) linear forwards;border:4px solid #ffffffe6;inset:7px;box-shadow:0 0 18px #9bc3ff8c}.defense-shield-center{background:#fff7dc;width:7px;height:7px;box-shadow:0 0 12px #fff7dcd1}.defense-reaction-legend{letter-spacing:.08em;text-transform:uppercase;justify-content:center;align-items:center;gap:8px;margin-top:-1px;font-size:.54rem;font-weight:950;line-height:1;display:flex}.defense-reaction-legend span{color:#9bc3ff}.defense-reaction-legend strong{color:#ffe29a}.battle-float-text.good{color:#9bc3ff;text-shadow:0 2px 5px #000,0 0 12px #9bc3ffb8}.battle-float-text.perfect{color:#ffe29a;text-shadow:0 2px 5px #000,0 0 14px #ffe29adb}@keyframes defenseShieldShrink{0%{opacity:.98;border-color:#fffffff0;transform:scale(1);box-shadow:0 0 18px #9bc3ff8c}48%{opacity:1;border-color:#9bc3fff5;transform:scale(.68);box-shadow:0 0 20px #9bc3ffb8}74%{opacity:1;border-color:#ffe29afa;transform:scale(.39);box-shadow:0 0 22px #ffe29ac7}to{opacity:.82;border-color:#ffe29afa;transform:scale(.25);box-shadow:0 0 26px #ffe29aeb}}@keyframes defensePerfectCorePulse{0%,to{opacity:.82;transform:scale(.94)}50%{opacity:1;transform:scale(1.06)}}html,body,#root{width:100%!important;height:auto!important;min-height:100%!important;overflow:hidden auto!important}body{margin:0!important;padding:0!important;display:block!important}#root{max-width:none!important;text-align:initial!important;place-items:initial!important;border:0!important;margin:0!important;display:block!important}main.app-shell:not(.app-page-map),main.starter-shell{-webkit-overflow-scrolling:auto!important;overscroll-behavior:auto!important;width:100%!important;max-width:100vw!important;height:auto!important;min-height:0!important;max-height:none!important;margin:0 auto!important;display:block!important;position:relative!important;overflow:visible!important}main.app-shell:not(.app-page-map) .app-container,main.app-shell:not(.app-page-map) .top-grid,main.app-shell:not(.app-page-map) .bottom-grid,main.app-shell:not(.app-page-map) .page-panel,main.app-shell:not(.app-page-map) .rpg-panel,main.app-shell:not(.app-page-map) .shop-list,main.starter-shell .mx-auto{height:auto!important;min-height:0!important;max-height:none!important;overflow:visible!important}main.app-shell:not(.app-page-map) .hero-status-card{inset:auto!important;z-index:auto!important;margin-bottom:18px!important;position:static!important;inset:auto!important;transform:none!important}main.app-shell:not(.app-page-map) .player-header{inset:auto!important;z-index:auto!important;position:static!important;inset:auto!important;transform:none!important}.app-page-training .page-panel-training,.app-page-shop .page-panel-shop,.app-page-training .location-hero,.app-page-shop .location-hero,.app-page-training .training-guild-showcase,.app-page-shop .shop-list{z-index:auto!important;height:auto!important;min-height:0!important;max-height:none!important;position:relative!important;inset:auto!important;overflow:visible!important;transform:none!important}@media (width>=700px){body{padding:16px 0 32px!important}main.app-shell:not(.app-page-map),main.starter-shell{width:var(--phone-frame-width)!important;border-radius:34px!important;max-width:calc(100vw - 32px)!important;min-height:0!important}}main.app-shell:not(.app-page-map):not(.app-battle-active){-webkit-overflow-scrolling:auto!important;overscroll-behavior:auto!important;height:auto!important;min-height:0!important;max-height:none!important;position:relative!important;overflow:visible!important}main.app-shell:not(.app-page-map):not(.app-battle-active) .app-container,main.app-shell:not(.app-page-map):not(.app-battle-active) .top-grid,main.app-shell:not(.app-page-map):not(.app-battle-active) .bottom-grid,main.app-shell:not(.app-page-map):not(.app-battle-active) .page-panel,main.app-shell:not(.app-page-map):not(.app-battle-active) .rpg-panel,main.app-shell:not(.app-page-map):not(.app-battle-active) .shop-list,main.app-shell:not(.app-page-map):not(.app-battle-active) .training-guild-showcase{height:auto!important;min-height:0!important;max-height:none!important;overflow:visible!important}main.app-shell:not(.app-page-map):not(.app-battle-active) .player-header,main.app-shell:not(.app-page-map):not(.app-battle-active) .hero-status-card,main.app-shell:not(.app-page-map):not(.app-battle-active) .location-hero,main.app-shell:not(.app-page-map):not(.app-battle-active) .location-hero-training,main.app-shell:not(.app-page-map):not(.app-battle-active) .location-hero-shop,main.app-shell:not(.app-page-map):not(.app-battle-active) .training-xp-sticky{inset:auto!important;z-index:auto!important;position:static!important;inset:auto!important;transform:none!important}.class-selection-screen .starter-card-copy{text-align:center;justify-items:center;width:100%;display:grid}.class-selection-screen .starter-card-copy p{text-align:center;max-width:28rem;margin-left:auto;margin-right:auto}.class-selection-screen .starter-card-copy button{width:min(100%,280px)}
