.loader-container{display:flex;justify-content:center;align-items:center;padding:2rem;min-height:200px}.loader{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;min-height:300px}.empty-state-icon{font-size:4rem;margin-bottom:1rem}.empty-state-message{font-size:1.1rem;color:#666;max-width:300px}.toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:#333;color:#fff;padding:12px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;max-width:90%;text-align:center;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.toast-success{background:#4caf50}.toast-error{background:#f44336}.toast-info{background:#2196f3}.tab-bar{position:fixed;bottom:0;left:0;right:0;display:flex;background:#fff;border-top:1px solid #e0e0e0;z-index:100;padding-bottom:env(safe-area-inset-bottom)}.tab-bar-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px;text-decoration:none;color:#666;transition:color .2s}.tab-bar-item.active{color:#1976d2}.tab-bar-icon{font-size:1.5rem;margin-bottom:4px}.tab-bar-label{font-size:.75rem;font-weight:500}.layout{display:flex;flex-direction:column;min-height:100vh;padding-bottom:60px}.layout-main{flex:1;padding-bottom:env(safe-area-inset-bottom)}.create-room-form{padding:1.5rem}.radio-group{display:flex;flex-direction:column;gap:.75rem}.radio-option{display:flex;align-items:center;gap:.5rem;padding:.75rem;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer}.radio-option input[type=radio]{width:18px;height:18px;cursor:pointer}.radio-option:has(input:checked){border-color:#1976d2;background:#e3f2fd}.rooms-page{padding:1rem}.rooms-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.rooms-header h1{font-size:1.5rem;font-weight:600}.btn-primary{background:#1976d2;color:#fff;padding:8px 16px;border-radius:8px;font-size:.9rem;font-weight:500;text-decoration:none}.rooms-segments{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:1px solid #e0e0e0}.segment{flex:1;padding:12px;background:none;border:none;border-bottom:2px solid transparent;font-size:.95rem;color:#666;cursor:pointer}.segment.active{color:#1976d2;border-bottom-color:#1976d2;font-weight:600}.rooms-list{display:flex;flex-direction:column;gap:1rem}.room-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:1rem;text-decoration:none;color:inherit;transition:box-shadow .2s}.room-card:active{box-shadow:0 2px 8px #0000001a}.room-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.room-card-header h3{font-size:1.1rem;font-weight:600;margin:0}.room-state{font-size:.8rem;padding:4px 8px;border-radius:4px;font-weight:500}.room-state-lobby{background:#e3f2fd;color:#1976d2}.room-state-voting{background:#fff3e0;color:#f57c00}.room-state-finished{background:#e8f5e9;color:#388e3c}.room-card-meta{font-size:.85rem;color:#666}.room-selections{margin-top:1rem}.selections-info{font-size:.9rem;color:#666;margin-bottom:1rem}.groups-list{display:flex;flex-direction:column;gap:.75rem}.group-item{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.group-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f5f5f5;cursor:pointer}.group-name{font-weight:500}.group-toggle{font-size:.8rem;color:#666}.group-activities{padding:.75rem}.select-all-btn{width:100%;padding:8px;margin-bottom:.75rem;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:6px;font-size:.9rem;cursor:pointer}.select-all-btn.all-selected{background:#e3f2fd;border-color:#1976d2;color:#1976d2;font-weight:500}.activity-checkbox{display:flex;align-items:center;gap:.5rem;padding:.5rem;cursor:pointer}.activity-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.room-detail-page{padding:1rem;padding-bottom:100px}.room-detail-header{margin-bottom:1.5rem}.room-detail-header h1{font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.room-detail-meta{font-size:.9rem;color:#666}.room-detail-section{margin-bottom:2rem}.room-detail-section h2{font-size:1.1rem;font-weight:600;margin-bottom:1rem}.members-list{display:flex;flex-direction:column;gap:.75rem}.member-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f5f5f5;border-radius:8px}.member-info{display:flex;align-items:center;gap:.5rem}.member-name{font-weight:500}.member-role{font-size:.8rem;color:#666;background:#e0e0e0;padding:2px 6px;border-radius:4px}.member-ready{font-size:.85rem;font-weight:500}.member-ready.ready{color:#4caf50}.member-ready.not-ready{color:#999}.room-detail-actions{position:fixed;bottom:70px;left:0;right:0;padding:1rem;background:#fff;border-top:1px solid #e0e0e0;display:flex;gap:1rem}.btn-ready{flex:1;padding:12px;background:#f5f5f5;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer}.btn-ready.ready{background:#4caf50;color:#fff;border-color:#4caf50}.btn-start-voting{flex:1;padding:12px;background:#1976d2;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer}.btn-start-voting:disabled{background:#ccc;cursor:not-allowed}.toast-message{position:fixed;bottom:150px;left:50%;transform:translate(-50%);background:#333;color:#fff;padding:12px 20px;border-radius:8px;z-index:1000}.invites-page{padding:1rem}.invites-header{margin-bottom:1rem}.invites-header h1{font-size:1.5rem;font-weight:600}.invites-filters{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:1px solid #e0e0e0}.filter{flex:1;padding:12px;background:none;border:none;border-bottom:2px solid transparent;font-size:.95rem;color:#666;cursor:pointer}.filter.active{color:#1976d2;border-bottom-color:#1976d2;font-weight:600}.invites-list{display:flex;flex-direction:column;gap:1rem}.invite-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:1rem}.invite-info h3{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.invite-info p{font-size:.9rem;color:#666;margin-bottom:1rem}.invite-actions{display:flex;gap:.5rem;flex-wrap:wrap}.btn-view{padding:8px 16px;background:#1976d2;color:#fff;border:none;border-radius:8px;font-size:.85rem;text-decoration:none;cursor:pointer}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d}.modal-close:hover{color:#000}.create-activity-form{padding:1.5rem}.image-preview{margin-top:1rem;position:relative}.image-preview img{width:100%;max-height:200px;object-fit:contain;border-radius:8px;background:#f5f5f5}.btn-remove-image{margin-top:.5rem;padding:8px 16px;background:#f44336;color:#fff;border:none;border-radius:8px;font-size:.85rem;cursor:pointer}.btn-primary:disabled{background:#ccc;cursor:not-allowed}.activities-page{padding:1rem}.activities-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.activities-header h1{font-size:1.5rem;font-weight:600}.activities-list{display:flex;flex-direction:column;gap:1rem}.activity-card{display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:1rem;text-decoration:none;color:inherit}.activity-card-content{flex:1}.activity-card-content h3{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.activity-description{font-size:.9rem;color:#666}.activity-detail-page{padding:1rem;padding-bottom:100px}.activity-image{width:100%;height:250px;margin-bottom:1rem;border-radius:12px;overflow:hidden;background:#f5f5f5}.activity-image img{width:100%;height:100%;object-fit:cover}.activity-content h1{font-size:1.5rem;font-weight:600;margin-bottom:1rem}.description-short{font-size:1rem;color:#666;margin-bottom:1rem}.description{font-size:.95rem;color:#666;line-height:1.6;margin-bottom:1.5rem}.activity-edit{display:flex;flex-direction:column;gap:1rem}.activity-actions{display:flex;gap:1rem;margin-top:1rem}.btn-secondary{padding:12px 24px;background:#f5f5f5;color:#333;border:1px solid #e0e0e0;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer}.activity-image-actions{margin-top:2rem;display:flex;flex-direction:column;gap:.5rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:400px;box-shadow:0 4px 20px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.modal-header h2{font-size:1.3rem;font-weight:600;margin:0}.modal-close{background:none;border:none;font-size:2rem;line-height:1;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.create-group-form{padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:500;margin-bottom:.5rem;font-size:.95rem}.input-field:focus{border-color:#1976d2;outline:none}.form-actions{display:flex;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e0e0e0}.groups-page{padding:1rem}.groups-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.groups-header h1{font-size:1.5rem;font-weight:600}.groups-list{display:flex;flex-direction:column;gap:1rem}.group-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:1rem;text-decoration:none;color:inherit}.group-card h3{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.group-card p{font-size:.9rem;color:#666;margin-bottom:.5rem}.btn-delete{padding:8px 16px;background:#f44336;color:#fff;border:none;border-radius:8px;font-size:.85rem;cursor:pointer}.load-more{margin-top:1rem;padding:12px;background:#f5f5f5;border:none;border-radius:8px;font-size:.9rem;cursor:pointer}.group-detail-page{padding:1rem;padding-bottom:100px}.group-content h1{font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.group-content p{color:#666;margin-bottom:1rem}.group-edit{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.input-field{width:100%;padding:12px;border:1px solid #e0e0e0;border-radius:8px;font-size:1rem;font-family:inherit}.group-actions{display:flex;gap:1rem}.group-activities-section{margin-top:2rem}.group-activities-section h2{font-size:1.1rem;font-weight:600;margin-bottom:1rem}.activities-list{display:flex;flex-direction:column;gap:.5rem}.activity-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f5f5f5;border-radius:8px}.btn-remove{padding:6px 12px;background:#f44336;color:#fff;border:none;border-radius:6px;font-size:.85rem;cursor:pointer}.group-add-activities{margin-top:2rem}.group-add-activities h2{font-size:1.1rem;font-weight:600;margin-bottom:1rem}.available-activities{display:flex;flex-direction:column;gap:.5rem}.btn-add-activity{padding:.75rem;background:#e3f2fd;color:#1976d2;border:1px solid #1976d2;border-radius:8px;font-size:.9rem;cursor:pointer;text-align:left}.friends-page{padding:1rem}.friends-header{margin-bottom:1rem}.friends-header h1{font-size:1.5rem;font-weight:600}.friends-tabs{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:1px solid #e0e0e0}.tab{flex:1;padding:12px;background:none;border:none;border-bottom:2px solid transparent;font-size:.95rem;color:#666;cursor:pointer}.tab.active{color:#1976d2;border-bottom-color:#1976d2;font-weight:600}.friends-list{display:flex;flex-direction:column;gap:.75rem}.friend-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#fff;border:1px solid #e0e0e0;border-radius:12px}.friend-name{font-weight:500}.requests-actions{margin-bottom:1.5rem}.requests-section{margin-bottom:2rem}.requests-section h2{font-size:1.1rem;font-weight:600;margin-bottom:1rem}.request-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#fff;border:1px solid #e0e0e0;border-radius:12px;margin-bottom:.75rem}.request-actions{display:flex;gap:.5rem}.btn-accept{padding:8px 16px;background:#4caf50;color:#fff;border:none;border-radius:8px;font-size:.85rem;cursor:pointer}.btn-decline{padding:8px 16px;background:#f44336;color:#fff;border:none;border-radius:8px;font-size:.85rem;cursor:pointer}.btn-cancel{padding:8px 16px;background:#ff9800;color:#fff;border:none;border-radius:8px;font-size:.85rem;cursor:pointer}.voting-card-container{display:flex;flex-direction:column;align-items:center;padding:1rem;min-height:500px}.voting-card{width:90%;max-width:400px;background:#fff;border-radius:16px;box-shadow:0 4px 12px #00000026;overflow:hidden;touch-action:pan-y;cursor:grab}.voting-card:active{cursor:grabbing}.voting-card-image{width:100%;height:300px;background:#f5f5f5;overflow:hidden}.voting-card-image img{width:100%;height:100%;object-fit:cover}.voting-card-content{padding:1.5rem}.voting-card-content h2{font-size:1.3rem;font-weight:600;margin-bottom:.5rem}.voting-card-description{color:#666;font-size:.95rem;line-height:1.5}.voting-card-actions{display:flex;gap:1rem;margin-top:2rem;width:90%;max-width:400px}.btn-like,.btn-dislike{flex:1;padding:16px;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .1s}.btn-like:active,.btn-dislike:active{transform:scale(.95)}.btn-like{background:#4caf50;color:#fff}.btn-dislike{background:#f44336;color:#fff}.btn-undo{margin-top:1rem;padding:12px 24px;background:#ff9800;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer}.voting-page{padding:1rem;padding-bottom:100px}.voting-progress{text-align:center;font-size:.9rem;color:#666;margin-bottom:1rem}.room-results-page{padding:1rem;padding-bottom:100px}.results-header{margin-bottom:2rem}.results-header h1{font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.results-mode{font-size:.9rem;color:#666}.results-winner{margin-bottom:2rem}.results-winner h2{font-size:1.2rem;font-weight:600;margin-bottom:1rem}.winner-card{background:#fff;border:2px solid #4caf50;border-radius:12px;padding:1.5rem;text-align:center}.winner-image{width:100%;height:200px;margin-bottom:1rem;border-radius:8px;overflow:hidden;background:#f5f5f5}.winner-image img{width:100%;height:100%;object-fit:cover}.winner-card h3{font-size:1.3rem;font-weight:600}.results-ranking{margin-top:2rem}.results-ranking h2{font-size:1.2rem;font-weight:600;margin-bottom:1rem}.ranking-list{display:flex;flex-direction:column;gap:1rem}.ranking-item{display:flex;gap:1rem;padding:1rem;background:#fff;border:1px solid #e0e0e0;border-radius:12px}.ranking-position{font-size:1.5rem;font-weight:600;color:#1976d2;min-width:50px}.ranking-activity{flex:1}.ranking-activity h3{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.ranking-stats{display:flex;gap:1rem;font-size:.9rem}.stat-like{color:#4caf50}.stat-dislike{color:#f44336}.app-loading{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:1.2rem;color:#666}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;color:#000;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column}button{font-family:inherit;cursor:pointer;border:none;outline:none}input,textarea{font-family:inherit;outline:none}a{text-decoration:none;color:inherit}
