*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f8f9fa;color:#333;line-height:1.5}#root{min-height:100vh;display:flex;justify-content:center;align-items:flex-start;padding:2rem}.App{background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;display:flex;max-width:1400px;width:100%;min-width:1100px;overflow:hidden;align-items:stretch}.GobanSection{display:flex;flex-direction:column;align-items:center;background:#fafafa;border-right:1px solid #e5e7eb;padding:1rem;height:600px}.ButtonRow{display:flex;gap:1rem;margin-bottom:1rem;align-items:center}.PlayModeButtons{display:flex;gap:.5rem;align-items:center}.StoneButton{background:none;border:none;padding:.5rem;cursor:pointer;border-radius:50%;transition:background-color .15s;display:flex;align-items:center;justify-content:center}.StoneButton:hover{background:#0000000d}.StoneButton[data-state=on]{background:#3b82f61a;outline:2px solid #3b82f6}.stone-circle{width:16px;height:16px;border-radius:50%;position:relative}.black-stone{background:#1f2937;border:1px solid #111827}.white-stone{background:#f9fafb;border:1px solid #d1d5db}.mixed-stone{overflow:hidden}.half-black,.half-white{position:absolute;width:50%;height:100%;top:0}.half-black{left:0;background:#1f2937;border-radius:50% 0 0 50%}.half-white{right:0;background:#f9fafb;border-radius:0 50% 50% 0;border-left:1px solid #d1d5db}.Goban{display:flex;align-items:center;justify-content:center;flex:1}.GobanSvg{width:min(70vh,500px);height:min(70vh,500px);min-width:400px;min-height:400px;aspect-ratio:1}.GobanSvgCoord{font:.02em Roboto;-webkit-user-select:none;user-select:none;text-anchor:middle;dominant-baseline:middle;fill:#666}.VariationNumber{font:.04em Roboto;-webkit-user-select:none;user-select:none;text-anchor:middle;dominant-baseline:middle}.DirectoryPanel{width:250px;padding:1rem;background:#f8f9fa;border-right:1px solid #e5e7eb;overflow-y:auto;display:flex;flex-direction:column;height:600px}.DirectoryPanel .panel-title{font-size:.875rem;font-weight:600;color:#4b5563;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.025em}.DirItem,.DirItemSelected,.FileItem,.FileItemSelected{padding:.375rem .5rem;margin:.125rem 0;border-radius:4px;cursor:pointer;transition:background-color .15s;font-size:.8125rem;display:block;text-decoration:none;border:none;background:transparent;text-align:left;width:100%;color:#374151}.DirItem:hover,.FileItem:hover{background:#e5e7eb}.DirItemSelected,.FileItemSelected{background:#3b82f6;color:#fff;font-weight:500}.DirItemSelected:hover,.FileItemSelected:hover{background:#2563eb}.SidePanel{width:260px;padding:1.5rem;background:#fff;border-right:1px solid #e5e7eb;overflow-y:auto;display:flex;flex-direction:column;height:600px}.login-row,.new-doc-row{display:flex;gap:.5rem;margin-bottom:1rem}.login-row input,.new-doc-row input{flex:1;padding:.5rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem}.login-row input:focus,.new-doc-row input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.login-row button,.new-doc-row button{padding:.5rem 1rem;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:.875rem;cursor:pointer;transition:background-color .15s;white-space:nowrap}.login-row button:hover,.new-doc-row button:hover{background:#2563eb}.login-row [data-radix-form-message],.new-doc-row [data-radix-form-message]{color:#dc2626;font-size:.75rem;margin-top:.25rem}.SidePanel input{width:100%;padding:.5rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;margin-bottom:.5rem}.SidePanel input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.SidePanel button{background:#3b82f6;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;cursor:pointer;margin-bottom:1rem;transition:background-color .15s}.SidePanel button:hover{background:#2563eb}.upload-button{width:100%;margin-bottom:1rem}.side-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.side-panel-title{font-size:1.25rem;font-weight:600;color:#0f172a;margin:0}.user-menu-trigger{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:2px solid #e5e7eb;background:#fff;cursor:pointer;transition:all .2s;padding:0}.user-menu-trigger:hover{border-color:#94a3b8;background:#f8fafc}.user-menu-trigger:focus{outline:none;box-shadow:0 0 0 2px #3b82f680}.user-icon{color:#64748b}.user-avatar{font-size:1rem;font-weight:600;color:#fff;background:#3b82f6;width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-radius:50%}.user-menu-content{min-width:220px;background:#fff;border-radius:8px;padding:.5rem;box-shadow:0 10px 38px -10px #16171859,0 10px 20px -15px #16171833;animation:slideDownAndFade .2s ease-out;z-index:1000}@keyframes slideDownAndFade{0%{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}.user-menu-info{padding:.75rem;background:#f0f9ff;border-radius:4px;margin-bottom:.25rem}.user-menu-name{font-weight:600;color:#0f172a;font-size:.875rem;margin-bottom:.25rem}.user-menu-email{font-size:.75rem;color:#64748b}.user-menu-separator{height:1px;background:#e5e7eb;margin:.5rem -.5rem}.user-menu-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;border-radius:4px;cursor:pointer;outline:none;transition:background .2s;font-size:.875rem;color:#0f172a}.user-menu-item:hover{background:#f1f5f9}.user-menu-item:focus{background:#e2e8f0}.user-menu-item.oauth-disabled{opacity:.5;cursor:not-allowed}.user-menu-icon{flex-shrink:0}.user-menu-login-form{padding:.5rem;display:flex;flex-direction:column;gap:.5rem}.user-menu-input{width:100%;padding:.5rem;border:1px solid #e5e7eb;border-radius:4px;font-size:.875rem;transition:border-color .2s}.user-menu-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.user-menu-login-btn{width:100%;padding:.5rem;background:#3b82f6;color:#fff;border:none;border-radius:4px;font-size:.875rem;cursor:pointer;transition:background .2s}.user-menu-login-btn:hover{background:#2563eb}.google-login{padding-left:.75rem}.Game,.GameSelected,.GameDir,.GameDirSelected{padding:.5rem .75rem;margin:.125rem 0;border-radius:6px;cursor:pointer;transition:all .15s ease;font-size:.875rem;display:block;text-decoration:none;border-left:3px solid transparent;border-right:none;border-top:none;border-bottom:none;background:transparent;text-align:left;width:100%;position:relative}.Game:hover,.GameDir:hover{background:#f3f4f6}.GameSelected,.GameDirSelected{background:linear-gradient(90deg,#3b82f6,#f0f9ff 3px 100%);color:#0f172a;font-weight:500}.GameSelected .event-name-frame{color:#0f172a;font-weight:600;border-color:#3b82f6;background-color:#e0f2fe}.GameSelected .game-date{color:#1e293b;font-weight:500;border-color:#bfdbfe;background-color:#fff}.GameSelected .result{color:#475569;font-weight:500;border-color:#bfdbfe;background-color:#fff}.GameSelected .result:hover{color:#1e293b;border-color:#93c5fd;background-color:#f8fafc}.GameSelected:hover,.GameDirSelected:hover{background:linear-gradient(90deg,#2563eb,#bfdbfe 3px 100%)}.game-info{display:flex;flex-direction:column;gap:4px}.date-result-row{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px}.player-names{display:flex;flex-direction:column;gap:2px}.white-player{background-color:#fff;color:#000;padding:4px 8px;border-radius:4px;border:1px solid #e5e7eb;font-weight:500}.black-player{background-color:#000;color:#fff;padding:4px 8px;border-radius:4px;font-weight:500}.rank{font-size:.75rem;font-weight:400;opacity:.7}.white-player .rank,.black-player .rank{color:inherit;opacity:.7}.GameSelected .rank{opacity:.8;color:#64748b}.GameSelected .white-player .rank,.GameSelected .black-player .rank{color:inherit;opacity:.8}.game-name{padding:4px 8px;font-style:italic;color:#6b7280}.game-metadata{display:flex;flex-direction:column;gap:2px;margin-top:4px;font-size:.75rem;color:#6b7280}.event-name-frame{font-weight:600;color:#1f2937;font-size:.8rem;width:100%;border:1px solid #d1d5db;border-radius:4px;padding:4px 8px;background-color:#f0f9ff;margin-bottom:4px}.game-date{color:#374151;font-size:.75rem;font-weight:500;white-space:nowrap;flex-shrink:0;padding:2px 6px;border:1px solid #e5e7eb;border-radius:3px;background-color:#f9fafb}.handicap{background-color:#fbbf24;color:#78350f;padding:2px 6px;border-radius:3px;display:inline-block;width:fit-content;font-weight:600;font-size:.75rem}.result{font-weight:500;color:#6b7280;cursor:pointer;font-size:.75rem;transition:all .2s ease;width:3rem;text-align:center;padding:2px 6px;border:1px solid #e5e7eb;border-radius:3px;background-color:#f9fafb;box-sizing:border-box}.result:hover{color:#374151;border-color:#d1d5db;background-color:#f3f4f6}.GameDoc{width:300px;padding:1.5rem;overflow-y:auto;background:#fff;font-size:.875rem;display:flex;flex-direction:column;height:600px}.GameEvent{display:flex;align-items:center;gap:.5rem;padding:.25rem 0}.ClickModeButton{padding:.5rem 1rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;cursor:pointer;font-size:.875rem;transition:all .15s ease;text-align:center}.ClickModeButton:hover{background:#f9fafb;border-color:#9ca3af}.ClickModeButton[data-state=on]{background:#3b82f61a;border-color:#3b82f6;color:#1d4ed8}.DisplayModeContainer{display:flex;gap:.5rem;align-items:center;margin-left:1rem}.DisplayModeToggle{display:flex;gap:.5rem;align-items:center}.DisplayModeButton{padding:.5rem 1rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;cursor:pointer;font-size:.875rem;transition:all .15s ease;text-align:center}.DisplayModeButton:hover{background:#f9fafb;border-color:#9ca3af}.DisplayModeButton[data-state=on]{background:#22c55e1a;border-color:#22c55e;color:#15803d}.VariationDepthInput{width:60px;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;font-size:.875rem;transition:all .15s ease}.VariationDepthInput:hover{border-color:#9ca3af}.VariationDepthInput:focus{outline:none;border-color:#22c55e;box-shadow:0 0 0 2px #22c55e1a}.BlackMove,.WhiteMove{width:50px;padding:.25rem;border-radius:4px;text-align:center;font-size:.75rem;font-weight:500;border:none;cursor:pointer;transition:all .15s ease}.BlackMove{background:#1f2937;color:#fff}.BlackMove:hover{background:#374151}.BlackMove:focus,.BlackMove:focus-visible,.BlackMove:focus-within{outline:none!important;box-shadow:none!important}.WhiteMove{background:#f9fafb;color:#1f2937;border:1px solid #d1d5db}.WhiteMove:hover{background:#f3f4f6}.WhiteMove:focus,.WhiteMove:focus-visible,.WhiteMove:focus-within{outline:none!important;box-shadow:none!important}.BlackMove.variation-node{background:#6b7280;opacity:.85;font-style:italic}.BlackMove.variation-node:hover{background:#4b5563;opacity:1}.WhiteMove.variation-node{background:#e5e7eb;color:#4b5563;border:1px solid #9ca3af;opacity:.85;font-style:italic}.WhiteMove.variation-node:hover{background:#d1d5db;opacity:1}.DirectoryPanel::-webkit-scrollbar,.SidePanel::-webkit-scrollbar,.GameDoc::-webkit-scrollbar{width:6px}.DirectoryPanel::-webkit-scrollbar-track,.SidePanel::-webkit-scrollbar-track,.GameDoc::-webkit-scrollbar-track{background:transparent}.DirectoryPanel::-webkit-scrollbar-thumb,.SidePanel::-webkit-scrollbar-thumb,.GameDoc::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.DirectoryPanel::-webkit-scrollbar-thumb:hover,.SidePanel::-webkit-scrollbar-thumb:hover,.GameDoc::-webkit-scrollbar-thumb:hover{background:#9ca3af}.port-switcher-external{position:fixed;bottom:1rem;left:1rem;z-index:1000;background:#fff;padding:.75rem;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #e5e7eb}.port-switcher{display:flex;gap:.25rem;align-items:center}.port-button{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;padding:.5rem .75rem;border-radius:6px;font-size:.875rem;font-family:monospace;cursor:pointer;transition:all .15s}.port-button:hover{background:#e5e7eb;border-color:#9ca3af}.port-button.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.connection-waiting{display:flex;justify-content:center;align-items:center;min-height:50vh;font-size:1.125rem;color:#6b7280;background:#f8f9fa;margin:2rem;border-radius:12px;padding:2rem;text-align:center}@media (max-width: 768px){#root{padding:1rem}.App{flex-direction:column;min-height:auto}.SidePanel{flex:none}.Goban{min-height:400px}.backend-switcher-dropdown{left:-100px;min-width:280px}}.landing-page{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.landing-content{text-align:center;padding:2rem}.landing-title{font-size:4rem;font-weight:700;margin:0 0 1rem;text-shadow:2px 2px 4px rgba(0,0,0,.3);letter-spacing:-.02em}.landing-subtitle{font-size:1.5rem;font-weight:300;margin:0;opacity:.8;letter-spacing:.1em}@media (max-width: 768px){.landing-title{font-size:2.5rem}.landing-subtitle{font-size:1.2rem}}
