:root{--breakpoint-mobile: 767px;--breakpoint-tablet: 1023px;--color-primary: #81b64c;--color-primary-dark: #6fa03d;--color-primary-light: #9ac96d;--color-bg-primary: #0a0a0a;--color-bg-secondary: #1a1a1a;--color-bg-tertiary: #2a2a2a;--color-bg-elevated: #333333;--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--bg-tertiary: #3a3a3a;--color-text-primary: #ffffff;--color-text-secondary: #cccccc;--color-text-tertiary: #888888;--color-text-disabled: #666666;--text-primary: #ffffff;--text-secondary: #a0a0a0;--text-muted: #666666;--color-border-primary: #333333;--color-border-secondary: #444444;--color-border-focus: #81b64c;--accent-green: #81b64c;--accent-red: #e74c3c;--accent-yellow: rgba(255, 255, 0, .5);--accent-blue: #3498db;--accent-purple: #9b59b6;--accent-orange: #e67e22;--color-success: #81b64c;--color-error: #ff6b6b;--color-warning: #ffa500;--color-info: #4a9eff;--board-light: #f0d9b5;--board-dark: #b58863;--color-square-light: #f0d9b5;--color-square-dark: #b58863;--color-square-selected: #81b64c;--color-square-legal: rgba(129, 182, 76, .5);--color-square-last-move: rgba(181, 136, 99, .4);--font-size-xs: 12px;--font-size-sm: 14px;--font-size-base: 16px;--font-size-lg: 18px;--font-size-xl: 20px;--font-size-2xl: 24px;--font-size-3xl: 28px;--font-size-4xl: 32px;--line-height-tight: 1.2;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 20px;--space-2xl: 24px;--space-3xl: 32px;--space-4xl: 40px;--space-5xl: 48px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--touch-target-min: 44px;--touch-target-comfortable: 48px;--button-height-sm: 36px;--button-height-md: 44px;--button-height-lg: 48px;--button-height-mobile: 48px;--button-height-desktop: 44px;--button-padding-x: 16px;--button-padding-x-lg: 24px;--input-height: 48px;--input-padding-x: 16px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-2xl: 16px;--radius-full: 9999px;--container-mobile: 100%;--container-tablet: 720px;--container-desktop: 1200px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 2px 8px rgba(0, 0, 0, .4);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .5);--shadow-xl: 0 8px 32px rgba(0, 0, 0, .6);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--z-base: 1;--z-elevated: 10;--z-dropdown: 100;--z-overlay: 999;--z-modal: 1000;--z-toast: 1100}@media(min-width:768px){:root{--font-size-lg: 20px;--font-size-xl: 24px;--font-size-2xl: 28px;--font-size-3xl: 32px;--font-size-4xl: 40px}}@media(min-width:1024px){:root{--font-size-2xl: 32px;--font-size-3xl: 36px;--font-size-4xl: 48px}}*{margin:0;padding:0;box-sizing:border-box}button,a,[role=button],[onclick],.clickable{-webkit-touch-callout:none;touch-action:manipulation}html{-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg-primary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--color-text-primary)}h1{font-size:var(--font-size-4xl);margin-bottom:var(--space-2xl)}h2{font-size:var(--font-size-3xl);margin-bottom:var(--space-xl)}h3{font-size:var(--font-size-2xl);margin-bottom:var(--space-lg)}h4{font-size:var(--font-size-xl);margin-bottom:var(--space-md)}h5{font-size:var(--font-size-lg);margin-bottom:var(--space-sm)}h6{font-size:var(--font-size-base);margin-bottom:var(--space-sm)}p{margin:0 0 var(--space-lg) 0;line-height:var(--line-height-normal)}p:last-child{margin-bottom:0}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-light)}code,pre{font-family:SF Mono,Menlo,Monaco,Courier New,monospace;background-color:var(--color-bg-tertiary);border-radius:var(--radius-sm);font-size:var(--font-size-sm)}code{padding:var(--space-xs) var(--space-sm)}pre{padding:var(--space-lg);overflow-x:auto;line-height:var(--line-height-relaxed)}.app-container{display:flex;flex-direction:column;align-items:center;padding:var(--space-lg);min-height:100vh}button{font-family:inherit;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);line-height:1;min-height:var(--touch-target-min);padding:0 var(--button-padding-x);border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-base);-webkit-tap-highlight-color:transparent;user-select:none;touch-action:manipulation;-webkit-touch-callout:none}button:hover{opacity:.9}button:active{transform:scale(.98)}button:disabled{opacity:.5;cursor:not-allowed}input,textarea,select{font-family:inherit;font-size:var(--font-size-base);min-height:var(--input-height);padding:0 var(--input-padding-x);background-color:var(--color-bg-tertiary);border:2px solid var(--color-border-primary);border-radius:var(--radius-md);color:var(--color-text-primary);transition:border-color var(--transition-base)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-border-focus)}textarea{padding:var(--space-md) var(--input-padding-x);resize:vertical;min-height:120px}label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--space-xs);display:block}.text-base{font-size:var(--font-size-base)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:var(--font-size-3xl)}.text-4xl{font-size:var(--font-size-4xl)}.font-regular{font-weight:var(--font-weight-regular)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.leading-tight{line-height:var(--line-height-tight)}.leading-normal{line-height:var(--line-height-normal)}.leading-relaxed{line-height:var(--line-height-relaxed)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}.text-warning{color:var(--color-warning)}.text-left{text-align:left}.text-right{text-align:right}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.m-0{margin:0}.m-auto{margin:auto}.mt-xs{margin-top:var(--space-xs)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mt-xl{margin-top:var(--space-xl)}.mt-2xl{margin-top:var(--space-2xl)}.mt-3xl{margin-top:var(--space-3xl)}.mb-xs{margin-bottom:var(--space-xs)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.mb-xl{margin-bottom:var(--space-xl)}.mb-2xl{margin-bottom:var(--space-2xl)}.mb-3xl{margin-bottom:var(--space-3xl)}.ml-xs{margin-left:var(--space-xs)}.ml-sm{margin-left:var(--space-sm)}.ml-md{margin-left:var(--space-md)}.ml-lg{margin-left:var(--space-lg)}.mr-xs{margin-right:var(--space-xs)}.mr-sm{margin-right:var(--space-sm)}.mr-md{margin-right:var(--space-md)}.mr-lg{margin-right:var(--space-lg)}.p-0{padding:0}.p-xs{padding:var(--space-xs)}.p-sm{padding:var(--space-sm)}.p-md{padding:var(--space-md)}.p-lg{padding:var(--space-lg)}.p-xl{padding:var(--space-xl)}.p-2xl{padding:var(--space-2xl)}.px-xs{padding-left:var(--space-xs);padding-right:var(--space-xs)}.px-sm{padding-left:var(--space-sm);padding-right:var(--space-sm)}.px-md{padding-left:var(--space-md);padding-right:var(--space-md)}.px-lg{padding-left:var(--space-lg);padding-right:var(--space-lg)}.py-xs{padding-top:var(--space-xs);padding-bottom:var(--space-xs)}.py-sm{padding-top:var(--space-sm);padding-bottom:var(--space-sm)}.py-md{padding-top:var(--space-md);padding-bottom:var(--space-md)}.py-lg{padding-top:var(--space-lg);padding-bottom:var(--space-lg)}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.gap-xl{gap:var(--space-xl)}.gap-2xl{gap:var(--space-2xl)}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-1{flex:1}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.w-full{width:100%}.h-full{height:100%}.loading-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;gap:var(--space-lg);padding:var(--space-2xl)}.loading-fallback p{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0}.spinner{width:40px;height:40px;border:3px solid var(--color-bg-tertiary);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.spinner-sm{width:20px;height:20px;border-width:2px}.spinner-lg{width:60px;height:60px;border-width:4px}.skeleton{background:linear-gradient(90deg,var(--color-bg-tertiary) 25%,var(--color-bg-elevated) 50%,var(--color-bg-tertiary) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:1em;margin-bottom:var(--space-sm)}.skeleton-button{height:var(--button-height-lg);width:100%}.skeleton-card{height:120px;width:100%}.flip-board-button{position:absolute;top:var(--space-sm);right:var(--space-sm);background-color:var(--color-bg-tertiary);color:var(--color-text-primary);border:1px solid var(--color-border-primary);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);z-index:10;min-height:var(--touch-target-min);min-width:var(--touch-target-min);display:flex;align-items:center;justify-content:center;gap:var(--space-xs);-webkit-tap-highlight-color:transparent;transition:all var(--transition-fast)}.flip-board-button:active{background-color:var(--color-bg-elevated);transform:scale(.95)}.piece-info-modal{position:fixed;inset:0;background-color:#000c;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:fade-in .2s ease}.piece-info-content{background-color:var(--color-bg-secondary);border-radius:var(--radius-lg);padding:var(--space-2xl);max-width:320px;width:90%;text-align:center;animation:scale-in .2s ease}.piece-info-content h3{margin-bottom:var(--space-lg);color:var(--color-primary);font-size:var(--font-size-xl)}.piece-info-content p{margin-bottom:var(--space-md);font-size:var(--font-size-lg);color:var(--color-text-secondary)}.piece-info-content .piece-image{width:80px;height:80px;margin:var(--space-lg) auto}.piece-info-content button{margin-top:var(--space-lg);width:100%;min-height:var(--touch-target-comfortable);background-color:var(--color-primary);color:var(--color-bg-primary);border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer}.pull-to-refresh-container{position:relative;overflow-y:auto;-webkit-overflow-scrolling:touch}.pull-to-refresh-indicator{position:absolute;top:-60px;left:0;right:0;height:60px;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);color:var(--color-text-secondary);font-size:var(--font-size-sm);transition:transform .2s ease,opacity .2s ease;z-index:10}.pull-to-refresh-indicator .pull-arrow{transition:transform .2s ease}.pull-to-refresh-indicator.ready .pull-arrow{transform:rotate(180deg)}.move-history-swipeable{touch-action:pan-y;user-select:none;-webkit-user-select:none}.move-history-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);background-color:var(--color-bg-tertiary);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.move-history-header button{min-width:var(--touch-target-min);min-height:var(--touch-target-min);background-color:var(--color-bg-elevated);border:1px solid var(--color-border-primary);color:var(--color-text-primary);font-size:var(--font-size-lg);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.move-history-header button:disabled{opacity:.3;cursor:not-allowed}.move-history-header button:not(:disabled):active{background-color:var(--color-primary);transform:scale(.95)}.gesture-hint{text-align:center;color:var(--color-text-tertiary);font-size:var(--font-size-xs);padding:var(--space-md);margin:0}@keyframes long-press-pulse{0%,to{transform:scale(1)}50%{transform:scale(.97)}}.chess-square.long-pressing{animation:long-press-pulse .3s ease-in-out}.gesture-help-overlay{position:fixed;inset:0;background-color:#000000eb;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--space-lg);animation:fade-in .3s ease}.gesture-help-content{background-color:var(--color-bg-secondary);border-radius:var(--radius-xl);padding:var(--space-2xl);max-width:400px;width:100%;max-height:85vh;overflow-y:auto;animation:scale-in .3s ease}.gesture-help-content h2{text-align:center;color:var(--color-primary);margin-bottom:var(--space-2xl);font-size:var(--font-size-2xl)}.gesture-list{display:flex;flex-direction:column;gap:var(--space-xl);margin-bottom:var(--space-2xl)}.gesture-item{display:flex;gap:var(--space-lg);align-items:flex-start}.gesture-icon{font-size:28px;flex-shrink:0;width:48px;text-align:center}.gesture-info strong{display:block;font-size:var(--font-size-lg);margin-bottom:var(--space-xs);color:var(--color-text-primary)}.gesture-info p{margin:0;font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-normal)}.gesture-help-dismiss{width:100%;min-height:var(--touch-target-comfortable);background-color:var(--color-primary);color:var(--color-bg-primary);border:none;border-radius:var(--radius-lg);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast)}.gesture-help-dismiss:active{transform:scale(.98);opacity:.9}.swipe-indicator{position:absolute;top:50%;transform:translateY(-50%);padding:var(--space-md) var(--space-lg);background-color:#000000b3;color:var(--color-text-primary);font-size:var(--font-size-sm);border-radius:var(--radius-md);pointer-events:none;opacity:0;transition:opacity .2s ease;z-index:100}.swipe-indicator.left{left:var(--space-lg)}.swipe-indicator.right{right:var(--space-lg)}.swipe-indicator.visible{opacity:1}@keyframes board-flip{0%{transform:rotateY(0)}50%{transform:rotateY(90deg)}to{transform:rotateY(0)}}.chess-board.flipping{animation:board-flip .4s ease-in-out}@media(max-width:767px){.gesture-instructions{display:block;position:fixed;bottom:calc(64px + var(--space-lg));left:50%;transform:translate(-50%);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border-primary);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-lg);font-size:var(--font-size-xs);color:var(--color-text-secondary);z-index:var(--z-elevated);white-space:nowrap;animation:fade-in .3s ease}.gesture-instructions.hidden{display:none}}@media(min-width:768px){.gesture-instructions,.gesture-help-overlay{display:none}}.update-banner{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background-color:var(--color-primary);color:var(--color-bg-primary);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-toast);display:flex;align-items:center;gap:var(--space-md);max-width:90%;animation:slide-up .3s ease}.update-banner p{margin:0;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm)}.update-banner button{padding:var(--space-sm) var(--space-md);border:none;border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);cursor:pointer;min-height:36px;font-size:var(--font-size-sm);transition:all var(--transition-fast)}.update-banner button:first-of-type{background-color:var(--color-bg-primary);color:var(--color-primary)}.update-banner button:last-of-type{background-color:transparent;color:var(--color-bg-primary);border:1px solid var(--color-bg-primary)}.install-prompt{position:fixed;bottom:80px;left:var(--space-lg);right:var(--space-lg);background-color:var(--color-bg-secondary);border:1px solid var(--color-border-primary);border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:var(--shadow-xl);z-index:var(--z-toast);animation:slide-up .3s ease}@media(min-width:768px){.install-prompt{left:50%;right:auto;transform:translate(-50%);max-width:400px;bottom:var(--space-2xl)}}.install-content{display:flex;flex-direction:column;gap:var(--space-lg);text-align:center}.install-icon{display:flex;justify-content:center}.install-text h3{margin:0 0 var(--space-sm) 0;font-size:var(--font-size-lg);color:var(--color-primary)}.install-text p{margin:0;font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-normal)}.install-actions{display:flex;gap:var(--space-md)}.install-actions button{flex:1;min-height:var(--touch-target-comfortable);border-radius:var(--radius-lg);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast)}.install-actions .btn-primary{background-color:var(--color-primary);color:var(--color-bg-primary);border:none}.install-actions .btn-primary:active{transform:scale(.98)}.install-actions .btn-secondary{background-color:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border-primary)}.install-actions .btn-secondary:active{background-color:var(--color-bg-tertiary)}.offline-indicator{position:fixed;top:var(--space-lg);left:50%;transform:translate(-50%);background-color:var(--color-warning);color:var(--color-bg-primary);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);z-index:var(--z-toast);animation:slide-down .3s ease;display:flex;align-items:center;gap:var(--space-sm);box-shadow:var(--shadow-lg)}@keyframes slide-down{0%{transform:translate(-50%) translateY(-100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}@media(display-mode:standalone){body{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.install-prompt{display:none!important}}@media(display-mode:standalone)and (max-width:767px){.mobile-nav{padding-bottom:env(safe-area-inset-bottom)}}*:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.hide-mobile,.hide-tablet,.hide-desktop{display:block}.show-mobile-only,.show-tablet-only,.show-desktop-only{display:none}@media(max-width:767px){:root{--font-size-base: 14px}.app-container{padding:var(--spacing-sm)}.hide-mobile{display:none!important}.show-mobile-only{display:block!important}}@media(min-width:768px)and (max-width:1023px){.hide-tablet{display:none!important}.show-tablet-only{display:block!important}}@media(min-width:1024px){.hide-desktop{display:none!important}.show-desktop-only{display:block!important}}.responsive-container{width:100%;max-width:var(--container-mobile);margin:0 auto;padding:0 var(--spacing-sm)}@media(min-width:768px){.responsive-container{max-width:var(--container-tablet);padding:0 var(--spacing-md)}}@media(min-width:1024px){.responsive-container{max-width:var(--container-desktop);padding:0 var(--spacing-lg)}}.touch-button{min-height:var(--touch-target-min);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);border:none;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs)}.mobile-scroll{-webkit-overflow-scrolling:touch;overflow-y:auto;overscroll-behavior:contain}.safe-area-bottom{padding-bottom:env(safe-area-inset-bottom,0)}.safe-area-top{padding-top:env(safe-area-inset-top,0)}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-col{display:flex;flex-direction:column}.flex-wrap{flex-wrap:wrap}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.text-center{text-align:center}.text-muted{color:var(--text-secondary)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.bottom-sheet{animation:slideUp .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .2s ease-out}.chess-board-container{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);width:100%;max-width:100vw;overflow-x:hidden;box-sizing:border-box}.chess-board{border:2px solid #333;border-radius:var(--radius-sm);overflow:hidden;box-shadow:0 4px 12px #0006;margin:0 auto;max-width:100%}@media(max-width:767px){.chess-board-container{padding:var(--spacing-sm)}.game-view{width:100%;max-width:100vw;overflow-x:hidden}}.mobile-nav{position:fixed;bottom:0;left:0;right:0;height:64px;background:#1a1a1af2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-top:1px solid var(--color-border-primary);display:none;justify-content:space-around;align-items:center;padding:0 var(--space-sm);z-index:var(--z-modal);box-shadow:0 -2px 10px #0000004d}@media(max-width:767px){.mobile-nav{display:flex;animation:slide-up .3s ease}.app-container{padding-bottom:80px}}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;transition:color var(--transition-base),transform var(--transition-fast);min-width:64px;min-height:var(--touch-target-comfortable);-webkit-tap-highlight-color:transparent;user-select:none}.mobile-nav-item.active{color:var(--color-primary)}.mobile-nav-item:active{transform:scale(.95)}.mobile-nav-icon{font-size:var(--font-size-2xl);line-height:1;display:block}.mobile-nav-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);line-height:1;display:block;white-space:nowrap}.chess-square{position:relative;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .15s ease,box-shadow .15s ease,transform .1s ease;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.chess-square:active{transform:scale(.97)}.chess-square.selected{z-index:10}.chess-square.invalid{animation:flash-invalid .3s ease}@keyframes flash-invalid{0%,to{background-color:inherit}50%{background-color:#f009!important}}.chess-square.in-check{animation:pulse-check 1s ease-in-out infinite}@keyframes pulse-check{0%,to{box-shadow:inset 0 0 0 3px #ff0000e6}50%{box-shadow:inset 0 0 0 3px #f006}}.chess-square img{pointer-events:none;user-select:none;-webkit-user-select:none;-webkit-user-drag:none}@media(min-width:768px){.chess-square img{pointer-events:auto;cursor:grab}.chess-square img:active{cursor:grabbing}}.legal-move-dot,.legal-move-ring{pointer-events:none}@keyframes piece-appear{0%{opacity:.5;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.chess-square.has-piece.last-move img{animation:piece-appear .2s ease}.mobile-lobby{padding:0 var(--space-lg) var(--space-lg);max-width:600px;margin:0 auto;width:100%}.lobby-card{background-color:var(--color-bg-secondary);border:1px solid var(--color-border-primary);border-radius:var(--radius-lg);padding:var(--space-xl);margin-bottom:var(--space-lg);box-shadow:var(--shadow-md)}.lobby-card h2,.lobby-card h3{margin:0 0 var(--space-lg) 0;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.lobby-card-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.lobby-card-header h3{margin:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.lobby-card-icon{font-size:var(--font-size-2xl);line-height:1}.time-control-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-sm);margin-bottom:var(--space-lg)}.time-control{background-color:var(--color-bg-tertiary);border:2px solid var(--color-border-secondary);border-radius:var(--radius-md);padding:var(--space-md) var(--space-sm);cursor:pointer;touch-action:manipulation;transition:all var(--transition-base);-webkit-tap-highlight-color:transparent;text-align:center;min-height:var(--touch-target-min)}.time-control:active{transform:scale(.97)}.time-control.active{background-color:var(--color-primary);border-color:var(--color-primary)}.time-control.active .time-label,.time-control.active .time-value{color:var(--color-bg-primary)}.time-label{font-size:var(--font-size-base);font-weight:var(--font-weight-bold);color:var(--color-text-primary);display:block}.time-control.active .time-label{color:var(--color-bg-primary)}.time-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.btn-lobby{width:100%;min-height:var(--button-height-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-base);-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center;gap:var(--space-sm)}.btn-lobby:active{transform:scale(.98)}.btn-lobby-primary{background-color:var(--color-primary);color:var(--color-bg-primary)}.btn-lobby-primary:active{background-color:var(--color-primary-dark)}.btn-lobby-primary:disabled{background-color:var(--color-bg-elevated);color:var(--color-text-disabled);cursor:not-allowed}.btn-lobby-secondary{background-color:var(--color-bg-elevated);color:var(--color-text-primary);border:1px solid var(--color-border-secondary)}.btn-lobby-secondary:active{background-color:var(--color-border-secondary)}.btn-lobby-secondary:disabled{opacity:.5;cursor:not-allowed}.lobby-button-group,.lobby-button-stack{display:flex;flex-direction:column;gap:var(--space-md)}.lobby-divider{text-align:center;color:var(--color-text-tertiary);font-size:var(--font-size-sm);margin:var(--space-xs) 0}.room-code-input{display:flex;gap:var(--space-sm)}.room-code-input input{flex:1;height:var(--input-height);background-color:var(--color-bg-tertiary);border:2px solid var(--color-border-secondary);border-radius:var(--radius-md);padding:0 var(--space-lg);color:var(--color-text-primary);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);text-align:center;text-transform:uppercase;letter-spacing:2px}.room-code-input input::placeholder{color:var(--color-text-disabled);text-transform:none;letter-spacing:normal;font-weight:var(--font-weight-regular)}.room-code-input input:focus{outline:none;border-color:var(--color-border-focus)}.room-code-input button{min-width:80px;height:var(--input-height)}.lobby-rating-display{margin:var(--space-md) 0 0 0;text-align:center;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.puzzle-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);padding:var(--space-md);background-color:var(--color-bg-tertiary);border-radius:var(--radius-md)}.puzzle-number{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary)}.puzzle-streak{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.lobby-error-message{background-color:#ff6b6b1a;border:1px solid rgba(255,107,107,.3);color:var(--color-error);padding:var(--space-md);border-radius:var(--radius-md);margin-top:var(--space-md);font-size:var(--font-size-sm);text-align:center}.lobby-success-message{background-color:#81b64c1a;border:1px solid rgba(129,182,76,.3);color:var(--color-success);padding:var(--space-md);border-radius:var(--radius-md);margin-top:var(--space-md);font-size:var(--font-size-sm);text-align:center}.lobby-searching{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-lg);background-color:var(--color-bg-tertiary);border-radius:var(--radius-md);margin-top:var(--space-md)}.lobby-searching-spinner{width:var(--space-xl);height:var(--space-xl);border:2px solid var(--color-border-secondary);border-top-color:var(--color-primary);border-radius:var(--radius-full);animation:spin 1s linear infinite}.variant-selector{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-sm);margin-bottom:var(--space-lg)}.variant-option{background-color:var(--color-bg-tertiary);border:2px solid var(--color-border-secondary);border-radius:var(--radius-md);padding:var(--space-md);cursor:pointer;transition:all var(--transition-base);min-height:var(--touch-target-min);text-align:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.variant-option:active{transform:scale(.97)}.variant-option.active,.variant-btn.active{background-color:var(--accent-purple);border-color:var(--accent-purple);color:var(--color-text-primary)}.variant-btn{background-color:var(--color-bg-tertiary);border:2px solid var(--color-border-secondary);border-radius:var(--radius-md);padding:var(--space-md);cursor:pointer;transition:all var(--transition-base);text-align:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);-webkit-tap-highlight-color:transparent;min-height:var(--touch-target-min)}.variant-btn:active{transform:scale(.97)}.time-desc{font-size:var(--font-size-xs);color:var(--color-text-tertiary);display:block;margin-top:var(--space-xs)}.time-control.active .time-desc{color:var(--color-bg-secondary)}@media(min-width:768px){.mobile-lobby{display:none}}@media(max-width:767px){.desktop-lobby{display:none}}
