.chess-piece{aspect-ratio:1;object-fit:contain;cursor:pointer;user-select:none;z-index:3;filter:drop-shadow(2px 2px 3px #0006);will-change:transform;backface-visibility:hidden;width:90%;position:relative}.chess-piece:active{transform:scale(.95)}@media (width<=768px){.chess-piece{width:102%}}@media (width<=480px){.chess-piece{width:96%}}@media (hover:hover){.chess-piece:hover{transform:scale(1.08)}}.chess-board-container{flex-direction:column;justify-content:center;align-items:center;max-width:100%;display:flex}.chess-board{--board-height:calc(100dvh - 160px);--board-width:calc(var(--board-height) * 9 / 12);width:min(95vw, var(--board-width), 600px);aspect-ratio:9/12;touch-action:manipulation;box-sizing:border-box;background:url(/board.svg) 50%/contain no-repeat;border:3px solid #8b4513;border-radius:6px;flex-shrink:0;position:relative;overflow:hidden;box-shadow:0 8px 20px #0000004d}.hint-arrow-canvas{pointer-events:none;z-index:5;width:100%;height:100%;position:absolute;top:0;left:0}@media (orientation:landscape){.chess-board{width:min(70vw,60vh,440px)}}.chess-board-lines{pointer-events:none;z-index:0;background-position:50%;background-repeat:no-repeat;background-size:contain;width:100%;height:100%;position:absolute;top:0;left:0}.chess-square{cursor:pointer;user-select:none;-webkit-tap-highlight-color:transparent;border:none;outline:none;justify-content:center;align-items:center;display:flex;position:absolute;box-shadow:none!important;background:0 0!important}.chess-square:hover,.chess-square:active,.chess-square.valid-move{box-shadow:none!important;background:0 0!important}.chess-square.selected{box-shadow:none!important;background:url(data:image/webp;base64,UklGRv4EAABXRUJQVlA4WAoAAAAQAAAA/wAA/wAAQUxQSDkCAAABkGNt2/JEXxdPfoGKcZeduHufitRkWrR3h8q7mQ24legS3N3hOSfyvR/6jH8RAYeRJEVSlHV8zwzpqt8Ti94q7e2f3Ibxqk4qVTDf9mR/X+nt2EFJJN/nXfaktp+LfkgmDsCFpjUApABYa7q4T071NkANsF3t7MeTcYAeYPyJsWANQBFQGzTjfQNN+OaZKBoBURgpkvmDoAqDviTwA2ThR0BQD7pQL9wqCIP2Rp1xysYdjWrIFtpfX08oHktce92+AHk1+c5uiaZTYcVn4dSU/C74uTx1kHS7itPcbtOLeGuCvRLFayV70kehXo5iCNKK2dIQlsrxUTpVcVu34FPO4R29KY8cd0pvx8u4Jz4rslsK+t3PKNdbDNETWtArz3ir16H4rV3vXcag3iuCXukNZUzq3STopt5oxoZenKC43lIG9BS9yY9n679/A1Xpx4/B45n+rP+s/6z/rP+s/6z/rP+s/6z//iLE///u4v9/p1n//QcA4+6UmNCdwr87hn53zjD/7qCfgu6k+2S7o4ql7iiT7iyXXXfWpEF3lvoE/brI6ZK6w/h3p9HvjvNNoxs7C0gp6DRObzy3DWnzbyh1B6bnzbsDVY1Rd+Krq0w+BolffWXUnVir646coNwdOeEozZ5S9vSnojtUBQl3pwaVsEK63bGF9Ltz+XcHGy1YR1N9kH539D7m1GzRs1XjqP3tXP0GNRv159T+5yQ/0+pO/5x0DuxrE3fK+vqndonYnRroK7sTUz8jUwBWUDggngIAAHAjAJ0BKgABAAE+MRaKQyIhIRS0LCADBLK3cLqogavf8B+I22ddo/jH6ofgBWb/Nt9v+0/30/3b7APpnts/MB+nv8w/gHu5/5f+O9IB1wHoAfwD+QelV+oHwlft96On//zgD+AfQB+fvf4IPqyevxOTc2hW6VyJulUnJs1MKv6QDIMOreGl5o2qocCvLbuRhx5jO7u7u7u7uuzbCOBXlt3y8cCvLbvl439LMzMzMzMzLiru7u7u7u7suGZmZmZmZmVv3d3d3d3d3XLeqqqqqqqqe3mZmZmZmZmEzd3d3d3d3dTrMzMzMzMzLwqUbiUtmZmZmZmXNT/hq3ZDgV5bd8vHAry275eFvuRt3d3d3d3jYRGpO//WcXB+zRtVQ35QIg/S5AAA/fu95lynfUyVcG5I4/9NzZZ6uI0GxNpDUni7/+Sw//9E0+QhXpT0Zv070rWaT1IWimxtqTw9sm7wAyK0qNL1OSxPBNyfvbGa8OZHStpiAE+cAe2kNOMPRcWGHcQaXPQc58Qs/jho/rH8NrFADMceRlnSJpo5tBw/7aCf//onTlhzd20JAzd0N3bWrLHmJnR5q0APr5bXVbgc6AVYb2fdFO+1zLB5fr8bag1mFGgW6oAAAAAAAAAABcfQMitKjS9TksTxqd9TJQq2znYLMdATm+qTsP23LVxxZbryyVav8AeNyEjTcRzBFNFCXTlTim+KZBxTfFMg4pvimQcU3xTINx5OamIJMANsPIa0kwASSHlhWPKDfILJZxqasrR+69HRlmWN+due7+eviJcr/yWH//omnt8A/IyJ5hyLC1v1gh/7tyJ3QBVENkyABTsx26v8sRptPSkqcSkCZ3PUnwb4rWImdE4ZTcCQTX+cuIRWIiAKIu5n7iAAAAA=) 50%/contain no-repeat!important}.chess-square.selected .chess-piece{filter:none}.chess-square.last-move-from{box-shadow:none!important;background:url(data:image/webp;base64,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) 50%/contain no-repeat!important}.chess-square.last-move-to{box-shadow:none!important;background:url(data:image/webp;base64,UklGRg4DAABXRUJQVlA4WAoAAAAQAAAA/wAA/wAAQUxQSDoCAAABkGNt2/JEXxdPfoFKxn124u59KlKTaYEVuEPl3cwG3Eq0ToW7O885ke/90Gf8iwg4jCQpkqKs43tmSFf9nlj0VmXfwNQOjJc5rWRgvp2pgf7K27HDkki+L7jsae0gF/2QTByCC83rAEgBsN588YCcmh2AGmCnxjmIJxMAPcDEE2PBWoAioC5oxvsGmvDNM1EyCqIwWiLzh0AVhnxJ4AfIwo+AoAF0oUG4VRAG7Y06E5RNOBo1kC12vL6eUDyWuPa6YxHyagud3RbNpMKKz8Kpafld8HMF6iHpcRWnuT2mF/HWBfsVitcq9qWPQr085RCkFbOlISyV56N0quK2HsGnvMO7etMeOe603q6XdU98VmS3FPS7n1WttxSiJ7SoV531Vq9T8VuH3rusIb1XBL3SG86a0rtJ0E29saxNvThBcb3lLOgpepMfz9Z//wbK6MePweOZ/qz/rP+s/6z/rP+s/6z/rP+s//4ixP//7uL/f6dZ//0HAOPulJjQncK/O4Z+d84I/+6gn4LupPtku6PKpe4ok+4sl1131pRBd5b6BP26yemWusP4d6fR747zTaMbu4pIKeoyTm88twNpC28odQemF8y7A1WtUXfiq6tMPgaJX31l1J1Yp+uOnKTcHTnpKM2eUvb0p6I7VAUJd6cGlbBiut2xxfS7c/l3BxstWE9TQ5B+d/QB5tRu07Nd66iD7VzDJjWbDefUweckP9PqTv+cdA7taxN3qvoHpveI2Jse7K+6E1M/I1NWUDggrgAAANASAJ0BKgABAAE+MRiLRCIhoRH0ACADBLS3cLtYjaBpM5I9lf7YSARIRpM5M+/lebo4xZ5BNHGLm6OKmbeV5ujjFyf2A8tYxc3RQPLWMXN0cYcWP9K3v5XmwP83Rxi5ujds+/lebo4xZ5BNHGLm6OKmbeV5ujjFyf2A8tYxc3RQPLWMXN0cYcWP9K3v5XmwP83Rxi5ujds+/lebo4xZgAD+/+8CAAAAAAAAAAAAAA==) 50%/contain no-repeat!important}.chess-square.last-move-from:after,.chess-square.last-move-to:after{display:none}.move-indicator{z-index:2;pointer-events:none;background:#00800099;border-radius:50%;width:30%;height:30%;position:absolute}@media (width<=768px){.chess-board{border-width:3px;width:min(95vw,95vh,500px)}}@media (width<=480px){.chess-board{border-width:2px;width:min(98vw,98vh,400px)}.move-indicator{width:25%;height:25%}}.modal-overlay{backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--modal-bg,#1e1e3cf7);color:var(--modal-text,white);border:1px solid #80808033;border-radius:16px;width:min(90vw,360px);transition:background .3s;animation:.3s slideUp;box-shadow:0 20px 60px #0006}.modal-content.theme-modal,.modal-content.record-modal{width:min(90vw,420px)}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid var(--modal-border,#80808026);color:var(--modal-text,white);justify-content:space-between;align-items:center;padding:1rem 1.25rem;font-size:1.1rem;font-weight:700;display:flex}.modal-close{background:var(--modal-element-bg,#ffffff1a);width:32px;height:32px;color:var(--modal-text,white);cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.modal-body{touch-action:pan-y;flex-direction:column;gap:1.25rem;max-height:60vh;padding:1.25rem;display:flex;overflow-y:auto}.modal-section{flex-direction:column;gap:.75rem;display:flex}.modal-section-header{align-items:center;gap:.75rem;display:flex}.section-icon{background:var(--modal-element-bg,#ffffff26);border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;display:flex}.section-title-text{flex-direction:column;gap:.15rem;display:flex}.modal-section-title{color:var(--modal-text-dim,#1e1e3cd9);font-size:.95rem;font-weight:600}.modal-section-desc{color:var(--modal-text-secondary,#1e1e3c99);font-size:.75rem}.sound-toggle-row{gap:.75rem;display:flex}.sound-toggle-btn{border:2px solid var(--modal-border,#ffffff26);background:var(--modal-element-bg,#ffffff14);color:var(--modal-text-secondary,#1e1e3cb3);cursor:pointer;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.875rem 1rem;font-size:.9rem;transition:all .25s;display:flex}.sound-toggle-btn:hover{background:var(--modal-element-hover,#ffffff1f);border-color:var(--modal-border-hover,#ffffff40)}.sound-toggle-btn.active{color:var(--modal-text,white);background:#667eea66;border-color:#667eeacc}.toggle-icon{font-size:1.1rem}.toggle-label{font-weight:500}.color-options{gap:.75rem;display:flex}.color-option{border:2px solid var(--modal-border,#fff3);background:var(--modal-element-bg,#ffffff1a);color:var(--modal-text,white);cursor:pointer;border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:.5rem;padding:1rem;transition:all .2s;display:flex}.color-option:hover{background:var(--modal-element-hover,#ffffff26);border-color:var(--modal-border-hover,#ffffff4d)}.color-option.active{background:#ffd70033;border-color:#ffd700cc}.color-option.active.red{background:#d6303133;border-color:#d63031cc}.color-option.active.black{background:#2d34364d;border-color:#2d3436cc}.color-option span{font-size:.85rem;font-weight:500}.theme-grid{gap:.75rem;display:flex}.theme-card{border:2px solid var(--modal-border,#ffffff26);background:var(--modal-element-bg,#ffffff14);color:var(--modal-text,white);cursor:pointer;border-radius:14px;flex-direction:column;flex:1;align-items:center;gap:.6rem;padding:1rem .5rem;transition:all .25s;display:flex}.theme-card:hover{background:var(--modal-element-hover,#ffffff1f);border-color:var(--modal-border-hover,#ffffff40);transform:translateY(-2px)}.theme-card.active{background:#ffd70026;border-color:#ffd700e6;box-shadow:0 4px 20px #ffd70033}.theme-label{letter-spacing:.02em;font-size:.8rem;font-weight:500}.theme-preview{border:2px solid #ffffff4d;border-radius:50%;width:36px;height:36px}.piece-preview-group{gap:6px;display:flex}.piece-preview{border:2px solid #fff6;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;display:flex;box-shadow:0 2px 8px #0000004d}.piece-preview span{text-shadow:0 1px 2px #0000004d;font-size:14px;font-weight:700}.board-preview{border:2px solid #ffffff4d;border-radius:6px;width:48px;height:36px;position:relative;overflow:hidden;box-shadow:0 2px 8px #0003}.board-lines{background-image:linear-gradient(#8b5a2b66 1px,#0000 1px),linear-gradient(90deg,#8b5a2b66 1px,#0000 1px);background-size:8px 8px;position:absolute;inset:0}.theme-preview.dihanglv{background:linear-gradient(145deg,#2d5a3d,#1a3d2a)}.theme-preview.hongmu{background:linear-gradient(145deg,#8b4513,#5d2f0d)}.theme-preview.hetianyu{background:linear-gradient(145deg,beige,#d4c8a8)}.theme-preview.board-brown{background:linear-gradient(145deg,#d4a574,#b8956a);border-radius:6px}.theme-preview.board-white{background:linear-gradient(145deg,#f5f5f5,#e8e8e8);border-radius:6px}.theme-preview.board-custom{background:linear-gradient(#a8c983 0%,#a0c17a 50%,#97b872 100%);border-radius:6px}.page-theme-grid{grid-template-columns:repeat(3,1fr);gap:.75rem;display:grid}.page-theme-card{border:2px solid var(--modal-border,#ffffff26);background:var(--modal-element-bg,#ffffff14);color:var(--modal-text,white);cursor:pointer;border-radius:12px;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem .5rem;transition:all .25s;display:flex}.page-theme-card:hover{background:var(--modal-element-hover,#ffffff1f);border-color:var(--modal-border-hover,#ffffff40);transform:translateY(-2px)}.page-theme-card.active{background:#ffd70026;border-color:#ffd700e6;box-shadow:0 4px 20px #ffd70033}.page-theme-card .theme-label{font-size:.75rem;font-weight:500}.page-theme-preview{border:1px solid #fff3;border-radius:8px;width:100%;height:36px;box-shadow:0 2px 8px #00000026}.custom-board-section{background:var(--modal-element-bg,#00000026);border-radius:12px;flex-direction:column;gap:1rem;margin-top:1rem;padding:1rem;display:flex}.custom-section-title{color:var(--modal-text-dim,#1e1e3cd9);border-bottom:1px solid var(--modal-border,#ffffff1a);padding-bottom:.5rem;font-size:.8rem;font-weight:600}.preset-colors-grid{grid-template-columns:repeat(4,1fr);gap:.75rem;display:grid}.preset-color-card{border:2px solid var(--modal-border,#fff3);cursor:pointer;border-radius:10px;justify-content:center;align-items:flex-end;height:48px;padding-bottom:4px;transition:all .25s;display:flex;position:relative;overflow:hidden}.preset-color-card:before{content:"";opacity:0;background:#0000004d;transition:opacity .2s;position:absolute;inset:0}.preset-color-card:hover{border-color:var(--modal-border-hover,#ffffff80);transform:translateY(-3px);box-shadow:0 6px 16px #0000004d}.preset-color-card:hover:before{opacity:1}.preset-name{z-index:1;color:#000c;text-shadow:0 1px 2px #ffffff80;font-size:.65rem;font-weight:500;position:relative}.color-pickers-row{justify-content:center;gap:1rem;display:flex}.color-preview{border:2px solid #ffffff4d;border-radius:10px;width:40px;height:40px;box-shadow:0 2px 8px #0003}.color-picker-item label{color:var(--modal-text-dim,#1e1e3ccc);font-size:.75rem;font-weight:500}.custom-preview{flex-direction:column;gap:.5rem;display:flex}.custom-preview-label{color:var(--modal-text-secondary,#1e1e3cb3);text-align:center;font-size:.75rem}.custom-preview-board{border:2px solid #ffffff4d;border-radius:8px;width:100%;height:60px;position:relative;overflow:hidden;box-shadow:0 2px 12px #0003}.preview-board-lines{background-image:linear-gradient(#8b5a2b4d 1px,#0000 1px),linear-gradient(90deg,#8b5a2b4d 1px,#0000 1px);background-size:12px 12px;position:absolute;inset:0}.ai-slider-container{flex-direction:column;gap:.5rem;display:flex}.ai-slider{appearance:none;background:var(--modal-element-bg,#fff3);cursor:pointer;border-radius:4px;outline:none;width:100%;height:8px}.ai-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:linear-gradient(145deg,#74b9ff,#0984e3);border-radius:50%;width:24px;height:24px;transition:transform .2s;box-shadow:0 2px 8px #0000004d}.ai-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.ai-slider::-moz-range-thumb{cursor:pointer;background:linear-gradient(145deg,#74b9ff,#0984e3);border:none;border-radius:50%;width:24px;height:24px;box-shadow:0 2px 8px #0000004d}.ai-slider-marks{color:var(--modal-text-secondary,#1e1e3cb3);justify-content:space-between;font-size:.8rem;display:flex}.modal-footer{border-top:1px solid var(--modal-border,#ffffff1a);justify-content:center;padding:1rem 1.25rem;display:flex}.modal-btn.confirm{color:var(--modal-text,white);background:linear-gradient(145deg,#55efc4,#00b894);box-shadow:0 4px 12px #00b8944d}.modal-btn.confirm:hover{transform:translateY(-2px);box-shadow:0 6px 16px #00b89466}.modal-btn.confirm:active{transform:translateY(0)}.record-actions{gap:.75rem;display:flex}.record-action-btn{cursor:pointer;border:none;border-radius:10px;flex:1;padding:.75rem;font-size:.9rem;font-weight:600;transition:all .2s}.record-action-btn.save{color:var(--modal-text,white);background:linear-gradient(145deg,#55efc4,#00b894)}.record-action-btn:disabled{opacity:.5;cursor:not-allowed}.records-list{flex-direction:column;gap:.5rem;display:flex}.records-list-header{color:var(--modal-text-dim,#1e1e3ccc);border-bottom:1px solid var(--modal-border,#ffffff1a);padding-bottom:.5rem;font-size:.85rem;font-weight:600}.records-list-content{touch-action:pan-y;flex-direction:column;gap:.5rem;max-height:200px;display:flex;overflow-y:auto}.no-records{text-align:center;color:var(--modal-text-secondary,#1e1e3c80);padding:1.5rem;font-size:.9rem}.record-item{background:var(--modal-element-bg,#ffffff1a);cursor:pointer;border:2px solid #0000;border-radius:10px;justify-content:space-between;align-items:center;padding:.75rem;transition:all .2s;display:flex}.record-item:hover{background:var(--modal-element-hover,#ffffff26)}.record-item.selected{background:#ffd70026;border-color:#ffd700cc}.record-item-info{flex-direction:column;gap:.25rem;display:flex}.record-item-name{color:var(--modal-text,white);font-size:.9rem;font-weight:600}.record-item-meta{color:var(--modal-text-secondary,#1e1e3c99);gap:.75rem;font-size:.75rem;display:flex}.record-item-actions{gap:.5rem;display:flex}.record-item-btn{background:var(--modal-element-bg,#ffffff1a);width:28px;height:28px;color:var(--modal-text,white);cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .2s;display:flex}.record-item-btn:hover{background:var(--modal-element-hover,#fff3)}.record-item-btn.delete:hover{background:#d6303180}.record-item-btn.replay{background:linear-gradient(145deg,#55efc4,#00b894)}.record-item-btn.replay:hover{box-shadow:0 2px 8px #00b89466}.record-detail{border-top:1px solid var(--modal-border,#ffffff1a);padding-top:.75rem}.record-detail-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.record-detail-header span{color:var(--modal-text,white);font-size:.95rem;font-weight:600}.replay-btn{color:var(--modal-text,white);cursor:pointer;background:linear-gradient(145deg,#74b9ff,#0984e3);border:none;border-radius:8px;padding:.5rem 1rem;font-size:.85rem;font-weight:600;transition:all .2s}.replay-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0984e34d}.moves-list{background:var(--modal-element-bg,#0003);touch-action:pan-y;border-radius:8px;flex-wrap:wrap;gap:.25rem;max-height:120px;padding:.5rem;display:flex;overflow-y:auto}.move-item{align-items:center;gap:.25rem;display:inline-flex}.move-number{color:var(--modal-text-secondary,#1e1e3c80);font-size:.75rem}.move-notation{border-radius:4px;padding:.125rem .25rem;font-size:.85rem}.move-notation.red{color:#ff6b6b}.move-notation.black{color:#ddd}.replay-panel{flex-direction:column;gap:1rem;display:flex}.replay-header{justify-content:space-between;align-items:center;display:flex}.replay-header span{color:var(--modal-text,white);font-size:1rem;font-weight:600}.stop-replay-btn{color:var(--modal-text,white);cursor:pointer;background:#d63031cc;border:none;border-radius:8px;padding:.5rem 1rem;font-size:.85rem;font-weight:600;transition:all .2s}.stop-replay-btn:hover{background:#d63031}.replay-progress{flex-direction:column;gap:.5rem;display:flex}.replay-progress span{color:var(--modal-text-dim,#1e1e3ccc);font-size:.85rem}.progress-bar{background:var(--modal-element-bg,#fff3);border-radius:3px;height:6px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#55efc4,#00b894);height:100%;transition:width .3s}.replay-controls{justify-content:center;gap:.5rem;display:flex}.replay-control-btn{background:var(--modal-element-bg,#ffffff26);width:44px;height:44px;color:var(--modal-text,white);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.replay-control-btn:hover:not(:disabled){background:var(--modal-element-hover,#ffffff40);transform:scale(1.05)}.replay-control-btn:disabled{opacity:.4;cursor:not-allowed}.replay-control-btn.play{background:linear-gradient(145deg,#55efc4,#00b894);width:52px;height:52px}.replay-control-btn.play:hover{box-shadow:0 4px 12px #00b89466}.speed-control{justify-content:center;align-items:center;gap:.75rem;display:flex}.speed-control span{color:var(--modal-text-secondary,#1e1e3cb3);font-size:.8rem}.speed-slider{appearance:none;background:var(--modal-element-bg,#fff3);cursor:pointer;border-radius:3px;outline:none;width:120px;height:6px}.speed-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#55efc4;border-radius:50%;width:16px;height:16px}.current-move{text-align:center;background:var(--modal-element-bg,#0003);border-radius:8px;padding:.75rem}.current-move-text{color:var(--modal-text,white);font-size:1.25rem;font-weight:700}@media (width<=480px){.modal-content{border-radius:12px;width:95vw}.modal-content.theme-modal,.modal-content.record-modal{width:95vw}.modal-header{color:var(--modal-text,white);padding:.875rem 1rem;font-size:1rem}.modal-body{gap:1rem;padding:1rem}.modal-section-header{gap:.5rem}.section-icon{width:30px;height:30px;font-size:.95rem}.modal-section-title{font-size:.85rem}.modal-section-desc{font-size:.7rem}.color-option{padding:.75rem}.color-option span{font-size:.8rem}.theme-card{padding:.75rem .25rem}.piece-preview{width:26px;height:26px}.piece-preview span{font-size:12px}.board-preview{width:40px;height:30px}.theme-label{font-size:.7rem}.page-theme-grid{gap:.5rem}.page-theme-card{padding:.5rem .25rem}.page-theme-preview{height:28px}.preset-colors-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.preset-color-card{height:40px}.color-preview{width:32px;height:32px}.custom-preview-board{height:50px}.modal-footer{padding:.875rem 1rem}.modal-btn{padding:.625rem 1.5rem;font-size:.9rem}.record-item{padding:.5rem}.record-item-name{font-size:.85rem}.record-item-meta{gap:.5rem;font-size:.7rem}.replay-control-btn{width:38px;height:38px}.replay-control-btn.play{width:44px;height:44px}}.edit-piece-selector{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}.edit-piece-btn{border:2px solid var(--modal-border,#fff3);background:var(--modal-element-bg,#ffffff1a);cursor:pointer;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;width:44px;height:44px;transition:all .2s;display:flex}.edit-piece-btn:hover{background:var(--modal-element-hover,#ffffff26);border-color:var(--modal-border-hover,#ffffff4d)}.edit-piece-btn.active{background:#ffd70033;border-color:#ffd700e6}.edit-piece-btn .piece-red{color:#ff6b6b;font-size:1rem;font-weight:700;line-height:1}.edit-piece-btn .piece-black{color:#ddd;font-size:1rem;font-weight:700;line-height:1}.edit-actions{gap:.75rem;display:flex}.edit-actions .modal-btn{flex:1}.fen-input-container{flex-direction:column;display:flex}.fen-input{border:2px solid var(--modal-border,#fff3);background:var(--modal-element-bg,#ffffff1a);width:100%;color:var(--modal-text,white);resize:none;border-radius:8px;padding:.75rem;font-family:monospace;font-size:.85rem}.edit-instructions{background:var(--modal-element-bg,#00000026);border-radius:8px;padding:.75rem}.edit-instructions p{color:var(--modal-text-secondary,#1e1e3cb3);margin-bottom:.35rem;font-size:.8rem;line-height:1.4}.edit-instructions p:last-child{margin-bottom:0}.fen-error{color:#ff7675;margin-top:.25rem;font-size:.8rem}.lobby-overlay{backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.lobby-modal{background:var(--modal-bg,linear-gradient(145deg, #667eeaf2, #764ba2f2));border-radius:16px;flex-direction:column;width:100%;max-width:420px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 20px 60px #0000004d}.lobby-header{border-bottom:1px solid var(--modal-border,#ffffff1a);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.lobby-header h2{color:var(--modal-text,white);margin:0;font-size:1.25rem}.lobby-close{background:var(--modal-element-bg,#ffffff1a);color:var(--modal-text,white);cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.5rem;transition:background .2s;display:flex}.lobby-close:hover{background:var(--modal-element-hover,#fff3)}.lobby-player-name{border-bottom:1px solid var(--modal-border,#ffffff1a);padding:1rem 1.25rem}.lobby-player-name label{color:var(--modal-text-dim,#fffc);margin-bottom:.5rem;font-size:.85rem;display:block}.lobby-player-name input{border:1px solid var(--modal-border,#fff3);background:var(--modal-element-bg,#ffffff1a);width:100%;color:var(--modal-text,white);box-sizing:border-box;border-radius:8px;padding:.75rem;font-size:16px}.lobby-player-name input::placeholder{color:var(--modal-text-secondary,#ffffff80)}.lobby-player-name input:focus{border-color:var(--modal-border-hover,#fff6);outline:none}.lobby-tabs{gap:.5rem;padding:.75rem 1.25rem;display:flex}.lobby-tab{background:var(--modal-element-bg,#ffffff1a);color:var(--modal-text-secondary,#ffffffb3);cursor:pointer;border:none;border-radius:8px;flex:1;padding:.75rem;font-size:.95rem;transition:all .2s}.lobby-tab.active{background:var(--modal-element-hover,#ffffff40);color:var(--modal-text,white);font-weight:600}.lobby-tab:hover:not(.active){background:var(--modal-element-hover,#ffffff26)}.lobby-content{touch-action:pan-y;flex:auto;min-height:0;padding:1rem 1.25rem;overflow-y:auto}.lobby-room-list{flex-direction:column;gap:.75rem;margin-bottom:1rem;display:flex}.lobby-empty{text-align:center;color:var(--modal-text-secondary,#fff9);padding:2rem}.lobby-empty p{margin:.25rem 0}.lobby-room-item{background:var(--modal-element-bg,#ffffff1a);border:1px solid var(--modal-border,#ffffff1a);border-radius:10px;justify-content:space-between;align-items:center;padding:.75rem;display:flex}.room-info{flex-direction:column;gap:.25rem;display:flex}.room-name{color:var(--modal-text,white);font-weight:600}.room-host{color:var(--modal-text-secondary,#fff9);font-size:.8rem}.join-btn{color:#fff;cursor:pointer;background:linear-gradient(145deg,#55efc4,#00b894);border:none;border-radius:6px;padding:.5rem 1rem;font-weight:600;transition:all .2s}.join-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #00b8944d}.join-btn:disabled{opacity:.6;cursor:not-allowed}.refresh-btn{border:1px solid var(--modal-border,#fff3);width:100%;color:var(--modal-text-dim,#fffc);cursor:pointer;background:0 0;border-radius:8px;padding:.75rem;transition:all .2s}.refresh-btn:hover{background:var(--modal-element-bg,#ffffff1a)}.create-room-form{flex-direction:column;gap:.75rem;margin-bottom:1.5rem;display:flex}.create-room-form label{color:var(--modal-text-dim,#fffc);font-size:.85rem}.create-room-form input{border:1px solid var(--modal-border,#fff3);background:var(--modal-element-bg,#ffffff1a);color:var(--modal-text,white);border-radius:8px;padding:.75rem;font-size:16px}.create-room-form input::placeholder{color:var(--modal-text-secondary,#ffffff80)}.create-room-form input:focus{border-color:var(--modal-border-hover,#fff6);outline:none}.create-btn{color:#fff;cursor:pointer;background:linear-gradient(145deg,#55efc4,#00b894);border:none;border-radius:8px;padding:.875rem;font-size:1rem;font-weight:600;transition:all .2s}.create-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #00b8944d}.create-btn:disabled{opacity:.6;cursor:not-allowed}.create-room-info{text-align:center;color:var(--modal-text-secondary,#fff9);font-size:.85rem}.create-room-info p{margin:.25rem 0}@media (width<=480px){.lobby-modal{max-height:90vh}.lobby-header{padding:.875rem 1rem}.lobby-header h2{font-size:1.1rem}.lobby-player-name,.lobby-tabs,.lobby-content{padding:.875rem 1rem}}.invite-panel{text-align:center;flex-direction:column;flex-shrink:0;align-items:center;padding:1rem 0;display:flex}.invite-icon{margin-bottom:.5rem;font-size:3rem}.invite-title{color:var(--modal-text,white);margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.invite-room-name{color:var(--modal-text-dim,#ffffffe6);margin-bottom:.25rem;font-size:1rem}.invite-desc{color:var(--modal-text-secondary,#fff9);margin-bottom:1rem;font-size:.85rem}.invite-url-box{box-sizing:border-box;width:100%;max-width:100%;margin-bottom:1rem;display:block}.invite-url-input{border:1px solid var(--modal-border,#ffffff26);color:#ffffffd9;box-sizing:border-box;text-overflow:ellipsis;appearance:none;background:#0003;border-radius:8px;outline:none;width:100%;min-height:36px;padding:.625rem .75rem;font-family:monospace;font-size:.8rem;transition:border-color .2s;display:block;opacity:1!important;visibility:visible!important}.invite-url-input:focus{border-color:var(--modal-border-hover,#fff6)}.invite-url-input::selection{background:#ffffff4d}.invite-actions{gap:.75rem;width:100%;margin-bottom:1rem;display:flex}.invite-btn{cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.75rem;font-size:.95rem;font-weight:600;transition:all .2s;display:flex}.invite-btn.primary{color:#fff;background:linear-gradient(145deg,#74b9ff,#0984e3)}.invite-btn.primary:hover{transform:translateY(-1px);box-shadow:0 4px 14px #0984e380}.invite-btn.primary:active{transform:scale(.98)}.invite-btn.secondary{background:var(--modal-element-bg,#ffffff26);color:var(--modal-text,white);border:1px solid var(--modal-border,#fff3)}.invite-btn.secondary:hover{background:var(--modal-element-hover,#ffffff40);border-color:var(--modal-border-hover,#ffffff59);transform:translateY(-1px)}.invite-btn.secondary:active{transform:scale(.98)}.invite-btn.secondary.copied{background:#00b8944d;border-color:#00b89480}.invite-btn-icon{font-size:1.1rem}.enter-room-btn{color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;background:linear-gradient(145deg,#55efc4,#00b894);border:none;border-radius:10px;width:100%;padding:.875rem;font-size:1rem;font-weight:600;transition:all .2s}.enter-room-btn:hover{transform:translateY(-1px);box-shadow:0 4px 14px #00b89473}.enter-room-btn:active{transform:scale(.98)}.link-join-section{margin-bottom:1rem}.link-join-label{color:var(--modal-text-dim,#fffc);margin-bottom:.5rem;font-size:.85rem;display:block}.link-join-row{gap:.5rem;display:flex}.link-join-input{border:1px solid var(--modal-border,#fff3);background:var(--modal-element-bg,#ffffff1a);color:var(--modal-text,white);box-sizing:border-box;border-radius:8px;flex:1;padding:.625rem .75rem;font-size:16px}.link-join-input::placeholder{color:var(--modal-text-secondary,#ffffff80)}.link-join-input:focus{border-color:var(--modal-border-hover,#fff6);outline:none}.link-join-btn{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(145deg,#74b9ff,#0984e3);border:none;border-radius:8px;padding:.625rem 1rem;font-size:.9rem;font-weight:600;transition:all .2s}.link-join-btn:disabled{opacity:.5;cursor:not-allowed}.lobby-divider{color:var(--modal-text-secondary,#ffffff80);align-items:center;margin:1rem 0;font-size:.8rem;display:flex}.lobby-divider:before,.lobby-divider:after{content:"";background:var(--modal-border,#fff3);flex:1;height:1px}.lobby-divider span{padding:0 .75rem}.game-controls{flex-direction:column;flex-shrink:0;gap:.4rem;width:min(95vw,75dvh - 120px,600px);display:flex}@media (orientation:landscape){.game-controls{width:min(70vw,60vh,440px)}}.toolbar{backdrop-filter:blur(10px);border:1px solid var(--modal-border,#ffffff1a);background:#00000026;border-radius:8px;justify-content:space-between;align-items:center;gap:.25rem;padding:.4rem;transition:background .3s;display:flex}.toolbar-btn{aspect-ratio:1;background:var(--modal-element-bg,#ffffff26);min-width:0;max-width:44px;color:var(--modal-text,white);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;transition:all .2s;display:flex}.toolbar-btn:hover{background:var(--modal-element-hover,#ffffff40);transform:translateY(-1px)}.toolbar-btn:active{transform:scale(.95)}.toolbar-btn.active{color:#000;background:#ffd70080;box-shadow:0 2px 8px #ffd7004d}.toolbar-btn.active.red{color:#fff;background:linear-gradient(145deg,#ff7676,#d63031);box-shadow:0 2px 8px #d630314d}.toolbar-btn.active.black{color:#fff;background:linear-gradient(145deg,#636e72,#2d3436);box-shadow:0 2px 8px #2d34364d}.toolbar-btn.undo:not(:disabled){color:#fff;background:linear-gradient(145deg,#a29bfe,#6c5ce7)}.toolbar-btn.undo:not(:disabled):hover{background:linear-gradient(145deg,#6c5ce7,#5a4bd1)}.toolbar-btn.undo:disabled{cursor:not-allowed;transform:none}.toolbar-btn.restart{background:linear-gradient(145deg,#74b9ff,#0984e3)}.toolbar-btn.restart:hover{background:linear-gradient(145deg,#0984e3,#0770c4)}.toolbar-btn.hint:not(:disabled){color:#fff;background:linear-gradient(145deg,#55efc4,#00b894)}.toolbar-btn.hint:not(:disabled):hover{background:linear-gradient(145deg,#00b894,#009874)}.toolbar-btn.hint:disabled{cursor:not-allowed}.toolbar-btn.hint.hinting{animation:1s ease-in-out infinite hintLoading}@keyframes hintLoading{0%,to{opacity:1}50%{opacity:.5}}.online-status{align-items:center;gap:.5rem;padding:0 .5rem;display:flex}.online-indicator{background:#55efc4;border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite onlinePulse}@keyframes onlinePulse{0%,to{box-shadow:0 0 #55efc466}50%{box-shadow:0 0 0 6px #55efc400}}.online-text{color:var(--modal-text-dim,#ffffffe6);font-size:.8rem;font-weight:500}.toolbar-btn.online{background:linear-gradient(145deg,#74b9ff,#0984e3)}.toolbar-btn.online:hover{background:linear-gradient(145deg,#0984e3,#0769b8)}.toolbar-btn.exit{background:linear-gradient(145deg,#fd79a8,#e84393)}.toolbar-btn.exit:hover{background:linear-gradient(145deg,#e84393,#c0392b)}.toolbar-btn.undo-online{background:linear-gradient(145deg,#a29bfe,#6c5ce7)}.toolbar-btn.undo-online:disabled{opacity:.4;cursor:not-allowed;transform:none}.toolbar-btn.undo-online:not(:disabled){background:linear-gradient(145deg,#a29bfe,#6c5ce7)}.toolbar-btn.undo-online:hover:not(:disabled){background:linear-gradient(145deg,#6c5ce7,#5a4bd1)}.toolbar-btn.surrender{color:#2d3436;background:linear-gradient(145deg,#ffeaa7,#fdcb6e)}.toolbar-btn.surrender:hover:not(:disabled){color:#fff;background:linear-gradient(145deg,#fdcb6e,#e17055)}.toolbar-btn.surrender:disabled{opacity:.5;cursor:not-allowed;transform:none}.toolbar-btn.chat{background:linear-gradient(145deg,#00cec9,#00b894);position:relative}.toolbar-btn.chat:hover{background:linear-gradient(145deg,#00b894,#009874)}.toolbar-btn.chat.active{background:linear-gradient(145deg,#fdcb6e,#e17055);box-shadow:0 0 10px #e1705580}.chat-unread-dot{background:#ff4757;border:2px solid #fff;border-radius:50%;width:10px;height:10px;animation:1.5s ease-in-out infinite pulse-dot;position:absolute;top:4px;right:4px}@keyframes pulse-dot{0%,to{transform:scale(1);box-shadow:0 0 #ff4757b3}50%{transform:scale(1.1);box-shadow:0 0 0 4px #ff475700}}.toolbar-divider{background:#fff3;flex-shrink:0;width:1px;height:24px}.online-dialog-overlay{backdrop-filter:blur(6px);z-index:2000;background:#000000a6;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.online-dialog{background:var(--modal-bg,linear-gradient(145deg, #1e1e3cf7, #141432f7));border:1px solid var(--modal-border,#ffffff26);box-shadow:0 24px 64px #0009, 0 0 0 1px var(--modal-element-bg,#ffffff0d) inset;border-radius:20px;flex-direction:column;align-items:center;gap:.85rem;width:min(88vw,340px);padding:2rem 1.75rem;animation:.3s cubic-bezier(.34,1.56,.64,1) dialogSlideUp;display:flex}@keyframes dialogSlideUp{0%{opacity:0;transform:translateY(30px)scale(.9)}to{opacity:1;transform:translateY(0)scale(1)}}.online-dialog-icon{filter:drop-shadow(0 4px 12px #0006);font-size:2.5rem;line-height:1}.online-dialog-icon.spinning{animation:1.5s ease-in-out infinite spinPulse}@keyframes spinPulse{0%,to{transform:scale(1)rotate(0)}50%{transform:scale(1.1)rotate(10deg)}}.online-dialog-title{color:var(--modal-text,white);text-align:center;letter-spacing:.02em;font-size:1.2rem;font-weight:700}.online-dialog-desc{color:var(--modal-text-secondary,#ffffffb3);text-align:center;font-size:.9rem;line-height:1.6}.online-dialog-desc .text-danger{color:#ff7675;font-weight:600}.online-dialog-desc strong{color:var(--modal-text-dim,#fffffff2)}.online-dialog-actions{gap:.75rem;width:100%;margin-top:.5rem;display:flex}.online-dialog-btn{cursor:pointer;letter-spacing:.02em;border:none;border-radius:12px;flex:1;padding:.7rem 1rem;font-size:.95rem;font-weight:600;transition:all .2s}.online-dialog-btn.cancel{background:var(--modal-element-bg,#ffffff1f);color:var(--modal-text-dim,#ffffffd9);border:1px solid var(--modal-border,#ffffff26)}.online-dialog-btn.cancel:hover{background:var(--modal-element-hover,#fff3);color:var(--modal-text,white)}.online-dialog-btn.danger{color:#fff;background:linear-gradient(145deg,#ff7675,#d63031);box-shadow:0 4px 16px #d6303166}.online-dialog-btn.danger:hover{background:linear-gradient(145deg,#d63031,#b71c1c);transform:translateY(-1px);box-shadow:0 6px 20px #d6303180}.online-dialog-btn.confirm{color:#fff;background:linear-gradient(145deg,#55efc4,#00b894);box-shadow:0 4px 16px #00b89466}.online-dialog-btn.confirm:hover{background:linear-gradient(145deg,#00b894,#009874);transform:translateY(-1px);box-shadow:0 6px 20px #00b89480}.online-dialog-btn:active{transform:scale(.97)!important}.panel{backdrop-filter:blur(10px);background:#00000040;border:1px solid #ffffff1a;border-radius:10px;animation:.2s slideDown;overflow:hidden}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.panel-header{color:#fff;background:#0003;justify-content:space-between;align-items:center;padding:.6rem .8rem;font-size:.9rem;font-weight:700;display:flex}.panel-close{color:#fff;cursor:pointer;background:#ffffff1a;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;transition:all .2s;display:flex}.panel-close:hover{background:#fff3}.panel-content{padding:.75rem}.theme-options{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}.theme-option{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:20px;padding:.5rem 1rem;font-size:.85rem;font-weight:700;transition:all .2s}.theme-option:hover{background:#ffffff40}.theme-option.active{background:linear-gradient(145deg,#a29bfe,#6c5ce7);box-shadow:0 2px 8px #6c5ce74d}.custom-colors{border-top:1px solid #ffffff1a;margin-top:.75rem;padding-top:.75rem}.preset-colors{justify-content:center;gap:.5rem;margin-bottom:.75rem;display:flex}.preset-color-btn{cursor:pointer;border:2px solid #ffffff4d;border-radius:8px;width:36px;height:36px;transition:all .2s}.preset-color-btn:hover{border-color:#fff9;transform:scale(1.1)}.color-pickers{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.color-picker-item{flex-direction:column;align-items:center;gap:.25rem;display:flex}.color-picker-item label{color:#ffffffb3;font-size:.75rem}.color-picker-item input[type=color]{cursor:pointer;background:0 0;border:none;border-radius:6px;width:40px;height:32px;padding:0}.color-picker-item input[type=color]::-webkit-color-swatch-wrapper{padding:0}.color-picker-item input[type=color]::-webkit-color-swatch{border:2px solid #ffffff4d;border-radius:6px}.ai-level-control{flex-direction:column;align-items:center;gap:.5rem;display:flex}.ai-level-value{color:#ffffffe6;font-size:.9rem;font-weight:700}.ai-level-slider{appearance:none;cursor:pointer;background:#fff3;border-radius:3px;outline:none;width:100%;max-width:200px;height:6px}.ai-level-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:linear-gradient(145deg,#74b9ff,#0984e3);border-radius:50%;width:20px;height:20px;transition:transform .2s;box-shadow:0 2px 6px #0000004d}.ai-level-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.ai-level-slider::-moz-range-thumb{cursor:pointer;background:linear-gradient(145deg,#74b9ff,#0984e3);border:none;border-radius:50%;width:20px;height:20px;box-shadow:0 2px 6px #0000004d}.ai-level-marks{color:#fff9;justify-content:space-between;width:100%;max-width:200px;font-size:.7rem;display:flex}@media (width<=768px){.game-controls{gap:.4rem;width:min(95vw,95vh,500px)}.toolbar{gap:.2rem;padding:.4rem}.toolbar-btn{max-width:40px}.toolbar-divider{height:20px}.panel-header{padding:.5rem .6rem;font-size:.85rem}.panel-content{padding:.6rem}.theme-option{padding:.4rem .8rem;font-size:.8rem}.preset-color-btn{width:32px;height:32px}}@media (width<=480px){.game-controls{gap:.3rem;width:min(98vw,98vh,400px)}.toolbar{gap:.15rem;padding:.35rem}.toolbar-btn{max-width:36px}.toolbar-divider{height:18px}.panel-header{padding:.4rem .5rem;font-size:.8rem}.panel-content{padding:.5rem}.theme-option{padding:.35rem .7rem;font-size:.75rem}.preset-color-btn{width:28px;height:28px}.color-picker-item input[type=color]{width:36px;height:28px}}@media (hover:none) and (pointer:coarse){.toolbar-btn:hover{transform:none}.toolbar-btn:active{transform:scale(.95)}}.ready-panel{background:var(--modal-bg,#0003);backdrop-filter:blur(10px);border:1px solid var(--modal-border,#ffffff1f);border-radius:12px;flex-direction:column;align-items:center;gap:.75rem;padding:1rem 1.25rem;animation:.25s slideDown;display:flex}.rematch-panel{background:#00000040;border-color:#ffd70033}.ready-panel-title{color:var(--modal-text,white);letter-spacing:.03em;text-align:center;font-size:1rem;font-weight:700}.ready-status-row{flex-wrap:wrap;justify-content:center;gap:.6rem;width:100%;display:flex}.ready-player-badge{color:var(--modal-text-dim,#ffffffbf);background:var(--modal-element-bg,#ffffff14);border:1px solid var(--modal-border,#ffffff1f);border-radius:20px;align-items:center;gap:.4rem;padding:.4rem .75rem;font-size:.8rem;font-weight:500;transition:all .3s;display:flex}.ready-player-badge.ready{color:#55efc4;background:#55efc426;border-color:#55efc466}.ready-player-badge.me{border-color:#74b9ff66}.ready-dot{background:var(--modal-text-secondary,#ffffff4d);border-radius:50%;flex-shrink:0;width:7px;height:7px;transition:background .3s}.ready-player-badge.ready .ready-dot{background:#55efc4;animation:2s ease-in-out infinite onlinePulse;box-shadow:0 0 6px #55efc499}.ready-label{opacity:.85;margin-left:2px;font-size:.72rem}.ready-btn{color:#fff;cursor:pointer;letter-spacing:.04em;background:linear-gradient(135deg,#55efc4,#00b894);border:none;border-radius:24px;padding:.6rem 2rem;font-size:.95rem;font-weight:700;transition:all .2s;box-shadow:0 4px 16px #00b89466}.ready-btn:hover{background:linear-gradient(135deg,#00b894,#009874);transform:translateY(-1px);box-shadow:0 6px 20px #00b89480}.ready-btn:active{transform:scale(.97)}.rematch-btn{background:linear-gradient(135deg,#74b9ff,#0984e3);box-shadow:0 4px 16px #0984e366}.rematch-btn:hover{background:linear-gradient(135deg,#0984e3,#0770c4);box-shadow:0 6px 20px #0984e380}.ready-waiting-text{color:var(--modal-text-secondary,#ffffffa6);text-align:center;font-size:.85rem;animation:2s ease-in-out infinite waitingPulse}.ready-waiting-text.rejected{color:#ff7675;animation:none}@keyframes waitingPulse{0%,to{opacity:1}50%{opacity:.5}}@media (width<=768px){.ready-panel{gap:.6rem;padding:.75rem 1rem}.ready-panel-title{font-size:.9rem}.ready-player-badge{padding:.35rem .6rem;font-size:.75rem}.ready-btn{padding:.55rem 1.5rem;font-size:.88rem}}@media (width<=480px){.ready-panel{gap:.5rem;padding:.6rem .75rem}.ready-panel-title{font-size:.85rem}.ready-status-row{gap:.4rem}.ready-player-badge{padding:.3rem .5rem;font-size:.7rem}.ready-btn{padding:.5rem 1.25rem;font-size:.85rem}}.snapshot-actions{width:100%;margin-bottom:1rem}.snapshot-list{flex-direction:column;gap:.5rem;width:100%;max-height:200px;margin-bottom:1rem;display:flex;overflow-y:auto}.snapshot-item{background:var(--modal-element-bg,#ffffff14);border:1px solid var(--modal-border,#ffffff1a);border-radius:10px;justify-content:space-between;align-items:center;padding:.6rem .75rem;display:flex}.snapshot-info{flex-direction:column;gap:.2rem;display:flex}.snapshot-name{color:#fff;font-size:.9rem;font-weight:600}.snapshot-time{color:#ffffff80;font-size:.7rem}.snapshot-item-actions{gap:.4rem;display:flex}.snapshot-restore-btn{color:#fff;cursor:pointer;background:linear-gradient(145deg,#55efc4,#00b894);border:none;border-radius:6px;padding:.35rem .6rem;font-size:.75rem;font-weight:600;transition:all .2s}.snapshot-restore-btn:hover{background:linear-gradient(145deg,#00b894,#009874)}.snapshot-delete-btn{color:#ffffffb3;cursor:pointer;background:#ffffff1f;border:none;border-radius:6px;padding:.35rem .6rem;font-size:.75rem;font-weight:600;transition:all .2s}.snapshot-delete-btn:hover{color:#ff7675;background:#ff76754d}.confirm-overlay{backdrop-filter:blur(6px);z-index:2000;background:#000000a6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.confirm-dialog{background:var(--modal-bg,linear-gradient(145deg, #1e1e3cf7, #141432f7));border:1px solid var(--modal-border,#ffffff26);border-radius:16px;flex-direction:column;align-items:center;gap:1rem;min-width:200px;padding:1.25rem 1.5rem;display:flex;box-shadow:0 24px 64px #0009}.confirm-dialog p{color:var(--modal-text,white);margin:0;font-size:1rem;font-weight:600}.confirm-actions{gap:.75rem;width:100%;display:flex}.confirm-btn{cursor:pointer;border:none;border-radius:10px;flex:1;padding:.6rem 1rem;font-size:.9rem;font-weight:600;transition:all .2s}.confirm-btn.cancel{background:var(--modal-element-bg,#ffffff1f);color:var(--modal-text-dim,#ffffffd9);border:1px solid var(--modal-border,#ffffff26)}.confirm-btn.cancel:hover{background:var(--modal-element-hover,#fff3)}.confirm-btn.confirm{color:#fff;background:linear-gradient(145deg,#55efc4,#00b894)}.confirm-btn.confirm:hover{background:linear-gradient(145deg,#00b894,#009874)}.game-status-wrapper{flex-shrink:0;width:min(95vw,75dvh - 120px,600px);margin:0 auto}@media (orientation:landscape){.game-status-wrapper{width:min(70vw,60vh,440px)}}.game-status{backdrop-filter:blur(10px);box-sizing:border-box;background:#00000026;border:1px solid #ffffff1a;border-radius:6px;flex-direction:column;width:100%;display:flex;overflow:hidden}.game-status-main{box-sizing:border-box;justify-content:space-between;align-items:center;min-height:40px;padding:.4rem;display:flex}.status-left{align-items:center;gap:8px;display:flex}.turn-indicator{border:2px solid #ffffff80;border-radius:50%;width:12px;height:12px}.turn-indicator.red{background:#e74c3c;box-shadow:0 0 6px #e74c3c80}.turn-indicator.black{background:#2c3e50;box-shadow:0 0 6px #2c3e5080}.status-text{color:#fff;font-size:.9rem;font-weight:600}.status-right{align-items:center;gap:12px;display:flex}.mode-text{color:#fffc;background:#ffffff1a;border-radius:4px;padding:2px 8px;font-size:.8rem}.move-count{color:#ffffffb3;font-size:.8rem}.status-evaluation-bar{border-radius:0 0 8px 8px;height:6px;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 2px 4px #0003,0 2px 4px #0003}.eval-bar-red{background:linear-gradient(#e74c3c 0%,#c0392b 100%);min-width:0;transition:width .5s}.eval-bar-black{background:linear-gradient(#34495e 0%,#2c3e50 100%);min-width:0;transition:width .5s}.eval-indicator{z-index:2;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.eval-pulse-dot{background:#ffffffe6;border-radius:50%;width:8px;height:8px;animation:1s ease-in-out infinite evalPulse;display:block;box-shadow:0 0 6px #ffffff80}@keyframes evalPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}}@media (width<=768px){.game-status-wrapper{width:min(95vw,95vh,500px)}.game-status-main{min-height:40px;padding:.4rem}.status-text{font-size:.85rem}.mode-text,.move-count{font-size:.75rem}.turn-indicator{width:10px;height:10px}.status-evaluation-bar{height:6px}}@media (width<=480px){.game-status-wrapper{width:min(98vw,98vh,400px)}.game-status-main{min-height:36px;padding:.35rem}.status-text{font-size:.8rem}.mode-text,.move-count{font-size:.7rem}.turn-indicator{width:8px;height:8px}.status-left{gap:6px}.status-right{gap:8px}.status-evaluation-bar{height:6px}.eval-pulse-dot{width:6px;height:6px}}.replay-controls-container{justify-content:center;align-items:center;max-width:100%;display:flex}.replay-controls-bar{background:var(--modal-bg,linear-gradient(145deg, #667eeaf2, #764ba2f2));box-sizing:border-box;border:3px solid #8b4513;border-radius:6px;flex-shrink:0;justify-content:space-between;align-items:center;gap:.25rem;width:min(95vw,75dvh - 120px,600px);padding:.3rem;transition:background .3s;display:flex;box-shadow:0 8px 20px #0000004d}@media (orientation:landscape){.replay-controls-bar{width:min(70vw,60vh,440px)}}.replay-step{color:#fff;white-space:nowrap;padding:0 .3rem;font-size:clamp(.7rem,2vw,.9rem);font-weight:600}.replay-step.highlight{color:#55efc4}.replay-buttons{align-items:center;gap:.15rem;display:flex}.replay-btn{aspect-ratio:1;color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#ffffff26;border:none;border-radius:50%;flex:1;justify-content:center;align-items:center;min-width:0;max-width:36px;transition:all .2s;display:flex}.replay-btn:hover:not(:disabled){background:#ffffff40;transform:scale(1.05)}.replay-btn:disabled{opacity:.4;cursor:not-allowed}.replay-btn.play{background:linear-gradient(145deg,#55efc4,#00b894);max-width:40px}.replay-btn.play:hover{box-shadow:0 2px 8px #00b89466}.replay-btn.exit{background:#d6303199}.replay-btn.exit:hover{background:#d63031e6}@media (width<=768px){.replay-controls-bar{gap:.2rem;width:min(95vw,95vh,500px);padding:.35rem}.replay-btn{max-width:32px}.replay-btn.play{max-width:36px}}@media (width<=480px){.replay-controls-bar{gap:.15rem;width:min(98vw,98vh,400px);padding:.3rem}.replay-btn{max-width:28px}.replay-btn.play{max-width:32px}}.install-prompt{z-index:1000;padding:1rem;animation:.3s ease-out slideUp;position:fixed;bottom:0;left:0;right:0}.install-prompt-content{backdrop-filter:blur(10px);background:#fffffff2;border-radius:16px;align-items:center;gap:1rem;max-width:500px;margin:0 auto;padding:1rem;display:flex;box-shadow:0 -4px 20px #00000026}.install-prompt-icon img{border-radius:12px;width:60px;height:60px}.install-prompt-text{flex:1}.install-prompt-text h3{color:#333;margin:0 0 .25rem;font-size:1rem}.install-prompt-text p{color:#666;margin:0;font-size:.85rem}.ios-hint{color:#888!important;margin-top:.5rem!important;font-size:.8rem!important}.invite-icon{text-align:center;color:#fff;vertical-align:middle;background:#007aff;border-radius:4px;width:20px;height:20px;font-size:14px;line-height:20px;display:inline-block}.install-prompt-actions{flex-direction:column;gap:.5rem;display:flex}.install-dismiss{color:#888;cursor:pointer;background:0 0;border:none;padding:.5rem 1rem;font-size:.85rem}.install-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:20px;padding:.6rem 1.2rem;font-size:.9rem;font-weight:700;transition:transform .2s,box-shadow .2s}.install-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #667eea66}@media (width<=480px){.install-prompt{padding:.5rem}.install-prompt-content{gap:.8rem;padding:.8rem}.install-prompt-icon img{width:50px;height:50px}.install-prompt-text h3{font-size:.9rem}.install-prompt-text p{font-size:.75rem}}.update-prompt{z-index:1000;padding:12px 16px;animation:.3s slideUp;position:fixed;bottom:0;left:0;right:0}.update-prompt-content{backdrop-filter:blur(10px);background:#000000e6;border-radius:12px;align-items:center;gap:12px;max-width:500px;margin:0 auto;padding:12px 16px;display:flex;box-shadow:0 -4px 20px #0000004d}.update-prompt-icon{color:#fff;background:linear-gradient(145deg,#74b9ff,#0984e3);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.update-prompt-text{flex:1;min-width:0}.update-prompt-text h3{color:#fff;margin:0 0 4px;font-size:.95rem;font-weight:600}.update-prompt-text p{color:#ffffffb3;margin:0;font-size:.8rem}.update-prompt-actions{flex-shrink:0;gap:8px;display:flex}.update-dismiss{color:#fffc;cursor:pointer;background:#ffffff1a;border:none;border-radius:8px;padding:8px 16px;font-size:.85rem;font-weight:500;transition:all .2s}.update-dismiss:hover{background:#fff3}.update-btn{color:#fff;cursor:pointer;background:linear-gradient(145deg,#55efc4,#00b894);border:none;border-radius:8px;padding:8px 20px;font-size:.85rem;font-weight:600;transition:all .2s}.update-btn:hover{background:linear-gradient(145deg,#00b894,#009874);transform:translateY(-1px)}.update-btn:active{transform:translateY(0)}@media (width<=480px){.update-prompt{padding:8px 12px}.update-prompt-content{gap:10px;padding:10px 12px}.update-prompt-icon{width:36px;height:36px}.update-prompt-icon svg{width:24px;height:24px}.update-prompt-text h3{font-size:.9rem}.update-prompt-text p{font-size:.75rem}.update-dismiss,.update-btn{padding:6px 14px;font-size:.8rem}}.chat-panel{z-index:1000;opacity:0;pointer-events:none;touch-action:auto;background:#fff;border:1px solid #0000000d;border-radius:12px;flex-direction:column;transition:transform .35s cubic-bezier(.34,1.56,.64,1),opacity .35s;display:flex;position:fixed;overflow:hidden;transform:translate(calc(100% + 30px));box-shadow:0 8px 30px #0000001f,0 2px 8px #0000000f}.chat-panel.open{opacity:1;pointer-events:auto;transform:translate(0)}.chat-panel.dragging,.chat-panel.resizing{user-select:none;transition:none}.chat-header{cursor:move;background:#fff;border-bottom:1px solid #f0f0f0;flex-shrink:0;justify-content:space-between;align-items:center;height:48px;padding:0 16px;display:flex}.chat-title{color:#333;font-size:15px;font-weight:600}.chat-close-btn{color:#999;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;transition:all .2s;display:flex}.chat-close-btn:hover{color:#666;background:#f5f5f5}.chat-messages{touch-action:pan-y;background:#f8f9fc;flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.chat-empty-state{text-align:center;color:#999;margin-top:40px;font-size:13px}.chat-message{align-items:flex-end;gap:8px;max-width:100%;display:flex}.chat-message.mine{flex-direction:row-reverse}.chat-avatar{color:#fff;background:linear-gradient(135deg,#a18cd1 0%,#fbc2eb 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:600;display:flex;box-shadow:0 2px 4px #0000001a}.chat-avatar.mine{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.chat-content-wrapper{flex-direction:column;gap:2px;max-width:70%;display:flex}.chat-sender-name{color:#999;margin-left:4px;font-size:11px}.chat-message.mine .chat-sender-name{text-align:right;margin-right:4px}.chat-bubble{word-wrap:break-word;border-radius:16px;padding:10px 14px;font-size:14px;line-height:1.5;box-shadow:0 1px 2px #0000000d}.chat-message.mine .chat-bubble{color:#fff;background:#4a90d9;border-bottom-right-radius:4px}.chat-message.theirs .chat-bubble{color:#333;background:#fff;border:1px solid #eee;border-bottom-left-radius:4px}.chat-input-area{background:#fff;border-top:1px solid #f0f0f0;align-items:center;gap:8px;padding:12px;display:flex}.quick-messages-toggle{cursor:pointer;background:#f5f7fa;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;transition:all .2s;display:flex}.quick-messages-toggle:hover{background:#eef4fb}.quick-messages-toggle.active{background:#4a90d9}.quick-messages-dropdown{z-index:10;touch-action:pan-y;background:#fff;border-radius:12px;flex-wrap:wrap;gap:6px;max-height:150px;padding:8px;animation:.2s dropdown-in;display:flex;position:absolute;bottom:60px;left:12px;right:12px;overflow-y:auto;box-shadow:0 4px 20px #00000026}@keyframes dropdown-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.quick-message-item{color:#555;cursor:pointer;white-space:nowrap;background:#f5f7fa;border:1px solid #0000;border-radius:16px;padding:8px 14px;font-size:13px;transition:all .2s}.quick-message-item:hover{color:#fff;background:#4a90d9}.chat-input{background:#f5f7fa;border:1px solid #0000;border-radius:20px;outline:none;flex:1;min-width:0;padding:10px 14px;font-size:14px;transition:all .2s}.chat-input:focus{background:#fff;border-color:#4a90d9;box-shadow:0 0 0 2px #4a90d91a}.chat-send-btn{color:#fff;cursor:pointer;background:#4a90d9;border:none;border-radius:18px;flex-shrink:0;justify-content:center;align-items:center;min-width:54px;padding:8px 14px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.chat-send-btn:hover{background:#357abd;transform:translateY(-1px)}.chat-send-btn:active{transform:translateY(1px)}.chat-send-btn:disabled{cursor:not-allowed;background:#e0e0e0;transform:none}.chat-messages::-webkit-scrollbar{width:5px}.quick-messages-dropdown::-webkit-scrollbar{width:5px}.chat-messages::-webkit-scrollbar-track{background:0 0}.quick-messages-dropdown::-webkit-scrollbar-track{background:0 0}.chat-messages::-webkit-scrollbar-thumb{background:#ddd;border-radius:3px}.quick-messages-dropdown::-webkit-scrollbar-thumb{background:#ddd;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#ccc}.quick-messages-dropdown::-webkit-scrollbar-thumb:hover{background:#ccc}@keyframes message-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message{animation:.3s cubic-bezier(.2,.8,.2,1) forwards message-in}.chat-resize-handle{cursor:nwse-resize;z-index:10;width:16px;height:16px;position:absolute;top:0;left:0}.chat-resize-handle:before{content:"";transform-origin:0 0;border-top:2px solid #ccc;border-left:2px solid #ccc;width:8px;height:8px;position:absolute;top:4px;left:4px;transform:rotate(-45deg)}.chat-resize-handle:hover:before{border-color:#999}.app{color:#fff;flex-direction:column;min-height:100svh;transition:background .3s;display:flex;overflow:hidden}.app-main{flex-direction:column;flex:1;align-items:center;gap:.3rem;max-height:100svh;padding:.3rem;display:flex;overflow:hidden}.app-main.edit-mode{justify-content:center}@media (width<=768px){.app-main{gap:.25rem;padding:.25rem}}@media (width<=480px){.app-main{gap:.15rem;padding:.15rem}}.landscape-warning{z-index:9999;background:#667eea;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.landscape-warning-content{text-align:center;color:#fff}.landscape-icon{margin-bottom:1rem;font-size:4rem;animation:1.5s ease-in-out infinite rotatePhone}.landscape-warning-content p{margin:0;font-size:1.5rem;font-weight:600}@keyframes rotatePhone{0%,to{transform:rotate(0)}25%{transform:rotate(-15deg)}75%{transform:rotate(15deg)}}.edit-piece-bar-wrapper{backdrop-filter:blur(10px);box-sizing:border-box;background:#00000026;border:1px solid #ffffff1a;border-radius:6px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:min(95vw,75dvh - 120px,600px);min-height:40px;padding:.4rem;display:flex}@media (orientation:landscape){.edit-piece-bar-wrapper{width:min(70vw,60vh,440px)}}.edit-piece-bar-wrapper.edit-piece-black{border-left:3px solid #fff9}.edit-piece-bar-wrapper.edit-piece-red{border-left:3px solid #ff6b6bcc}.edit-piece-list{flex-wrap:wrap;justify-content:center;gap:.35rem;display:flex}.edit-piece-select-btn{cursor:pointer;background:#ffffff1a;border:2px solid #fff3;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;font-weight:700;transition:all .2s;display:flex}.edit-piece-select-btn:hover{background:#fff3;border-color:#fff6}.edit-piece-select-btn.active{background:#ffd70040;border-color:#ffd700e6;box-shadow:0 0 10px #ffd7004d}.edit-icon-btn{cursor:pointer;background:#ffffff1a;border:2px solid #fff3;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex}.edit-icon-btn:hover{background:#fff3;border-color:#fff6}.edit-confirm-btn{background:linear-gradient(145deg,#55efc4,#00b894);border-color:#55efc480}.edit-confirm-btn:hover{background:linear-gradient(145deg,#00b894,#009874);border-color:#00b894b3}.edit-cancel-btn{background:#ff76754d;border-color:#ff767580}.edit-cancel-btn:hover{background:#ff767580;border-color:#ff7675b3}.edit-clear-btn{background:#d6303199;border-color:#d6303180}.edit-clear-btn:hover{background:#d63031cc;border-color:#d63031b3}.edit-fen-btn{background:#74b9ff80;border-color:#74b9ff80}.edit-fen-btn:hover{background:#74b9ffb3;border-color:#74b9ffb3}.modal-overlay{backdrop-filter:blur(6px);z-index:2000;background:#000000a6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--modal-bg,linear-gradient(145deg, #1e1e3cf7, #141432f7));border:1px solid var(--modal-border,#ffffff26);box-shadow:0 24px 64px #0009, 0 0 0 1px var(--modal-element-bg,#ffffff0d) inset;box-sizing:border-box;color:var(--modal-text,white);border-radius:20px;padding:1.5rem}.modal-compact{border-radius:16px;padding:1rem}.modal-header{color:var(--modal-text,white);justify-content:space-between;align-items:center;padding:.5rem 0;font-size:1.1rem;font-weight:700;display:flex}.modal-close{background:var(--modal-element-bg,#ffffff1a);cursor:pointer;color:var(--modal-text,white);border:none;border-radius:8px;justify-content:center;align-items:center;padding:.25rem;transition:all .2s;display:flex}.modal-close:hover{background:var(--modal-element-hover,#fff3)}.modal-body{padding:.5rem 0}.color-options{justify-content:center;gap:.75rem;display:flex}.color-option{cursor:pointer;border:none;border-radius:12px;padding:.75rem 1.25rem;font-size:.95rem;font-weight:600;transition:all .2s}.color-option.red{color:#fff;background:linear-gradient(145deg,#ff7676,#d63031);box-shadow:0 4px 16px #d6303166}.color-option.red:hover{background:linear-gradient(145deg,#d63031,#b71c1c)}.color-option.black{color:#fff;background:linear-gradient(145deg,#636e72,#2d3436);box-shadow:0 4px 16px #2d343666}.color-option.black:hover{background:linear-gradient(145deg,#2d3436,#1a1a1a)}.fen-actions{gap:.5rem;margin-bottom:1rem;display:flex}.fen-input-container{flex-direction:column;gap:.5rem;display:flex}.fen-input{border:1px solid var(--modal-border,#fff3);background:var(--modal-element-bg,#ffffff1a);width:100%;color:var(--modal-text,white);resize:none;box-sizing:border-box;border-radius:10px;padding:.75rem;font-family:monospace;font-size:.9rem}.fen-input::placeholder{color:var(--modal-text-secondary,#ffffff80)}.fen-input:focus{border-color:#74b9ff99;outline:none}.fen-error{color:#ff7676;font-size:.85rem}.modal-btn{cursor:pointer;border:none;border-radius:10px;padding:.6rem 1.2rem;font-size:.9rem;font-weight:600;transition:all .2s}.modal-btn.confirm{color:#fff;background:linear-gradient(145deg,#55efc4,#00b894)}.modal-btn.confirm:hover{background:linear-gradient(145deg,#00b894,#009874)}.modal-btn:disabled{opacity:.5;cursor:not-allowed}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;height:100%;font-size:16px;overflow:hidden}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior:none;touch-action:none;background:#667eea;width:100%;height:100%;min-height:100svh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;position:fixed;overflow:hidden}#root{flex-direction:column;min-height:100svh;display:flex}button{cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;outline:none;font-family:inherit}input,textarea{font-family:inherit}@media (width<=768px){html{font-size:14px}}@media (width<=480px){html{font-size:12px}}
