*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0d0b08;--panel:#161310;--panel2:#1e1a15;--border:#2a2419;--accent:#c9a227;--accent-h:#e8bc3a;--text:#c4b89a;--text-dim:#6b5f48;--text-h:#f0e8d5;--green:#4a7c50;--green-h:#5a9a62;--danger:#b83232;--gold:#c9a227;--violet:#a07adc;--violet-dim:#a07adc99;--font-heading:"Cormorant Garamond", serif;--font-body:"Inter", system-ui, sans-serif;--noise-opacity:.03;--shadow-sm:0 1px 3px #0006, 0 1px 2px #0000004d;--shadow-md:0 4px 16px #00000080, 0 2px 6px #0000004d;--shadow-lg:0 12px 48px #000000b3, 0 4px 16px #0006}body{background:var(--bg);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-size:14px;line-height:1.5}.panel-noise{isolation:isolate;position:relative}.panel-noise:before{content:"";opacity:var(--noise-opacity);border-radius:inherit;pointer-events:none;z-index:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");position:absolute;inset:0}.panel-noise>*{z-index:1;position:relative}.app{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}@supports (height:100dvh){.app{min-height:100dvh}}@media (width<=640px){.app{align-items:flex-start;padding:8px}}@keyframes rise-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.rise{animation:.4s ease-out both rise-in}.rise-1{animation-delay:50ms}.rise-2{animation-delay:.12s}.rise-3{animation-delay:.19s}.rise-4{animation-delay:.26s}@keyframes card-pulse{0%,to{opacity:1}50%{opacity:.55}}.theme-picker{z-index:200;align-items:center;gap:8px;display:flex;position:fixed;top:14px;right:14px}.theme-swatch{background:var(--swatch-color);cursor:pointer;border:1.5px solid #0000;border-radius:50%;width:12px;height:12px;padding:0;transition:transform .18s ease-out,border-color .18s ease-out}.theme-swatch:hover{transform:scale(1.2)}.theme-swatch.active{border-color:#ffffffd9;transform:scale(1.15)}.fop{background:var(--panel);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-top-color:#ffffff12;position:relative}.modal-overlay{z-index:100;background-color:#000000d1;background-image:linear-gradient(#000000d1,#000000d1),repeating-conic-gradient(#ffffff04 0% 25%,#0000 0% 50%);background-position:0 0;background-repeat:repeat;background-size:cover,48px 48px;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--panel);border:1px solid var(--border);text-align:center;width:440px;max-width:95vw;box-shadow:var(--shadow-lg);border-top-color:#ffffff17;border-radius:10px;padding:44px 40px;animation:.35s ease-out both rise-in}@media (width<=640px){.modal{padding:32px 22px}}.modal-logo{margin-bottom:10px;font-size:52px;line-height:1}.modal-title{font-family:var(--font-heading);color:var(--text-h);letter-spacing:.06em;margin-bottom:4px;font-size:32px;font-weight:700}.modal-subtitle{color:var(--text-dim);margin-bottom:32px;font-size:13px}.field-group{text-align:left;border:none;margin-bottom:22px}.field-group legend{text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);width:100%;margin-bottom:10px;font-size:10px;font-weight:600}.level-buttons,.color-buttons{flex-wrap:wrap;gap:6px;display:flex}.radio-card{cursor:pointer;flex:auto}.radio-card input[type=radio]{display:none}.radio-card span{background:var(--panel2);border:1px solid var(--border);text-align:center;font-size:13px;font-family:var(--font-body);color:var(--text);white-space:nowrap;border-top-color:#ffffff0d;border-radius:6px;padding:9px 10px;transition:border-color .18s ease-out,color .18s ease-out,background .18s ease-out;display:block}.radio-card input:checked+span{background:linear-gradient(180deg, var(--accent-h) 0%, var(--accent) 100%);border-color:var(--accent);color:#000;box-shadow:0 0 10px color-mix(in srgb, var(--accent) 40%, transparent);font-weight:600}.radio-card:hover span{border-color:var(--accent);color:var(--text-h)}.btn-primary{background:linear-gradient(180deg, var(--green-h) 0%, var(--green) 100%);color:#fff;font-size:14px;font-weight:600;font-family:var(--font-body);cursor:pointer;letter-spacing:.01em;border:none;border-radius:6px;padding:10px 20px;transition:box-shadow .18s ease-out,filter .18s ease-out}.btn-primary:hover{filter:brightness(1.1);box-shadow:0 0 14px #4a7c508c}.btn-large{width:100%;margin-top:8px;padding:14px;font-size:15px}.btn-control{background:var(--panel2);color:var(--text);border:1px solid var(--border);font-size:13px;font-family:var(--font-body);cursor:pointer;text-align:center;border-top-color:#ffffff0d;border-radius:6px;flex:1;padding:8px 12px;transition:border-color .18s ease-out,color .18s ease-out,box-shadow .18s ease-out}.btn-control:hover:not(:disabled){border-color:var(--accent);color:var(--text-h);box-shadow:0 0 8px color-mix(in srgb, var(--accent) 25%, transparent)}.btn-control:disabled{opacity:.35;cursor:not-allowed}.btn-control.btn-primary{color:#000}.btn-back{color:var(--text-dim);font-size:13px;font-family:var(--font-body);cursor:pointer;background:0 0;border:none;margin-top:14px;padding:4px 8px;transition:color .18s ease-out;display:block}.btn-back:hover{color:var(--text)}.btn-logout{border:1px solid var(--border);font-size:12px;font-family:var(--font-body);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:6px;padding:4px 10px;transition:color .18s ease-out,border-color .18s ease-out}.btn-logout:hover{color:var(--danger);border-color:var(--danger)}.btn-mygames{border:1px solid var(--border);font-size:12px;font-family:var(--font-body);color:var(--accent);cursor:pointer;background:0 0;border-radius:6px;padding:4px 10px;transition:all .18s ease-out}.btn-mygames:hover{color:var(--accent-h);border-color:var(--accent);box-shadow:0 0 8px color-mix(in srgb, var(--accent) 25%, transparent)}.auth-btn-primary{background:linear-gradient(180deg, var(--accent-h) 0%, var(--accent) 100%);color:#000;font-size:14px;font-weight:600;font-family:var(--font-body);cursor:pointer;letter-spacing:.01em;border:none;border-radius:6px;margin-top:4px;padding:12px;transition:box-shadow .18s ease-out,filter .18s ease-out}.auth-btn-primary:hover:not(:disabled){box-shadow:0 0 18px color-mix(in srgb, var(--accent) 45%, transparent);filter:brightness(1.08)}.auth-btn-primary:disabled{opacity:.45;cursor:not-allowed}.game-layout{align-items:flex-start;gap:16px;width:100%;max-width:1040px;animation:.4s ease-out both rise-in;display:flex}.board-section{flex-direction:column;flex:none;gap:0;display:flex}.board-wrapper{width:min(600px,100vw - 296px)}@media (width<=640px){.game-layout{flex-direction:column;gap:10px;width:100%}.board-section,.board-wrapper{width:100%}.sidebar{width:100%!important}}.status-bar{background:var(--panel);border:1px solid var(--border);border-top:none;border-radius:0 0 8px 8px;justify-content:space-between;align-items:center;padding:6px 14px;display:flex}.status-level{color:var(--text-dim);font-size:11px;font-style:italic}.status-text{color:var(--text-h);font-size:13px;font-weight:600}.status-text.thinking,.status-text.notification{color:var(--gold)}.board-wrapper-inner{border:1px solid var(--border);border-bottom:none;border-radius:8px 8px 0 0;overflow:hidden}.sidebar{border:1px solid var(--border);background:var(--panel);box-shadow:var(--shadow-sm);border-top-color:#ffffff12;border-radius:10px;flex-direction:column;flex:0 0 280px;align-self:stretch;gap:0;display:flex;overflow:hidden}.sidebar-divider{background:var(--border);flex-shrink:0;height:1px}.sidebar-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);flex-shrink:0;padding:8px 14px 4px;font-size:10px;font-weight:600}.player-card{flex-shrink:0;align-items:center;gap:10px;padding:12px 14px;display:flex}.player-avatar{background:var(--panel2);border:1px solid var(--border);width:32px;height:32px;font-family:var(--font-heading);color:var(--accent);letter-spacing:0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:600;display:flex}.player-info{flex:1;min-width:0}.player-name{font-family:var(--font-heading);color:var(--text-h);letter-spacing:.04em;white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:600;overflow:hidden}.player-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;font-size:10px}.player-timer{color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:13px;font-family:var(--font-body);flex-shrink:0}.player-timer.warn{color:#e05555;font-weight:600}.player-captured{flex-wrap:wrap;align-items:center;gap:1px;margin-top:2px;display:flex}.player-captured-piece{font-size:13px;line-height:1}.player-score{color:var(--gold);margin-left:3px;font-size:10px;font-weight:700}.captured-panel{flex-shrink:0;padding:8px 14px}.captured-row{align-items:center;gap:8px;min-height:22px;display:flex}.captured-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);flex-shrink:0;width:52px;font-size:10px;font-weight:600}.captured-pieces{flex-wrap:wrap;align-items:center;gap:1px;display:flex}.captured-piece{font-size:14px;line-height:1}.score-diff{color:var(--gold);margin-left:4px;font-size:11px;font-weight:700}.captured-divider{background:var(--border);height:1px;margin:3px 0}.move-history{flex-direction:column;flex:1 1 0;min-height:0;display:flex;overflow:hidden}.move-history-header{text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 14px;font-size:10px;font-weight:600;display:flex}.move-history-body{flex:1 1 0;max-height:360px;padding:4px 0;overflow-y:auto}@media (width<=640px){.move-history-body{max-height:140px}}.move-row{align-items:center;gap:4px;padding:3px 14px;display:flex}.move-row:nth-child(2n){background:#ffffff05}.move-num{color:var(--text-dim);flex-shrink:0;width:22px;font-size:11px}.move-san{color:var(--text-h);cursor:pointer;border-radius:4px;flex:1;padding:1px 4px;font-family:Courier New,monospace;font-size:13px;transition:background .15s}.move-san:hover{background:var(--panel2)}.move-san.move-active{background:linear-gradient(180deg, var(--accent-h) 0%, var(--accent) 100%);color:#000}.move-black{color:var(--text)}.live-btn{border:1px solid var(--accent);color:var(--accent);cursor:pointer;font-size:10px;font-family:var(--font-body);background:0 0;border-radius:10px;padding:2px 8px;font-weight:600;transition:background .18s ease-out,color .18s ease-out}.live-btn:hover{background:var(--accent);color:#000}.no-moves{color:var(--text-dim);text-align:center;padding:14px;font-size:12px;font-style:italic}.move-history-body::-webkit-scrollbar{width:4px}.move-history-body::-webkit-scrollbar-track{background:0 0}.move-history-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.game-controls{flex-direction:row;flex-shrink:0;gap:6px;padding:10px 12px;display:flex}@media (width<=640px){.btn-control{padding:10px 6px;font-size:12px}}.cards-body{flex-direction:column;gap:8px;padding:10px 14px 14px;display:flex}.cards-row{align-items:center;gap:10px;display:flex}.cards-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);flex-shrink:0;width:52px;font-size:10px;font-weight:600}.card-slots{gap:8px;display:flex}.card-wrapper{perspective:600px;width:60px;height:84px}.card{width:60px;height:84px;transform-style:preserve-3d;cursor:default;transition:transform .6s cubic-bezier(.4,0,.2,1);position:relative}.card.revealed{transform:rotateY(180deg)}.card.drawable{cursor:pointer;animation:1.1s ease-in-out infinite card-pulse}.card-back,.card-front{backface-visibility:hidden;border-radius:7px;flex-direction:column;justify-content:center;align-items:center;gap:4px;display:flex;position:absolute;inset:0}.card-back{background:var(--panel2);border:1px solid var(--border);color:var(--text-dim);border-top-color:#ffffff12;font-size:22px}.card-front{background:var(--panel2);border:1px solid var(--gold);border-top-color:color-mix(in srgb, var(--gold) 60%, white 40%);transform:rotateY(180deg);box-shadow:inset 0 0 20px #0000004d}.card-symbol{font-size:26px;line-height:1}.card-label{font-family:var(--font-heading);letter-spacing:.06em;text-transform:uppercase;color:var(--text-dim);text-align:center;font-size:9px;font-weight:600;line-height:1}.card-super{color:var(--gold)}.card-blank-text{color:var(--text-dim);font-size:28px}.card-doublemove{color:var(--accent);letter-spacing:-3px;font-size:22px;font-weight:700}.card-freeze{font-size:26px}.card-ghost{color:var(--violet);font-size:22px}.draw-prompt{color:var(--gold);text-align:center;font-size:12px;font-weight:600;animation:1.1s ease-in-out infinite card-pulse}.draw-prompt.dim{color:var(--text-dim);font-style:italic;font-weight:400;animation:none}.card.card-active .card-front{border-color:var(--violet);box-shadow:0 0 18px #a07adc99}.card.card-active{filter:drop-shadow(0 0 7px #a07adc80)}.mp-player-bar{background:var(--panel);border:1px solid var(--border);border-top-color:#ffffff0f;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:4px;padding:8px 14px;display:flex}.mp-player-bar-me{border-color:color-mix(in srgb, var(--accent) 40%, var(--border));margin-top:4px;margin-bottom:0}.mp-name{font-family:var(--font-heading);color:var(--text-h);letter-spacing:.04em;font-size:13px;font-weight:600}.mp-timer{color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:12px}.mp-timer.mp-timer-warn{color:#e05555;font-weight:600}.game-result-banner{text-align:center;font-family:var(--font-heading);letter-spacing:.1em;border-radius:8px;padding:14px 20px;font-size:22px;font-weight:700;animation:.4s ease-out both rise-in}.game-result-banner.win{color:#7ddc9c;background:#122410fa;border:1px solid #4caf76;box-shadow:0 0 28px #4caf764d,inset 0 0 20px #4caf760f}.game-result-banner.loss{color:#e07070;background:#1e0a0afa;border:1px solid #b83232;box-shadow:0 0 28px #b8323240,inset 0 0 20px #b832320f}.game-result-banner.draw{border:1px solid var(--accent);color:var(--accent-h);box-shadow:0 0 22px color-mix(in srgb, var(--accent) 30%, transparent), inset 0 0 14px color-mix(in srgb, var(--accent) 8%, transparent);background:#0e1018fa}.auth-loading{color:var(--text-dim);font-size:15px}.auth-container{flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:24px 16px;animation:.4s ease-out both rise-in;display:flex}.auth-title{font-family:var(--font-heading);color:var(--text-h);letter-spacing:.06em;margin-bottom:28px;font-size:36px;font-weight:700}.auth-subtitle{color:var(--text-h);text-align:center;margin-bottom:6px;font-size:18px;font-weight:600}.auth-hint{color:var(--text-dim);text-align:center;margin-bottom:20px;font-size:13px}.auth-card{background:var(--panel);border:1px solid var(--border);width:380px;max-width:95vw;box-shadow:var(--shadow-lg);border-top-color:#ffffff17;border-radius:10px;padding:36px 32px}.auth-tabs{border-bottom:1px solid var(--border);margin-bottom:24px;display:flex}.auth-tab{font-size:14px;font-weight:600;font-family:var(--font-body);color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-1px;padding:10px;transition:color .18s ease-out,border-color .18s ease-out}.auth-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.auth-tab:hover:not(.active){color:var(--text-h)}.auth-form{flex-direction:column;gap:12px;display:flex}.auth-input{background:var(--panel2);border:1px solid var(--border);font-size:14px;font-family:var(--font-body);color:var(--text-h);border-radius:6px;width:100%;padding:11px 14px;transition:border-color .18s ease-out,box-shadow .18s ease-out}.auth-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 15%, transparent);outline:none}.auth-input::placeholder{color:var(--text-dim)}.auth-error{color:var(--danger);font-size:13px}.auth-message{color:var(--green-h);font-size:13px}.auth-divider{text-align:center;color:var(--text-dim);margin:16px 0;font-size:12px;position:relative}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);width:40%;height:1px;position:absolute;top:50%}.auth-divider:before{left:0}.auth-divider:after{right:0}.auth-btn-google{background:var(--panel2);border:1px solid var(--border);width:100%;font-size:14px;font-weight:600;font-family:var(--font-body);color:var(--text-h);cursor:pointer;border-top-color:#ffffff0f;border-radius:6px;padding:10px;transition:border-color .18s ease-out,color .18s ease-out}.auth-btn-google:hover{border-color:var(--accent);color:var(--accent-h)}.mode-tabs{border:1px solid var(--border);border-radius:7px;margin-bottom:22px;display:flex;overflow:hidden}.mode-tab{background:var(--panel2);color:var(--text-dim);font-size:13px;font-weight:600;font-family:var(--font-body);cursor:pointer;border:none;flex:1;padding:10px;transition:background .18s ease-out,color .18s ease-out}.mode-tab:not(:last-child){border-right:1px solid var(--border)}.mode-tab.active{background:linear-gradient(180deg, var(--accent-h) 0%, var(--accent) 100%);color:#000}.mode-tab:not(.active):hover{color:var(--text-h);background:var(--panel)}.modal-user-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:14px;display:flex}.modal-username{color:var(--text-dim);font-size:13px}.modal-user-actions{align-items:center;gap:6px;display:flex}.online-section{flex-direction:column;gap:14px;display:flex}.online-explainer{color:var(--text-dim);font-size:13px;line-height:1.6}.invite-link-box{text-align:left;background:#0e0b05;border:1px solid #7a5c14;border-top-color:#a07820;border-radius:7px;align-items:center;gap:8px;margin:14px 0 0;padding:11px 14px;display:flex;box-shadow:0 0 16px #8b691433,inset 0 1px #c9a2270f}.invite-link-text{color:#c8b060;word-break:break-all;flex:1;font-family:Courier New,monospace;font-size:11px}.btn-copy{color:#f0d9a0;font-size:12px;font-weight:600;font-family:var(--font-body);cursor:pointer;background:linear-gradient(#9a7218 0%,#7a5c14 100%);border:none;border-radius:5px;flex-shrink:0;padding:6px 11px;transition:box-shadow .18s ease-out,filter .18s ease-out}.btn-copy:hover{filter:brightness(1.15);box-shadow:0 0 10px #c9a22766}.superhorse-info{background:color-mix(in srgb, var(--gold) 5%, var(--panel));border:1px solid color-mix(in srgb, var(--gold) 40%, transparent);border-radius:7px;flex-direction:column;gap:7px;padding:10px 14px;display:flex}.shi-title{font-family:var(--font-heading);color:var(--gold);text-align:center;letter-spacing:.06em;font-size:12px;font-weight:700}.shi-body{align-items:center;gap:12px;display:flex}.shi-grid{flex-shrink:0;grid-template-rows:repeat(7,18px);grid-template-columns:repeat(7,18px);gap:1px;display:grid}.shi-cell{background:#ffffff08;border-radius:3px;justify-content:center;align-items:center;width:18px;height:18px;font-size:12px;display:flex}.shi-knight{color:var(--text-h);background:#ffffff17;font-size:13px}.shi-normal{background:#50a05066}.shi-extra{background:#c9a22780}.shi-legend{color:var(--text-dim);flex-direction:column;gap:5px;font-size:11px;display:flex}.shi-dot{vertical-align:middle;border-radius:50%;width:10px;height:10px;margin-right:5px;display:inline-block}.shi-dot.normal{background:#50a050cc}.shi-dot.extra{background:#c9a227e6}.ghostbishop-info{background:color-mix(in srgb, var(--violet) 5%, var(--panel));border:1px solid color-mix(in srgb, var(--violet) 40%, transparent);border-radius:7px;flex-direction:column;gap:7px;padding:10px 14px;display:flex}.gbi-title{font-family:var(--font-heading);color:var(--violet);text-align:center;letter-spacing:.06em;font-size:12px;font-weight:700}.gbi-body{align-items:center;gap:12px;display:flex}.gbi-grid{flex-shrink:0;grid-template-rows:repeat(9,16px);grid-template-columns:repeat(9,16px);gap:1px;display:grid}.gbi-cell{background:#ffffff08;border-radius:2px;justify-content:center;align-items:center;width:16px;height:16px;font-size:11px;display:flex}.gbi-bishop{color:var(--text-h);background:#ffffff17;font-size:12px}.gbi-normal{background:#50a05066}.gbi-ghost{background:#a07adc80}.gbi-legend{color:var(--text-dim);flex-direction:column;gap:5px;font-size:11px;display:flex}.gbi-dot{vertical-align:middle;border-radius:50%;width:10px;height:10px;margin-right:5px;display:inline-block}.gbi-dot.normal{background:#50a050cc}.gbi-dot.ghost{background:#a07adce6}.freeze-info{background:color-mix(in srgb, #6ab4ff 5%, var(--panel));color:#8cc8ffe6;text-align:center;border:1px solid #64b4ff80;border-radius:7px;padding:10px 14px;font-size:12px;font-weight:600;animation:1.1s ease-in-out infinite card-pulse}.history-page{align-self:flex-start;width:100%;max-width:700px;padding:28px 0;animation:.4s ease-out both rise-in}.history-header{align-items:center;gap:16px;margin-bottom:28px;display:flex}.history-back-btn{flex:none}.history-title{font-family:var(--font-heading);color:var(--text-h);letter-spacing:.06em;font-size:1.6rem}.history-empty{color:var(--text-dim);text-align:center;padding:48px 0;font-style:italic}.history-table{border-collapse:collapse;width:100%}.history-table th{text-align:left;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);border-bottom:1px solid var(--border);padding:8px 14px;font-size:10px;font-weight:600}.history-row{cursor:pointer;transition:background .15s}.history-row:hover{background:var(--panel2)}.history-row td{border-bottom:1px solid var(--border);color:var(--text);padding:11px 14px;font-size:13px}.result-badge{letter-spacing:.04em;border-radius:5px;padding:2px 9px;font-size:11px;font-weight:600;display:inline-block}.result-win{color:var(--green-h);background:#3d8c5f2e}.result-loss{color:#e07070;background:#b832322e}.result-draw{color:var(--gold);background:#c9a2271f}.replay-page{align-self:flex-start;width:100%;max-width:960px;padding:18px 0;animation:.4s ease-out both rise-in}.replay-header{align-items:center;gap:14px;margin-bottom:18px;display:flex}.replay-back-btn{flex:none}.replay-reason{color:var(--text-dim);text-transform:capitalize;font-size:12px}.replay-layout{align-items:flex-start;gap:16px;display:flex}.replay-board-col{flex-direction:column;flex:none;display:flex}.replay-board-wrapper{width:min(520px,100vw - 280px)}.replay-controls{justify-content:center;align-items:center;gap:6px;margin-top:8px;display:flex}.replay-btn{min-width:40px;padding:7px 14px;flex:none!important}.replay-ply{color:var(--text-dim);text-align:center;font-variant-numeric:tabular-nums;min-width:64px;font-size:12px}.replay-moves{background:var(--panel);border:1px solid var(--border);min-width:0;box-shadow:var(--shadow-sm);border-top-color:#ffffff12;border-radius:8px;flex-direction:column;flex:1;display:flex;overflow:hidden}.replay-move-body{flex:1 1 0;max-height:520px;padding:4px 0;overflow-y:auto}.replay-move-body::-webkit-scrollbar{width:4px}.replay-move-body::-webkit-scrollbar-track{background:0 0}.replay-move-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.card-tag{color:var(--violet);font-size:10px;font-family:var(--font-body);vertical-align:middle;margin-left:4px;display:inline-block}@media (width<=640px){.replay-layout{flex-direction:column}.replay-board-wrapper,.replay-moves{width:100%}.replay-move-body{max-height:200px}}
