:root{font-family:IBM Plex Mono,JetBrains Mono,Consolas,monospace;line-height:1.45;font-weight:400;color:#1c2c1f}*{box-sizing:border-box}html,body,#root{width:100%;min-height:100%;margin:0}body{background-color:#ebe5d7;background-image:linear-gradient(130deg,#ffffff8c,#cbbd9a73),repeating-linear-gradient(0deg,rgba(63,90,58,.06),rgba(63,90,58,.06) 1px,transparent 1px,transparent 28px),repeating-linear-gradient(90deg,rgba(63,90,58,.05),rgba(63,90,58,.05) 1px,transparent 1px,transparent 28px)}.app-shell{min-height:100vh}.app-main{padding:12px}.app-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-bottom:1px solid #7f876c;background:#f0ece0eb;position:sticky;top:0;z-index:3}.logo{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:700}.logo-icon{height:2em;width:auto;display:block}.nav-links{display:flex;gap:8px}.nav-right{display:flex;align-items:center;gap:10px}.header-stats{display:flex;align-items:center;gap:10px;font-size:12px;border:1px dashed #7f876c;border-radius:8px;padding:4px 8px;background:#d8ddc459}.header-stats-meta{display:flex;align-items:center;gap:10px;white-space:nowrap}.header-bars{display:flex;align-items:center;gap:10px}.header-gold{white-space:nowrap}.header-bar-row{display:flex;align-items:center;gap:6px;white-space:nowrap}.header-bar{position:relative;height:8px;width:90px;border:1px solid #5a6f57;border-radius:999px;overflow:hidden;background:#1e2b1c3d}.header-bar-fill{height:100%}.header-bar-hp .header-bar-fill{background:linear-gradient(90deg,#3a8f3f,#7ad35f)}.header-bar-exp .header-bar-fill{background:linear-gradient(90deg,#3d9dd0,#8be4ff)}.nav-links a{text-decoration:none;color:#2f4b31;border:1px dashed #7f876c;padding:5px 8px;border-radius:8px}.nav-links a.active{background:#d8ddc4}.corner-layout{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;min-height:calc(100vh - 90px)}.panel{border:1px solid #7f876c;border-radius:10px;background:#fcfaf3eb;padding:10px;box-shadow:0 4px 18px #27382a14;height:100%}.panel h2{margin:0 0 8px;font-size:15px;border-bottom:1px dashed #8a8f79;padding-bottom:4px}.panel-content p,.panel-content li{margin:4px 0}.mono-list{margin:0;padding-left:16px}.log-list{max-height:280px;overflow:auto}.stack-form{display:grid;gap:8px}label{display:grid;gap:4px;font-size:13px}input,select,button{font:inherit}input,select{border:1px solid #8a8f79;border-radius:8px;padding:8px;background:#fcfbf6}button{border:1px solid #4a6650;border-radius:8px;background:#cbd9bf;padding:7px 10px;color:#1e341f;cursor:pointer}button:disabled{opacity:.5;cursor:not-allowed}.ghost-button{background:#f0ede3}.button-row{display:flex;flex-wrap:wrap;gap:6px;margin:10px 0}.text-link-button{display:inline-block;border:1px solid #4a6650;border-radius:8px;background:#cbd9bf;padding:7px 10px;color:#1e341f;text-decoration:none}.battle-result-single{width:100%}.result-title{margin:0 0 10px;font-size:28px;font-weight:800;letter-spacing:1px}.result-hero{position:relative;border:1px dashed #8a8f79;border-radius:10px;padding:10px;overflow:hidden}.result-banner-image{display:block;width:min(100%,900px);max-height:280px;object-fit:contain;margin:0 auto}.result-hero.victory{background:radial-gradient(circle at 18% 8%,rgba(255,237,131,.45),transparent 42%),radial-gradient(circle at 82% 85%,rgba(128,182,113,.34),transparent 44%),#f4efdae6;box-shadow:0 0 0 1px #bb9c4c40 inset}.result-hero.victory.victory-theme-sun{background:radial-gradient(circle at 15% 10%,rgba(255,232,124,.52),transparent 46%),radial-gradient(circle at 85% 82%,rgba(156,211,118,.34),transparent 42%),linear-gradient(135deg,#fff8dbd1,#eedca1b3);border-color:#9e8e56}.result-hero.victory.victory-theme-steel{background:linear-gradient(135deg,#d7e2dc9e,#bcccc48c),repeating-linear-gradient(45deg,rgba(70,92,83,.08),rgba(70,92,83,.08) 8px,transparent 8px,transparent 18px);border-color:#6f8479}.result-hero.victory.victory-theme-royal{background:radial-gradient(circle at 80% 12%,rgba(243,215,144,.42),transparent 42%),linear-gradient(145deg,#ede5c3c7,#d2ba7e85);border-color:#8f7342}.result-hero.defeat{background:radial-gradient(circle at 20% 10%,rgba(157,60,44,.32),transparent 42%),radial-gradient(circle at 80% 85%,rgba(79,48,42,.28),transparent 44%),#e2d7cee6}.result-fx{position:absolute;inset:0;pointer-events:none}.result-fx.victory:before,.result-fx.victory:after{content:"";position:absolute;width:140%;height:100%;left:-20%;background:radial-gradient(circle,rgba(255,215,92,.55) 1px,transparent 2px) 0 0 / 24px 20px;animation:resultSparkle 8s linear infinite}.result-fx.victory:after{animation-delay:-4s;opacity:.7}.result-fx.defeat:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(160deg,rgba(120,61,52,.16),rgba(120,61,52,.16) 8px,transparent 8px,transparent 20px);animation:resultSmoke 7s linear infinite}.reward-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.reward-tile{border:1px solid #7f876c;border-radius:10px;padding:8px;display:grid;gap:4px;background:#f5f2e6cc}.reward-tile strong{font-size:24px;line-height:1}.reward-label{font-size:12px;opacity:.85}.reward-gold{background:linear-gradient(180deg,#fae7a58c,#dcbb5f59)}.reward-exp{background:linear-gradient(180deg,#a6dfff8c,#5ca8de59)}.reward-levelup{background:linear-gradient(180deg,#b7f2ab8c,#77c56b59)}.exp-levelup-badge{display:inline-block;width:fit-content;margin-top:2px;border:1px solid #4e6e37;border-radius:999px;padding:3px 10px;font-size:11px;font-weight:700;letter-spacing:.2px;background:linear-gradient(180deg,#d1f598cc,#a5d85db3);color:#1f3d13;box-shadow:0 0 0 1px #ffffff59 inset,0 1px 6px #59802c40}.exp-track-wrap{margin-top:8px}.exp-track-wrap p{margin:0 0 5px}.exp-track{position:relative;height:16px;border-radius:999px;border:1px solid #5a6f57;overflow:hidden;background:#1e2b1c4d}.exp-track-fill{position:absolute;top:0;bottom:0;left:0;transition:width .7s ease}.exp-track-fill-before{background:linear-gradient(90deg,#3d9dd0,#5fc0eb)}.exp-track-fill-gain{background:linear-gradient(90deg,#8ae0ff,#d1f5ff)}.exp-track-fill-loss{background:linear-gradient(90deg,#f4b2b2,#de6a6a)}.exp-track-divider{position:absolute;top:-2px;bottom:-2px;width:2px;margin-left:-1px;background:#f5fcfff2;box-shadow:0 0 0 1px #3b586859}.drop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}.drop-card{text-align:left;display:grid;gap:2px;padding:8px;border-radius:10px;border:1px solid #7f876c;background:#f6f3e9e6;animation:dropReveal .45s ease both}.drop-card[role=button]{cursor:pointer}.drop-card strong{line-height:1.1}.drop-qty{font-weight:700}.drop-card .item-image{margin:2px 0 4px}.drop-card.rarity-common{box-shadow:0 0 0 1px #60725d33 inset}.drop-card.rarity-uncommon{box-shadow:0 0 0 2px #49925a59 inset}.drop-card.rarity-rare{box-shadow:0 0 0 2px #467cb659 inset}.drop-card.rarity-epic{box-shadow:0 0 0 2px #875cb159 inset}.drop-card.rarity-legendary{box-shadow:0 0 0 2px #c6943f6b inset}.ascii-banner{margin:0;padding:10px;border:1px dashed #7f876c;border-radius:8px;background:#d8ddc459;font-size:16px;line-height:1.2;overflow-x:auto}.ascii-victory{font-weight:700;letter-spacing:.3px;text-shadow:0 1px 0 rgba(255,255,255,.45);line-height:1.15}.ascii-victory-sun{border-color:#9a8748;background:radial-gradient(circle at 20% 25%,rgba(255,235,156,.5),transparent 44%),linear-gradient(180deg,#f5e2aa59,#e0c1703d),#faf2d48c;box-shadow:0 0 0 1px #b88f3447 inset}.ascii-victory-steel{border-color:#6f7c74;background:linear-gradient(135deg,#d2dfd652,#b6c4be33),repeating-linear-gradient(90deg,rgba(90,113,101,.08),rgba(90,113,101,.08) 2px,transparent 2px,transparent 14px),#e5ece899;color:#1f3328;box-shadow:0 0 0 1px #576f633d inset}.ascii-victory-royal{border-color:#7f7350;background:linear-gradient(160deg,#ecdbb059,#cbb07038),radial-gradient(circle at 78% 18%,rgba(241,206,120,.35),transparent 38%),#f2e8c98c;box-shadow:0 0 0 1px #8f713442 inset}.status-error{color:#9d2d21;margin:8px 0 0}.status-ok{color:#285b2c;margin:8px 0 0}.full-page-message{padding:24px;font-size:15px}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:20px}.auth-panel{width:min(560px,100%);border:1px solid #6d7d61;border-radius:12px;background:#fbfaf4f2;padding:18px}.auth-panel h1{margin:0 0 4px;font-size:24px}.auth-logo{width:200px;height:200px;display:block;margin:0 auto 10px;object-fit:contain}.hint-line{margin:0 0 12px}.mode-switch{display:flex;gap:6px;margin-bottom:12px}.mode-switch button.active{background:#b6c6a2;font-weight:700}hr{border:0;border-top:1px dashed #8a8f79;margin:10px 0}.world-graph-wrap{margin-top:8px;border:1px dashed #8a8f79;border-radius:10px;padding:8px;overflow:hidden;background:radial-gradient(circle at 20% 10%,rgba(176,199,163,.28),transparent 42%),radial-gradient(circle at 85% 80%,rgba(132,163,120,.2),transparent 38%),#efecdfa6}.world-graph{width:100%;height:auto;display:block;overflow:visible;position:absolute;inset:0}.world-graph-stage{position:relative;width:100%;max-width:100%;aspect-ratio:980 / 620}.world-nodes-layer{position:absolute;inset:0}.world-graph-edge{fill:none;stroke:#829275;stroke-width:1.5;opacity:.7}.world-graph-edge.current-branch{stroke:#486848;stroke-width:2;opacity:.95}.world-graph-arrow{fill:#5f7560}.world-graph-node{fill:#e4e1d3;stroke:#627a5b;stroke-width:1.5;transition:fill .2s ease,stroke .2s ease,transform .2s ease}.world-graph-node:hover{fill:#d6dec2}.world-graph-node.reachable{fill:#d6e4cc;stroke:#4f714e}.world-graph-node.current{fill:#a9c49f;stroke:#2f552f;stroke-width:2.5}.world-graph-node-id{font-size:12px;font-weight:700;fill:#1f351f;pointer-events:none}.world-graph-node-label{font-size:11px;fill:#223723;pointer-events:none}.world-node-card{position:absolute;transform:translate(-50%,-50%);border:1px solid #9aa193;border-radius:10px;background:#eeece6e0;padding:4px;width:122px;display:grid;justify-items:center;gap:4px;z-index:2;cursor:default}.world-node-card:disabled{opacity:1}.world-node-card.reachable{border-color:#4f714e;box-shadow:0 0 0 1px #63925b3d inset;background:#e8f2e2f2}.world-node-card.reachable:not(:disabled){cursor:pointer}.world-node-card.current{border-color:#2f552f;box-shadow:0 0 0 2px #5f94584d inset;background:#d6e8cdf5}.world-node-card:not(.current):not(.reachable) .world-node-thumb img{filter:grayscale(.9) brightness(.82)}.world-node-card:not(.current):not(.reachable) .world-node-name{color:#566055}.world-node-thumb{position:relative;width:62px;height:62px;border:1px solid #7f876c;border-radius:10px;background:#d8ddc44d;overflow:hidden}.world-node-thumb img{width:100%;height:100%;object-fit:cover;display:block}.world-node-fallback{position:absolute;inset:0;display:grid;place-items:center;font-size:11px;font-weight:700;color:#4e6651}.world-node-name{width:100%;font-size:10px;line-height:1.2;text-align:center;white-space:normal;overflow-wrap:anywhere;word-break:break-word;min-height:24px}.world-graph-legend{margin-top:8px;display:flex;flex-wrap:wrap;gap:10px;font-size:11px}.world-graph-legend span{border:1px dashed #7f876c;border-radius:999px;padding:2px 7px;background:#f4f1e8bf}.world-graph-legend .legend-current{background:#d0e2c9}.world-graph-legend .legend-reachable{background:#e4efde}.world-graph-legend .legend-disabled{background:#e7e6e0;color:#5e665b}.location-page{display:grid;gap:10px}.location-pvp-banner{width:100%;border:1px solid #7f876c;border-radius:10px;background:linear-gradient(180deg,#f4ebd6f2,#e5d6b0e6);padding:8px 10px;display:flex;gap:12px;align-items:center;flex-wrap:wrap}.location-pvp-banner.incoming{background:linear-gradient(180deg,#deebf6f2,#c9dfefe6)}.location-pvp-banner-timer{font-weight:700}.duel-board{display:grid;grid-template-columns:1fr auto 1fr;gap:10px;align-items:center;padding:8px;border:1px solid #7f876c;border-radius:10px;background:linear-gradient(180deg,#e7dfc9e6,#d2c5a6a6)}.battle-screen{display:grid;gap:10px}.duel-side{display:grid;gap:6px}.duel-name{margin:0;font-weight:700}.duel-vs{text-align:center;padding:4px 10px;border:1px solid #6e5f40;border-radius:999px;background:radial-gradient(circle at 30% 25%,#f0e2bb,#b28a54);color:#3a2712;font-weight:700;min-width:74px}.duel-vs small{display:block;font-size:10px;opacity:.85}.battle-bar{position:relative;border:1px solid #596548;border-radius:999px;overflow:hidden;height:20px;background:#18201259}.battle-bar-fill{height:100%;transition:width .25s ease}.battle-bar-hp .battle-bar-fill{background:linear-gradient(90deg,#3a8f3f,#7ad35f)}.battle-bar-mp .battle-bar-fill{background:linear-gradient(90deg,#256ba8,#6ac5f2)}.battle-bar span{position:absolute;inset:0;display:grid;place-items:center;color:#f3f7ef;font-size:12px;text-shadow:0 1px 2px rgba(0,0,0,.6)}.battle-scene{display:grid;grid-template-columns:1fr auto 1fr;gap:8px;align-items:center;border:1px dashed #7f876c;border-radius:10px;padding:16px 10px 10px;background:radial-gradient(circle at 20% 40%,rgba(137,178,121,.18),transparent 50%),radial-gradient(circle at 80% 50%,rgba(113,153,168,.16),transparent 50%),#f4f1e8b3}.arena-controls{display:grid;gap:8px;align-items:center;justify-items:center}.fighter-wrap{position:relative;align-self:end;min-height:320px;display:grid;align-items:end}.battle-actor{width:100%;border:1px dashed #8a8f79;border-radius:10px;background:#faf8f0eb;padding:8px;display:grid;place-items:center;transition:transform .12s ease,filter .12s ease,box-shadow .12s ease}.battle-actor-head{margin:0 0 6px;width:100%;font-size:11px;letter-spacing:.3px;text-transform:uppercase;color:#4d5b46}.battle-actor-monster{min-height:290px}.battle-monster-image{width:min(100%,280px);aspect-ratio:1 / 1;object-fit:cover;border:1px solid #7f876c;border-radius:12px;background:#d8ddc438}.battle-monster-fallback{width:min(100%,280px);aspect-ratio:1 / 1;border:1px solid #7f876c;border-radius:12px;background:#d8ddc438;display:grid;place-items:center;font-weight:700;opacity:.7}.floating-fx{position:absolute;top:-8px;left:50%;transform:translate(-50%);font-size:20px;font-weight:800;letter-spacing:.5px;text-shadow:0 2px 8px rgba(0,0,0,.35);animation:floatUpFade .9s ease forwards;pointer-events:none}.fx-hit{color:#d0432a}.fx-crit{color:#ff8e1a}.fx-dodge{color:#3b78c5}.fx-heal{color:#2f8f40}.battle-actor.fx-hit{transform:scale(.995);filter:saturate(1.2);box-shadow:0 0 0 2px #d0432a38 inset}.battle-actor.fx-crit{transform:scale(1.015);filter:saturate(1.35);box-shadow:0 0 0 2px #ff8e1a47 inset}.battle-actor.fx-dodge{transform:scale(.995);box-shadow:0 0 0 2px #3b78c538 inset}.battle-actor.fx-heal{transform:scale(1.02);box-shadow:0 0 0 2px #2f8f4047 inset}@keyframes floatUpFade{0%{opacity:0;transform:translate(-50%,6px) scale(.95)}20%{opacity:1;transform:translate(-50%,-2px) scale(1)}to{opacity:0;transform:translate(-50%,-28px) scale(1.05)}}@keyframes resultSparkle{0%{transform:translateY(-8%)}to{transform:translateY(18%)}}@keyframes resultSmoke{0%{transform:translate(-6%)}to{transform:translate(6%)}}@keyframes dropReveal{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.arena-center{display:grid;gap:6px;justify-items:center;text-align:center}.arena-center p{margin:0;min-height:24px;max-width:220px;display:grid;place-items:center}.arena-timer{min-width:74px;text-align:center;border:1px solid #6e5f40;border-radius:999px;padding:4px 10px;background:linear-gradient(180deg,#2a1e11,#5f4624);color:#f2e8d2;font-size:18px;font-weight:700}.battle-wheel{display:grid;grid-template-columns:1fr auto 1fr;grid-template-rows:auto auto auto;gap:8px;align-items:center;justify-items:center;margin:2px 0 4px;min-width:340px;border:1px dashed #7f876c;border-radius:12px;padding:10px;background:#e9e3d2bf}.battle-wheel-center{margin:0}.wheel-btn{min-width:112px}.wheel-top{grid-column:2;grid-row:1}.wheel-left{grid-column:1;grid-row:2}.wheel-core{grid-column:2;grid-row:2;width:90px;height:90px;border-radius:50%;border:2px solid #6e5f40;background:radial-gradient(circle at 28% 25%,#f6e7bf,#b3864b 70%),linear-gradient(180deg,#593f22,#7f5b2f);color:#2e1d0c;display:grid;place-items:center;text-align:center}.wheel-core small{font-size:11px}.wheel-right{grid-column:3;grid-row:2}.wheel-bottom{grid-column:2;grid-row:3}.consumable-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;margin-bottom:10px}.battle-bottom{display:grid;grid-template-columns:1fr 1fr;gap:12px;border-top:1px dashed #8a8f79;padding-top:8px}.battle-extra{border:1px dashed #8a8f79;border-radius:8px;background:#f8f5ebb8;padding:6px 8px}.battle-extra>summary{cursor:pointer;font-weight:700;list-style:none}.battle-extra>summary::-webkit-details-marker{display:none}.battle-extra>summary:before{content:"▸ "}.battle-extra[open]>summary:before{content:"▾ "}.battle-extra-body{padding-top:6px}.consumable-card{text-align:left;display:grid;gap:2px;padding:8px}.consumable-card.selected{border-color:#345b34;box-shadow:0 0 0 2px #497a4940 inset;background:#d5e5cc}.consumable-name{font-weight:700}.shop-category-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.shop-category-tabs button.active{background:#b8d0ad;font-weight:700}.shop-slot-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.shop-slot-tabs button.active{background:#b8d0ad;font-weight:700}.shop-table-scroll{flex:1;min-height:0;overflow:auto;border:1px dashed #8a8f79;border-radius:8px;padding:2px 4px}.shop-layout{min-height:0;height:calc(100dvh - 96px);grid-template-rows:minmax(0,1fr)}.shop-layout>div{min-height:0}.shop-layout .panel{display:flex;flex-direction:column;min-height:0}.shop-layout .panel-content{min-height:0;overflow:auto}.game-table{width:100%;border-collapse:collapse}.game-table th,.game-table td{text-align:left;padding:5px 6px 5px 0;vertical-align:top}.game-table thead th{border-bottom:1px dashed #8a8f79;padding-bottom:6px}.table-sort-button{border:0;background:transparent;padding:0;border-radius:0;color:inherit;cursor:pointer}.table-sort-button:hover{text-decoration:underline}.shop-action-cell{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.shop-action-cell input{width:70px;padding:6px}.inventory-layout{min-height:0;height:calc(100dvh - 96px);grid-template-rows:minmax(0,1fr) auto}.inventory-layout>div{min-height:0}.inventory-layout .panel{min-height:0}.inventory-table-scroll{max-height:calc(100dvh - 260px);overflow:auto;border:1px dashed #8a8f79;border-radius:8px;padding:2px 4px}.item-card-header{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:38px;margin-bottom:8px}.item-card-title{margin:0;font-weight:700}.item-card-header>span{min-width:0;flex:1}.item-card-header button{margin-left:auto}.item-card-visual{width:220px;height:220px;min-height:220px;margin:0}.item-image{display:inline-flex;align-items:center;justify-content:center;border:1px solid #7f876c;border-radius:8px;background:#e1e6d361;overflow:hidden}.item-image img{width:100%;height:100%;object-fit:contain;display:block}.item-image-fallback{opacity:.65;font-weight:700;letter-spacing:1px}.item-image-tiny{width:30px;height:30px}.item-image-slot{width:52px;height:52px;border-radius:10px}.item-image-card{width:220px;height:220px;border-radius:10px;background:radial-gradient(circle at 24% 20%,rgba(255,255,255,.45),transparent 40%),#d8ddc466}.item-name-cell{display:inline-flex;align-items:center;gap:8px}.item-icon-trigger{border:0;padding:0;margin:0;background:transparent;line-height:0;border-radius:0}.item-icon-trigger:focus-visible{outline:1px dashed #4a6650;outline-offset:2px}.item-hover-popup{position:fixed;z-index:110;width:320px;padding:8px;border:1px solid #7f876c;border-radius:10px;background:#fcfaf3fa;box-shadow:0 8px 24px #27382a38;pointer-events:none}.item-hover-header{display:grid;grid-template-columns:auto 1fr;gap:8px;align-items:center}.item-hover-header p{margin:2px 0 0;opacity:.8}.item-hover-text{margin:8px 0 0;font-size:12px;line-height:1.35}.item-hover-bonuses{margin:6px 0 0;padding-left:16px;font-size:12px;line-height:1.3}.character-hover-trigger{border:0;padding:0;margin:0;background:transparent;color:inherit;text-decoration:underline dotted;text-underline-offset:2px}.character-hover-trigger:hover{color:#2f5d2f}.character-hover-popup{position:fixed;z-index:120;width:380px;padding:8px;border:1px solid #7f876c;border-radius:10px;background:#fcfaf3fa;box-shadow:0 8px 24px #27382a38;pointer-events:none}.character-hover-head{display:flex;align-items:center;gap:10px;margin-bottom:8px}.character-hover-paperdoll .paperdoll-grid{max-width:100%}.character-hover-paperdoll .paperdoll-wrap{gap:0}.mob-drops-modal{width:min(920px,calc(100vw - 40px))}.mob-drops-head{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:center}.mob-drops-head p{margin:3px 0}.mob-drops-mob-icon{width:96px;height:96px;border:1px solid #7f876c;border-radius:10px;object-fit:cover;background:#d8ddc43d}.mob-drops-table-scroll{max-height:360px;overflow:auto;border:1px dashed #8a8f79;border-radius:8px;padding:4px}.item-modal-overlay{position:fixed;inset:0;z-index:100;background:#1215111a;display:grid;place-items:center;padding:20px}.item-modal-window{width:min(980px,calc(100vw - 40px));max-height:calc(100dvh - 40px);height:auto;overflow:auto}.item-modal-window.panel{height:auto}.item-card-split{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:start}.item-card-text>:first-child{margin-top:0}.item-card-side{display:flex;justify-content:flex-end}.paperdoll-wrap{display:grid;gap:8px}.paperdoll-title{margin:0}.paperdoll-grid{position:relative;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-template-rows:repeat(4,auto);gap:8px;max-width:440px;padding:10px;border:1px dashed #8a8f79;border-radius:10px;background:#ece8d866}.paperdoll-hero{grid-column:2;grid-row:3;align-self:center;justify-self:center;border:1px dashed #7f876c;border-radius:10px;padding:6px 12px;background:#d2d9c059;z-index:0}.paperdoll-hero pre{margin:0;font-size:16px;line-height:1.1}.paperdoll-slot{display:grid;justify-items:center;gap:4px;min-height:86px;padding:6px;border:1px solid #7f876c;border-radius:10px;background:#faf7eed9;z-index:1;cursor:default}.paperdoll-empty{width:52px;height:52px;display:grid;place-items:center;border:1px solid #8a8f79;border-radius:10px;background:#d8ddc43d;opacity:.75}.paperdoll-slot-name{font-size:12px}.paperdoll-slot-helmet{grid-column:2;grid-row:1}.paperdoll-slot-weapon{grid-column:1;grid-row:2}.paperdoll-slot-armor{grid-column:2;grid-row:2}.paperdoll-slot-amulet{grid-column:3;grid-row:2}.paperdoll-slot-gloves{grid-column:1;grid-row:3}.paperdoll-slot-ring{grid-column:3;grid-row:3}.paperdoll-slot-boots{grid-column:2;grid-row:4}.paperdoll-grid-compact{width:100%;max-width:320px;padding:8px;gap:6px}.paperdoll-grid-compact .paperdoll-slot{min-height:68px;padding:4px;gap:2px}.paperdoll-grid-compact .paperdoll-slot-name{font-size:10px}.paperdoll-grid-compact .paperdoll-hero{padding:4px 10px}.paperdoll-grid-compact .paperdoll-hero pre{font-size:14px}@media(max-width:1024px){.corner-layout{grid-template-columns:1fr;min-height:auto}.app-nav{flex-wrap:wrap}.nav-right{width:100%;justify-content:space-between}.header-stats{min-width:0;flex-wrap:wrap}.battle-bottom{grid-template-columns:1fr}.battle-scene{grid-template-columns:1fr;justify-items:center}.battle-wheel{min-width:0;width:100%}.reward-grid,.item-card-split{grid-template-columns:1fr}.inventory-layout{height:auto;grid-template-rows:none}.inventory-table-scroll{max-height:none}}@media(max-width:768px){.app-main,.panel{padding:8px}.app-nav{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"logo logout" "stats stats" "tabs tabs";gap:8px;padding:8px;align-items:flex-start}.logo{grid-area:logo;font-size:13px}.nav-links{grid-area:tabs;width:100%;overflow-x:auto;white-space:nowrap;flex-wrap:nowrap;padding-bottom:2px}.nav-links a{flex:0 0 auto}.nav-right{display:contents}.nav-right>.ghost-button{grid-area:logout;margin-left:0;padding:4px 8px;font-size:12px}.header-stats{grid-area:stats;flex:1 1 100%;min-width:0;padding:4px 6px;gap:6px}.header-stats-meta{gap:8px;font-size:11px;flex-wrap:wrap}.header-stats-meta span{line-height:1.2}.header-bars{width:100%;min-width:0;display:flex;gap:6px;flex-wrap:nowrap}.header-bar-row{min-width:0;width:auto;flex:1 1 0;justify-content:flex-start}.header-bar-row span{font-size:11px;white-space:nowrap}.header-bar{width:auto;flex:1 1 auto;max-width:none;min-width:34px}.header-gold{font-size:11px}.nav-links .battle-tab-link{display:none}.battle-page,.pvp-battle-page{height:calc(100dvh - 146px);min-height:0;overflow:hidden}.battle-page .panel,.pvp-battle-page .panel{height:100%;min-height:0;display:flex;flex-direction:column}.battle-page .panel-content,.pvp-battle-page .panel-content{min-height:0;flex:1;display:flex;flex-direction:column;overflow:hidden}.battle-page .battle-screen,.pvp-battle-page .battle-screen{min-height:0;flex:1;display:flex;flex-direction:column;gap:8px}.world-graph-stage{aspect-ratio:1 / 1}.world-node-card{width:94px;padding:3px;border-radius:8px}.world-node-thumb{width:46px;height:46px;border-radius:8px}.world-node-name{font-size:9px;min-height:20px}.location-pvp-banner{padding:8px;gap:8px}.duel-board{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;padding:5px 6px}.duel-vs{display:none}.battle-bar{height:15px}.battle-bar span{font-size:10px}.duel-side{display:grid;gap:3px;align-items:start;min-width:0}.duel-side .duel-name,.duel-side strong{width:100%;margin:0;font-size:12px;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.duel-side .battle-bar{width:100%;min-width:0}.battle-page .battle-scene,.pvp-battle-page .battle-scene{flex:1;min-height:0;overflow:hidden;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);grid-template-rows:minmax(0,1fr) auto;grid-template-areas:"player enemy" "controls controls";align-items:stretch;gap:6px;padding:6px}.battle-page .battle-scene>.fighter-wrap-player,.pvp-battle-page .battle-scene>.fighter-wrap-player{grid-area:player}.battle-page .battle-scene>.fighter-wrap-enemy,.pvp-battle-page .battle-scene>.fighter-wrap-enemy{grid-area:enemy}.battle-page .battle-scene>.arena-controls,.pvp-battle-page .battle-scene>.arena-controls{grid-area:controls;align-self:stretch;position:static;width:100%;border:1px dashed #8a8f79;border-radius:10px;background:#f3eee0f5;padding:3px 5px 5px;position:relative}.fighter-wrap{min-height:0;width:100%}.battle-page .battle-actor,.pvp-battle-page .battle-actor{height:100%;min-height:0;padding:4px;gap:4px}.battle-page .battle-actor-head,.pvp-battle-page .battle-actor-head{display:none}.battle-monster-image,.battle-monster-fallback{width:clamp(126px,34vw,190px)}.battle-page .battle-paperdoll .paperdoll-grid-compact,.pvp-battle-page .battle-paperdoll .paperdoll-grid-compact{max-width:clamp(148px,36vw,210px);width:100%;padding:4px;gap:3px}.battle-page .battle-paperdoll .paperdoll-grid-compact .paperdoll-slot,.pvp-battle-page .battle-paperdoll .paperdoll-grid-compact .paperdoll-slot{min-height:38px;padding:2px;gap:1px}.battle-page .battle-paperdoll .paperdoll-grid-compact .paperdoll-slot-name,.pvp-battle-page .battle-paperdoll .paperdoll-grid-compact .paperdoll-slot-name{font-size:8px}.battle-page .battle-paperdoll .paperdoll-grid-compact .paperdoll-hero pre,.pvp-battle-page .battle-paperdoll .paperdoll-grid-compact .paperdoll-hero pre{font-size:10px}.battle-page .battle-paperdoll .item-image-slot,.pvp-battle-page .battle-paperdoll .item-image-slot,.battle-page .battle-paperdoll .paperdoll-empty,.pvp-battle-page .battle-paperdoll .paperdoll-empty{width:28px;height:28px}.battle-wheel{min-width:0;width:100%;max-width:248px;gap:3px;padding:3px}.wheel-btn{min-width:64px;min-height:30px;padding:3px 6px;font-size:11px}.wheel-core{width:50px;height:50px;font-size:10px}.arena-timer{font-size:12px;min-width:48px;padding:2px 6px}.arena-center p{max-width:none;min-height:12px;font-size:10px;line-height:1.2;margin:0}.pvp-battle-page .arena-center p:last-child{display:none}.battle-page .battle-bottom,.pvp-battle-page .battle-bottom{max-height:19dvh;overflow:auto;gap:6px;padding-top:4px;padding-bottom:0}.battle-page .battle-surrender-btn,.pvp-battle-page .battle-surrender-btn{position:absolute;top:4px;left:6px;width:auto;min-height:0;padding:2px 6px;font-size:10px;line-height:1.1;border-radius:999px;z-index:1}.battle-page .battle-extra,.pvp-battle-page .battle-extra{padding:5px 6px}.battle-page .battle-extra>summary,.pvp-battle-page .battle-extra>summary{font-size:12px}.battle-page .battle-extra-body,.pvp-battle-page .battle-extra-body{padding-top:5px}.battle-page .log-list,.pvp-battle-page .mono-list{max-height:15dvh;overflow:auto}.battle-page .consumable-grid{grid-template-columns:repeat(auto-fill,minmax(132px,1fr));gap:5px;margin-bottom:6px}.battle-page .consumable-card{padding:5px 6px;gap:1px;font-size:11px;line-height:1.15}.battle-page .consumable-name{font-size:11px;line-height:1.1}.battle-page .battle-extra-consumables .battle-extra-body{max-height:15dvh;overflow:auto;display:grid;gap:4px;padding-bottom:3px}.battle-page .battle-extra-consumables .battle-extra-body>button:last-child{position:sticky;bottom:0;z-index:2;width:100%;min-height:32px;padding:4px 6px;font-size:11px;background:#c4d3b5;box-shadow:0 -2px #f8f5ebe6}.drop-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.reward-tile strong{font-size:20px}.result-banner-image{max-height:200px}.inventory-layout,.shop-layout{height:auto;grid-template-rows:none}.inventory-layout .panel-content,.shop-layout .panel-content{overflow:auto}.inventory-table-scroll,.shop-table-scroll,.mob-drops-table-scroll{max-height:46dvh}.inventory-items-table{table-layout:fixed}.inventory-items-table th,.inventory-items-table td{word-break:break-word}.inventory-items-table th:nth-child(1),.inventory-items-table td:nth-child(1){width:58px}.inventory-items-table th:nth-child(2),.inventory-items-table td:nth-child(2){width:88px}.shop-layout .game-table{table-layout:fixed}.shop-layout .game-table th,.shop-layout .game-table td{word-break:break-word}.item-name-cell{display:flex;min-width:0}.item-name-cell>span{min-width:0;overflow-wrap:anywhere}.shop-table-scroll{overflow-x:hidden}.shop-buy-table th:nth-child(1),.shop-buy-table td:nth-child(1),.shop-buy-table th:nth-child(3),.shop-buy-table td:nth-child(3){display:none}.shop-sell-table th:nth-child(2),.shop-sell-table td:nth-child(2){display:none}.item-modal-overlay{padding:8px}.item-modal-window{width:calc(100vw - 16px);max-height:calc(100dvh - 16px)}.item-card-visual{width:156px;height:156px;min-height:156px;margin:0 auto}.item-image-card{width:156px;height:156px}.item-card-side{justify-content:center}.character-hover-popup{width:min(360px,calc(100vw - 16px))}.mob-drops-modal{width:calc(100vw - 16px)}.mob-drops-head{grid-template-columns:1fr}.mob-drops-mob-icon{width:80px;height:80px}.auth-logo{width:140px;height:140px}.auth-panel h1{font-size:20px}}@media(max-width:640px){.app-nav{padding:6px}.logo{gap:4px}.logo-icon{height:1.5em}.nav-right>.ghost-button{margin-left:0}.header-bar{width:34vw;max-width:110px}.world-node-card{width:82px}.world-node-thumb{width:40px;height:40px}.battle-scene{padding:8px}.fighter-wrap{min-height:210px}.paperdoll-grid-compact{max-width:270px}.paperdoll-grid-compact .paperdoll-slot{min-height:58px}.paperdoll-grid-compact .paperdoll-hero pre{font-size:11px}.battle-bottom{gap:8px}.consumable-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.item-hover-popup{width:min(300px,calc(100vw - 16px))}.shop-slot-tabs{overflow-x:visible;white-space:normal;flex-wrap:wrap;padding-bottom:0;gap:6px}.shop-slot-tabs button{flex:0 1 auto;padding:4px 8px;font-size:12px}.game-table th,.game-table td{padding:4px 4px 4px 0;font-size:13px}}@media(max-width:768px)and (max-height:740px){.battle-page,.pvp-battle-page{height:calc(100dvh - 134px)}.battle-page .duel-name,.pvp-battle-page .duel-name{font-size:13px}.battle-page .battle-bar,.pvp-battle-page .battle-bar{height:14px}.battle-page .battle-scene,.pvp-battle-page .battle-scene{gap:4px;padding:4px}.battle-page .battle-actor,.pvp-battle-page .battle-actor{padding:3px}.battle-page .battle-paperdoll .paperdoll-grid-compact,.pvp-battle-page .battle-paperdoll .paperdoll-grid-compact{max-width:clamp(132px,34vw,180px)}.battle-page .battle-paperdoll .item-image-slot,.pvp-battle-page .battle-paperdoll .item-image-slot,.battle-page .battle-paperdoll .paperdoll-empty,.pvp-battle-page .battle-paperdoll .paperdoll-empty{width:22px;height:22px}.battle-page .battle-monster-image,.battle-page .battle-monster-fallback{width:clamp(110px,30vw,160px);height:auto}.battle-page .battle-wheel,.pvp-battle-page .battle-wheel{max-width:224px}.battle-page .wheel-core,.pvp-battle-page .wheel-core{width:46px;height:46px}.battle-page .wheel-btn,.pvp-battle-page .wheel-btn{min-width:58px;min-height:31px;font-size:10px}.battle-page .battle-bottom,.pvp-battle-page .battle-bottom{max-height:15dvh}}@media(max-width:480px){.app-main{padding:6px}.panel h2{font-size:14px}.nav-links a{padding:4px 6px;font-size:12px}.header-stats-meta,.header-gold,.header-bar-row span{font-size:10px}.duel-name{font-size:14px}.battle-page .battle-wheel,.pvp-battle-page .battle-wheel{max-width:228px;padding:4px;gap:4px}.battle-page .wheel-btn,.pvp-battle-page .wheel-btn{min-width:60px;min-height:31px;font-size:10px;padding:4px 6px}.battle-page .wheel-core,.pvp-battle-page .wheel-core{width:50px;height:50px;font-size:9px}.battle-page .arena-center p,.pvp-battle-page .arena-center p{font-size:10px;min-height:12px}.drop-grid,.consumable-grid{grid-template-columns:1fr}.battle-page .battle-extra-consumables .battle-extra-body{max-height:17dvh}.battle-page .consumable-card{font-size:10px}.battle-page .battle-extra-consumables .battle-extra-body>button:last-child{min-height:30px;font-size:10px;padding:3px 6px}.result-banner-image{max-height:160px}.auth-logo{width:120px;height:120px}.auth-panel h1{font-size:18px}}@media(hover:none),(pointer:coarse){.item-hover-popup,.character-hover-popup{display:none}}
