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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{display:flex;flex-direction:column;height:100vh;overflow:hidden;text-align:center}.App-header{background-color:#282c34;color:#fff;flex-shrink:0;justify-content:space-between;padding:10px 10px 10px 20px;z-index:20}.App-header,.header-controls{align-items:center;display:flex}.header-controls{flex:1 1;gap:20px;justify-content:flex-end}.view-variations-button{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease;white-space:nowrap}.view-variations-button:hover{background:#0056b3;transform:translateY(-1px)}.view-variations-button:disabled{background:#6c757d;cursor:not-allowed}.App-header h1{font-size:1.5rem;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;overflow:hidden;position:relative}.left-panel{background-color:#f5f5f5;border-right:1px solid #ddd;height:calc(100vh - 60px);left:0;overflow-y:auto;position:fixed;top:60px;width:250px;z-index:10}.center-panel{background-color:#fafafa;flex:1 1;margin-left:250px;max-height:calc(100vh - 260px);max-width:calc(100vw - 250px);min-height:0;overflow:visible;padding:20px;z-index:5}.center-panel,.chess-board-container{align-items:center;display:flex;justify-content:center;position:relative}.chess-board-container{flex-direction:column;gap:15px;max-width:800px;padding:10px;pointer-events:auto;width:100%;z-index:10}.board-controls{align-items:center;display:flex;flex-shrink:0;flex-wrap:wrap;gap:10px;justify-content:center}.nav-button{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;min-width:80px;padding:8px 16px;transition:all .2s ease}.nav-button:hover:not(:disabled){background:#0056b3;transform:translateY(-1px)}.nav-button:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.move-history-info{color:#666;display:flex;flex-direction:column;flex-shrink:0;font-size:.9rem;gap:5px;text-align:center}.current-position{background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;color:#888;font-family:monospace;font-size:.8rem;padding:4px 8px}.bottom-panel{background-color:#f5f5f5;border-top:1px solid #ddd;bottom:0;height:200px;left:250px;position:fixed;right:0;z-index:10}@media (max-width:768px){.left-panel{width:200px}.center-panel{margin-left:200px;max-height:calc(100vh - 260px);max-width:calc(100vw - 200px)}.bottom-panel{left:200px}.board-controls{gap:8px}.nav-button{font-size:.8rem;min-width:70px;padding:6px 12px}.chess-board-container{gap:12px;max-width:650px}}.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:480px){.left-panel{width:150px}.center-panel{margin-left:150px;max-height:calc(100vh - 260px);max-width:calc(100vw - 150px)}.bottom-panel{left:150px}.board-controls{flex-direction:column;gap:6px}.nav-button{max-width:120px;width:100%}.chess-board-container{gap:10px;max-width:480px}}.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}.move-list{display:flex;flex-direction:column;height:100%;padding:15px}.move-list h3{border-bottom:3px solid #007bff;color:#212529;font-size:1.3rem;font-weight:700;margin:0 0 15px;padding-bottom:10px}.move-list h4{border-bottom:2px solid #e9ecef;color:#495057;font-size:1rem;font-weight:600;margin:20px 0 10px;padding-bottom:6px}.moves-container{flex:1 1;margin-bottom:15px;overflow-y:auto}.moves-container h4{border-bottom:1px solid #eee;color:#555;font-size:1rem;margin:0 0 10px;padding-bottom:5px}.available-moves{height:300px;margin-bottom:20px;overflow-y:auto}.move-item{align-items:center;background:#fff;border:2px solid #e9ecef;border-radius:10px;box-shadow:0 2px 4px #0000000f;cursor:pointer;display:flex;margin:10px 0;padding:14px 16px;position:relative;transition:all .25s cubic-bezier(.4,0,.2,1)}.move-item:hover{border-color:#007bff;box-shadow:0 4px 12px #0000001f;transform:translateY(-2px)}.move-item.current-move{background:linear-gradient(135deg,#e7f3ff,#d0e9ff);border-color:#007bff;box-shadow:0 3px 10px #0000001a}.move-item.current-move:hover{box-shadow:0 4px 14px #00000026;transform:translateY(-2px)}.move-item.available-move{background:#f8fbff;border:2px solid #007bff}.move-item.available-move:hover{background:#e7f3ff;border-color:#0056b3;box-shadow:0 6px 16px #00000026;transform:translateY(-3px)}.move-text{align-items:center;display:flex;justify-content:flex-start;padding:4px 0}.move-actions{margin-left:auto}.delete-move-btn{background:#0000;border:none;border-radius:6px;color:#6c757d;cursor:pointer;font-size:1.1rem;font-weight:700;padding:6px 10px;transition:all .2s ease}.delete-move-btn:hover{background:#fee;color:#dc3545;transform:scale(1.1)}.move-number{color:#007bff;font-size:.95rem;font-weight:600;margin-right:12px;min-width:32px}.move-notation{color:#212529;font-size:1.2rem;font-weight:700;letter-spacing:.5px}.move-details{color:#868e96;display:flex;flex-direction:column;font-size:.85rem;gap:2px}.move-from-to{background:#f8f9fa;border-radius:4px;color:#495057;display:inline-block;font-family:SF Mono,Monaco,Courier New,monospace;font-weight:500;padding:2px 6px}.capture-indicator{color:#dc3545;font-style:italic}.no-moves{color:#666;margin-top:20px;text-align:center}.no-moves p{margin:5px 0}.no-available-moves{color:#666;font-style:italic;padding:20px;text-align:center}.no-available-moves p{margin:0}.game-status{color:#007bff;font-size:1.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:#f1f1f1;border-radius:3px}.available-moves::-webkit-scrollbar-thumb,.moves-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.available-moves::-webkit-scrollbar-thumb:hover,.moves-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.move-history-list{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;font-family:Courier New,monospace;font-size:14px;line-height:1;padding:15px}.move-row{align-items:center;display:flex;margin-bottom:4px;padding:2px 0}.move-row .move-number{color:#495057;flex-shrink:0;font-weight:700;margin-right:12px;min-width:30px}.move-row .move-notation{color:#212529;font-weight:500;margin-right:12px}.move-row .clickable-move{border-radius:3px;cursor:pointer;padding:2px 6px;transition:all .2s ease}.move-row .clickable-move:hover{background-color:#e9ecef;color:#495057}.move-row .clickable-move.current-move{background-color:#007bff;color:#fff;font-weight:700}.move-row .clickable-move.current-move:hover{background-color:#0056b3}.move-row .white-move{color:#2c3e50}.move-row .black-move{color:#7f8c8d}.move-notes-tooltip{animation:tooltipFadeIn .2s ease-out;max-width:250px;pointer-events:none}.tooltip-content{background:#2c3e50;border:1px solid #34495e;border-radius:8px;box-shadow:0 4px 12px #0000004d;color:#fff;max-width:250px;min-width:150px;padding:12px}.tooltip-body{color:#ecf0f1;font-size:.9rem;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 #2c3e50;height:0;left:50%;position:absolute;top:100%;transform:translateX(-50%);width:0}.tooltip-arrow.arrow-up{border-bottom:8px solid #2c3e50;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-color:#f8f9fa}.notes-panel{display:flex;flex-direction:column;height:100%;padding:15px}.notes-header{align-items:center;display:flex;flex-shrink:0;justify-content:space-between;margin-bottom:10px}.notes-header h3{color:#333;font-size:1.2rem;margin:0}.notes-actions{display:flex;gap:8px}.save-notes-btn{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;font-weight:600;padding:4px 8px;transition:all .2s ease}.save-notes-btn:hover:not(:disabled){background:#0056b3;transform:translateY(-1px)}.save-notes-btn:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.clear-notes-btn{background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;padding:4px 8px;transition:background-color .2s ease}.clear-notes-btn:hover{background:#c82333}.notes-content{display:flex;flex:1 1;flex-direction:column}.notes-textarea{background-color:#fff;border:1px solid #ddd;border-radius:6px;color:#333;flex:1 1;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:.9rem;line-height:1.4;padding:12px;resize:none;transition:border-color .2s ease}.notes-textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.notes-textarea::placeholder{color:#999;font-style:italic}.notes-footer{color:#666;display:flex;flex-direction:column;flex-shrink:0;font-size:.8rem;gap:6px;margin-top:8px}.notes-status{align-items:center;display:flex;min-height:20px}.save-error{color:#dc3545}.save-error,.save-success{font-size:.75rem;font-weight:600}.save-success{color:#007bff}.unsaved-changes{color:#ffc107;font-size:.75rem;font-weight:600}.notes-info{align-items:center;display:flex;justify-content:space-between}.character-count{background:#f8f9fa;border:1px solid #e9ecef;border-radius:3px;font-family:monospace;padding:2px 6px}.notes-tip{color:#007bff;font-style:italic}@media (max-width:768px){.notes-footer{align-items:flex-start;flex-direction:column;gap:4px}}.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:#3a3f4b;border:1px solid #fff3;border-radius:6px;color:#fff;cursor:pointer;display:flex;gap:8px;padding:6px 10px}.selected-repertoire-name{font-weight:600;max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.caret{opacity:.8}.selector-dropdown{background:#fff;border:1px solid #dee2e6;border-radius:8px;box-shadow:0 10px 30px #00000026;max-height:420px;overflow:auto;padding:12px;position:absolute;right:0;top:calc(100% + 8px);width:360px;z-index:1000}.dropdown-loading{color:#495057;padding:12px;text-align:center}.selector-header{align-items:center;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:8px}.selector-header h3{color:#495057;font-size:16px;font-weight:600;margin:0}.refresh-button{background:none;border:none;border-radius:4px;color:#6c757d;cursor:pointer;font-size:18px;padding:4px 8px;transition:all .2s ease}.refresh-button:hover{background:#e9ecef;color:#495057}.repertoire-list{display:flex;flex-direction:column;gap:8px}.repertoire-item{background:#fff;border:2px solid #e9ecef;border-radius:6px;cursor:pointer;padding:12px;transition:all .2s ease}.repertoire-item:hover{border-color:#007bff;box-shadow:0 2px 4px #007bff1a}.repertoire-item.selected{background:#f8f9ff;border-color:#007bff;box-shadow:0 2px 8px #007bff26}.repertoire-item-header{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-bottom:4px}.repertoire-name{color:#212529;flex:1 1;font-size:14px;font-weight:600}.delete-repertoire-button{align-items:center;background:#0000;border:none;border-radius:4px;color:#6c757d;cursor:pointer;display:flex;flex-shrink:0;font-size:24px;font-weight:700;height:24px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:24px}.delete-repertoire-button:hover{background:#fee;color:#dc3545;transform:scale(1.1)}.repertoire-meta{display:flex;gap:8px;margin-bottom:6px}.color-badge{font-size:11px;font-weight:500;padding:2px 6px}.color-badge.white{color:#495057}.color-badge.black{background:#212529}.public-badge{background:#d4edda;border:1px solid #c3e6cb;border-radius:12px;color:#155724;font-size:11px;font-weight:500;padding:2px 6px}.repertoire-description{color:#6c757d;font-size:12px;line-height:1.4;margin-top:4px}.error-message{color:#dc3545;padding:20px}.error-message p{font-size:14px;margin:0 0 12px}.retry-button{background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background .2s ease}.retry-button:hover{background:#c82333}.no-repertoires{color:#6c757d;padding:20px;text-align:center}.no-repertoires p{font-size:14px;margin:0}.header-buttons{gap:8px}.create-button,.header-buttons{align-items:center;display:flex}.create-button{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:16px;font-weight:700;height:28px;justify-content:center;transition:all .2s ease;width:28px}.create-button:hover{background:#0056b3;transform:translateY(-1px)}.create-button-always-visible{align-items:center;background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:32px;justify-content:center;transition:all .2s ease;width:32px}.create-button-always-visible:hover{background:#0056b3;transform:translateY(-1px)}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.modal-content{background:#fff;border-radius:8px;box-shadow:0 20px 40px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;padding:20px 24px 16px}.modal-header h3{color:#333;font-size:18px;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:4px;color:#666;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;padding:0;transition:background-color .2s;width:32px}.modal-close:hover{background:#f8f9fa}.create-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{color:#333;display:block;font-weight:600;margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{border:1px solid #dee2e6;border-radius:6px;box-sizing:border-box;font-size:14px;padding:10px 12px;transition:border-color .2s,box-shadow .2s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.form-group textarea{min-height:80px;resize:vertical}.checkbox-group label{align-items:center;cursor:pointer;display:flex;font-weight:400;gap:8px}.checkbox-group input[type=checkbox]{margin:0;width:auto}.form-actions{border-top:1px solid #dee2e6;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px}.cancel-button{background:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:background-color .2s}.cancel-button:hover:not(:disabled){background:#5a6268}.cancel-button:disabled{cursor:not-allowed;opacity:.6}.create-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}.create-submit-button:hover:not(:disabled){background:#0056b3}.create-submit-button:disabled{cursor:not-allowed;opacity:.6}.repertoire-viewer{background-color:#f8f9fa;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;height:100vh}.repertoire-viewer,.viewer-header{display:flex;flex-direction:column}.viewer-header{align-items:flex-start;background:#fff;border-bottom:1px solid #e9ecef;box-shadow:0 2px 4px #0000001a;padding:1rem 2rem}.back-button{background:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;margin-bottom:1rem;padding:.5rem 1rem;transition:background-color .2s}.back-button:hover{background:#5a6268}.viewer-header h2{color:#343a40;font-size:1.5rem;margin:0 0 .5rem}.repertoire-info{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.color-badge{border-radius:12px;font-size:.8rem;font-weight:600;padding:.25rem .5rem;text-transform:capitalize}.color-badge.white{background:#f8f9fa;border:1px solid #dee2e6;color:#343a40}.color-badge.black{background:#343a40;color:#fff}.description{color:#6c757d;font-size:.9rem;font-style:italic}.viewer-content{flex:1 1;overflow-y:auto;padding:1rem 2rem}.error-indicator,.loading-indicator,.no-repertoire{align-items:center;color:#6c757d;display:flex;flex-direction:column;height:200px;justify-content:center}.error-indicator button{background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;margin-top:1rem;padding:.5rem 1rem}.error-indicator button:hover{background:#c82333}.all-variations{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.variations-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:1rem 1.5rem}.variations-header h3{color:#343a40;font-size:1.2rem;margin:0}.search-box{flex:1 1;margin-left:2rem;max-width:300px}.search-input{border:1px solid #ced4da;border-radius:4px;font-size:.9rem;padding:.5rem;width:100%}.search-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.variations-content{max-height:70vh;overflow-y:auto;padding:1rem}.variations-content.compact{padding:.75rem}.variation-block{margin-bottom:1rem}.variation-block.depth-0,.variation-block.depth-1{border-left:3px solid #007bff}.variation-block.depth-1{margin-left:1rem}.variation-block.depth-2{border-left:3px solid #ffc107;margin-left:2rem}.variation-block.depth-3{border-left:3px solid #dc3545;margin-left:3rem}.variation-header{align-items:center;background:#f8f9fa;border-radius:4px;cursor:pointer;display:flex;margin-bottom:.5rem;padding:.5rem;transition:background-color .2s}.variation-header:hover{background:#e9ecef}.expand-button{background:none;border:none;border-radius:2px;color:#6c757d;cursor:pointer;font-size:.8rem;margin-right:.5rem;padding:.25rem;transition:background-color .2s}.expand-button:hover{background:#dee2e6}.variation-path{color:#343a40;font-weight:600;margin-right:1rem}.position-notes{color:#6c757d;font-size:.9rem;font-style:italic}.variation-content{margin-left:1rem}.move-variation{background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;margin-bottom:1rem;padding:.5rem}.move-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:.5rem}.move-san{background:#fff;border:1px solid #007bff;border-radius:4px;color:#007bff;font-weight:600;padding:.25rem .5rem}.move-notes{color:#6c757d;font-size:.9rem;font-style:italic}.move-evaluation{background:#007bff;border-radius:4px;color:#fff;font-size:.8rem;font-weight:600;padding:.25rem .5rem}.child-variations{margin-top:.5rem}.no-variations{color:#6c757d;font-style:italic;padding:2rem;text-align:center}.variations-list{display:flex;flex-direction:column;gap:.5rem}.variation-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:.75rem;transition:background-color .2s}.variation-item:hover{background:#e9ecef}.variation-item.clickable{cursor:pointer;transition:all .2s ease}.variation-item.clickable:hover{background:#e3f2fd;border-color:#2196f3;box-shadow:0 2px 8px #2196f333;transform:translateY(-1px)}.variation-line{align-items:center;display:flex;gap:.5rem;margin-bottom:.25rem}.variation-number{color:#007bff;font-size:.9rem;font-weight:600;min-width:2rem}.variation-sequence{color:#343a40;font-family:Courier New,monospace;font-size:.95rem;line-height:1.4}.variation-notes{border-left:2px solid #dee2e6;margin-top:.5rem;padding-left:2.5rem}.move-note{align-items:center;display:flex;font-size:.85rem;gap:.5rem;margin-bottom:.25rem}.move-note:last-child{margin-bottom:0}.note-move{color:#007bff;font-weight:600;min-width:2rem}.note-content{color:#6c757d;font-style:italic}.starting-position-notes{background:#e3f2fd;border-left:4px solid #2196f3;border-radius:4px;color:#1565c0;margin:1rem 0;padding:1rem}@media (max-width:768px){.viewer-content,.viewer-header{padding:1rem}.variations-header{align-items:flex-start;flex-direction:column;gap:1rem}.search-box{margin-left:0;max-width:none;width:100%}.variation-block.depth-1,.variation-block.depth-2,.variation-block.depth-3{margin-left:.5rem}.move-header{align-items:flex-start;flex-direction:column;gap:.5rem}}.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-card{background:#fff;border:1px solid #e1e5e9;border-radius:12px;box-shadow:0 4px 20px #0000001a;max-width:400px;padding:40px;width:100%}.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}.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-card{background:#fff;border:1px solid #e1e5e9;border-radius:12px;box-shadow:0 4px 20px #0000001a;max-width:400px;padding:40px;width:100%}.register-card h2{color:#282c34;font-size:28px;font-weight:600;margin-bottom:30px;text-align:center}.register-form{gap:20px}.form-group,.register-form{display:flex;flex-direction:column}.form-group{gap:8px}.form-group label{color:#555;font-size:14px;font-weight:500}.form-group input{border:2px solid #e1e5e9;border-radius:8px;font-size:16px;padding:12px 16px;transition:border-color .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-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}.register-button:hover:not(:disabled){background:#0056b3;box-shadow:0 4px 15px #007bff4d;transform:translateY(-1px)}.register-button:disabled{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}.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}.dropdown-overlay{background:#0000;bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}
/*# sourceMappingURL=main.ca5053cb.css.map*/