:root{color:#f5efe4;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0d0b09;font-family:Georgia,Times New Roman,serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html{min-height:100%;margin:0}body{min-height:100vh;margin:0}button,input,textarea,select{font:inherit}#root{min-height:100vh}.app-shell{background:radial-gradient(circle at top,#c4a8782e,#0000 34%),linear-gradient(#171411 0%,#0d0b09 100%);place-items:center;min-height:100vh;padding:32px 20px;display:grid}.landing-panel{text-align:center;background:#181410e0;border:1px solid #d6bf9b3d;border-radius:28px;width:min(100%,760px);padding:42px 36px;box-shadow:0 24px 80px #00000061}.selection-panel{background:#181410e6;border:1px solid #d6bf9b3d;border-radius:28px;width:min(100%,1080px);padding:32px;box-shadow:0 24px 80px #00000061}.battle-panel{background:#181410eb;border:1px solid #d6bf9b3d;border-radius:28px;width:min(100%,1200px);padding:28px;box-shadow:0 24px 80px #0000006b}.end-panel{text-align:center;border:1px solid #d6bf9b3d;border-radius:28px;width:min(100%,860px);padding:48px 40px;box-shadow:0 24px 80px #0000006b}.victory-panel{background:radial-gradient(circle at top,#d6c0802e,#0000 42%),#181410f0}.final-victory-panel{background:radial-gradient(circle at top,#ecd68f38,#0000 44%),linear-gradient(#211b13f5,#120e0af5)}.defeat-panel{background:radial-gradient(circle at top,#8f493433,#0000 42%),#181410f0}.eyebrow{letter-spacing:.24em;text-transform:uppercase;color:#d4bc92;margin:0 0 16px;font-size:.8rem}.landing-panel h1{letter-spacing:.05em;text-transform:uppercase;margin:0;font-size:clamp(2.5rem,7vw,4.1rem);line-height:1}.selection-panel h2,.selection-panel h3,.battle-panel h2,.battle-panel h3{margin:0}.lead{color:#d8d1c6;width:min(100%,540px);margin:18px auto 0;font-size:1rem;line-height:1.6}.end-copy{width:min(100%,620px)}.feature-list{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:32px 0;display:grid}.feature-list p{color:#efe6d6;background:#ffffff0a;border:1px solid #d6bf9b24;border-radius:16px;margin:0;padding:14px 12px}.selection-header{justify-content:space-between;align-items:center;gap:16px;display:flex}.selection-copy{color:#d8d1c6;margin:12px 0 0;line-height:1.55}.class-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;margin-top:28px;display:grid}.class-card{color:#f5efe4;text-align:left;cursor:pointer;background:#ffffff0a;border:1px solid #d6bf9b24;border-radius:20px;flex-direction:column;align-items:flex-start;gap:10px;padding:18px 16px;transition:transform .16s,border-color .16s,background .16s;display:flex}.class-card:hover{border-color:#ead6ac73;transform:translateY(-2px)}.class-card.selected{background:#ead6ac1a;border-color:#ead6acb8}.class-role{letter-spacing:.18em;text-transform:uppercase;color:#d4bc92;font-size:.78rem}.class-summary{color:#cfc5b5;line-height:1.5}.class-preview{background:#ffffff08;border:1px solid #d6bf9b29;border-radius:20px;margin-top:28px;padding:20px}.preview-details{gap:8px;margin:14px 0 18px;display:grid}.preview-details p{color:#efe6d6;background:#0000002e;border-radius:12px;margin:0;padding:10px 12px;font-size:.92rem;line-height:1.35}.matchup-banner{color:#efe6d6;text-transform:uppercase;letter-spacing:.08em;background:#ffffff0a;border:1px solid #d6bf9b24;border-radius:999px;justify-content:center;align-items:center;gap:16px;margin-top:16px;padding:12px 18px;display:flex}.matchup-banner strong{color:#d4bc92}.matchup-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px;display:grid}.combatant-card{background:#ffffff08;border:1px solid #d6bf9b29;border-radius:20px;padding:16px}.hero-card{box-shadow:inset 0 0 0 1px #ead6ac0f}.boss-card{box-shadow:inset 0 0 0 1px #bb8f4f14}.combatant-summary{color:#d8d1c6;margin:10px 0 0;line-height:1.55}.combatant-health{color:#f1dfbe;letter-spacing:.04em;text-transform:uppercase;margin:8px 0 0;font-size:.9rem;font-weight:700}.abilities-panel{gap:8px;margin-top:8px;display:grid}.ability-row{background:#0003;border:1px solid #d6bf9b1a;border-radius:14px;gap:4px;padding:10px 12px;display:grid}.ability-row strong{color:#f7eedf}.ability-row span{color:#cfc5b5;font-size:.92rem;line-height:1.45}.actions-row{justify-content:space-between;align-items:center;gap:16px;margin-top:20px;display:flex}.battle-status-bar{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:16px;display:grid}.battle-status-bar>div{background:#ffffff0a;border:1px solid #d6bf9b1f;border-radius:16px;padding:12px 14px}.status-label{letter-spacing:.16em;text-transform:uppercase;color:#d4bc92;margin:0 0 8px;font-size:.72rem}.battle-grid{grid-template-columns:minmax(0,1fr) minmax(280px,.82fr) minmax(0,1fr);align-items:stretch;gap:12px;margin-top:16px;display:grid}.battle-card{box-sizing:border-box;background:#ffffff08;border:1px solid #d6bf9b29;border-radius:20px;height:100%;padding:16px}.battle-card-head{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.battle-role{color:#efe6d6;background:#ffffff0d;border:1px solid #d6bf9b24;border-radius:999px;justify-content:center;align-items:center;padding:8px 12px;font-size:.78rem;display:inline-flex}.health-block{margin-top:12px}.health-row{color:#efe6d6;justify-content:space-between;gap:12px;margin-bottom:8px;font-size:.92rem;display:flex}.health-track{background:#ffffff0f;border:1px solid #d6bf9b1f;border-radius:999px;height:12px;overflow:hidden}.health-fill{border-radius:inherit;height:100%;transition:width .22s}.hero-fill{background:linear-gradient(90deg,#d7c08f 0%,#edd8aa 100%)}.boss-fill{background:linear-gradient(90deg,#9e4f3a 0%,#db8c60 100%)}.battle-abilities,.boss-abilities{margin-top:14px}.ability-button{color:#f5efe4;text-align:left;cursor:pointer;background:#ffffff0a;border:1px solid #d6bf9b24;border-radius:14px;gap:5px;width:100%;padding:12px;transition:transform .16s,border-color .16s,background .16s;display:grid}.ability-button:hover:enabled{background:#ead6ac14;border-color:#ead6ac73;transform:translateY(-2px)}.ability-button:disabled{opacity:.56;cursor:not-allowed}.ability-button span{font-size:.9rem;line-height:1.4}.log-panel,.result-panel{background:#ffffff08;border:1px solid #d6bf9b29;border-radius:20px;padding:16px}.battle-log-panel{box-sizing:border-box;height:100%;min-height:100%;max-height:520px;overflow:hidden}.compact-header{align-items:flex-start}.log-list{gap:8px;max-height:440px;margin-top:12px;display:grid;overflow:hidden}.log-entry{color:#efe6d6;background:#0000002e;border-radius:12px;margin:0;padding:10px 12px;font-size:.9rem;line-height:1.45}.log-divider{text-align:center;color:#a79d8d;letter-spacing:.12em;margin:0;font-size:.8rem}.result-actions{flex-wrap:wrap;gap:12px;margin-top:24px;display:flex}.centered-actions{justify-content:center}.battle-actions{justify-content:center;margin-top:14px}.end-highlight{border:1px solid #d6bf9b29;border-radius:22px;gap:12px;width:min(100%,520px);margin:28px auto 0;padding:18px 20px;display:grid}.end-highlight p{color:#efe6d6;margin:0}.success-highlight{background:#ead6ac14}.defeat-highlight{background:#ad5e4a1f}.matchup-boost{width:min(100%,620px);margin-top:0;margin-left:auto;margin-right:auto;padding:10px 12px}.end-log-panel{text-align:left;background:#ffffff08;border:1px solid #d6bf9b29;border-radius:24px;width:min(100%,620px);margin:28px auto 0;padding:24px}.ghost-button{color:#f5efe4;cursor:pointer;background:0 0;border:1px solid #d6bf9b38;border-radius:999px;padding:10px 16px}.ghost-button:hover{border-color:#ead6ac8c}.start-button{color:#120f0b;font:inherit;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;background:linear-gradient(135deg,#ead6ac 0%,#bb8f4f 100%);border:0;border-radius:999px;padding:14px 24px;font-weight:700;transition:transform .16s,box-shadow .16s;box-shadow:0 14px 34px #bb8f4f47}.start-button:hover{transform:translateY(-2px);box-shadow:0 18px 40px #bb8f4f5c}.start-button:focus-visible{outline-offset:4px;outline:3px solid #f3dfb4}@media (width<=720px){.landing-panel,.selection-panel,.battle-panel,.end-panel{padding:36px 22px}.feature-list{grid-template-columns:1fr}.selection-header{flex-direction:column;align-items:flex-start}.class-grid{grid-template-columns:1fr}.matchup-banner,.actions-row{flex-direction:column;align-items:stretch}.matchup-grid,.battle-status-bar,.battle-grid{grid-template-columns:1fr}.battle-card-head,.result-actions{flex-direction:column}}@media (width<=1040px){.class-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.matchup-panel{padding:20px}.matchup-grid{gap:12px}.combatant-card{padding:16px}.battle-grid{grid-template-columns:1fr}}
