:root{--primary-color: #6c5ce7;--primary-light: #a29bfe;--secondary-color: #00b894;--accent-color: #fd79a8;--warning-color: #fdcb6e;--error-color: #e17055;--background: #f8f9fa;--card-bg: #ffffff;--text-primary: #2d3436;--text-secondary: #636e72;--border-radius: 16px;--shadow: 0 4px 20px rgba(0, 0, 0, .1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:linear-gradient(135deg,#f8f9fa,#e9ecef);min-height:100vh;color:var(--text-primary)}#root{min-height:100vh}.app{min-height:100vh;padding:2rem}.app-header{text-align:center;margin-bottom:2rem}.app-title{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,var(--primary-color),var(--accent-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.app-subtitle{color:var(--text-secondary);font-size:1.1rem}.app-content{max-width:1200px;margin:0 auto}.tabs{display:flex;gap:1rem;margin-bottom:2rem;justify-content:center}.tab-btn{padding:.75rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:var(--border-radius);cursor:pointer;transition:all .3s ease;background:var(--card-bg);color:var(--text-secondary);box-shadow:var(--shadow)}.tab-btn:hover{transform:translateY(-2px);box-shadow:0 6px 25px #00000026}.tab-btn.active{background:linear-gradient(135deg,var(--primary-color),var(--primary-light));color:#fff}.upload-container{background:var(--card-bg);border-radius:var(--border-radius);padding:3rem;box-shadow:var(--shadow);text-align:center}.upload-zone{border:3px dashed var(--primary-light);border-radius:var(--border-radius);padding:4rem 2rem;cursor:pointer;transition:all .3s ease;background:linear-gradient(135deg,#f8f9fa,#fff)}.upload-zone:hover{border-color:var(--primary-color);background:linear-gradient(135deg,#f0f0ff,#fff);transform:scale(1.01)}.upload-zone.dragging{border-color:var(--secondary-color);background:linear-gradient(135deg,#e8fff5,#fff)}.upload-zone.disabled{opacity:.5;cursor:not-allowed}.upload-icon{font-size:4rem;margin-bottom:1rem}.upload-text{font-size:1.25rem;color:var(--text-primary);margin-bottom:.5rem}.upload-subtext{color:var(--text-secondary)}.upload-btn{margin-top:1.5rem;padding:1rem 2.5rem;font-size:1.1rem;font-weight:600;border:none;border-radius:var(--border-radius);background:linear-gradient(135deg,var(--primary-color),var(--primary-light));color:#fff;cursor:pointer;transition:all .3s ease}.upload-btn:hover{transform:translateY(-3px);box-shadow:0 8px 25px #6c5ce766}.upload-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.editor-container{background:var(--card-bg);border-radius:var(--border-radius);padding:2rem;box-shadow:var(--shadow)}.editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.editor-title{font-size:1.5rem;font-weight:600;color:var(--text-primary)}.editor-actions{display:flex;gap:.75rem;flex-wrap:wrap}.btn{padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,var(--secondary-color),#00cec9);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00b89466}.btn-secondary{background:var(--background);color:var(--text-primary);border:2px solid #ddd}.btn-secondary:hover{border-color:var(--primary-color);color:var(--primary-color)}.btn-danger{background:linear-gradient(135deg,var(--error-color),#ff7675);color:#fff}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 6px 20px #e1705566}.json-textarea{width:100%;min-height:500px;padding:1.5rem;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.9rem;line-height:1.5;border:2px solid #e9ecef;border-radius:12px;resize:vertical;background:#2d3436;color:#dfe6e9}.json-textarea:focus{outline:none;border-color:var(--primary-color)}.success-container{background:var(--card-bg);border-radius:var(--border-radius);padding:4rem 2rem;box-shadow:var(--shadow);text-align:center}.success-animation{font-size:6rem;margin-bottom:1.5rem;animation:bounce .6s ease infinite alternate}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-20px)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.success-title{font-size:2rem;font-weight:700;color:var(--secondary-color);margin-bottom:1rem}.success-message{font-size:1.2rem;color:var(--text-secondary);margin-bottom:2rem}.confetti{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden;z-index:1000}.confetti-piece{position:absolute;width:10px;height:10px;animation:confetti-fall 3s ease-out forwards}@keyframes confetti-fall{0%{opacity:1;transform:translateY(-100vh) rotate(0)}to{opacity:0;transform:translateY(100vh) rotate(720deg)}}.error-container{background:var(--card-bg);border-radius:var(--border-radius);padding:4rem 2rem;box-shadow:var(--shadow);text-align:center}.error-animation{font-size:5rem;margin-bottom:1.5rem;animation:wobble .5s ease infinite}@keyframes wobble{0%,to{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}.error-title{font-size:1.75rem;font-weight:700;color:var(--error-color);margin-bottom:1rem}.error-message{font-size:1.1rem;color:var(--text-secondary);margin-bottom:.5rem}.error-details{font-size:.95rem;color:var(--text-secondary);background:#fff5f5;padding:1rem;border-radius:8px;margin:1rem 0 2rem;font-family:monospace}.search-container{background:var(--card-bg);border-radius:var(--border-radius);padding:2rem;box-shadow:var(--shadow)}.search-header{margin-bottom:1.5rem}.search-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.search-subtitle{color:var(--text-secondary)}.search-form{display:flex;gap:1rem;margin-bottom:2rem}.search-input{flex:1;padding:1rem 1.5rem;font-size:1rem;border:2px solid #e9ecef;border-radius:12px;transition:all .3s ease}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 4px #6c5ce71a}.search-btn{padding:1rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:12px;background:linear-gradient(135deg,var(--primary-color),var(--primary-light));color:#fff;cursor:pointer;transition:all .3s ease}.search-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6c5ce766}.search-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.search-results{margin-top:1.5rem}.results-count{font-size:1rem;color:var(--text-secondary);margin-bottom:1rem}.result-card{background:linear-gradient(135deg,#f8f9fa,#fff);border:1px solid #e9ecef;border-radius:12px;padding:1.5rem;margin-bottom:1rem;transition:all .3s ease;text-align:left}.result-card:hover{transform:translate(5px);border-color:var(--primary-light);box-shadow:0 4px 15px #0000000d}.result-header{display:flex;gap:.75rem;align-items:center;margin-bottom:.75rem;flex-wrap:wrap}.result-game{font-weight:600;color:var(--primary-color)}.result-badge{padding:.25rem .75rem;font-size:.75rem;font-weight:600;border-radius:20px;text-transform:uppercase}.badge-text{background:var(--primary-light);color:#fff}.badge-picture{background:var(--accent-color);color:#fff}.badge-music{background:var(--secondary-color);color:#fff}.badge-game{background:var(--warning-color);color:var(--text-primary)}.result-round{font-size:.85rem;color:var(--text-secondary)}.result-content{color:var(--text-primary)}.result-question{font-weight:500;margin-bottom:.5rem}.result-answer{color:var(--text-secondary)}.result-answer strong{color:var(--secondary-color)}.no-results{text-align:center;padding:3rem;color:var(--text-secondary)}.no-results-icon{font-size:3rem;margin-bottom:1rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--card-bg);border-radius:var(--border-radius);padding:2rem;max-width:450px;width:90%;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-title{font-size:1.5rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary)}.modal-message{color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.6}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.loading{display:flex;flex-direction:column;align-items:center;padding:3rem}.spinner{width:50px;height:50px;border:4px solid var(--background);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.loading-text{margin-top:1rem;color:var(--text-secondary);font-size:1.1rem}.section-tabs{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:2px solid #e9ecef;padding-bottom:.5rem}.section-tab{padding:.5rem 1rem;font-size:.9rem;font-weight:600;border:none;border-radius:8px 8px 0 0;cursor:pointer;background:transparent;color:var(--text-secondary);transition:all .2s ease}.section-tab:hover{background:#f8f9fa;color:var(--text-primary)}.section-tab.active{background:var(--primary-color);color:#fff}.table-container{overflow-x:auto;max-height:500px;overflow-y:auto;border:1px solid #e9ecef;border-radius:8px}.data-table{width:100%;border-collapse:collapse;font-size:.9rem}.data-table thead{background:#f8f9fa;position:sticky;top:0;z-index:1}.data-table th{padding:.75rem .5rem;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid #e9ecef}.data-table td{padding:.5rem;border-bottom:1px solid #e9ecef;vertical-align:middle}.data-table tr:hover{background:#f8f9fa}.table-input{width:100%;padding:.5rem;font-size:.85rem;border:1px solid #ddd;border-radius:4px;transition:border-color .2s ease}.table-input:focus{outline:none;border-color:var(--primary-color)}.table-input-small{width:60px}.table-input-medium{width:100px}.delete-btn{width:28px;height:28px;padding:0;font-size:.8rem;font-weight:700;border:none;border-radius:4px;background:#fee;color:var(--error-color);cursor:pointer;transition:all .2s ease}.delete-btn:hover{background:var(--error-color);color:#fff}.empty-row{text-align:center;color:var(--text-secondary);padding:2rem!important;font-style:italic}.game-view-container{background:var(--card-bg);border-radius:var(--border-radius);padding:2rem;box-shadow:var(--shadow)}.game-view-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.game-view-actions{display:flex;gap:.75rem;flex-wrap:wrap}.game-metadata{display:flex;flex-direction:column;gap:.5rem}.metadata-row{display:flex;align-items:center;gap:.75rem}.metadata-label{font-weight:600;color:var(--text-secondary);min-width:80px}.metadata-value{color:var(--text-primary)}.metadata-input{padding:.5rem .75rem;font-size:1rem;border:1px solid #ddd;border-radius:6px;min-width:250px;transition:border-color .2s ease}.metadata-input:focus{outline:none;border-color:var(--primary-color)}.round-tabs{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:2px solid #e9ecef;padding-bottom:.5rem;flex-wrap:wrap}.round-tab{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;font-weight:600;border:none;border-radius:8px 8px 0 0;cursor:pointer;background:transparent;color:var(--text-secondary);transition:all .2s ease}.round-tab:hover{background:#f8f9fa;color:var(--text-primary)}.round-tab.active{color:#fff}.round-tab-text.active{background:var(--primary-color)}.round-tab-picture.active{background:var(--accent-color)}.round-tab-music.active{background:var(--secondary-color)}.round-tab-count{font-size:.8rem;opacity:.8}.round-tab-input{width:120px;padding:.25rem .5rem;font-size:.85rem;font-weight:600;border:1px solid rgba(255,255,255,.5);border-radius:4px;background:#fff3;color:inherit}.round-tab-input:focus{outline:none;border-color:#fff;background:#ffffff4d}.game-view-summary{margin-top:1rem;color:var(--text-secondary);font-size:.9rem}.no-rounds{text-align:center;padding:3rem;color:var(--text-secondary);font-style:italic}.game-management-container{background:var(--card-bg);border-radius:var(--border-radius);padding:2rem;box-shadow:var(--shadow)}.game-list-header{margin-bottom:1.5rem}.game-list-header h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.game-list-header p{color:var(--text-secondary)}.game-search-filters{background:#f8f9fa;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.filter-row{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.filter-group{flex:1;min-width:150px}.filter-group label{display:block;font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:.25rem}.filter-group input{width:100%;padding:.5rem .75rem;font-size:.9rem;border:1px solid #ddd;border-radius:6px;transition:border-color .2s ease}.filter-group input:focus{outline:none;border-color:var(--primary-color)}.filter-actions{display:flex;gap:.75rem;justify-content:flex-end}.game-list-info{color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem}.game-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;margin-bottom:1.5rem}.game-card{background:linear-gradient(135deg,#f8f9fa,#fff);border:1px solid #e9ecef;border-radius:12px;padding:1.25rem;cursor:pointer;transition:all .3s ease}.game-card:hover{transform:translateY(-3px);border-color:var(--primary-light);box-shadow:0 6px 20px #0000001a}.game-card-header{margin-bottom:1rem}.game-card-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem;line-height:1.3}.game-card-subject{display:inline-block;padding:.2rem .5rem;font-size:.75rem;background:var(--primary-light);color:#fff;border-radius:4px}.game-card-stats{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.stat{display:flex;flex-direction:column;align-items:center;min-width:45px}.stat-value{font-size:1.25rem;font-weight:700;color:var(--primary-color)}.stat-label{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase}.game-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px solid #e9ecef}.game-card-date{font-size:.8rem;color:var(--text-secondary)}.btn-small{padding:.4rem .8rem;font-size:.85rem}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem}.page-info{color:var(--text-secondary);font-size:.9rem}.no-games{text-align:center;padding:3rem;color:var(--text-secondary)}.no-games-icon{font-size:4rem;margin-bottom:1rem}.no-games-hint{font-size:.9rem;margin-top:.5rem}.game-detail-header{display:flex;gap:.75rem;margin-bottom:1.5rem}.error-message{background:#fff5f5;color:var(--error-color);padding:1rem;border-radius:8px;margin-bottom:1rem}.play-date-manager{background:#f8f9fa;border-radius:12px;padding:1.5rem;margin-top:1.5rem}.play-date-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.play-date-header h4{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.play-date-error{background:#fff5f5;color:var(--error-color);padding:.5rem .75rem;border-radius:6px;font-size:.85rem;margin-bottom:1rem}.play-date-form{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap;align-items:flex-end}.play-date-form input{flex:1;min-width:150px;padding:.5rem .75rem;font-size:.9rem;border:1px solid #ddd;border-radius:6px}.play-date-form input:focus{outline:none;border-color:var(--primary-color)}.play-date-form-actions{display:flex;gap:.5rem}.play-date-list{max-height:200px;overflow-y:auto}.play-date-empty{text-align:center;padding:1rem;color:var(--text-secondary);font-style:italic}.play-date-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#fff;border-radius:6px;margin-bottom:.5rem}.play-date-info{display:flex;flex-direction:column;gap:.25rem}.play-date-date{font-weight:500;color:var(--text-primary)}.play-date-external{font-size:.8rem;color:var(--text-secondary)}.upload-queue{background:var(--card-bg);border-radius:var(--border-radius);padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow)}.queue-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.queue-header h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.queue-progress{font-size:.9rem;color:var(--text-secondary)}.queue-progress-bar{height:6px;background:#e9ecef;border-radius:3px;margin-bottom:1rem;overflow:hidden}.queue-progress-fill{height:100%;background:linear-gradient(135deg,var(--secondary-color),#00cec9);border-radius:3px;transition:width .3s ease}.queue-list{display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto}.queue-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#f8f9fa;border-radius:8px;border-left:3px solid #ddd;transition:all .2s ease}.queue-item-active,.queue-item-success{background:#e8f5e9;border-left-color:var(--secondary-color)}.queue-item-error{background:#fff5f5;border-left-color:var(--error-color)}.queue-item-icon{font-size:1.25rem}.queue-item-name{flex:1;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-item-status{font-size:.85rem;font-weight:600;padding:.25rem .5rem;border-radius:4px;background:#e9ecef;color:var(--text-secondary)}.status-processing,.status-review{background:var(--warning-color);color:var(--text-primary)}.status-accepted{background:var(--secondary-color);color:#fff}.status-rejected,.status-error{background:var(--error-color);color:#fff}.queue-item-error-msg{font-size:.8rem;color:var(--error-color)}
