*{box-sizing:border-box}html{-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;min-height:100%}body,html{height:auto;max-width:100vw;overflow-x:hidden;overflow-y:auto;width:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;min-height:100vh;padding:0;position:relative}#root{max-width:100vw;overflow-x:hidden;width:100%}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{display:flex;flex-direction:column;height:100vh;max-width:100vw;overflow:hidden;text-align:center;width:100%}@media (max-width:768px){.App{height:auto!important;max-height:none!important;min-height:100vh;overflow-x:hidden;overflow-y:auto!important}}.App:has(.guest-banner){padding-top:0}.App-header{align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e);border-bottom:1px solid #ffffff14;box-shadow:0 4px 20px #0000004d;color:#fff;display:flex;flex-shrink:0;justify-content:space-between;left:0;padding:12px 24px;position:fixed;right:0;top:0;z-index:20}.App:has(.guest-banner) .App-header{top:85px;top:var(--guest-banner-height,85px)}.header-controls{align-items:center;display:flex;flex:1 1;gap:8px;justify-content:flex-end}.analysis-button,.builder-button,.export-pgn-button,.import-pgn-button,.view-variations-button{align-items:center;border:none;border-radius:20px;color:#fff;cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:6px;letter-spacing:.02em;line-height:1;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.export-pgn-button,.import-pgn-button{background:#ffffff1a;border:1px solid #fff3}.view-variations-button{background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 2px 8px #6366f14d}.analysis-button{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 8px #10b9814d}.builder-button{background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 2px 8px #6366f14d}.export-pgn-button:hover,.import-pgn-button:hover{background:#ffffff2e;border-color:#ffffff4d;transform:translateY(-1px)}.view-variations-button:hover{background:linear-gradient(135deg,#7c7ff7,#9d70fa);box-shadow:0 4px 12px #6366f166;transform:translateY(-1px)}.analysis-button:hover{background:linear-gradient(135deg,#34d399,#10b981);box-shadow:0 4px 12px #10b98166;transform:translateY(-1px)}.builder-button:hover{background:linear-gradient(135deg,#7c7ff7,#9d70fa);box-shadow:0 4px 12px #6366f166;transform:translateY(-1px)}.analysis-button:disabled,.builder-button:disabled,.export-pgn-button:disabled,.import-pgn-button:disabled,.view-variations-button:disabled{background:#ffffff0d;border-color:#ffffff1a;box-shadow:none;color:#fff6;cursor:not-allowed;transform:none}.btn-icon{align-items:center;display:flex;font-size:.95rem;justify-content:center}.btn-icon svg{height:16px;width:16px}.btn-text{font-size:.85rem}@media (max-width:768px){.btn-text{display:none}.analysis-button,.builder-button,.export-pgn-button,.import-pgn-button,.view-variations-button{border-radius:50%;height:36px;justify-content:center;padding:8px;width:36px}}.App-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#fffc);-webkit-background-clip:text;background-clip:text;font-size:1.4rem;font-weight:700;letter-spacing:-.02em;margin:0}.selected-repertoire-info{align-items:center;display:flex;font-size:14px;gap:12px}.color-indicator{border-radius:12px;font-size:12px;font-weight:500;padding:4px 8px;text-transform:capitalize}.color-indicator.white{background:#f8f9fa;border:1px solid #dee2e6;color:#495057}.color-indicator.black{background:#212529;color:#fff}.App-main{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden;position:relative}@media (max-width:768px){.App-main{height:auto;min-height:0;overflow:visible!important;overflow-y:auto!important}}.left-panel{background:linear-gradient(180deg,#1e1e2e,#1a1a2a);border-right:1px solid #ffffff14;height:calc(100vh - 60px);left:0;overflow-anchor:none;overflow-y:auto;position:fixed;top:60px;width:250px;z-index:10}.App:has(.guest-banner) .left-panel{height:calc(100vh - 145px);height:calc(100vh - var(--guest-banner-height, 85px) - 60px);top:145px;top:calc(var(--guest-banner-height, 85px) + 60px)}.center-panel{align-items:center;background:linear-gradient(135deg,#12121a,#1a1a24 50%,#0f1015);bottom:200px;display:flex;flex-direction:column;gap:12px;justify-content:flex-start;left:250px;min-height:0;overflow:hidden;padding:40px 20px 20px;position:fixed;right:0;top:60px;z-index:5}.App:has(.guest-banner) .center-panel{top:145px;top:calc(var(--guest-banner-height, 85px) + 60px)}.chess-board-container{align-items:center;display:flex;flex-direction:column;gap:15px;justify-content:center;margin:0 auto;max-width:800px;padding:10px;pointer-events:auto;position:relative;text-align:center;width:100%;z-index:10}.chess-board-wrapper{display:inline-block;position:relative}@media (max-width:768px){.chess-board-container{gap:10px;max-width:100%;padding:5px}}.flip-board-button{align-items:center;background:#ffffff1a;border:1px solid #ffffff26;border-radius:10px;bottom:0;color:#fff;cursor:pointer;display:flex;font-size:16px;height:34px;justify-content:center;opacity:.7;padding:0;pointer-events:auto;position:absolute;right:-40px;transition:all .2s ease;width:34px;z-index:20}.flip-board-button:hover{background:#6366f133;border-color:#6366f166;opacity:1;transform:scale(1.1)}@media (max-width:768px){.flip-board-button{display:none!important}.mobile-nav-controls{display:flex!important;flex-shrink:0;gap:10px;justify-content:center;margin-bottom:5px;margin-top:10px;max-width:100%;padding:0 10px;position:relative;width:100%;z-index:10}.mobile-nav-button{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:12px;box-shadow:0 2px 8px #6366f14d;color:#fff;cursor:pointer;display:flex;flex:1 1;font-size:.9rem;font-weight:600;height:44px;justify-content:center;max-width:150px;min-height:44px;min-width:0;padding:10px 16px;transition:all .2s ease;white-space:nowrap;width:100%}.mobile-nav-button:hover:not(:disabled){background:linear-gradient(135deg,#7c7ff7,#9d70fa);transform:translateY(-1px)}.mobile-nav-button:disabled{background:#ffffff1a;box-shadow:none;cursor:not-allowed;opacity:.5}}@media (min-width:769px){.mobile-nav-controls{display:none!important}}.board-controls{align-items:center;display:flex;flex-shrink:0;flex-wrap:wrap;gap:10px;justify-content:center}.nav-button{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:12px;box-shadow:0 2px 8px #6366f14d;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;min-width:80px;padding:8px 16px;transition:all .2s ease}.nav-button:hover:not(:disabled){background:linear-gradient(135deg,#7c7ff7,#9d70fa);box-shadow:0 4px 12px #6366f166;transform:translateY(-1px)}.nav-button:disabled{background:#ffffff1a;box-shadow:none;cursor:not-allowed;opacity:.5}.move-history-info{color:#fff9;display:flex;flex-direction:column;flex-shrink:0;font-size:.9rem;gap:5px;text-align:center}.current-position{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;color:#ffffff80;font-family:SF Mono,Monaco,monospace;font-size:.8rem;padding:4px 10px}.right-panel{background-color:#f5f5f5;border-left:1px solid #ddd;display:none;height:calc(100vh - 70px);overflow-y:auto;padding:10px;top:70px;width:300px}.bottom-panel,.right-panel{position:fixed;right:0;z-index:10}.bottom-panel{background:linear-gradient(180deg,#1e1e2e,#1a1a2a);border-top:1px solid #ffffff14;bottom:0;height:200px;left:250px}@media (max-width:1200px){.right-panel{display:none}.center-panel{margin-right:0}.bottom-panel{right:0}}.loading-indicator{background:#e3f2fd;border:1px solid #bbdefb;border-radius:6px;margin:8px 0;padding:12px;text-align:center}.loading-indicator p{color:#1976d2;font-size:14px;margin:0}.error-indicator{background:#ffebee;border:1px solid #ffcdd2;border-radius:6px;margin:8px 0;padding:12px;text-align:center}.error-indicator p{color:#d32f2f;font-size:14px;margin:0}@media (max-width:768px){.App-header{left:0!important;position:relative!important;right:0!important;top:0!important;z-index:auto!important}.App:has(.guest-banner) .App-header{top:0!important}.guest-banner{position:relative!important;top:0!important;z-index:auto!important}.App-main{-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;height:auto!important;margin:0;max-height:none!important;min-height:100vh;overflow-x:hidden;overflow-y:auto!important;overflow:visible!important;padding:0;position:relative;scroll-behavior:auto!important;scroll-snap-type:none!important;width:100%}.center-panel{align-items:center!important;background:linear-gradient(135deg,#12121a,#1a1a24 50%,#0f1015)!important;display:flex!important;flex-direction:column!important;flex-shrink:0!important;justify-content:flex-start!important;left:0!important;margin:0 auto!important;min-height:50vh!important;order:2!important;overflow:visible!important;padding:10px!important;position:relative!important;right:0!important;text-align:center!important;top:0!important;width:100%!important;z-index:2!important}.center-panel>.position-label-container{align-self:flex-start!important;flex-shrink:0!important;margin:0 auto 8px 0!important}.left-panel{border-right:none!important;min-height:0!important;order:1!important;top:0!important}.bottom-panel,.left-panel{background:linear-gradient(180deg,#1e1e2e,#1a1a2a)!important;border-top:1px solid #ffffff14!important;flex-shrink:0!important;height:auto!important;left:0!important;max-height:none!important;overflow-y:visible!important;padding:0!important;position:relative!important;width:100%!important;z-index:1!important}.bottom-panel{bottom:0!important;display:block!important;margin:0!important;min-height:200px!important;opacity:1!important;order:3!important;overflow-x:hidden!important;right:0!important;visibility:visible!important}.chess-board-container{box-sizing:border-box!important;flex:0 0 auto!important;flex-direction:column!important;margin:0 auto!important;max-height:none!important;max-width:100vw!important;min-height:0!important;padding:0!important;text-align:center!important;width:100%!important}.chess-board-container,.chess-board-container>div{align-items:center!important;display:flex!important;justify-content:center!important;overflow:visible!important}.chess-board-container>div{max-width:none!important;width:auto!important}.chess-board-container canvas,.chess-board-container svg{height:auto!important;max-width:none!important;overflow:visible!important;width:auto!important}.chess-board-container [style*=width]{overflow:visible!important}.App-header{flex-direction:column;gap:8px;padding:8px 12px}.App-header h1{font-size:.95rem;text-align:center}.header-controls{gap:6px;justify-content:center;width:100%}.view-variations-button{font-size:.8rem;min-height:36px;padding:.4rem .8rem}.board-controls{flex-wrap:wrap;gap:8px}.nav-button{font-size:.9rem;min-width:80px;padding:10px 16px}.nav-button,.repertoire-item,button{min-height:44px}.move-item{min-height:24px}.selector-dropdown{max-width:360px;right:10px;width:calc(100vw - 20px)}}@media (max-width:480px){.App-header h1{font-size:.85rem}.header-controls{gap:4px}.analysis-button,.builder-button,.export-pgn-button,.import-pgn-button,.view-variations-button{height:32px;padding:6px;width:32px}.left-panel{max-height:35vh}.bottom-panel{display:block!important;max-height:none!important;min-height:200px!important;position:relative!important;visibility:visible!important}.nav-button{font-size:.85rem;min-width:70px;padding:8px 12px}}.loading-screen{align-items:center;background-color:#fafafa;color:#282c34;display:flex;flex-direction:column;justify-content:center;min-height:100vh;text-align:center}.loading-screen h1{font-size:2.5rem;margin-bottom:20px}.loading-screen p{color:#666;font-size:1.2rem;opacity:.7}.modal-overlay{background:#00000080}.auth-modal-content{background:#fff;border-radius:8px;box-shadow:0 20px 40px #0000004d;max-height:90vh;max-width:700px;overflow-y:auto;width:95%}.auth-modal-content .login-container,.auth-modal-content .register-container{padding:0}.auth-modal-content .login-container .login-card,.auth-modal-content .register-container .register-card{box-shadow:none;margin:0}.auth-modal-content .WelcomeSection{display:none}.engine-eval{gap:6px;height:28px;padding:0 2px;pointer-events:auto}.engine-eval,.engine-toggle{align-items:center;display:flex}.engine-toggle{background:#ffffff0f;border:1px solid #ffffff26;border-radius:5px;color:#fff6;cursor:pointer;flex-shrink:0;height:24px;justify-content:center;padding:0;transition:all .2s ease;width:24px}.engine-toggle:hover{background:#ffffff1a;border-color:#ffffff40;color:#ffffffb3}.engine-toggle--active{background:#6366f133;border-color:#6366f166;color:#a5b4fc}.engine-toggle--active:hover{background:#6366f14d;color:#c7d2fe}.engine-score{align-items:center;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:5px;color:#e2e8f0;display:flex;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:12px;gap:5px;line-height:1;padding:2px 8px;white-space:nowrap}.engine-score-value{font-weight:600}.engine-score-depth{color:#ffffff59;font-size:10px}.engine-thinking-dot{animation:engine-pulse 1s ease-in-out infinite;background:#6366f1;border-radius:50%;height:5px;width:5px}@keyframes engine-pulse{0%,to{opacity:.3}50%{opacity:1}}@media (max-width:768px){.engine-eval{height:24px}.engine-toggle{height:22px;width:22px}.engine-toggle svg{height:12px;width:12px}.engine-score{font-size:11px;padding:2px 6px}.engine-score-depth{font-size:9px}}.move-list{display:flex;flex-direction:column;height:100%;padding:15px}.move-list h3{border-bottom:2px solid #6366f180;color:#fff;font-size:1.1rem;font-weight:600;letter-spacing:.02em;margin:0 0 15px;padding-bottom:10px}.move-list h4{border-bottom:1px solid #ffffff1a;color:#ffffffb3;font-size:.85rem;font-weight:600;letter-spacing:.05em;margin:20px 0 10px;padding-bottom:6px;text-transform:uppercase}.moves-container{flex:1 1;margin-bottom:15px;overflow-y:auto}.moves-container h4{border-bottom:1px solid #ffffff1a;color:#fff9;font-size:.85rem;margin:0 0 10px;padding-bottom:5px}.available-moves{height:300px;margin-bottom:20px;overflow-y:auto}.move-item{align-items:center;background:#ffffff0d;border:1px solid #ffffff14;border-radius:10px;cursor:pointer;display:flex;margin:8px 0;padding:12px 14px;position:relative;transition:all .2s ease}.move-item:hover{border-color:#6366f166;box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.move-item.current-move{background:linear-gradient(135deg,#6366f140,#8b5cf633);border-color:#6366f180;box-shadow:0 2px 8px #6366f133}.move-item.current-move:hover{box-shadow:0 4px 14px #6366f14d;transform:translateY(-2px)}.move-item.available-move{background:#6366f11a;border:1px solid #6366f14d}.move-item.available-move:hover{background:#6366f133;border-color:#6366f180;box-shadow:0 4px 12px #6366f140;transform:translateY(-2px)}.move-item.transposition-move{background:#10b9811a;border-color:#10b98166}.move-item.transposition-move:hover{background:#10b98133;border-color:#10b98199}.transposition-badge{color:#34d399;display:inline-block;font-size:1rem;font-weight:700;line-height:1;margin-left:8px;vertical-align:middle}.move-text{align-items:center;display:flex;justify-content:flex-start;padding:4px 0}.move-actions{margin-left:auto}.delete-move-btn{background:#ffffff14;border:none;border-radius:8px;color:#fff9;cursor:pointer;font-size:1rem;font-weight:700;padding:6px 10px;transition:all .2s ease}.delete-move-btn:hover{background:#ef444433;color:#f87171;transform:scale(1.1)}.move-number{color:#6366f1e6;font-size:.9rem;font-weight:600;margin-right:12px;min-width:32px}.move-notation{color:#fff;font-size:1.1rem;font-weight:700;letter-spacing:.5px}.move-annotation{display:inline-block;font-size:1rem;font-weight:700;line-height:1;margin-left:4px;vertical-align:middle}.annotation-good{color:#22c55e}       /* ! green */.annotation-brilliant{color:#facc15}   /* !! gold */.annotation-mistake{color:#f97316}.annotation-blunder{color:#ef4444}.annotation-interesting{color:#06b6d4} /* !? cyan */.annotation-dubious{color:#fb923c}.annotate-move-btn{background:#ffffff14;border:none;border-radius:6px;color:#ffffff80;cursor:pointer;font-size:.85rem;font-weight:700;margin-right:4px;padding:4px 8px;transition:all .2s ease}.annotate-move-btn:hover{background:#6366f133;color:#ffffffe6}.move-item.annotation-menu-open{z-index:10}.annotation-menu{background:linear-gradient(180deg,#2a2a3e,#1e1e2e);border:1px solid #ffffff26;border-radius:8px;box-shadow:0 8px 24px #0006;display:flex;gap:2px;padding:6px;position:absolute;right:0;top:100%;z-index:100}.annotation-option{background:#ffffff14;border:1px solid #ffffff1a;border-radius:6px;color:#fffc;cursor:pointer;font-size:.85rem;font-weight:700;min-width:28px;padding:4px 8px;text-align:center;transition:all .15s ease}.annotation-option:hover{background:#6366f14d;border-color:#6366f180;color:#fff;transform:scale(1.1)}.annotation-option.active{background:#6366f166;border-color:#6366f199;color:#fff}.annotation-option.annotation-good.active,.annotation-option.annotation-good:hover{color:#22c55e}.annotation-option.annotation-brilliant.active,.annotation-option.annotation-brilliant:hover{color:#facc15}.annotation-option.annotation-mistake.active,.annotation-option.annotation-mistake:hover{color:#f97316}.annotation-option.annotation-blunder.active,.annotation-option.annotation-blunder:hover{color:#ef4444}.annotation-option.annotation-interesting.active,.annotation-option.annotation-interesting:hover{color:#06b6d4}.annotation-option.annotation-dubious.active,.annotation-option.annotation-dubious:hover{color:#fb923c}.annotation-clear{color:#ffffff80;font-size:.7rem;font-weight:600}.annotation-clear:hover{background:#ef444433;border-color:#ef44444d;color:#f87171}.move-details{color:#ffffff80;display:flex;flex-direction:column;font-size:.8rem;gap:2px}.move-from-to{background:#ffffff14;border-radius:4px;color:#fff9;display:inline-block;font-family:SF Mono,Monaco,Courier New,monospace;font-size:.75rem;font-weight:500;padding:2px 6px}.capture-indicator{color:#f87171;font-style:italic}.no-moves{color:#ffffff80;margin-top:20px;text-align:center}.no-moves p{margin:5px 0}.no-available-moves{color:#ffffff80;font-style:italic;padding:20px;text-align:center}.no-available-moves p{margin:0}.game-status{color:#818cf8;font-size:1rem;font-weight:700}.available-moves::-webkit-scrollbar,.moves-container::-webkit-scrollbar{width:6px}.available-moves::-webkit-scrollbar-track,.moves-container::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.available-moves::-webkit-scrollbar-thumb,.moves-container::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.available-moves::-webkit-scrollbar-thumb:hover,.moves-container::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.move-history-list{background:#ffffff08;border:1px solid #ffffff14;border-radius:8px;font-family:SF Mono,Monaco,Courier New,monospace;font-size:13px;line-height:1;padding:12px}.move-row{align-items:center;display:flex;margin-bottom:4px;padding:2px 0}.move-row .move-number{color:#ffffff80;flex-shrink:0;font-weight:700;margin-right:12px;min-width:30px}.move-row .move-notation{color:#fff;font-weight:500;margin-right:12px}.move-row .clickable-move{border-radius:4px;cursor:pointer;padding:2px 6px;transition:all .2s ease}.move-row .clickable-move:hover{background:#ffffff1a;color:#fff}.move-row .clickable-move.current-move{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-weight:700}.move-row .clickable-move.current-move:hover{background:linear-gradient(135deg,#7c7ff7,#9d70fa)}.move-row .white-move{color:#fff}.move-row .black-move{color:#ffffffb3}.move-notes-tooltip{animation:tooltipFadeIn .2s ease-out;max-width:250px;pointer-events:none}.tooltip-content{background:linear-gradient(180deg,#2a2a3e,#1e1e2e);border:1px solid #ffffff1a;border-radius:10px;box-shadow:0 8px 24px #0006;color:#fff;max-width:250px;min-width:150px;padding:12px}.tooltip-body{color:#ffffffe6;font-size:.85rem;line-height:1.4;max-height:1.4em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tooltip-arrow{border-left:8px solid #0000;border-right:8px solid #0000;border-top:8px solid #1e1e2e;height:0;left:50%;position:absolute;top:100%;transform:translateX(-50%);width:0}.tooltip-arrow.arrow-up{border-bottom:8px solid #2a2a3e;border-top:none;top:-8px}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateX(-50%) translateY(-100%) translateY(-5px)}to{opacity:1;transform:translateX(-50%) translateY(-100%) translateY(0)}}.move-item:hover{background:#ffffff1a}@media (max-width:768px){.move-list h4,.moves-container{display:none!important}.available-moves{-webkit-overflow-scrolling:touch;display:flex!important;flex-direction:row!important;gap:6px!important;height:auto!important;margin-bottom:0!important;max-height:none!important;overflow-x:auto!important;overflow-y:hidden!important;padding:0!important}.move-item{background:#ffffff14!important;flex-shrink:0!important;height:auto!important;margin:0!important;min-height:56px!important;min-width:-webkit-fit-content!important;min-width:fit-content!important;padding:8px 20px!important;white-space:nowrap!important;width:auto!important}.move-item,.move-text{line-height:1.4!important}.move-text{align-items:center!important;flex-direction:row!important;padding:0!important}.move-notation{font-size:1.5rem!important;line-height:1.4!important}.move-number{font-size:1.4rem!important;line-height:1.4!important;margin-right:8px!important;min-width:40px!important}.delete-move-btn,.move-details{display:none!important}.mobile-delete-btn{background:#ef44444d!important;border:1px solid #ef444466!important;border-radius:6px!important;color:#f87171!important;cursor:pointer!important;display:block!important;flex-shrink:0!important;font-size:.7rem!important;font-weight:600!important;margin-left:8px!important;padding:4px 8px!important;white-space:nowrap!important}.mobile-delete-btn:active{background:#ef444466!important}.move-list{background:linear-gradient(180deg,#1e1e2e,#1a1a2a)!important;height:auto!important;min-height:0!important;padding:5px 10px 0!important}.available-moves{align-items:center!important;min-height:0!important}.annotate-move-btn{display:none!important}.annotation-menu{bottom:80px!important;left:50%!important;position:fixed!important;right:auto!important;top:auto!important;transform:translateX(-50%)!important}}.notes-panel{display:flex;flex-direction:column;height:100%;padding:15px}.notes-actions{display:flex;gap:8px}.save-notes-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:16px;box-shadow:0 2px 6px #6366f14d;color:#fff;cursor:pointer;font-size:.8rem;font-weight:600;padding:6px 14px;transition:all .2s ease}.save-notes-btn:hover:not(:disabled){background:linear-gradient(135deg,#7c7ff7,#9d70fa);box-shadow:0 4px 10px #6366f166;transform:translateY(-1px)}.save-notes-btn:disabled{background:#ffffff1a;box-shadow:none;color:#fff6;cursor:not-allowed}.clear-notes-btn{background:#ef444426;border:1px solid #ef44444d;border-radius:16px;color:#f87171;cursor:pointer;font-size:.8rem;font-weight:600;padding:6px 14px;transition:all .2s ease}.clear-notes-btn:hover{background:#ef444440;border-color:#ef444480}.notes-content{display:flex;flex:1 1;flex-direction:column}.notes-textarea{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;color:#fff;flex:1 1;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:.9rem;line-height:1.5;padding:12px;resize:none;transition:all .2s ease}.notes-textarea:focus{background:#ffffff14;border-color:#6366f180;box-shadow:0 0 0 3px #6366f126;outline:none}.notes-textarea::placeholder{color:#fff6;font-style:italic}.notes-footer{color:#ffffff80;flex-shrink:0;font-size:.8rem;gap:6px;justify-content:space-between;margin-top:10px}.notes-footer,.notes-status{align-items:center;display:flex}.notes-status{min-height:20px}.save-error{color:#f87171}.save-error,.save-success{font-size:.75rem;font-weight:600}.save-success{color:#34d399}.unsaved-changes{color:#fbbf24;font-size:.75rem;font-weight:600}.notes-info{align-items:center;display:flex;justify-content:space-between}.character-count{background:#ffffff14;border:1px solid #ffffff1a;border-radius:6px;color:#fff9;font-family:SF Mono,Monaco,monospace;font-size:.75rem;padding:3px 8px}.notes-tip{color:#818cf8;font-style:italic}@media (max-width:768px){.notes-panel{background:linear-gradient(180deg,#1e1e2e,#1a1a2a)!important;display:flex!important;height:auto!important;min-height:150px!important;padding:10px!important;visibility:visible!important}.notes-textarea{min-height:80px!important}.notes-footer{align-items:center;flex-direction:row;flex-wrap:wrap;gap:4px;justify-content:space-between}}.repertoire-selector{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;margin-bottom:16px;max-height:400px;overflow-y:auto;padding:16px}.repertoire-topbar{align-items:center;display:flex;gap:8px;position:relative}.selected-repertoire-button{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:20px;color:#fff;cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:10px;letter-spacing:.02em;padding:8px 14px;transition:all .2s ease}.selected-repertoire-button:hover{background:#ffffff2e;border-color:#ffffff4d}.selected-repertoire-name{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.repertoire-icon{display:none;font-size:1rem}.caret{font-size:.75rem;opacity:.7;transition:transform .2s ease}.selected-repertoire-button:hover .caret{opacity:1}.selector-dropdown{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(180deg,#1e1e2e,#1a1a2a);border:1px solid #ffffff1a;border-radius:16px;box-shadow:0 20px 50px #0006,inset 0 0 0 1px #ffffff0d;max-height:480px;overflow:auto;padding:16px;position:absolute;right:0;top:calc(100% + 12px);width:380px;z-index:1000}.dropdown-loading{color:#fff9;font-size:.9rem;padding:24px;text-align:center}.selector-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.selector-header h3{color:#ffffffe6;font-size:.95rem;font-weight:600;letter-spacing:.02em;margin:0}.refresh-button{background:#ffffff1a;border:none;border-radius:8px;color:#ffffffb3;cursor:pointer;font-size:14px;padding:6px 10px;transition:all .2s ease}.refresh-button:hover{background:#ffffff26;color:#fff;transform:rotate(180deg)}.repertoire-list{display:flex;flex-direction:column;gap:8px}.repertoire-item{background:#ffffff0d;border:1px solid #ffffff14;border-radius:12px;cursor:pointer;padding:14px;transition:all .2s ease}.repertoire-item:hover{background:#ffffff1a;border-color:#6366f166;transform:translateY(-1px)}.repertoire-item.selected{background:linear-gradient(135deg,#6366f133,#8b5cf626);border-color:#6366f180;box-shadow:0 4px 12px #6366f133}.repertoire-item-header{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-bottom:8px}.repertoire-name{align-items:center;color:#fff;display:flex;flex:1 1;font-size:.9rem;font-weight:600;gap:8px}.repertoire-item-actions{align-items:center;display:flex;gap:4px}.edit-repertoire-button{align-items:center;background:#ffffff14;border:none;border-radius:8px;color:#ffffffbf;cursor:pointer;display:flex;flex-shrink:0;font-size:13px;height:28px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:28px}.edit-repertoire-button:hover{background:#fbbf2440;color:#fbbf24;transform:scale(1.1)}.share-repertoire-button{align-items:center;background:#ffffff14;border:none;border-radius:8px;color:#ffffffbf;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;height:28px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:28px}.share-repertoire-button:hover{background:#6366f140;color:#a5b4fc;transform:scale(1.1)}.share-repertoire-button.guest-share-button{cursor:help;opacity:.5}.share-repertoire-button.guest-share-button:hover{background:#fbbf2440;color:#fbbf24;opacity:.7}.delete-repertoire-button{align-items:center;background:#ffffff14;border:none;border-radius:8px;color:#ffffffb3;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:28px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:28px}.delete-repertoire-button:hover{background:#ef444440;color:#f87171;transform:scale(1.1)}.repertoire-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:6px}.color-badge{border-radius:20px;font-size:.7rem;font-weight:600;letter-spacing:.05em;padding:3px 10px;text-transform:uppercase}.color-badge.white{background:#ffffffe6;color:#1a1a2e}.color-badge.black{background:#2d2d3d;border:1px solid #fff3;color:#fff}.public-badge{background:#10b98133;color:#34d399;font-size:.7rem;padding:3px 10px}.public-badge,.shared-badge{border-radius:20px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.shared-badge{background:#fbbf2433;color:#fbbf24;display:inline-block;font-size:.65rem;padding:3px 8px}.owner-badge{background:#6366f133;border-radius:20px;color:#a5b4fc;font-size:.7rem;font-weight:500;padding:3px 10px}.unsubscribe-repertoire-button{background:#ef444433;border:1px solid #ef44444d;border-radius:20px;color:#f87171;cursor:pointer;flex-shrink:0;font-size:.7rem;font-weight:600;letter-spacing:.03em;padding:4px 12px;text-transform:uppercase;transition:all .2s ease;white-space:nowrap}.unsubscribe-repertoire-button:hover{background:#ef44444d;border-color:#ef444480;transform:translateY(-1px)}.repertoire-description{color:#ffffff80;font-size:.8rem;line-height:1.4;margin-top:6px}.error-message{color:#f87171;padding:24px}.error-message p{font-size:.9rem;margin:0 0 16px}.retry-button{background:#ef444433;border:1px solid #ef44444d;border-radius:20px;color:#f87171;cursor:pointer;font-size:.85rem;font-weight:600;padding:10px 20px;transition:all .2s ease}.retry-button:hover{background:#ef44444d;transform:translateY(-1px)}.no-repertoires{color:#ffffff80;padding:32px 20px;text-align:center}.no-repertoires p{font-size:.9rem;margin:0}.header-buttons{gap:8px}.create-button,.header-buttons{align-items:center;display:flex}.create-button{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:8px;box-shadow:0 2px 8px #6366f14d;color:#fff;cursor:pointer;font-size:18px;font-weight:700;height:32px;justify-content:center;transition:all .2s ease;width:32px}.create-button:hover{background:linear-gradient(135deg,#7c7ff7,#9d70fa);box-shadow:0 4px 12px #6366f166;transform:translateY(-1px)}.create-button-always-visible{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:8px;box-shadow:0 2px 8px #6366f14d;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:20px;font-weight:700;height:36px;justify-content:center;transition:all .2s ease;width:36px}.create-button-always-visible:hover{background:linear-gradient(135deg,#7c7ff7,#9d70fa);box-shadow:0 4px 12px #6366f166;transform:translateY(-1px)}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.modal-content{background:linear-gradient(180deg,#1e1e2e,#1a1a2a);border:1px solid #ffffff1a;border-radius:16px;box-shadow:0 25px 60px #00000080;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:20px 24px 16px}.modal-header h3{color:#fff;font-size:1.1rem;font-weight:600;margin:0}.modal-close{align-items:center;background:#ffffff1a;border:none;border-radius:8px;color:#ffffffb3;cursor:pointer;display:flex;font-size:20px;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.modal-close:hover{background:#ffffff26;color:#fff}.create-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{color:#ffffffe6;display:block;font-size:.85rem;font-weight:600;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{background:#ffffff0d;border:1px solid #ffffff26;border-radius:10px;box-sizing:border-box;color:#fff;font-size:.9rem;padding:12px 14px;transition:all .2s ease;width:100%}.form-group input::placeholder,.form-group textarea::placeholder{color:#fff6}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{background:#ffffff14;border-color:#6366f180;box-shadow:0 0 0 3px #6366f126;outline:none}.form-group select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%23fff' fill-opacity='.6' d='M6 8 1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;cursor:pointer;padding-right:36px}.form-group select option{background:#1e1e2e;color:#fff}.form-group textarea{min-height:80px;resize:vertical}.checkbox-group label{align-items:center;color:#fffc;cursor:pointer;display:flex;font-weight:400;gap:10px}.checkbox-group input[type=checkbox]{accent-color:#6366f1;cursor:pointer;height:18px;margin:0;width:18px}.form-actions{border-top:1px solid #ffffff1a;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px}.cancel-button{background:#ffffff1a;border:1px solid #ffffff26;border-radius:20px;color:#fffc;cursor:pointer;font-size:.85rem;font-weight:600;padding:10px 20px;transition:all .2s ease}.cancel-button:hover:not(:disabled){background:#ffffff26;color:#fff}.cancel-button:disabled{cursor:not-allowed;opacity:.5}.create-submit-button{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:20px;box-shadow:0 2px 8px #6366f14d;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:10px 24px;transition:all .2s ease}.create-submit-button:hover:not(:disabled){background:linear-gradient(135deg,#7c7ff7,#9d70fa);box-shadow:0 4px 12px #6366f166;transform:translateY(-1px)}.create-submit-button:disabled{cursor:not-allowed;opacity:.5;transform:none}@media (max-width:768px){.selected-repertoire-button{gap:6px;padding:6px 10px}.selected-repertoire-name{display:none}.repertoire-icon{display:inline}.selector-dropdown{left:0;max-width:320px;padding:12px;right:auto;width:calc(100vw - 32px)}.repertoire-item{padding:12px}.repertoire-name{font-size:.85rem}}@media (max-width:480px){.repertoire-item-actions{display:none}}.share-modal-content{max-width:600px}.share-modal-body{padding:24px}.share-form{border-bottom:1px solid #dee2e6;margin-bottom:32px;padding-bottom:24px}.form-help-text{color:#6c757d;display:block;font-size:12px;font-style:italic;margin-top:6px}.shares-list-section{margin-top:24px}.shares-list-section h4{color:#333;font-size:16px;font-weight:600;margin:0 0 16px}.loading-message,.no-shares-message{color:#6c757d;font-size:14px;padding:16px;text-align:center}.shares-list{display:flex;flex-direction:column;gap:12px}.share-item{align-items:center;background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;display:flex;justify-content:space-between;padding:12px 16px}.share-item-info{flex:1 1}.share-user-name{color:#333;font-size:14px;font-weight:600;margin-bottom:4px}.share-user-email{color:#6c757d;font-size:12px;margin-bottom:6px}.share-permission-badge{background:#e9ecef;border-radius:4px;color:#495057;display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;text-transform:uppercase}.share-permission-badge.editable{background:#d4edda;color:#155724}.remove-share-button{align-items:center;background:none;border:none;border-radius:4px;color:#dc3545;cursor:pointer;display:flex;font-size:20px;height:32px;justify-content:center;padding:4px 8px;transition:background-color .2s;width:32px}.remove-share-button:hover{background:#f8d7da}.share-submit-button{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:background-color .2s;width:100%}.share-submit-button:hover:not(:disabled){background:#0056b3}.share-submit-button:disabled{background:#6c757d;cursor:not-allowed}.error-message{background:#f8d7da;border-radius:6px;color:#721c24;margin-bottom:16px;padding:12px}.login-container{align-items:center;background-color:#fafafa;display:flex;flex-direction:column;gap:40px;justify-content:center;min-height:100vh;padding:40px 20px}@media (min-width:768px){.login-container{align-items:center;flex-direction:row;gap:60px;padding:40px}}.login-container.login-modal{align-items:stretch;flex-direction:column;gap:20px;min-height:auto;padding:0}.login-container.login-modal .login-welcome-section{background:#f8f9fa;border-radius:8px 8px 0 0;padding:20px}.login-container.login-modal .login-card{border-radius:0 0 8px 8px;border-top:1px solid #e1e5e9;box-shadow:none;box-sizing:border-box;width:100%}.login-container.login-modal .login-welcome-section .welcome-section{max-width:100%;text-align:center}.login-container.login-modal .login-welcome-section .app-title{font-size:2rem}.login-container.login-modal .login-welcome-section .tagline{font-size:1.2rem}.login-container.login-modal .login-welcome-section .description{margin-bottom:20px}.login-container.login-modal .login-welcome-section .description-intro{font-size:1rem}.login-container.login-modal .login-welcome-section .description-cta,.login-container.login-modal .login-welcome-section .description-features{font-size:.95rem}.login-container.login-modal .login-welcome-section .features{display:none}.login-card{background:#fff;border:1px solid #e1e5e9;border-radius:12px;box-shadow:0 4px 20px #0000001a;max-width:400px;padding:40px;width:100%}.login-container.login-modal .login-card{max-width:100%;padding:30px}.login-card h2{color:#282c34;font-size:28px;font-weight:600;margin-bottom:30px;text-align:center}.login-form{display:flex;flex-direction:column;gap:20px;max-width:100%}.login-container.login-modal .login-form{margin:0 auto;max-width:100%;width:100%}.login-container.login-modal .form-group input{box-sizing:border-box;width:100%}.login-button{background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:10px;padding:14px 24px;transition:all .2s ease}.login-button:hover:not(:disabled){background:#0056b3;box-shadow:0 4px 15px #007bff4d;transform:translateY(-1px)}.login-button:disabled{cursor:not-allowed;opacity:.7;transform:none}.welcome-section{max-width:500px;text-align:center}@media (min-width:768px){.welcome-section{text-align:left}}.app-title{color:#282c34;font-size:3rem;font-weight:700;letter-spacing:-.5px;margin:0 0 12px}.tagline{color:#007bff;font-size:1.5rem;font-weight:600;margin:0 0 20px}.description{margin:0 0 30px}.description-intro{color:#282c34;font-size:1.2rem;font-weight:600;line-height:1.7;margin:0 0 16px}.description-features{color:#555;font-size:1.05rem;line-height:1.8;margin:0 0 16px}.description-cta{color:#666;font-size:1.05rem;line-height:1.8;margin:0}.description-cta strong{color:#007bff;font-weight:600}.features{display:flex;gap:16px;justify-content:center}@media (min-width:768px){.features{gap:20px;justify-content:flex-start}}.feature{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000014;display:flex;flex:1 1;flex-direction:column;gap:8px;max-width:140px;padding:16px 12px;transition:transform .2s ease,box-shadow .2s ease}.feature:hover{box-shadow:0 4px 12px #007bff26;transform:translateY(-2px)}.feature-icon{font-size:2rem}.feature span:last-child{color:#333;font-size:.9rem;font-weight:500}.register-container{align-items:center;background-color:#fafafa;display:flex;flex-direction:column;gap:40px;justify-content:center;min-height:100vh;padding:40px 20px}@media (min-width:768px){.register-container{align-items:center;flex-direction:row;gap:60px;padding:40px}}.register-container.register-modal{align-items:stretch;flex-direction:column;gap:20px;min-height:auto;padding:0}.register-container.register-modal .register-welcome-section{background:#f8f9fa;border-radius:8px 8px 0 0;padding:20px}.register-container.register-modal .register-card{border-radius:0 0 8px 8px;border-top:1px solid #e1e5e9;box-shadow:none;box-sizing:border-box;width:100%}.register-container.register-modal .register-welcome-section .welcome-section{max-width:100%;text-align:center}.register-container.register-modal .register-welcome-section .app-title{font-size:2rem}.register-container.register-modal .register-welcome-section .tagline{font-size:1.2rem}.register-container.register-modal .register-welcome-section .description{margin-bottom:20px}.register-container.register-modal .register-welcome-section .description-intro{font-size:1rem}.register-container.register-modal .register-welcome-section .description-cta,.register-container.register-modal .register-welcome-section .description-features{font-size:.95rem}.register-container.register-modal .register-welcome-section .features{display:none}.register-card{background:#fff;border:1px solid #e1e5e9;border-radius:12px;box-shadow:0 4px 20px #0000001a;max-width:400px;padding:40px;width:100%}.register-container.register-modal .register-card{max-width:100%;padding:30px}.register-card h2{color:#282c34;font-size:28px;font-weight:600;margin-bottom:30px;text-align:center}.register-form{display:flex;flex-direction:column;gap:20px;max-width:100%}.register-container.register-modal .register-form{margin:0 auto;max-width:100%;width:100%}.register-container.register-modal .form-group input{box-sizing:border-box;width:100%}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#555;font-size:14px;font-weight:500}.form-group input{background-color:#fff;border:2px solid #c5ccd3;border-radius:8px;color:#333;font-size:16px;padding:12px 16px;transition:border-color .2s ease,box-shadow .2s ease}.form-group input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.field-error{color:#c33;font-size:12px;margin-top:4px}.register-card .register-button,.register-form .register-button{background:#007bff!important;border:none;border-radius:8px;color:#fff!important;cursor:pointer;font-size:16px;font-weight:600;margin-top:10px;padding:14px 24px;transition:all .2s ease}.register-card .register-button:hover:not(:disabled),.register-form .register-button:hover:not(:disabled){background:#0056b3!important;box-shadow:0 4px 15px #007bff4d;color:#fff!important;transform:translateY(-1px)}.register-card .register-button:disabled,.register-form .register-button:disabled{background:#007bff!important;color:#fff!important;cursor:not-allowed;opacity:.7;transform:none}.error-message{background-color:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:14px;padding:12px 16px;text-align:center}.switch-form{border-top:1px solid #e1e5e9;margin-top:24px;padding-top:24px;text-align:center}.switch-form p{color:#666;margin:0}.switch-button{background:none;border:none;color:#007bff;cursor:pointer;font-size:inherit;font-weight:600;margin-left:8px;text-decoration:underline}.switch-button:hover:not(:disabled){color:#0056b3}.switch-button:disabled{cursor:not-allowed;opacity:.5}.user-menu{display:inline-block;position:relative}.user-button{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;gap:8px;padding:8px 12px;transition:all .2s ease}.user-button:hover{background:#fff3;border-color:#ffffff4d}.user-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:600;height:32px;justify-content:center;width:32px}.user-name{font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-arrow{font-size:10px;transition:transform .2s ease}.dropdown-arrow.open{transform:rotate(180deg)}.user-dropdown{background:#fff;border-radius:8px;box-shadow:0 8px 25px #00000026;margin-top:4px;min-width:200px;overflow:hidden;position:absolute;right:0;top:100%;z-index:1000}.user-info{background:#f8f9fa;padding:16px}.user-email{color:#333;font-weight:500;margin-bottom:4px;word-break:break-all}.user-joined{color:#666;font-size:12px}.dropdown-divider{background:#e1e5e9;height:1px}.menu-action-button{background:none;border:none;color:#333;cursor:pointer;font-weight:500;padding:12px 16px;text-align:left;transition:background-color .2s ease;width:100%}.menu-action-button:hover{background:#f0f0f0}.logout-button{background:none;border:none;color:#c33;cursor:pointer;font-weight:500;padding:12px 16px;text-align:left;transition:background-color .2s ease;width:100%}.logout-button:hover{background:#fee}.register-button{color:#007bff;font-weight:600}.menu-action-button.register-button:hover{background:#f5f5f5!important;color:#0056b3}.dropdown-overlay{background:#0000;bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}@media (max-width:768px){.user-button{gap:4px;padding:6px 8px}.user-name{display:none}.user-avatar{font-size:12px;height:28px;width:28px}.dropdown-arrow{font-size:8px}}.position-label-container{align-self:flex-start;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;max-width:100%;padding:10px 16px;position:relative;z-index:11}.position-label-display{align-items:center;display:flex;gap:10px;justify-content:space-between}.position-label-text{color:#fff;flex:1 1;font-size:18px;font-weight:600;letter-spacing:.01em;margin:0;word-break:break-word}.position-label-edit-btn{background:#ffffff14;border:none;border-radius:8px;color:#fff9;cursor:pointer;flex-shrink:0;font-size:16px;padding:6px 10px;transition:all .2s ease}.position-label-edit-btn:hover{background:#fbbf2433;color:#fbbf24}.position-label-add-btn{background:none;border:1px dashed #ffffff4d;border-radius:8px;color:#fff9;cursor:pointer;font-size:13px;padding:8px 14px;text-align:left;transition:all .2s ease;width:100%}.position-label-add-btn:hover{background:#6366f11a;border-color:#6366f180;color:#a5b4fc}.position-label-editor{display:flex;flex-direction:column;gap:10px}.position-label-input{background:#ffffff0d;border:1px solid #ffffff26;border-radius:8px;color:#fff;font-size:14px;outline:none;padding:10px 12px;transition:all .2s ease;width:100%}.position-label-input::placeholder{color:#fff6}.position-label-input:focus{background:#ffffff14;border-color:#6366f180;box-shadow:0 0 0 3px #6366f126}.position-label-buttons{display:flex;gap:8px}.position-label-cancel-btn,.position-label-save-btn{border:none;border-radius:16px;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s ease}.position-label-save-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 2px 6px #6366f14d;color:#fff}.position-label-save-btn:hover:not(:disabled){background:linear-gradient(135deg,#7c7ff7,#9d70fa);box-shadow:0 4px 10px #6366f166;transform:translateY(-1px)}.position-label-save-btn:disabled{background:#ffffff1a;box-shadow:none;color:#fff6;cursor:not-allowed}.position-label-cancel-btn{background:#ffffff1a;border:1px solid #ffffff26;color:#fffc}.position-label-cancel-btn:hover:not(:disabled){background:#ffffff26;color:#fff}.position-label-cancel-btn:disabled{cursor:not-allowed;opacity:.5}.position-label-error{color:#f87171;font-size:12px;margin-top:4px}@media (max-width:768px){.position-label-container{align-self:flex-start;background:#ffffff14!important;margin-bottom:6px!important;margin-top:0!important;max-width:100%;padding:6px 12px!important;width:auto}.position-label-text{font-size:14px}.position-label-add-btn{font-size:12px;line-height:1.2!important;min-height:auto!important;padding:6px 12px!important;text-align:left;width:100%}}.guest-banner{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);border-bottom:1px solid #ffffff1a;box-shadow:0 4px 20px #0000004d;color:#fff;left:0;padding:12px 24px;position:fixed;right:0;top:0;z-index:150}.guest-banner-content{gap:16px;margin:0 auto;max-width:1200px}.guest-banner-content,.guest-banner-icon{align-items:center;display:flex;justify-content:center}.guest-banner-icon{color:#fbbf24;flex-shrink:0}.guest-banner-message{color:#ffffffe6;font-size:.95rem;letter-spacing:.01em}.guest-banner-message strong{color:#fbbf24;font-weight:600}.guest-banner-actions{display:flex;flex-shrink:0;gap:10px}.guest-banner-btn{border:none;border-radius:20px;cursor:pointer;font-size:.85rem;font-weight:600;letter-spacing:.02em;padding:8px 18px;transition:all .2s ease}.guest-banner-btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 2px 8px #6366f166;color:#fff}.guest-banner-btn-primary:hover{background:linear-gradient(135deg,#7c7ff7,#9d70fa);box-shadow:0 4px 12px #6366f180;transform:translateY(-1px)}.guest-banner-btn-secondary{background:#ffffff1a;border:1px solid #fff3;color:#fff}.guest-banner-btn-secondary:hover{background:#ffffff2e;border-color:#ffffff4d}@media (max-width:768px){.guest-banner{padding:16px 20px;position:relative!important;top:0!important;z-index:auto!important}.guest-banner-content{flex-direction:column;gap:12px}.guest-banner-icon{display:none}.guest-banner-message{text-align:center}.guest-banner-actions{justify-content:center;width:100%}.guest-banner-btn{padding:10px 20px}}.skeleton-ui{background-color:#1a1a2e;color:#e0e0e0;display:flex;flex-direction:column;height:100vh}@keyframes skeleton-pulse{0%,to{opacity:.4}50%{opacity:.7}}.skeleton-button,.skeleton-move,.skeleton-section-title,.skeleton-text{animation:skeleton-pulse 1.5s ease-in-out infinite;background:linear-gradient(90deg,#2a2a4a 25%,#3a3a5a 50%,#2a2a4a 75%);background-size:200% 100%;border-radius:4px}.skeleton-header{background-color:#16213e;border-bottom:1px solid #2a2a4a;justify-content:space-between;padding:15px 20px}.skeleton-header,.skeleton-title{align-items:center;display:flex}.skeleton-text-large{height:28px;width:150px}.skeleton-controls{display:flex;gap:10px}.skeleton-button{height:36px;width:100px}.skeleton-main{grid-gap:20px;display:grid;flex:1 1;gap:20px;grid-template-columns:250px 1fr;grid-template-rows:1fr auto;overflow:hidden;padding:20px}.skeleton-left-panel{display:flex;flex-direction:column;gap:15px;grid-row:1/3}.skeleton-section-title{height:20px;width:120px}.skeleton-move-list{display:flex;flex-direction:column;gap:10px}.skeleton-move{height:40px;width:100%}.skeleton-center-panel{align-items:flex-start;display:flex;justify-content:center}.skeleton-board{aspect-ratio:1;background-color:#16213e;border-radius:8px;padding:8px;width:min(70vh,500px)}.skeleton-board-inner{border-radius:4px;display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);overflow:hidden}.skeleton-board-inner,.skeleton-square{height:100%;width:100%}.skeleton-square.light{background-color:#b7c0d8}.skeleton-square.dark{background-color:#7b8bb5}.skeleton-bottom-panel{background-color:#16213e;border-radius:8px;display:flex;flex-direction:column;gap:10px;padding:15px}.skeleton-notes{display:flex;flex-direction:column;gap:8px}.skeleton-text{height:16px;width:100%}.skeleton-text:last-child{width:70%}@media (max-width:900px){.skeleton-main{grid-template-columns:1fr;grid-template-rows:auto 1fr auto}.skeleton-left-panel{flex-direction:row;grid-row:auto;overflow-x:auto}.skeleton-move-list{flex-direction:row}.skeleton-move{flex-shrink:0;width:80px}.skeleton-board{width:min(80vw,400px)}}
/*# sourceMappingURL=main.e5f1120f.css.map*/