:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;padding:0;min-height:100vh}#root{width:100%;min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);background-repeat:no-repeat;background-attachment:fixed;background-size:cover;min-height:100vh;color:#333}body.modal-open{overflow:hidden;position:fixed;width:100%}.app{min-height:100vh;display:flex;flex-direction:column}.header{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #0000001a;padding:1rem 2rem;border-bottom:3px solid #ffd700;position:relative;z-index:100}.header-content{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto}.header-left{display:flex;align-items:center;flex-shrink:0}.header-center{display:flex;align-items:center;justify-content:center;flex:1;margin:0 2rem}.header-right{display:flex;align-items:center;gap:1rem;flex-shrink:0}.header-icon{color:gold;margin-right:1rem}.header h1{color:#333;font-size:2rem;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.title-mobile{display:none}.title-full{display:inline}.header-stats{display:flex;gap:2rem;font-weight:600;color:#666}.header-stats span{background:#667eea1a;padding:.5rem 1rem;border-radius:20px;border:2px solid rgba(102,126,234,.2)}.nav-tabs{display:flex;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:0 2rem;box-shadow:0 2px 10px #0000001a}.nav-tab{display:flex;align-items:center;gap:.5rem;padding:1rem 2rem;background:none;border:none;cursor:pointer;font-size:1rem;font-weight:600;color:#666;border-bottom:3px solid transparent;transition:all .3s ease}.nav-tab:hover{background:#667eea1a;color:#667eea}.nav-tab.active{color:#667eea;border-bottom-color:#667eea;background:#667eea1a}.main-content{flex:1;padding:2rem;max-width:1200px;margin:0 auto;width:100%}.teams-container{display:flex;flex-direction:column;gap:2rem}.add-participant-section{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:20px;box-shadow:0 8px 32px #0000001a;border:1px solid rgba(255,255,255,.2)}.add-participant-section h2{margin-bottom:1rem;color:#333;font-size:1.5rem}.add-participant-form{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.team-select,.participant-input,.epreuve-select{padding:.75rem 1rem;border:2px solid #e1e5e9;border-radius:12px;font-size:1rem;background:#fff;transition:all .3s ease}.team-select:focus,.participant-input:focus,.epreuve-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.participant-input{flex:1;min-width:200px}.add-btn,.save-btn,.export-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.add-btn:hover,.save-btn:hover,.export-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.teams-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem}.team-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;overflow:hidden;box-shadow:0 8px 32px #0000001a;border:3px solid;transition:all .3s ease}.team-card:hover{transform:translateY(-5px);box-shadow:0 12px 40px #00000026}.team-header{padding:1.5rem;color:#fff;display:flex;justify-content:space-between;align-items:center;flex-direction:column;gap:1rem}.team-header h3{font-size:1.3rem;font-weight:700}.team-header-controls{display:flex;justify-content:space-between;align-items:center;width:100%;flex-wrap:wrap;gap:1rem}.participant-count{background:#fff3;padding:.3rem .8rem;border-radius:15px;font-size:.9rem}.color-selector{display:flex;align-items:center;gap:.5rem}.color-picker-label{font-size:.9rem;color:#ffffffe6;font-weight:500;cursor:pointer}.color-picker{width:40px;height:30px;border:2px solid rgba(255,255,255,.3);border-radius:8px;cursor:pointer;transition:all .3s ease;background:none;padding:0}.color-picker:hover{border-color:#fffc;transform:scale(1.05);box-shadow:0 0 10px #ffffff4d}.color-picker:focus{outline:none;border-color:#fff;box-shadow:0 0 15px #ffffff80}.color-picker::-webkit-color-swatch-wrapper{padding:0;border:none;border-radius:6px;overflow:hidden}.color-picker::-webkit-color-swatch{border:none;border-radius:6px}.participants-list{padding:1.5rem;min-height:150px}.no-participants{color:#999;font-style:italic;text-align:center;padding:2rem}.participant-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;margin-bottom:.5rem;background:#667eea0d;border-radius:12px;border:1px solid rgba(102,126,234,.1);transition:all .3s ease}.participant-item:hover{background:#667eea1a;transform:translate(5px)}.remove-btn{background:#ef4444;color:#fff;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.remove-btn:hover{background:#dc2626;transform:scale(1.1)}.epreuves-container{display:flex;flex-direction:column;gap:2rem}.epreuve-selector{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:20px;box-shadow:0 8px 32px #0000001a}.epreuve-selector h2{margin-bottom:1rem;color:#333}.epreuve-select{width:100%;max-width:400px;padding:.75rem 1rem;border:2px solid #e1e5e9;border-radius:12px;font-size:1rem;background:#fff;transition:all .3s ease;cursor:pointer;pointer-events:auto!important}.epreuve-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.epreuve-select:hover{border-color:#667eea}.epreuve-select option{padding:.5rem;cursor:pointer}.epreuve-content{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:20px;box-shadow:0 8px 32px #0000001a}.epreuve-info{margin-bottom:2rem;text-align:center}.epreuve-info h3{font-size:1.8rem;color:#333;margin-bottom:.5rem}.points-info{color:#666;font-size:1.1rem;background:#667eea1a;padding:1rem;border-radius:12px;display:inline-block}.classement-section{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem}.participants-disponibles,.classement-actuel{background:#f8fafccc;padding:1.5rem;border-radius:16px;border:2px solid rgba(102,126,234,.1)}.participants-disponibles h4,.classement-actuel h4{margin-bottom:1rem;color:#333;font-size:1.2rem}.participants-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem}.participant-btn{padding:.75rem 1rem;background:#fff;border:2px solid;border-radius:12px;cursor:pointer;transition:all .3s ease;text-align:left;font-size:.9rem}.participant-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.participant-btn small{display:block;font-size:.8rem;margin-top:.2rem}.classement-list{display:flex;flex-direction:column;gap:.5rem}.classement-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border-radius:12px;border:2px solid rgba(102,126,234,.1);cursor:move;transition:all .3s ease;-webkit-user-select:none;user-select:none}.classement-item:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.classement-item[draggable=true]:active{cursor:grabbing}.classement-item:drag{opacity:.5;transform:rotate(2deg)}.classement-item[style*="opacity: 0.5"]{transform:rotate(2deg) scale(.95);box-shadow:0 8px 25px #0003}.position{color:#fff;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem}.participant-info{flex:1}.participant-name{font-weight:600;color:#333}.points{background:#10b981;color:#fff;padding:.3rem .8rem;border-radius:12px;font-weight:700;font-size:.9rem}.actions{text-align:center}.classement-container{display:flex;flex-direction:column;gap:2rem}.classement-header{display:flex;justify-content:space-between;align-items:center;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:20px;box-shadow:0 8px 32px #0000001a}.classement-header h2{color:#333;font-size:2rem}.podium{display:flex;justify-content:center;align-items:end;gap:2rem;margin:2rem 0;padding:2rem;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 8px 32px #0000001a}.podium-place{text-align:center;padding:2rem 1.5rem;border-radius:20px;background:linear-gradient(135deg,#ffffffe6,#f8fafce6);box-shadow:0 8px 32px #0000001a;border:3px solid;transition:all .3s ease;min-width:200px}.place-1{border-color:gold;transform:scale(1.1)}.place-2{border-color:silver}.place-3{border-color:#cd7f32}.podium-place:hover{transform:translateY(-5px) scale(1.05)}.place-1:hover{transform:translateY(-5px) scale(1.15)}.podium-medal{margin-bottom:1rem}.podium-info h3{font-size:1.3rem;margin-bottom:.5rem}.podium-points{font-size:1.5rem;font-weight:700;color:#333}.classement-detaille{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:20px;box-shadow:0 8px 32px #0000001a}.classement-detaille h3{margin-bottom:1.5rem;color:#333;font-size:1.5rem}.classement-table{display:flex;flex-direction:column;gap:.5rem;overflow-x:auto}.epreuve-col{width:80px;min-width:80px;max-width:80px;font-size:.82rem;text-align:center;font-weight:600;line-height:1;padding:.4rem .2rem;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;white-space:normal;vertical-align:middle;display:flex;align-items:center;justify-content:center}.epreuve-col br{line-height:.8}.points-cell{width:80px;min-width:80px;max-width:80px;font-size:.8rem;text-align:center;font-weight:500}.classement-individuel{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:20px;box-shadow:0 8px 32px #0000001a;margin-top:2rem}.classement-individuel h3{margin-bottom:1.5rem;color:#333;font-size:1.5rem}.classement-table-container{overflow-x:auto;margin:0 -1rem;padding:0 1rem;scrollbar-width:thin;scrollbar-color:rgba(102,126,234,.3) transparent;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a}.classement-table-container::-webkit-scrollbar{height:8px}.classement-table-container::-webkit-scrollbar-track{background:#0000001a;border-radius:4px}.classement-table-container::-webkit-scrollbar-thumb{background:#667eea4d;border-radius:4px}.classement-table-container::-webkit-scrollbar-thumb:hover{background:#667eea80}.table-header-individuel{display:flex;gap:.8rem;padding:1rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-radius:12px;font-weight:700;font-size:.9rem;min-width:fit-content;white-space:nowrap}.table-row-individuel{display:flex;gap:.8rem;padding:1rem;background:#f8fafccc;border-radius:12px;align-items:center;transition:all .3s ease;margin-bottom:.5rem;min-width:fit-content;white-space:nowrap}.table-header-individuel>div,.table-row-individuel>div{flex-shrink:0;text-align:center}.position-col,.position-cell{width:80px;min-width:80px}.participant-col,.participant-cell{width:180px;min-width:180px;text-align:left!important}.total-col,.total-cell-individuel{width:120px;min-width:120px}.epreuve-col,.points-cell{width:80px;min-width:80px}.table-row-individuel:hover{background:#10b9811a;transform:translate(5px)}.participant-cell{font-weight:600;font-size:1rem;overflow:hidden;text-overflow:ellipsis}.total-cell-individuel{text-align:center;font-weight:700;font-size:1.1rem;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:.5rem;border-radius:8px}.medal{font-size:1.2rem;margin-right:.5rem}.classement-detaille .table-header-individuel{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:16px;box-shadow:0 4px 20px #667eea4d;border:2px solid rgba(255,255,255,.2)}.classement-detaille .table-row-individuel{background:linear-gradient(135deg,#f8fafcf2,#ffffffe6);border:2px solid rgba(102,126,234,.1);border-radius:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .4s ease;position:relative;overflow:hidden}.classement-detaille .table-row-individuel:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(102,126,234,.1),transparent);transition:left .6s ease}.classement-detaille .table-row-individuel:hover:before{left:100%}.classement-detaille .table-row-individuel:hover{background:linear-gradient(135deg,#667eea14,#764ba20d);transform:translate(8px) scale(1.02);box-shadow:0 8px 32px #667eea33;border-color:#667eea4d}.classement-detaille .total-cell-individuel{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:700;border-radius:12px;box-shadow:0 4px 15px #667eea66;position:relative;overflow:hidden}.classement-detaille .total-cell-individuel:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:#ffffff4d;border-radius:50%;transform:translate(-50%,-50%);transition:all .3s ease}.classement-detaille .table-row-individuel:hover .total-cell-individuel:after{width:100%;height:100%}.classement-detaille .participant-cell{font-weight:700;font-size:1.1rem;position:relative;text-shadow:0 1px 2px rgba(0,0,0,.1)}.classement-detaille .participant-cell:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:currentColor;transition:width .3s ease}.classement-detaille .table-row-individuel:hover .participant-cell:after{width:100%}.classement-detaille .points-cell{background:#ffffffb3;border-radius:8px;font-weight:600;transition:all .3s ease;border:1px solid rgba(102,126,234,.1);position:relative}.classement-detaille .points-cell:hover{background:#667eea1a;transform:scale(1.05);box-shadow:0 2px 8px #667eea33}.classement-detaille .points-cell:not(:empty):not([data-points="0"]){background:linear-gradient(135deg,#10b9811a,#0596690d);color:#059669;border-color:#10b98133}.classement-detaille .points-cell:not(:empty):not([data-points="0"]):hover{background:linear-gradient(135deg,#10b98133,#0596691a);color:#047857}.classement-detaille .table-row-individuel:first-child{background:linear-gradient(135deg,#ffd7001a,#ffc1070d);border-color:#ffd7004d}.classement-detaille .table-row-individuel:first-child:hover{background:linear-gradient(135deg,#ffd70026,#ffc1071a);box-shadow:0 8px 32px #ffd7004d}.classement-detaille .table-row-individuel:first-child .total-cell-individuel{background:linear-gradient(135deg,gold,#ffb300);color:#333;font-weight:900;box-shadow:0 4px 20px #ffd70080}.classement-detaille .table-row-individuel{animation:detailledTableSlideIn .6s ease-out;animation-fill-mode:both}.classement-detaille .table-row-individuel:nth-child(1){animation-delay:.1s}.classement-detaille .table-row-individuel:nth-child(2){animation-delay:.2s}.classement-detaille .table-row-individuel:nth-child(3){animation-delay:.3s}.classement-detaille .table-row-individuel:nth-child(4){animation-delay:.4s}.classement-detaille .table-row-individuel:nth-child(5){animation-delay:.5s}@keyframes detailledTableSlideIn{0%{opacity:0;transform:translate(-30px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}@media (max-width: 768px){.classement-detaille .table-header-individuel,.classement-detaille .table-row-individuel{border-radius:12px;padding:.75rem}.classement-detaille .total-cell-individuel{border-radius:8px}.classement-detaille .points-cell{border-radius:6px}}@media (max-width: 320px){.classement-detaille .table-row-individuel:hover{transform:translate(4px) scale(1.01)}.classement-detaille .participant-cell{font-size:.9rem}}@media (max-width: 768px){.header{padding:1rem}.header-content{flex-direction:column;gap:.75rem;text-align:center}.header-left{width:100%;justify-content:center;gap:.5rem}.header-center{margin:0;width:100%;justify-content:center}.header-right{gap:.75rem;width:100%;justify-content:center;flex-wrap:wrap}.header h1{font-size:1.3rem}.title-full{display:none}.title-mobile{display:inline}.header-stats{flex-direction:row;gap:1rem;justify-content:center;flex-wrap:wrap}.header-stats span{font-size:.9rem;padding:.4rem .8rem}.nav-tabs{flex-direction:column;padding:0}.nav-tab{padding:1rem;border-bottom:1px solid rgba(0,0,0,.1);border-left:3px solid transparent}.nav-tab.active{border-left-color:#667eea;border-bottom-color:transparent}.main-content{padding:1rem}.add-participant-form{flex-direction:column;align-items:stretch}.teams-grid{grid-template-columns:1fr}.team-header-controls{flex-direction:column;align-items:flex-start;gap:.5rem}.color-selector{align-self:stretch;justify-content:space-between}.color-picker{width:35px;height:25px}.color-picker-label{font-size:.8rem}.classement-section{grid-template-columns:1fr;gap:1rem}.participants-disponibles,.classement-actuel{padding:1rem}.participants-grid{grid-template-columns:1fr;gap:.5rem}.participant-btn{padding:.5rem .75rem;font-size:.85rem;text-align:center}.classement-item{padding:.75rem;gap:.75rem;flex-wrap:wrap}.participant-info{font-size:.9rem;min-width:0;flex:1}.position{width:28px;height:28px;font-size:.9rem;flex-shrink:0}.points{padding:.25rem .6rem;font-size:.8rem;flex-shrink:0}.podium{flex-direction:column;align-items:center}.podium-place{min-width:auto;width:100%;max-width:300px}.place-1{transform:none;order:-1}.table-header-individuel,.table-row-individuel{gap:.5rem;font-size:.8rem;padding:.75rem}.position-col,.position-cell{width:60px;min-width:60px}.participant-col,.participant-cell{width:120px;min-width:120px}.total-col,.total-cell-individuel{width:80px;min-width:80px}.epreuve-col,.points-cell{width:50px;min-width:50px;font-size:.7rem}.classement-table-container{margin:0 -.5rem;padding:0 .5rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.classement-table{min-width:1200px}.epreuve-col{width:70px;min-width:70px;max-width:70px;font-size:.75rem;font-weight:600;line-height:1;padding:.3rem .1rem;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.points-cell{width:70px;min-width:70px;max-width:70px;font-size:.7rem}.epreuve-col{font-size:.7rem;min-width:60px}.classement-individuel .classement-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:8px;box-shadow:inset 0 0 10px #0000001a}.classement-individuel .classement-table{min-width:1000px}.classement-table-container:after{content:"👈 Faites défiler horizontalement pour voir toutes les colonnes";display:block;text-align:center;font-size:.8rem;color:#666;padding:.5rem;background:#ffffffe6;border-top:1px solid #e0e0e0;position:sticky;bottom:0;left:0;right:0;border-radius:0 0 12px 12px}.mode-buttons{flex-direction:column;gap:.5rem}.mode-btn{padding:1rem;font-size:.9rem}.score-input-row{flex-direction:column;gap:.5rem;text-align:center}.score-input{width:100%;max-width:200px}.score-actions{flex-direction:column;gap:.5rem}.apply-scores-btn,.reset-scores-btn{width:100%;justify-content:center}}.team-card,.epreuve-content,.classement-container>*{animation:slideIn .5s ease-out}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0000001a;border-radius:4px}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#5a67d8,#6b46c1)}.warning-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease-out}.warning-content{background:#fff;padding:2rem;border-radius:20px;text-align:center;max-width:400px;width:90%;animation:scaleIn .3s ease-out;box-shadow:0 0 30px #ff00004d;border:3px solid #ef4444}.warning-icon{color:#ef4444;margin-bottom:1rem;animation:pulse 1s infinite}.warning-content h2{color:#ef4444;margin-bottom:1rem;font-size:1.5rem}.warning-actions{display:flex;gap:1rem;justify-content:center;margin-top:2rem}.confirm-btn,.cancel-btn{padding:.75rem 1.5rem;border-radius:12px;font-weight:600;cursor:pointer;transition:all .3s ease}.confirm-btn{background:#ef4444;color:#fff;border:none}.confirm-btn:hover{background:#dc2626;transform:translateY(-2px)}.cancel-btn{background:#fff;color:#666;border:2px solid #ddd}.cancel-btn:hover{background:#f3f4f6;transform:translateY(-2px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.9)}to{transform:scale(1)}}.team-name-display{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem;border-radius:8px;transition:background-color .3s ease}.team-name-display:hover{background-color:#fff3}.edit-icon{font-size:1rem;opacity:.7;transition:opacity .3s ease}.team-name-display:hover .edit-icon{opacity:1}.team-name-edit{display:flex;align-items:center;gap:.5rem;background:#fff3;padding:.5rem;border-radius:8px}.team-name-input{background:#fff;border:none;padding:.5rem;border-radius:4px;font-size:1.2rem;font-weight:700;color:#333;width:200px}.save-team-name-btn,.cancel-team-name-btn{background:none;border:none;color:#fff;font-size:1.2rem;cursor:pointer;padding:.25rem;border-radius:4px;transition:background-color .3s ease}.save-team-name-btn:hover{background-color:#10b9814d}.cancel-team-name-btn:hover{background-color:#ef44444d}.fast-epreuve-popup{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;justify-content:center;align-items:center;z-index:1000}.fast-epreuve-content{position:relative;background:#fff;padding:2rem;border-radius:20px;text-align:center;max-width:500px;width:90%;box-shadow:0 8px 32px #0003;animation:popIn .3s ease-out}@keyframes popIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.fast-epreuve-title{font-size:2rem;color:#333;margin-bottom:1rem}.fast-epreuve-description{font-size:1.2rem;color:#666;margin-bottom:2rem}.fast-epreuve-go-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 3rem;font-size:1.5rem;border-radius:12px;cursor:pointer;transition:all .3s ease;font-weight:700}.fast-epreuve-go-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.fast-epreuve-countdown{font-size:4rem;font-weight:700;color:#667eea;margin:2rem 0;animation:pulse 1s infinite}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.epreuve-controls{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.fast-epreuve-btn{background:linear-gradient(135deg,#ff6b6b,#ff8e8e);color:#fff;border:none;padding:.75rem 1.5rem;font-size:1rem;border-radius:12px;cursor:pointer;transition:all .3s ease;font-weight:700;display:flex;align-items:center;gap:.5rem}.fast-epreuve-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff6b6b66}.fast-epreuve-close-btn{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;color:#666;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s ease}.fast-epreuve-close-btn:hover{background:#0000001a;color:#333;transform:rotate(90deg)}.admin-controls{margin-left:auto;padding:0 1rem}.login-btn,.logout-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;font-weight:600;font-size:.95rem;box-shadow:0 2px 8px #0000001a;position:relative;overflow:hidden}.login-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.login-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.login-btn:hover:before{left:100%}.login-btn:hover,.logout-btn:hover{transform:translateY(-2px);box-shadow:0 4px 16px #667eea4d}.logout-btn{background:linear-gradient(135deg,#fecaca,#ef4444);color:#fff}.logout-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.logout-btn:hover:before{left:100%}.logout-btn:hover{transform:translateY(-2px);box-shadow:0 4px 16px #ef44444d}.login-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.login-content{background:linear-gradient(135deg,#fff,#f8fafc);padding:2.5rem;border-radius:20px;box-shadow:0 20px 40px #0000001a,0 8px 16px #0000000f;width:100%;max-width:420px;position:relative;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-content h2{margin-bottom:2rem;text-align:center;color:#1f2937;font-size:1.8rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.close-btn{position:absolute;top:1rem;right:1rem;background:#6b72801a;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.close-btn:hover{background:#6b728033;color:#374151;transform:rotate(90deg)}.login-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;color:#4b5563}.form-group input{padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;transition:all .3s ease;background:#fffc}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;background:#fff}.login-submit-btn{margin-top:1rem;padding:.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;cursor:pointer;font-weight:600;font-size:1rem;transition:all .3s ease;box-shadow:0 2px 8px #667eea33;position:relative;overflow:hidden}.login-submit-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.login-submit-btn:hover:before{left:100%}.login-submit-btn:hover{transform:translateY(-2px);box-shadow:0 4px 16px #667eea66}.login-error{color:#dc2626;background-color:#fee2e2;padding:.75rem;border-radius:4px;margin-bottom:1rem;text-align:center}.admin-only{opacity:.5;pointer-events:none}.admin-only.admin-active{opacity:1;pointer-events:auto}.add-participant-form,.team-name-edit,.participant-item .remove-btn,.epreuve-controls,.classement-item .remove-btn,.actions,.export-btn{opacity:.5;pointer-events:none}.admin-active .add-participant-form,.admin-active .team-name-edit,.admin-active .participant-item .remove-btn,.admin-active .epreuve-controls,.admin-active .classement-item .remove-btn,.admin-active .actions,.admin-active .export-btn{opacity:1;pointer-events:auto}.results-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.results-content{background:#fff;padding:2rem;border-radius:20px;width:90%;max-width:800px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 8px 32px #0003}.results-content h2{text-align:center;color:#333;font-size:2rem;margin-bottom:2rem}.results-summary{display:flex;flex-direction:column;gap:2rem}.winner-section{text-align:center;padding:2rem;background:linear-gradient(135deg,#f6f8fc,#f1f5f9);border-radius:16px;border:3px solid #ffd700}.winner-section h3{font-size:1.5rem;color:#333;margin-bottom:1rem}.winner-team{font-size:2rem;font-weight:700;margin-bottom:.5rem}.winner-points{font-size:1.5rem;color:#10b981;font-weight:700}.points-breakdown{background:#f8fafc;padding:1.5rem;border-radius:16px}.points-breakdown h3{font-size:1.3rem;color:#333;margin-bottom:1rem}.team-points{display:flex;align-items:center;padding:.8rem;background:#fff;border-radius:12px;margin-bottom:.5rem;font-weight:500}.team-position{width:40px;font-weight:700}.team-name{flex:1}.team-score{font-weight:700;color:#10b981}.total-points{margin-top:1rem;padding-top:1rem;border-top:2px solid #e2e8f0;text-align:right;font-weight:700;color:#333}.participants-breakdown{background:#f8fafc;padding:1.5rem;border-radius:16px}.participants-breakdown h3{font-size:1.3rem;color:#333;margin-bottom:1rem}.team-participants{margin-bottom:1.5rem}.team-participants h4{font-size:1.1rem;margin-bottom:.5rem}.participant-points{display:flex;justify-content:space-between;padding:.5rem;background:#fff;border-radius:8px;margin-bottom:.3rem}.participant-name{font-weight:500}.participant-score{font-weight:700;color:#10b981}.close-btn{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:.5rem;line-height:1;border-radius:50%;transition:all .3s ease}.close-btn:hover{background:#f1f5f9;color:#333}.bomb-effect{position:fixed;top:0;left:0;width:100%;height:100%;z-index:2000;pointer-events:none;display:flex;justify-content:center;align-items:center}.bomb-explosion{width:0;height:0;background:radial-gradient(circle,#ff4d4d 0%,#ff0000 50%,transparent 70%);border-radius:50%;animation:explode 1s ease-out forwards;box-shadow:0 0 100px red}@keyframes explode{0%{width:0;height:0;opacity:1;transform:scale(0)}50%{width:100vmax;height:100vmax;opacity:.8;transform:scale(1)}to{width:100vmax;height:100vmax;opacity:0;transform:scale(1.2)}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px,-5px)}20%,40%,60%,80%{transform:translate(5px,5px)}}.bomb-effect{animation:shake .5s ease-in-out}.quiz-container{padding:2rem;background:linear-gradient(135deg,#f6f8fc,#f1f5f9);border-radius:16px;animation:slideIn .5s ease-out}.quiz-header{text-align:center;margin-bottom:2rem}.quiz-header h2{color:#333;margin-bottom:.5rem}.quiz-header p{color:#666;font-size:1.1rem}.quiz-scores{margin-bottom:2rem}.quiz-scores h3{color:#333;margin-bottom:1rem;text-align:center}.scores-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.score-card{background:#fff;border-radius:12px;border:3px solid;overflow:hidden;box-shadow:0 4px 12px #0000001a;transition:transform .3s ease}.score-card:hover{transform:translateY(-4px)}.score-header{padding:1rem;color:#fff;text-align:center}.score-header h4{margin:0;font-size:1.2rem}.score-value{padding:1rem 1.5rem .5rem;text-align:center;font-size:2rem;font-weight:700;color:#333}.score-breakdown{padding:0 1.5rem 1.5rem;text-align:center}.score-breakdown small{color:#666;font-size:.8rem}.quiz-controls{margin-bottom:2rem}.quiz-controls h3{color:#333;margin-bottom:1rem;text-align:center}.question-types{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}.type-count{background:#fff;padding:1.5rem;border-radius:12px;text-align:center;box-shadow:0 4px 12px #0000001a;transition:transform .3s ease;flex:1;min-width:200px}.type-count:hover{transform:translateY(-4px)}.type-count.theme{border-top:4px solid #8b5cf6}.type-count.rapidite{border-top:4px solid #f59e0b}.type-count.panel{border-top:4px solid #10b981}.type-count.blindtest{border-top:4px solid #ff6b6b}.type-count.four-images{border-top:4px solid #f59e0b}.type-count h4{margin-bottom:.5rem;color:#333}.type-count p{color:#666;font-size:1.1rem;font-weight:500}.quiz-action{text-align:center;margin-bottom:2rem}.start-quiz-btn{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;padding:1rem 2rem;font-size:1.3rem;font-weight:700;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #8b5cf64d}.start-quiz-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf666}.quiz-instruction{margin-top:1rem;color:#666;font-style:italic}.quiz-session-controls{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;margin:1rem 0}.start-quiz-btn.new-session{background:linear-gradient(135deg,#3b82f6,#1d4ed8);box-shadow:0 4px 12px #3b82f64d}.start-quiz-btn.new-session:hover{box-shadow:0 6px 20px #3b82f666}.start-quiz-btn.continue-session{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 4px 12px #f59e0b4d}.start-quiz-btn.continue-session:hover{box-shadow:0 6px 20px #f59e0b66}.quiz-session-info{text-align:center;margin-top:1rem}.quiz-info{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 4px 12px #0000001a}.quiz-info h3{color:#333;margin-bottom:1rem;text-align:center}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.info-item{background:#f8fafc;padding:1rem;border-radius:8px}.info-item h4{color:#333;margin-bottom:.5rem}.info-item p{color:#666;margin:.25rem 0;font-size:.9rem}.quiz-popup{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000f2;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease-out}.quiz-content{background:#fff;padding:2rem;border-radius:16px;width:95vw;height:95vh;overflow-y:auto;position:relative;animation:popIn .3s ease-out}.quiz-controls-header{position:absolute;top:1rem;right:1rem;left:1rem;display:flex;justify-content:space-between;align-items:center}.quiz-left-controls{display:flex;gap:.5rem;align-items:center}.music-mute-btn{background:#8b5cf6;color:#fff;border:none;width:40px;height:40px;border-radius:50%;font-size:1.2rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.music-mute-btn:hover{background:#7c3aed;transform:scale(1.1)}.quiz-close-btn{background:#ef4444;color:#fff;border:none;width:40px;height:40px;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.quiz-close-btn:hover{background:#dc2626;transform:scale(1.1)}.humor-modal-btn{background:#ffffffe6;color:#8b5cf6;border:2px solid #8b5cf6;padding:.5rem;border-radius:50%;font-size:1.2rem;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center}.humor-modal-btn:hover{background:#8b5cf6;color:#fff;transform:scale(1.1)}.humor-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;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.humor-modal{background:#fff;border-radius:20px;padding:0;max-width:400px;width:90%;box-shadow:0 20px 40px #0000004d;animation:humorModalAppear .3s ease-out;overflow:hidden}.humor-modal-header{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center}.humor-modal-header h3{margin:0;font-size:1.2rem}.humor-modal-close{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s ease}.humor-modal-close:hover{background:#fff3}.humor-modal-content{padding:1.5rem}.humor-modal-content p{text-align:center;margin:0 0 1.5rem;color:#374151;font-size:1rem}.humor-team-buttons{display:flex;gap:1rem;justify-content:center}.humor-team-btn{background:#fff;border:3px solid;padding:1rem 1.5rem;border-radius:15px;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:.5rem;font-weight:600;min-width:120px}.humor-team-btn.rouge{border-color:#ef4444;color:#ef4444}.humor-team-btn.rouge:hover{background:#ef4444;color:#fff;transform:translateY(-2px);box-shadow:0 8px 20px #ef44444d}.humor-team-btn.bleu{border-color:#3b82f6;color:#3b82f6}.humor-team-btn.bleu:hover{background:#3b82f6;color:#fff;transform:translateY(-2px);box-shadow:0 8px 20px #3b82f64d}.humor-team-btn span{font-size:.9rem;opacity:.8}@keyframes humorModalAppear{0%{opacity:0;transform:scale(.8) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.humor-confirmation{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:1.5rem 2rem;border-radius:16px;box-shadow:0 10px 30px #0000004d;z-index:1000;text-align:center;animation:humorConfirmationAppear .5s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.2)}.humor-confirmation h3{margin:0 0 .5rem;font-size:1.2rem;font-weight:700}.humor-confirmation p{margin:0;font-size:1rem;opacity:.9}.humor-confirmation .emoji{font-size:2rem;margin-bottom:.5rem;display:block}@keyframes humorConfirmationAppear{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}50%{transform:translate(-50%,-50%) scale(1.05)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.quiz-step{text-align:center}.quiz-step h2{color:#333;margin-bottom:1rem}.quiz-step h3{color:#8b5cf6;font-size:2rem;margin-bottom:.5rem}.quiz-step h4{color:#666;margin-bottom:2rem}.multiple-choice-indicator{font-size:.9rem;color:#f59e0b;font-weight:400;background:#fef3c7;padding:.2rem .5rem;border-radius:4px;margin-left:.5rem}.questions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-top:2rem}.question-btn{background:#fff;border:3px solid #e2e8f0;padding:1.5rem;border-radius:12px;cursor:pointer;transition:all .3s ease;text-align:center}.question-btn:hover{transform:translateY(-4px);box-shadow:0 6px 20px #0000001a}.question-btn.theme{border-color:#8b5cf6}.question-btn.theme:hover{background:#8b5cf6;color:#fff}.question-btn.rapidite{border-color:#f59e0b}.question-btn.rapidite:hover{background:#f59e0b;color:#fff}.question-btn.panel{border-color:#10b981}.question-btn.panel:hover{background:#10b981;color:#fff}.question-number{font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.question-type{font-size:.9rem;font-weight:700;margin-bottom:.5rem}.question-theme{font-size:.8rem;opacity:.8}.participants-selection{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin:2rem 0}.team-selection h4{margin-bottom:.5rem}.team-selection select{width:100%;padding:.8rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem}.rotation-info{margin-top:.5rem;text-align:center}.rotation-info small{color:#666;font-style:italic;font-size:.8rem;display:block;margin-bottom:.5rem}.rotation-details{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:.5rem}.participant-stat{padding:.25rem .5rem;border-radius:4px;font-size:.7rem;font-weight:500;border:1px solid}.participant-stat.available{background:#dcfce7;border-color:#16a34a;color:#15803d}.participant-stat.waiting{background:#fef3c7;border-color:#f59e0b;color:#92400e}.participation-stats{margin-top:2rem;padding:1.5rem;background:#f8fafc;border-radius:12px;border:2px solid #e2e8f0}.participation-stats h4{text-align:center;margin-bottom:1rem;color:#374151;font-size:1.1rem}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.team-stats{background:#fff;padding:1rem;border-radius:8px;border:2px solid #e2e8f0}.team-stats.rouge{border-color:#fecaca;background:#fef2f2}.team-stats.bleu{border-color:#bfdbfe;background:#eff6ff}.team-stats h5{text-align:center;margin-bottom:.75rem;font-weight:600}.team-stats.rouge h5{color:#dc2626}.team-stats.bleu h5{color:#2563eb}.participant-stat{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #e5e7eb}.participant-stat:last-child{border-bottom:none}.participant-stat .participant-name{font-weight:500;color:#374151}.participant-stat .question-count{font-size:.9rem;color:#6b7280;background:#f3f4f6;padding:.25rem .5rem;border-radius:4px}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr;gap:1rem}.participation-stats{margin-top:1rem;padding:1rem}}.confirm-btn{background:#10b981;color:#fff;border:none;padding:1rem 2rem;font-size:1.1rem;border-radius:8px;cursor:pointer;transition:all .3s ease}.confirm-btn:disabled{background:#d1d5db;cursor:not-allowed}.confirm-btn:not(:disabled):hover{background:#059669;transform:translateY(-2px)}.question-display{margin:2rem 0}.question-text{font-size:1.5rem;font-weight:700;color:#333;margin-bottom:2rem;min-height:100px;display:flex;align-items:center;justify-content:flex-start;background:#f8fafc;border-radius:12px;padding:2rem;text-align:left}.choices{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:2rem}.choice{background:#f8fafc;padding:1rem;border-radius:8px;font-size:1.1rem;border:2px solid #e2e8f0}.reveal-btn{background:#8b5cf6;color:#fff;border:none;padding:1rem 2rem;font-size:1.2rem;border-radius:8px;cursor:pointer;transition:all .3s ease}.reveal-btn:hover:not(:disabled){background:#7c3aed;transform:translateY(-2px)}.reveal-btn:disabled{background:#95a5a6;cursor:not-allowed;transform:none;box-shadow:none;opacity:.6}.reveal-controls{display:flex;justify-content:center;margin-top:1rem}.pause-btn,.play-btn{background:#f59e0b;color:#fff;border:none;padding:.8rem 1.5rem;font-size:1.1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem}.pause-btn:hover{background:#d97706;transform:translateY(-2px);box-shadow:0 4px 12px #f59e0b4d}.play-btn{background:#10b981}.play-btn:hover{background:#059669;transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.timer-step{display:flex;flex-direction:column;align-items:center;gap:2rem}.question-with-timer{position:relative;width:100%}.question-text-timer{font-size:1.5rem;font-weight:700;color:#333;margin-bottom:2rem;min-height:100px;display:flex;align-items:center;justify-content:flex-start;background:#f8fafc;border-radius:12px;padding:2rem;text-align:left}.timer-header{text-align:center;margin-bottom:2rem}.timer-display-integrated{display:inline-flex;align-items:center;gap:1rem;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:1.2rem 2rem;border-radius:20px;box-shadow:0 8px 25px #f59e0b4d;animation:timerPulse 1s ease-in-out infinite}.timer-number-integrated{font-size:3rem;font-weight:700;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.timer-display-integrated span{font-size:1.1rem;font-weight:500;opacity:.95}@keyframes timerPulse{0%,to{transform:scale(1);box-shadow:0 8px 25px #f59e0b4d}50%{transform:scale(1.05);box-shadow:0 12px 35px #f59e0b80}}.timer-critical{background:linear-gradient(135deg,#ef4444,#dc2626)!important;animation:timerCritical .5s ease-in-out infinite!important}@keyframes timerCritical{0%,to{transform:scale(1);box-shadow:0 8px 25px #ef444480}50%{transform:scale(1.1);box-shadow:0 15px 40px #ef4444b3}}.timer-display{display:flex;flex-direction:column;align-items:center;gap:1rem}.timer-number{font-size:5rem;font-weight:700;color:#ef4444;animation:pulse 1s infinite}.scoring{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin:2rem 0}.team-scoring{text-align:center}.team-scoring h4{margin-bottom:1rem}.scoring-buttons{display:flex;gap:1rem;justify-content:center}.point-btn{background:#f8fafc;border:2px solid #e2e8f0;padding:.8rem 1.5rem;border-radius:8px;cursor:pointer;transition:all .3s ease}.point-btn:hover{background:#10b981;color:#fff;transform:translateY(-2px)}.current-scores{background:#f8fafc;padding:1.5rem;border-radius:8px;margin:2rem 0}.current-scores h4{margin-bottom:1rem;color:#333}.current-scores p{margin:.5rem 0;font-size:1.1rem;font-weight:500}.next-btn{background:#8b5cf6;color:#fff;border:none;padding:1rem 2rem;font-size:1.2rem;border-radius:8px;cursor:pointer;transition:all .3s ease;margin-top:2rem}.next-btn:hover{background:#7c3aed;transform:translateY(-2px)}.panel-answers{margin-top:2rem;background:#f8fafc;padding:1.5rem;border-radius:12px;border:2px solid #10b981}.panel-answers h4{color:#333;margin-bottom:1rem;text-align:center}.panel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.panel-answer{background:#fff;padding:.8rem;border-radius:8px;border:2px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;transition:all .3s ease}.panel-answer:hover{border-color:#10b981;transform:translateY(-2px)}.answer-text{font-weight:500;color:#333}.answer-points{font-weight:700;color:#10b981;font-size:.9rem}.panel-instruction{text-align:center;font-style:italic;color:#666;margin:0}@media (max-width: 768px){.quiz-content{padding:1rem;max-width:95vw}.questions-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.participants-selection,.choices,.scoring{grid-template-columns:1fr}.timer-number-integrated{font-size:2rem}.timer-display-integrated{padding:1rem 1.5rem;gap:.8rem}.timer-number{font-size:3rem}.info-grid{grid-template-columns:1fr;gap:1rem}.info-item{padding:.75rem}.info-item h4{font-size:.9rem;margin-bottom:.4rem}.info-item p{font-size:.8rem;margin:.2rem 0}.quiz-title-with-humor{flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.quiz-title-with-humor h2{order:2}.humor-btn{position:relative;left:auto!important;right:auto!important;padding:.3rem .6rem;font-size:.7rem}.humor-btn.left{order:1}.humor-btn.right{order:3}}.quiz-intro{text-align:center;padding:2rem}.quiz-intro p{font-size:1.2rem;margin:1rem 0}.starting-scores{margin:2rem 0;background:#f8fafc;padding:1.5rem;border-radius:12px}.starting-scores h3{margin-bottom:1rem;color:#333}.score-display{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}.team-score{background:#fff;padding:1.5rem;border-radius:12px;text-align:center;border:3px solid}.team-score.rouge{border-color:#ef4444}.team-score.bleu{border-color:#3b82f6}.team-score .team-name{font-weight:700;font-size:1.2rem;margin-bottom:.5rem;display:block}.team-score.rouge .team-name{color:#ef4444}.team-score.bleu .team-name{color:#3b82f6}.team-score .score{font-size:2rem;font-weight:700;color:#333}.start-first-question-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:1rem 2rem;font-size:1.3rem;font-weight:700;border-radius:12px;cursor:pointer;transition:all .3s ease;margin-top:2rem}.start-first-question-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.point-btn.correct{background:#10b981;color:#fff}.point-btn.correct:hover{background:#059669}.point-btn.incorrect{background:#ef4444;color:#fff}.point-btn.incorrect:hover{background:#dc2626}.rapidite-scoring{text-align:center;margin:2rem 0}.rapidite-scoring h3{margin-bottom:1.5rem;font-size:1.5rem}.panel-scoring{text-align:center;margin:2rem 0}.panel-scoring h3{margin-bottom:.5rem}.panel-scoring p{margin-bottom:1.5rem;color:#666}.score-break{text-align:center;padding:2rem}.big-scores{display:grid;grid-template-columns:1fr auto 1fr;gap:3rem;align-items:center;margin:3rem 0}.team-big-score{background:#fff;padding:2rem;border-radius:20px;border:4px solid;box-shadow:0 8px 25px #0000001a}.team-big-score.rouge{border-color:#ef4444}.team-big-score.bleu{border-color:#3b82f6}.team-big-score h3{margin-bottom:1rem;font-size:1.5rem}.team-big-score.rouge h3{color:#ef4444}.team-big-score.bleu h3{color:#3b82f6}.big-score-number{font-size:4rem;font-weight:700;color:#333;margin:1rem 0}.vs{font-size:2.5rem;font-weight:700;color:#666;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.continue-btn{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;padding:1rem 3rem;font-size:1.3rem;font-weight:700;border-radius:12px;cursor:pointer;transition:all .3s ease;margin-top:2rem}.continue-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf666}@media (max-width: 768px){.quiz-content{width:98vw;height:98vh;padding:1rem}.score-display{grid-template-columns:1fr}.big-scores{grid-template-columns:1fr;gap:1rem}.vs{font-size:1.5rem}.big-score-number{font-size:2.5rem}}.panel-input-section{display:flex;gap:1rem;margin:1.5rem 0;justify-content:center;align-items:center}.panel-input{flex:1;max-width:400px;padding:.8rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem}.panel-input:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.panel-submit-btn{background:#8b5cf6;color:#fff;border:none;padding:.8rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;transition:all .3s ease}.panel-submit-btn:hover{background:#7c3aed;transform:translateY(-1px)}.panel-answer.revealed{background:#dcfce7;border-color:#16a34a;animation:revealAnswer .5s ease-out}.panel-answer.empty{background:#f1f5f9;border:2px dashed #cbd5e1;opacity:.7}.panel-answer.empty .answer-text{color:#94a3b8;font-style:italic}@keyframes revealAnswer{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.points-given{padding:1rem;border-radius:8px;font-weight:700;text-align:center;border:2px solid;display:flex;flex-direction:column;gap:.5rem;align-items:center}.points-given.correct{background:#dcfce7;color:#16a34a;border-color:#16a34a}.points-given.incorrect{background:#fee2e2;color:#dc2626;border-color:#dc2626}.points-given span{margin-bottom:.5rem}.reset-btn{background:#f59e0b;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:700;transition:all .3s ease}.reset-btn:hover{background:#d97706;transform:translateY(-1px)}.buzzer-rules{background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;padding:1rem;margin-bottom:2rem}.buzzer-rules ul{margin:.5rem 0 0;padding-left:1rem;list-style:none}.buzzer-rules li{margin:.25rem 0;font-weight:500}.buzzer-actions{display:flex;flex-direction:column;gap:2rem;align-items:center}.buzzer-teams{display:flex;gap:2rem;justify-content:center}.buzzer-btn{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border:3px solid #d1d5db;padding:1.5rem 2rem;border-radius:12px;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .3s ease;min-width:200px;text-align:center}.buzzer-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 8px 16px #0003}.buzzer-btn:disabled{opacity:.5;cursor:not-allowed}.buzzer-btn.team-rouge{background:linear-gradient(135deg,#fecaca,#ef4444);border-color:#dc2626;color:#fff}.buzzer-btn.team-bleu{background:linear-gradient(135deg,#93c5fd,#3b82f6);border-color:#2563eb;color:#fff}.buzzer-btn.nobody{background:linear-gradient(135deg,#fde68a,#f59e0b);border-color:#d97706;color:#92400e}.buzzer-response{background:#dcfce7;border:2px solid #16a34a;border-radius:12px;padding:2rem;margin-top:2rem;text-align:center;animation:buzzResponse .5s ease-in-out}@keyframes buzzResponse{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.response-buttons{display:flex;gap:1rem;justify-content:center;margin-top:1rem}.response-buttons .point-btn{flex:1;max-width:200px}.buzzer-completed{background:#dcfce7;border:2px solid #16a34a;border-radius:12px;padding:2rem;text-align:center;color:#16a34a}.buzzer-completed h4{margin:0 0 .5rem;color:#16a34a}.answer-revelation-section{margin:2rem 0;text-align:center}.reveal-answer-btn{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #8b5cf64d}.reveal-answer-btn:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);transform:translateY(-2px);box-shadow:0 6px 16px #8b5cf666}.revealed-answer{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border:2px solid #7c3aed;border-radius:16px;padding:2rem;margin-top:1rem;text-align:left;animation:revealAnswer .5s ease-in-out}@keyframes revealAnswer{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.revealed-answer h3{color:#7c3aed;margin:0 0 1rem;font-size:1.5rem;text-align:center}.revealed-answer .answer-text{background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:1.5rem;font-size:1.3rem;font-weight:700;color:#1f2937;margin-bottom:1rem;white-space:pre-line}.revealed-answer .answer-explanation{margin-top:1.5rem}.revealed-answer .answer-explanation h4{color:#f59e0b;margin:0 0 .5rem;font-size:1.2rem}.revealed-answer .answer-explanation p{background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;padding:1rem;margin:0;font-style:italic;color:#92400e}.panel-summary{background:#f8fafc;padding:2rem;border-radius:12px;margin:1rem 0}.panel-summary p{font-size:1.1rem;margin-bottom:1rem}.revealed-answers-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin:1.5rem 0}.revealed-answer-item{background:#fff;padding:1rem;border-radius:8px;border:2px solid #16a34a;display:flex;justify-content:space-between;align-items:center}.revealed-answer-item span:first-child{font-weight:700}.revealed-answer-item span:last-child{color:#16a34a;font-weight:700}.panel-instruction{background:#e0f2fe;padding:1rem;border-radius:8px;font-style:italic;color:#0369a1;margin-top:1rem}.panel-family-feud{width:100%;max-width:1000px;margin:0 auto}.panel-initial-phase{background:linear-gradient(135deg,#fef3c7,#fbbf24);padding:2rem;border-radius:16px;margin:2rem 0;text-align:center}.panel-initial-phase h4{color:#92400e;font-size:1.8rem;margin-bottom:1rem}.panel-initial-phase p{color:#92400e;font-size:1.1rem;margin-bottom:2rem}.initial-answers-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:2rem}.team-initial-answer{background:#fffc;padding:1.5rem;border-radius:12px;border:3px solid}.team-initial-answer.rouge{border-color:#ef4444}.team-initial-answer.bleu{border-color:#3b82f6}.team-initial-answer h5{margin-bottom:1rem;font-size:1.3rem}.team-initial-answer.rouge h5{color:#ef4444}.team-initial-answer.bleu h5{color:#3b82f6}.initial-input{width:100%;padding:.8rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;margin-bottom:1rem}.initial-input:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.submit-initial-btn{background:#10b981;color:#fff;border:none;padding:.8rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;transition:all .3s ease;width:100%}.submit-initial-btn:disabled{background:#d1d5db;cursor:not-allowed}.submit-initial-btn:not(:disabled):hover{background:#059669;transform:translateY(-1px)}.initial-feedback{margin-top:1rem;padding:.8rem;border-radius:8px;font-size:.9rem;font-weight:500;text-align:center;animation:feedbackAppear .3s ease-in-out;background:#f3f4f6;border:2px solid #d1d5db;color:#374151}.initial-feedback.success{background:#d1fae5;border-color:#10b981;color:#065f46}.initial-feedback.error{background:#fee2e2;border-color:#ef4444;color:#991b1b}@keyframes feedbackAppear{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.panel-playing-phase{background:linear-gradient(135deg,#ede9fe,#c4b5fd);padding:2rem;border-radius:16px;margin:2rem 0}.panel-board{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 15px #0000001a}.panel-board h4{color:#7c3aed;font-size:1.8rem;margin-bottom:2rem;text-align:center}.panel-answer.hidden{background:#1f2937;color:#fff;border:2px solid #374151}.panel-answer.hidden .answer-hidden{color:#9ca3af;font-weight:700;font-size:1.2rem}.panel-answer.revealed{background:#dcfce7;border-color:#16a34a;animation:revealAnswer .8s ease-out}.answer-percentage{color:#16a34a;font-weight:700;font-size:1.1rem}.panel-scores{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin:2rem 0;padding:1.5rem;background:#f8fafc;border-radius:12px}.panel-scores .team-score{text-align:center;padding:1rem;border-radius:8px;border:3px solid}.panel-scores .team-score.rouge{background:#fef2f2;border-color:#ef4444;color:#ef4444}.panel-scores .team-score.bleu{background:#eff6ff;border-color:#3b82f6;color:#3b82f6}.panel-scores .team-score span{font-size:1.2rem;font-weight:700;display:block;margin-bottom:.5rem}.wrong-answers{display:flex;justify-content:center;gap:.5rem}.wrong-mark{font-size:1.5rem;animation:wrongAnswerPop .5s ease-out}@keyframes wrongAnswerPop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2);opacity:1}to{transform:scale(1);opacity:1}}.active-team-indicator{text-align:center;padding:1rem;margin-bottom:1rem;border-radius:8px;font-size:1.2rem;font-weight:700;animation:teamIndicatorPulse 2s infinite}.active-team-indicator.rouge{background:#fef2f2;color:#ef4444;border:3px solid #ef4444}.active-team-indicator.bleu{background:#eff6ff;color:#3b82f6;border:3px solid #3b82f6}@keyframes teamIndicatorPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.last-chance-indicator{display:block;margin-top:.5rem;font-size:.9rem;font-weight:700;color:#fbbf24;animation:warningPulse 1s ease-in-out infinite}@keyframes warningPulse{0%,to{opacity:1}50%{opacity:.6}}.panel-finished{text-align:center;padding:2rem;background:linear-gradient(135deg,#fef3c7,#fbbf24);border-radius:12px;margin:2rem 0}.panel-finished h5{color:#92400e;font-size:1.5rem;margin-bottom:1rem}.finish-panel-btn{background:#f59e0b;color:#fff;border:none;padding:1rem 2rem;font-size:1.2rem;font-weight:700;border-radius:8px;cursor:pointer;transition:all .3s ease}.finish-panel-btn:hover{background:#d97706;transform:translateY(-2px)}.panel-final-results{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);padding:2rem;border-radius:16px;margin:2rem 0}.final-scores-comparison{display:grid;grid-template-columns:1fr auto 1fr;gap:2rem;align-items:center;margin:2rem 0}.team-final-score{text-align:center;padding:2rem;border-radius:16px;border:4px solid;background:#fff;box-shadow:0 4px 15px #0000001a}.team-final-score.rouge{border-color:#ef4444}.team-final-score.bleu{border-color:#3b82f6}.team-final-score h4{font-size:1.5rem;margin-bottom:1rem}.team-final-score.rouge h4{color:#ef4444}.team-final-score.bleu h4{color:#3b82f6}.final-score-number{font-size:3rem;font-weight:700;color:#333}.vs-final{font-size:2rem;font-weight:700;color:#666;text-align:center}.winner-announcement{text-align:center;margin:2rem 0;padding:2rem;border-radius:12px;font-size:1.5rem;font-weight:700}.winner.rouge{background:#fef2f2;color:#dc2626;border:3px solid #ef4444;animation:winnerCelebration 2s ease-out}.winner.bleu{background:#eff6ff;color:#2563eb;border:3px solid #3b82f6;animation:winnerCelebration 2s ease-out}.tie{background:#f9fafb;color:#6b7280;border:3px solid #d1d5db}@keyframes winnerCelebration{0%,to{transform:scale(1)}25%{transform:scale(1.05)}50%{transform:scale(1.1)}75%{transform:scale(1.05)}}.panel-stats{font-size:1.1rem;color:#374151;text-align:center;margin-top:1rem}.team-change-animation{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000e6;display:flex;justify-content:center;align-items:center;z-index:9999;animation:fadeInOut 2s ease-out}.team-change-content{background:linear-gradient(135deg,#f59e0b,#d97706);padding:3rem;border-radius:20px;text-align:center;color:#fff;box-shadow:0 10px 30px #f59e0b80;animation:bounceIn 2s ease-out}.team-change-content h2{font-size:3rem;margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.team-change-content p{font-size:1.5rem;font-weight:700}@keyframes fadeInOut{0%,to{opacity:0}10%,90%{opacity:1}}@keyframes bounceIn{0%{transform:scale(.3);opacity:0}50%{transform:scale(1.1);opacity:1}to{transform:scale(1);opacity:1}}@media (max-width: 768px){.initial-answers-grid,.final-scores-comparison,.panel-scores{grid-template-columns:1fr;gap:1rem}.team-change-content h2{font-size:2rem}.team-change-content p{font-size:1.2rem}.final-score-number{font-size:2rem}}.pictionary-instruction{background:linear-gradient(135deg,#fef3c7,#fbbf24);padding:2rem;border-radius:16px;text-align:center;border:3px solid #f59e0b;box-shadow:0 4px 15px #f59e0b4d}.pictionary-instruction h3{color:#92400e;font-size:2rem;margin-bottom:1rem;text-shadow:1px 1px 2px rgba(0,0,0,.1)}.pictionary-instruction>p{color:#92400e;font-size:1.3rem;font-weight:700;margin-bottom:1.5rem;line-height:1.4}.pictionary-rules{background:#ffffffb3;padding:1.5rem;border-radius:12px;margin-top:1rem}.pictionary-rules p{color:#92400e;font-size:1.1rem;font-weight:700;margin-bottom:.8rem}.pictionary-rules ul{list-style:none;padding:0}.pictionary-rules li{color:#92400e;font-size:1rem;margin-bottom:.5rem;padding-left:1.5rem;position:relative}.pictionary-rules li:before{content:"✏️";position:absolute;left:0;top:0}@media (max-width: 768px){.pictionary-instruction h3{font-size:1.5rem}.pictionary-instruction>p{font-size:1.1rem}.pictionary-rules p{font-size:1rem}.pictionary-rules li{font-size:.9rem}}.pictionary-scoring{background:linear-gradient(135deg,#fef3c7,#fbbf24);padding:2rem;border-radius:16px;text-align:center;border:3px solid #f59e0b;box-shadow:0 4px 15px #f59e0b4d;margin-top:2rem}.pictionary-scoring h3{color:#92400e;font-size:1.8rem;margin-bottom:1.5rem;text-shadow:1px 1px 2px rgba(0,0,0,.1)}.pictionary-scoring-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.pictionary-point-btn{padding:1rem 2rem;border:none;border-radius:12px;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 8px #0000001a;min-width:200px}.pictionary-point-btn.team-rouge{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.pictionary-point-btn.team-rouge:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-2px);box-shadow:0 6px 12px #ef44444d}.pictionary-point-btn.team-bleu{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.pictionary-point-btn.team-bleu:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 6px 12px #3b82f64d}.pictionary-point-btn.no-point{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff}.pictionary-point-btn.no-point:hover{background:linear-gradient(135deg,#4b5563,#374151);transform:translateY(-2px);box-shadow:0 6px 12px #6b72804d}@media (max-width: 768px){.pictionary-scoring-buttons{flex-direction:column;align-items:center}.pictionary-point-btn{min-width:250px;font-size:1.1rem}.pictionary-scoring h3{font-size:1.5rem}}.pictionary-current-choice{background:#ffffffe6;padding:1rem;border-radius:8px;margin-bottom:1rem;border:2px solid #10b981}.pictionary-current-choice p{margin:0;font-size:1.1rem;color:#065f46;text-align:center}.pictionary-point-btn.selected{transform:scale(1.05);box-shadow:0 0 0 3px #fffc,0 8px 16px #0003;position:relative}.pictionary-point-btn.selected:after{content:"✓";position:absolute;top:-8px;right:-8px;background:#10b981;color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}.pictionary-point-btn.reset-choice{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.pictionary-point-btn.reset-choice:hover{background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-2px);box-shadow:0 6px 12px #f59e0b4d}.pictionary-point-btn.next-question{background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-weight:700}.pictionary-point-btn.next-question:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 6px 12px #10b9814d}.app{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.nav-tab,.add-btn,.save-btn,.export-btn,.point-btn,.buzzer-btn,.reveal-btn,.next-btn,.start-quiz-btn,.confirm-btn,.participant-btn,.question-btn{-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:44px}@media (hover: none) and (pointer: coarse){.nav-tab:hover,.add-btn:hover,.save-btn:hover,.export-btn:hover,.point-btn:hover,.buzzer-btn:hover,.reveal-btn:hover,.next-btn:hover,.start-quiz-btn:hover,.confirm-btn:hover,.participant-btn:hover,.question-btn:hover{transform:none;box-shadow:initial}.nav-tab:active,.add-btn:active,.save-btn:active,.export-btn:active,.point-btn:active,.buzzer-btn:active,.reveal-btn:active,.next-btn:active,.start-quiz-btn:active,.confirm-btn:active,.participant-btn:active,.question-btn:active{transform:scale(.95);opacity:.8}}@media (display-mode: standalone){.header{padding-top:calc(1rem + env(safe-area-inset-top))}body{-webkit-user-select:none;-webkit-touch-callout:none}.app{height:100vh;height:100dvh}}@media (max-width: 480px){.header{padding:.5rem 1rem}.header h1{font-size:1.2rem}.header-stats{flex-direction:column;gap:.5rem;font-size:.8rem}.nav-tabs{padding:0 .5rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.nav-tab{padding:.75rem 1rem;font-size:.9rem;white-space:nowrap}.main-content{padding:1rem}.teams-grid{grid-template-columns:1fr}.add-participant-form{flex-direction:column;align-items:stretch}.participant-input{min-width:auto}.quiz-content{padding:1rem;margin:.5rem}.question-text{font-size:1.1rem;line-height:1.4}.timer-number-integrated{font-size:2rem}.scoring-buttons{flex-direction:column;gap:.75rem}.point-btn{padding:1rem;font-size:1rem}.buzzer-btn{padding:1.5rem 1rem;font-size:1rem}.buzzer-teams{flex-direction:column;gap:1rem}.panel-grid{grid-template-columns:1fr;gap:.75rem}.panel-answer{padding:1rem}.big-scores{flex-direction:column;gap:1rem}.vs{font-size:1.5rem}}@media (max-width: 320px){.header h1{font-size:1rem}.nav-tab{padding:.5rem .75rem;font-size:.8rem}.quiz-content{padding:.75rem;margin:.25rem}.question-text{font-size:1rem}.timer-number-integrated{font-size:1.5rem}.info-grid{gap:.5rem}.info-item{padding:.5rem}.info-item h4{font-size:.8rem}.info-item p{font-size:.75rem}.participants-grid{grid-template-columns:1fr}.participant-btn{padding:.5rem;font-size:.8rem}.classement-item{padding:.5rem;gap:.5rem}.position{width:24px;height:24px;font-size:.8rem}.points{padding:.2rem .5rem;font-size:.75rem}.participant-info .participant-name{font-size:.85rem}.classement-table{min-width:1100px}.classement-individuel .classement-table{min-width:1000px}.epreuve-col{width:70px;min-width:70px;max-width:70px;font-size:.65rem;font-weight:600;line-height:.9;padding:.2rem .1rem;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.points-cell{width:70px;min-width:70px;max-width:70px;font-size:.65rem;padding:.2rem}.participant-col,.participant-cell{min-width:120px;font-size:.8rem}.total-col,.total-cell-individuel{min-width:70px;font-size:.9rem}.classement-table-container:after{font-size:.7rem;padding:.3rem}}.nav-tabs-pwa{position:fixed;bottom:0;left:0;right:0;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;justify-content:space-around;padding:.5rem 0;box-shadow:0 -4px 20px #0000001a;border-top:1px solid rgba(0,0,0,.1);z-index:1000;padding-bottom:calc(.5rem + env(safe-area-inset-bottom))}.nav-tab-pwa{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem 1rem;background:none;border:none;cursor:pointer;font-size:.75rem;font-weight:600;color:#666;transition:all .3s ease;border-radius:12px;min-width:60px;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.nav-tab-pwa:active{transform:scale(.95);opacity:.8}.nav-tab-pwa.active{color:#667eea;background:#667eea1a}.nav-tab-pwa span{font-size:.7rem;text-align:center;line-height:1}@media (display-mode: standalone){.main-content{padding-bottom:calc(5rem + env(safe-area-inset-bottom));flex:1}.header{padding:.75rem 1rem}.header h1{font-size:1.5rem}.header-stats{font-size:.8rem}}@media (display-mode: standalone) and (max-width: 768px){.nav-tab-pwa{padding:.75rem .5rem;min-width:50px}.nav-tab-pwa span{font-size:.65rem}.main-content{padding:1rem .75rem calc(5.5rem + env(safe-area-inset-bottom)) .75rem}.header{padding:.5rem .75rem}.header h1{font-size:1.2rem}.header-stats{display:none}}.nav-tabs-pwa{animation:slideUpPWA .3s ease-out}@keyframes slideUpPWA{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes spinAnimation{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinning{animation:spinAnimation 1s linear infinite}.notifications-container{padding:20px;width:100%}.notifications-header{text-align:center;margin-bottom:30px}.notifications-header h2{margin-bottom:10px;color:#1f2937}.notifications-header p{color:#6b7280;font-size:1.1rem}.notification-status{background:#fff;border-radius:8px;padding:20px;margin-bottom:30px;box-shadow:0 2px 4px #0000001a}.permission-status h3{margin-bottom:15px;color:#1f2937}.status-granted{color:#059669;font-weight:600}.status-granted p{color:#6b7280;margin-top:5px;font-weight:400}.status-denied{color:#dc2626;font-weight:600}.status-denied p{color:#6b7280;margin:10px 0;font-weight:400}.enable-notifications-btn{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;padding:12px 20px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s}.enable-notifications-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f59e0b66}.compose-notification-btn{background:linear-gradient(135deg,#3b82f6,#1e40af);color:#fff;border:none;padding:15px 25px;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:10px;transition:all .2s;margin:15px 0}.compose-notification-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.notification-actions{display:flex;flex-direction:column;gap:30px}.send-notification-section{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;text-align:center}.send-notification-section h3{margin-bottom:10px;color:#1f2937}.send-notification-section p{color:#6b7280;margin-bottom:20px}.notification-templates-preview{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a}.notification-templates-preview h3{margin-bottom:20px;color:#1f2937}.templates-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:15px}.template-preview{border:2px solid #e5e7eb;border-radius:8px;padding:15px;transition:all .2s}.template-preview:hover{border-color:#3b82f6;box-shadow:0 2px 8px #3b82f61a}.template-title{font-weight:600;color:#1f2937;margin-bottom:8px}.template-body{color:#6b7280;margin-bottom:12px;font-size:.9rem}.use-template-btn{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;padding:8px 12px;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s;width:100%}.use-template-btn:hover{background:#e5e7eb;border-color:#9ca3af}.notification-tips{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a}.notification-tips h3{margin-bottom:15px;color:#1f2937}.notification-tips ul{list-style:none;padding:0}.notification-tips li{padding:8px 0;color:#4b5563;border-bottom:1px solid #f3f4f6}.notification-tips li:last-child{border-bottom:none}.notification-templates{margin-bottom:20px}.notification-templates h3{margin-bottom:15px;color:#1f2937}.template-buttons{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.template-btn{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;padding:8px 12px;border-radius:6px;font-size:.85rem;cursor:pointer;transition:all .2s}.template-btn:hover{background:#e5e7eb;border-color:#9ca3af}.notification-form{display:flex;flex-direction:column;gap:15px}.notification-form .form-group{display:flex;flex-direction:column;gap:5px}.notification-form label{font-weight:600;color:#1f2937}.notification-form input,.notification-form textarea{padding:10px;border:2px solid #e5e7eb;border-radius:6px;font-size:1rem;transition:border-color .2s}.notification-form input:focus,.notification-form textarea:focus{outline:none;border-color:#3b82f6}.notification-actions{display:flex;gap:10px;justify-content:flex-end}.send-notification-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:12px 20px;border-radius:6px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s}.send-notification-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #10b98166}.send-notification-btn:disabled{opacity:.6;cursor:not-allowed}.cancel-btn{background:#6b7280;color:#fff;border:none;padding:12px 20px;border-radius:6px;cursor:pointer;transition:all .2s}.cancel-btn:hover{background:#4b5563}.notification-compose-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:9999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overflow-y:auto;padding:1rem;overscroll-behavior:contain}.notification-compose-content{background:linear-gradient(135deg,#fff,#f8fafc);border-radius:24px;box-shadow:0 25px 50px #00000026;width:100%;max-width:500px;max-height:85vh;overflow-y:auto;position:relative;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.notification-compose-content h2{margin-bottom:2rem;text-align:center;color:#1f2937;font-size:1.8rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.notification-compose-modal .close-btn{position:absolute;top:1rem;right:1rem;background:#6b72801a;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:10}.notification-compose-modal .close-btn:hover{background:#6b728033;color:#374151;transform:rotate(90deg)}@media (max-width: 768px){.notification-compose-modal{align-items:flex-start;padding:2rem 1rem 1rem;padding-bottom:140px}.notification-compose-content{max-width:100%;max-height:calc(100vh - 200px);min-height:auto;padding:1.5rem;margin:0;border-radius:16px}.notification-compose-modal .close-btn{top:.75rem;right:.75rem;width:36px;height:36px;font-size:1.25rem}.templates-grid{grid-template-columns:1fr}.template-buttons{flex-direction:column}.notification-actions{flex-direction:column;gap:.75rem}.template-btn{width:100%;text-align:left;padding:.75rem 1rem;font-size:.9rem}.send-notification-btn,.cancel-btn{width:100%;padding:.875rem 1.5rem;font-size:1rem}}.scoring-mode-selector{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1.5rem;border-radius:16px;box-shadow:0 4px 16px #0000001a;margin-bottom:2rem;text-align:center}.scoring-mode-selector h4{margin-bottom:1rem;color:#333;font-size:1.2rem}.mode-buttons{display:flex;gap:1rem;justify-content:center}.mode-btn{padding:.75rem 1.5rem;border:2px solid #e2e8f0;background:#fff;border-radius:12px;cursor:pointer;transition:all .3s ease;font-weight:500;font-size:.95rem}.mode-btn:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.mode-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea;box-shadow:0 4px 16px #667eea4d}.score-entry-section{background:#f8fafccc;padding:1.5rem;border-radius:16px;border:2px solid rgba(102,126,234,.1)}.score-entry-section h4{margin-bottom:1.5rem;color:#333;font-size:1.2rem;text-align:center}.score-inputs{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.score-input-row{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:#fff;border-radius:12px;border:2px solid rgba(102,126,234,.1);transition:all .3s ease}.score-input-row:hover{border-color:#667eea4d;transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.score-input-row .participant-info{flex:1}.score-input-row .participant-name{font-weight:600;color:#333;display:block}.score-input-row small{font-size:.85rem;opacity:.8}.score-input{width:120px;padding:.5rem .75rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;font-weight:500;text-align:center;transition:all .3s ease}.score-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.score-input:disabled{background:#f8fafc;color:#94a3b8;cursor:not-allowed}.score-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.apply-scores-btn,.reset-scores-btn{padding:.75rem 1.5rem;border:none;border-radius:12px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem}.apply-scores-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 16px #10b9814d}.apply-scores-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.apply-scores-btn:disabled{background:#94a3b8;cursor:not-allowed;transform:none;box-shadow:none}.reset-scores-btn{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 16px #ef44444d}.reset-scores-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ef444466}.participant-display{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;background:linear-gradient(135deg,#ffffff26,#ffffff0d);padding:1rem 1.5rem;border-radius:16px;margin:1rem 0;border:2px solid rgba(255,255,255,.3);box-shadow:0 8px 24px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;text-align:center;min-height:80px}.participant-display.rouge{background:linear-gradient(135deg,#ef444433,#dc26261a);border:2px solid rgba(239,68,68,.4);box-shadow:0 8px 24px #ef444433}.participant-display.rouge:hover{background:linear-gradient(135deg,#ef444440,#dc262626);border-color:#ef444480;box-shadow:0 12px 32px #ef44444d}.participant-display.rouge .participant-name{color:#dc2626;text-shadow:0 1px 2px rgba(239,68,68,.2)}.participant-display.bleu{background:linear-gradient(135deg,#3b82f633,#2563eb1a);border:2px solid rgba(59,130,246,.4);box-shadow:0 8px 24px #3b82f633}.participant-display.bleu:hover{background:linear-gradient(135deg,#3b82f640,#2563eb26);border-color:#3b82f680;box-shadow:0 12px 32px #3b82f64d}.participant-display.bleu .participant-name{color:#2563eb;text-shadow:0 1px 2px rgba(59,130,246,.2)}.participant-display:hover{transform:translateY(-2px);box-shadow:0 12px 32px #00000026;border-color:#fff6}.participant-label{font-size:1.8rem;flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.participant-name{font-weight:700;font-size:1.2rem;color:#1f2937;text-shadow:0 1px 2px rgba(0,0,0,.1);letter-spacing:.5px;margin:0}.buzzer-participant-display{display:flex;align-items:center;gap:.5rem;background:#667eea1a;padding:.75rem 1rem;border-radius:10px;margin:.75rem 0;border:2px solid rgba(102,126,234,.3);animation:participantHighlight .5s ease-out}.buzzer-participant-display.rouge{background:linear-gradient(135deg,#ef444426,#dc262614);border:2px solid rgba(239,68,68,.4)}.buzzer-participant-display.bleu{background:linear-gradient(135deg,#3b82f626,#2563eb14);border:2px solid rgba(59,130,246,.4)}.buzzer-participant-label{font-size:1.4rem;flex-shrink:0}.buzzer-participant-name{font-weight:700;font-size:1.1rem;color:#1f2937}@keyframes participantHighlight{0%{transform:scale(.95);opacity:0}50%{transform:scale(1.02)}to{transform:scale(1);opacity:1}}@media (max-width: 768px){.participant-display{padding:.8rem 1rem;gap:.4rem;margin:.75rem 0;min-height:70px}.participant-label{font-size:1.5rem}.participant-name{font-size:1rem;font-weight:600}.buzzer-participant-display{padding:.6rem .8rem;gap:.4rem}.buzzer-participant-label{font-size:1.2rem}.buzzer-participant-name{font-size:1rem}}.connected-users-section{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:20px;box-shadow:0 8px 32px #0000001a;margin-top:2rem}.connected-users-section h3{color:#333;margin-bottom:1rem;font-size:1.5rem}.connected-users-section p{color:#666;margin-bottom:1.5rem}.users-table{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000001a;margin-bottom:2rem}.table-header-users{display:grid;grid-template-columns:2fr 1.5fr 1.5fr 1.5fr 1fr;gap:1rem;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:700;font-size:.9rem}.users-list{display:flex;flex-direction:column}.user-row{display:grid;grid-template-columns:2fr 1.5fr 1.5fr 1.5fr 1fr;gap:1rem;padding:1rem;border-bottom:1px solid #f0f0f0;align-items:center;transition:background-color .3s ease}.user-row:hover{background-color:#667eea0d}.user-row:last-child{border-bottom:none}.device-info{display:flex;align-items:center;gap:.5rem}.device-icon{font-size:1.2rem}.connection-status{font-weight:600;font-size:.9rem}.connection-status.online{color:#10b981}.connection-status.offline{color:#ef4444}.users-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:1rem}.stat-item{background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:1rem;border-radius:12px;text-align:center;border:1px solid #e2e8f0}.stat-item strong{color:#667eea;font-size:1.2rem}.device-actions{display:flex;justify-content:center;gap:.5rem}.send-to-device-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.3rem}.send-to-device-btn:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.send-to-device-btn:disabled{background:linear-gradient(135deg,#9ca3af,#6b7280);cursor:not-allowed;opacity:.6}.send-to-device-btn.disabled{background:linear-gradient(135deg,#ef4444,#dc2626)}.delete-token-btn{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;padding:.5rem;border-radius:8px;font-size:.8rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;min-width:35px}.delete-token-btn:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}@media (max-width: 768px){.table-header-users,.user-row{grid-template-columns:1fr;gap:.5rem;text-align:left}.table-header-users{display:none}.user-row{padding:1.5rem 1rem;border-radius:8px;margin-bottom:.5rem;background:#fff;box-shadow:0 2px 8px #0000001a}.user-row>div{display:flex;justify-content:space-between;align-items:center;padding:.25rem 0}.device-actions{justify-content:flex-end;margin-top:.5rem;padding-top:.5rem;border-top:1px solid #f0f0f0;gap:.5rem}.send-to-device-btn{font-size:.9rem;padding:.75rem 1.25rem}.delete-token-btn{font-size:.9rem;padding:.75rem}.users-stats{grid-template-columns:1fr}}.blindtest-scoring{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:2rem;margin:2rem 0;box-shadow:0 8px 32px #0000001a;border:3px solid #ff6b6b}.blindtest-scoring h3{color:#ff6b6b;text-align:center;margin-bottom:1.5rem;font-size:1.8rem;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.blindtest-audio-controls{display:flex;justify-content:center;gap:1rem;margin-bottom:2rem}.audio-control-btn{display:flex;align-items:center;gap:.5rem;padding:1rem 2rem;border:none;border-radius:15px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0000001a}.audio-control-btn.playing{background:linear-gradient(135deg,#ff6b6b,#ee5a52);color:#fff}.audio-control-btn.paused{background:linear-gradient(135deg,#4ecdc4,#44a08d);color:#fff}.audio-control-btn.stop{background:linear-gradient(135deg,#95a5a6,#7f8c8d);color:#fff}.audio-control-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0003}.blindtest-rules{background:#ff6b6b1a;border:2px solid rgba(255,107,107,.3);border-radius:15px;padding:1.5rem;margin-bottom:2rem}.blindtest-rules p{font-weight:600;color:#333;margin-bottom:.5rem}.blindtest-rules ul{list-style:none;padding:0}.blindtest-rules li{padding:.3rem 0;color:#555;font-weight:500}.four-images-rules{background:#f59e0b1a;border:2px solid rgba(245,158,11,.3);border-radius:15px;padding:1.5rem;margin-bottom:2rem;text-align:center}.four-images-rules h3{margin:0 0 1rem;color:#92400e;font-size:1.5rem;font-weight:700}.four-images-rules p{font-weight:600;color:#333;margin-bottom:.5rem}.four-images-rules ul{list-style:none;padding:0;text-align:left;display:inline-block}.four-images-rules li{padding:.3rem 0;color:#555;font-weight:500}.blindtest-teams{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.blindtest-team{background:#fffc;border-radius:15px;padding:1.5rem;box-shadow:0 4px 15px #0000001a;transition:all .3s ease}.blindtest-team:hover{transform:translateY(-3px);box-shadow:0 6px 20px #00000026}.blindtest-team.rouge{border:3px solid #ef4444}.blindtest-team.bleu{border:3px solid #3b82f6}.blindtest-team h4{text-align:center;margin-bottom:1rem;font-size:1.3rem}.blindtest-team.rouge h4{color:#ef4444}.blindtest-team.bleu h4{color:#3b82f6}.blindtest-input{width:100%;padding:1rem;border:2px solid #e1e5e9;border-radius:10px;font-size:1rem;margin-bottom:1rem;transition:all .3s ease}.blindtest-input:focus{outline:none;border-color:#ff6b6b;box-shadow:0 0 0 3px #ff6b6b1a}.blindtest-check-btn{width:100%;padding:1rem;background:linear-gradient(135deg,#4ecdc4,#44a08d);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-bottom:1rem}.blindtest-check-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #4ecdc44d}.blindtest-check-btn:disabled{background:#95a5a6;cursor:not-allowed;transform:none;box-shadow:none}.blindtest-result{background:#ffffffe6;border-radius:10px;padding:1rem;border:2px solid #e1e5e9}.score-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #f0f0f0}.score-item:last-of-type{border-bottom:none}.score-item.correct{color:#22c55e;font-weight:600}.score-item.incorrect{color:#ef4444;font-weight:600}.total-score{margin-top:.5rem;padding-top:.5rem;border-top:2px solid #e1e5e9;font-weight:700;font-size:1.1rem;text-align:center;color:#333}.temporary-score-notice{font-size:.8rem;color:#666;font-style:italic;margin-top:.5rem;text-align:center;background:#ffc1071a;padding:.3rem .5rem;border-radius:6px;border:1px solid rgba(255,193,7,.3)}.blindtest-playing{text-align:center;padding:3rem 2rem}.blindtest-status{margin-top:2rem}.audio-indicator{display:flex;flex-direction:column;align-items:center;gap:1rem}.playing-indicator,.loading-indicator{font-size:1.2rem;color:#667eea;font-weight:600}.audio-wave{display:flex;gap:4px;align-items:center}.audio-wave span{width:4px;height:20px;background:#667eea;border-radius:2px;animation:audioWave .8s ease-in-out infinite alternate}.audio-wave span:nth-child(2){animation-delay:.2s}.audio-wave span:nth-child(3){animation-delay:.4s}.audio-wave span:nth-child(4){animation-delay:.6s}@keyframes audioWave{0%{height:10px}to{height:30px}}.audio-progress-container{margin-top:1.5rem;padding:1rem;background:#ffffff1a;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.audio-progress-bar{position:relative;width:100%;height:8px;background:#fff3;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.audio-progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:4px;transition:width .1s ease;position:relative}.audio-progress-fill:after{content:"";position:absolute;top:0;right:0;width:4px;height:100%;background:#fffc;border-radius:2px;box-shadow:0 0 8px #fff9;animation:progressGlow 2s ease-in-out infinite}.audio-progress-glow{position:absolute;top:-2px;left:0;right:0;bottom:-2px;background:linear-gradient(90deg,transparent 0%,rgba(102,126,234,.3) 50%,transparent 100%);border-radius:6px;animation:progressSweep 3s ease-in-out infinite}.audio-time-display{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;color:#ffffffe6;font-weight:600}.current-time{color:#667eea;font-weight:700;text-shadow:0 0 10px rgba(102,126,234,.5)}.duration{color:#ffffffb3}@keyframes progressGlow{0%,to{opacity:.8;transform:scaleX(1)}50%{opacity:1;transform:scaleX(1.2)}}@keyframes progressSweep{0%{transform:translate(-100%);opacity:0}50%{opacity:.3}to{transform:translate(100%);opacity:0}}.blindtest-video{margin-top:2rem;text-align:center}.blindtest-video h4{margin-bottom:1rem;color:#333;font-size:1.2rem}.youtube-embed{position:relative;width:100%;max-width:560px;margin:0 auto;border-radius:12px;overflow:hidden;box-shadow:0 4px 20px #0003}.youtube-embed iframe{width:100%;height:315px;border:none}.buzzer-instruction{background:linear-gradient(135deg,#fef3c7,#fbbf24);border:2px solid #f59e0b;border-radius:12px;padding:1rem;margin-top:1rem;text-align:center;font-size:1.1rem;color:#92400e;box-shadow:0 4px 12px #f59e0b4d;animation:buzzerGlow 2s ease-in-out infinite alternate}.buzzer-instruction strong{color:#78350f}@keyframes buzzerGlow{0%{box-shadow:0 4px 12px #f59e0b4d}to{box-shadow:0 6px 20px #f59e0b80}}.rapidite-rules,.panel-rules{background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;padding:1rem;margin-bottom:2rem}.four-images-one-word{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;width:100%;text-align:center;position:relative}.four-images-one-word .question-title{font-size:1.5rem;font-weight:700;color:#333;text-align:center}.four-images-timer-overlay{position:absolute;top:10px;right:10px;z-index:10}.timer-display-overlay{display:inline-flex;align-items:center;gap:.5rem;background:#f59e0bf2;color:#fff;padding:.8rem 1.5rem;border-radius:25px;font-weight:700;font-size:1.1rem;box-shadow:0 4px 12px #0003;border:2px solid #ffffff}.timer-number-overlay{font-size:1.8rem;font-weight:900;min-width:2rem;text-align:center}.timer-display-overlay.timer-critical{background:#ef4444f2;animation:timerCritical .5s infinite alternate}.image-container{position:relative;display:flex;justify-content:center;align-items:center;width:100%;max-width:800px;margin:0 auto;border-radius:16px;overflow:hidden;box-shadow:0 8px 32px #0003;background:#fff;padding:1rem;border:3px solid #f59e0b}.four-images-image{width:100%;height:auto;max-height:600px;object-fit:contain;display:block;border-radius:12px;box-shadow:0 4px 16px #0003}@media (max-width: 768px){.four-images-image{max-height:350px}.image-container{padding:.8rem}.timer-display-overlay{padding:.6rem 1.2rem;font-size:1rem}.timer-number-overlay{font-size:1.5rem}}@media (max-width: 768px){.blindtest-teams{flex-direction:column;gap:1rem}.blindtest-scoring{padding:1rem}.blindtest-scoring h3{font-size:1.2rem}.audio-control-btn{padding:.5rem 1rem;font-size:.9rem}.blindtest-playing{padding:2rem 1rem}.youtube-embed{max-width:100%}.youtube-embed iframe{height:250px}.audio-progress-container{margin-top:1rem;padding:.75rem}.audio-progress-bar{height:6px}.audio-time-display{font-size:.8rem}}.update-notification{position:fixed;top:20px;right:20px;z-index:10000;background:#fffffffa;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:16px;box-shadow:0 8px 32px #0003;border:2px solid rgba(102,126,234,.3);max-width:400px;animation:slideInFromRight .5s ease-out}.update-content{display:flex;align-items:center;gap:1rem;padding:1.5rem}.update-icon{font-size:2rem;animation:rotate 2s linear infinite}.update-text h3{margin:0 0 .5rem;color:#333;font-size:1.1rem;font-weight:600}.update-text p{margin:0;color:#666;font-size:.9rem;line-height:1.4}.update-actions{display:flex;gap:.5rem;margin-top:1rem}.update-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;padding:.5rem 1rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #667eea4d}.update-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.dismiss-btn{background:transparent;color:#666;border:1px solid #ddd;border-radius:8px;padding:.5rem 1rem;font-size:.9rem;cursor:pointer;transition:all .3s ease}.dismiss-btn:hover{background:#f5f5f5;color:#333}@keyframes slideInFromRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.update-notification{top:10px;right:10px;left:10px;max-width:none}.update-content{padding:1rem}.update-actions{flex-direction:column}.update-btn,.dismiss-btn{width:100%;text-align:center}}.multi-team-section{margin-top:2rem}.sub-events{display:flex;flex-direction:column;gap:2rem}.sub-event{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:1.5rem;box-shadow:0 4px 20px #0000001a;border:1px solid rgba(255,255,255,.2)}.sub-event h4{color:#333;font-size:1.2rem;font-weight:600;margin-bottom:1rem;text-align:center}.sub-event-teams{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.team-btn{padding:1rem 2rem;border:2px solid;border-radius:12px;background:transparent;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:120px;position:relative}.team-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #0003}.team-btn:disabled{opacity:.5;cursor:not-allowed}.team-btn.selected{box-shadow:0 4px 20px #0000004d;transform:translateY(-2px)}.winner-display{text-align:center;margin-top:1rem;padding:.75rem;background:#ffd7001a;border:2px solid #ffd700;border-radius:8px;font-weight:600;color:#333}@media (max-width: 768px){.sub-events{gap:1.5rem}.sub-event{padding:1rem}.sub-event-teams{flex-direction:column;align-items:center}.team-btn{width:100%;max-width:200px}}.header-notifications{display:flex;align-items:center}.notification-btn{position:relative;display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:#667eea1a;border:2px solid rgba(102,126,234,.2);border-radius:50%;cursor:pointer;transition:all .3s ease;color:#667eea}.notification-btn:hover{background:#667eea33;border-color:#667eea66;transform:translateY(-2px)}.notification-badge{position:absolute;top:-5px;right:-5px;background:#ef4444;color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;border:2px solid white;animation:notificationPulse 2s infinite}@keyframes notificationPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.notification-history-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .3s ease}.notification-history-content{background:linear-gradient(135deg,#fff,#f8fafc);border-radius:24px;box-shadow:0 25px 50px #00000026;max-width:600px;width:90%;max-height:80vh;overflow:hidden;border:1px solid rgba(255,255,255,.2);display:flex;flex-direction:column}.notification-history-header{padding:2rem;border-bottom:1px solid rgba(0,0,0,.1);background:#667eea0d}.notification-history-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.notification-history-title h2{color:#333;font-size:1.5rem;font-weight:700;margin:0}.modal-close-btn{background:#6b72801a;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.modal-close-btn:hover{background:#6b728033;color:#374151;transform:rotate(90deg)}.notification-history-actions{display:flex;gap:1rem;align-items:center}.mark-all-read-btn{padding:.5rem 1rem;background:#667eea1a;color:#667eea;border:1px solid rgba(102,126,234,.3);border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease}.mark-all-read-btn:hover{background:#667eea33;border-color:#667eea80}.clear-all-btn{padding:.5rem 1rem;background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease}.clear-all-btn:hover{background:#ef444433;border-color:#ef444480}.notification-history-list{flex:1;overflow-y:auto;padding:1rem;max-height:60vh}.no-notifications{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:#6b7280;text-align:center}.no-notifications svg{opacity:.5;margin-bottom:1rem}.notification-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem;border-radius:12px;margin-bottom:.5rem;transition:all .3s ease;border:1px solid transparent;position:relative;touch-action:pan-y}.notification-item:hover{background:#667eea0d;border-color:#667eea1a}.notification-item.unread{background:#667eea14;border-color:#667eea33}.notification-icon{font-size:1.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fffc;border-radius:50%;flex-shrink:0}.notification-content{flex:1;cursor:pointer}.notification-delete-btn{position:absolute;top:.75rem;right:.75rem;width:32px;height:32px;background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600;transition:all .3s ease;opacity:0;transform:scale(.8)}.notification-item:hover .notification-delete-btn{opacity:1;transform:scale(1)}.notification-delete-btn:hover{background:#ef444433;border-color:#ef444466;transform:scale(1.1)}.notification-title{font-weight:600;color:#333;margin-bottom:.25rem;font-size:1rem}.notification-body{color:#666;font-size:.9rem;line-height:1.4;margin-bottom:.5rem}.notification-time{color:#9ca3af;font-size:.8rem;font-weight:500}.notification-unread-dot{position:absolute;top:1rem;right:1rem;width:8px;height:8px;background:#ef4444;border-radius:50%;animation:notificationPulse 2s infinite}@media (max-width: 768px){.header-notifications{margin:0 .5rem}.notification-btn{width:44px;height:44px}.notification-badge{width:22px;height:22px;font-size:11px}.notification-history-content{width:95%;max-height:90vh;margin:1rem}.notification-history-header{padding:1.5rem 1rem;flex-direction:column;gap:1rem;align-items:flex-start}.notification-history-actions{width:100%;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.mark-all-read-btn,.clear-all-btn{padding:.5rem .75rem;font-size:.8rem}.notification-item{padding:.75rem 3rem .75rem .75rem}.notification-icon{width:35px;height:35px;font-size:1.25rem}.notification-delete-btn{opacity:1;transform:scale(1);top:.5rem;right:.5rem;width:28px;height:28px;font-size:16px}.admin-active .notification-item{position:relative;overflow:hidden}.admin-active .notification-item:after{content:"🗑️ Glissez pour supprimer";position:absolute;top:0;right:-100%;width:100%;height:100%;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem;transition:right .3s ease;z-index:-1}.modal-close-btn{width:36px;height:36px;font-size:20px}}.fast-celebration-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#ffd700f2,#ff8c00f2);display:flex;align-items:center;justify-content:center;z-index:10000;animation:celebrationFadeIn .5s ease-out}.fast-celebration-content{background:#fff;border-radius:20px;padding:3rem;text-align:center;position:relative;max-width:500px;width:90%;box-shadow:0 20px 60px #0000004d;animation:celebrationBounce .6s ease-out}.celebration-animation{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;overflow:hidden;border-radius:20px}.confetti{position:absolute;font-size:2rem;animation:confettiFall 3s infinite linear}.confetti:nth-child(1){left:10%;animation-delay:0s}.confetti:nth-child(2){left:20%;animation-delay:.5s}.confetti:nth-child(3){left:40%;animation-delay:1s}.confetti:nth-child(4){left:60%;animation-delay:1.5s}.confetti:nth-child(5){left:80%;animation-delay:2s}.confetti:nth-child(6){left:90%;animation-delay:2.5s}.celebration-main{position:relative;z-index:1}.celebration-title{font-size:2.5rem;margin:0 0 1.5rem;background:linear-gradient(135deg,gold,#ff8c00);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:titlePulse 2s infinite ease-in-out}.winner-info{margin:2rem 0}.winner-name{font-size:2rem;font-weight:700;color:#2d3748;margin-bottom:.5rem}.winner-team{font-size:1.2rem;color:#4a5568;font-weight:600}.challenge-info{margin:2rem 0;padding:1.5rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:15px;border:2px solid #e2e8f0}.challenge-info h2{margin:0 0 1rem;color:#2d3748;font-size:1.5rem}.points-earned{font-size:1.8rem;font-weight:700;color:#38a169;text-shadow:0 2px 4px rgba(56,161,105,.3)}.celebration-message{font-size:1.1rem;color:#4a5568;margin:1.5rem 0;font-style:italic}.close-celebration-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 2rem;border-radius:50px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea66}.close-celebration-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea99}@keyframes celebrationBounce{0%{transform:scale(.3) rotate(-10deg);opacity:0}50%{transform:scale(1.05) rotate(2deg)}70%{transform:scale(.95) rotate(-1deg)}to{transform:scale(1) rotate(0);opacity:1}}@keyframes titlePulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.fast-admin-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000;padding:2rem}.fast-admin-content{background:#fff;border-radius:20px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease-out}.fast-admin-header{padding:2rem 2rem 1rem;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;align-items:center}.fast-admin-header h2{color:#333;font-size:1.8rem;margin:0}.fast-epreuves-list{padding:2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem}.fast-epreuve-card{background:linear-gradient(135deg,#f8f9ff,#e8f2ff);border:2px solid #e1e8ff;border-radius:15px;padding:1.5rem;transition:all .3s ease;position:relative;overflow:hidden}.fast-epreuve-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2)}.fast-epreuve-card:hover{transform:translateY(-5px);box-shadow:0 15px 35px #667eea33;border-color:#667eea}.fast-epreuve-info h3{color:#333;font-size:1.3rem;margin-bottom:.8rem;font-weight:700}.fast-epreuve-description{color:#666;font-size:.95rem;line-height:1.5;margin-bottom:1rem}.fast-epreuve-details{display:flex;gap:1rem;margin-bottom:1rem}.fast-duration,.fast-points{background:#667eea1a;color:#667eea;padding:.3rem .8rem;border-radius:20px;font-size:.85rem;font-weight:600}.fast-materiel{color:#777;font-size:.9rem;margin-bottom:1.5rem;padding:.8rem;background:#0000000d;border-radius:8px;border-left:4px solid #667eea}.fast-launch-btn{width:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.fast-launch-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.fast-launch-btn:hover:before{left:100%}.fast-launch-btn:hover{transform:translateY(-2px);box-shadow:0 10px 25px #667eea66}.fast-epreuve-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:3000;padding:2rem}.fast-epreuve-content{background:#fff;border-radius:20px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 25px 70px #0006;animation:fastModalAppear .5s ease-out}@keyframes fastModalAppear{0%{opacity:0;transform:scale(.8) translateY(50px)}to{opacity:1;transform:scale(1) translateY(0)}}.fast-countdown{text-align:center;padding:4rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:20px}.fast-countdown-number{font-size:8rem;font-weight:700;line-height:1;animation:countdownPulse 1s infinite;text-shadow:0 0 30px rgba(255,255,255,.5);transition:all .3s ease}.fast-countdown-number.critical{color:#f44;text-shadow:0 0 40px rgba(255,68,68,.8);animation:countdownCritical 1s infinite}.fast-countdown-text{font-size:2rem;margin-top:1rem;font-weight:600;text-transform:uppercase;letter-spacing:2px}@keyframes countdownPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes countdownCritical{0%,to{transform:scale(1);text-shadow:0 0 40px rgba(255,68,68,.8)}50%{transform:scale(1.2);text-shadow:0 0 60px rgba(255,68,68,1)}}.fast-description{padding:2rem}.fast-description-header{text-align:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:3px solid #f0f0f0}.fast-description-header h2{color:#333;font-size:2.2rem;margin-bottom:1rem}.fast-description-meta{display:flex;justify-content:center;gap:2rem}.fast-description-meta .fast-duration,.fast-description-meta .fast-points{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.8rem 1.5rem;border-radius:25px;font-weight:700;font-size:1.1rem}.fast-description-body{margin-bottom:2rem}.fast-challenge,.fast-rules,.fast-material{margin-bottom:2rem;padding:1.5rem;border-radius:15px}.fast-challenge{background:linear-gradient(135deg,#e8f5e8,#f0fff0);border-left:5px solid #4caf50}.fast-rules{background:linear-gradient(135deg,#fff3e0,#ffeaa7);border-left:5px solid #ff9800}.fast-material{background:linear-gradient(135deg,#e3f2fd,#f0f8ff);border-left:5px solid #2196f3}.fast-challenge h3,.fast-rules h3,.fast-material h3{margin-bottom:1rem;font-size:1.3rem;color:#333}.fast-challenge p,.fast-rules p,.fast-material p{color:#555;line-height:1.6;font-size:1rem}.fast-epreuve-card.completed{opacity:.6;background:linear-gradient(135deg,#f5f5f5,#e8e8e8);border:2px solid #28a745}.fast-epreuve-card.completed .fast-epreuve-info h3{color:#28a745}.fast-launch-btn.disabled{background:linear-gradient(135deg,#6c757d,#5a6268);cursor:not-allowed;opacity:.7}.fast-launch-btn.disabled:hover{background:linear-gradient(135deg,#6c757d,#5a6268);transform:none;box-shadow:0 4px 12px #6c757d4d}.fast-admin-actions{margin-top:2rem;padding-top:2rem;border-top:2px solid #e9ecef;text-align:center}.fast-reset-btn{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-weight:700;cursor:pointer;transition:all .3s ease;font-size:1rem;box-shadow:0 4px 12px #dc35454d}.fast-reset-btn:hover{background:linear-gradient(135deg,#c82333,#a71e2a);transform:translateY(-2px);box-shadow:0 6px 16px #dc354566}.fast-winner-selection{background:linear-gradient(135deg,#f8f9ff,#e8f2ff);padding:2rem;border-radius:15px;margin-bottom:2rem}.fast-winner-selection h3{text-align:center;margin-bottom:1.5rem;color:#333;font-size:1.5rem}.fast-teams-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.fast-team-section{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 5px 15px #0000001a}.fast-team-section h4{text-align:center;margin-bottom:1rem;font-size:1.2rem;font-weight:700}.fast-participants{display:flex;flex-direction:column;gap:.8rem}.fast-participant-btn{padding:.8rem 1rem;border:2px solid;background:#fff;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease;color:#333}.fast-participant-btn:hover{background:#0000000d;transform:translateY(-2px);box-shadow:0 5px 15px #0003}.fast-winner-announcement{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;padding:2rem;border-radius:15px;text-align:center;animation:winnerCelebration 1s ease-out}.fast-winner-announcement h3{margin-bottom:1rem;font-size:1.8rem}.fast-winner-announcement p{font-size:1.2rem;line-height:1.5}@keyframes winnerCelebration{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}@media (max-width: 768px){.fast-admin-modal{padding:1rem}.fast-admin-content{max-height:95vh}.fast-admin-header{padding:1.5rem 1.5rem 1rem}.fast-admin-header h2{font-size:1.5rem}.fast-epreuves-list{grid-template-columns:1fr;padding:1.5rem;gap:1rem}.fast-epreuve-card{padding:1.2rem}.fast-countdown-number{font-size:5rem}.fast-countdown-text{font-size:1.5rem}.fast-description{padding:1.5rem}.fast-description-header h2{font-size:1.8rem}.fast-description-meta{flex-direction:column;gap:1rem}.fast-teams-grid{grid-template-columns:1fr;gap:1rem}.fast-team-section{padding:1.2rem}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}.buzzer-container{display:flex;flex-direction:column;align-items:center;gap:2rem;padding:2rem;max-width:800px;margin:0 auto;min-height:calc(100vh - 200px);justify-content:center}.buzzer-team-selection{display:flex;flex-direction:column;align-items:center;gap:2rem;padding:2rem;max-width:600px;margin:0 auto;min-height:calc(100vh - 200px);justify-content:center}.team-selection-header{text-align:center;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:20px;box-shadow:0 8px 32px #0000001a;border:1px solid rgba(255,255,255,.2);width:100%}.team-selection-header h2{font-size:2rem;color:#333;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.team-selection-header p{color:#666;font-size:1.1rem}.team-selection-buttons{display:grid;grid-template-columns:1fr 1fr;gap:2rem;width:100%}.team-selection-btn{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;border:none;border-radius:20px;cursor:pointer;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 32px #0000001a;border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.team-selection-btn:hover{transform:translateY(-5px);box-shadow:0 12px 40px #00000026}.team-selection-btn:hover{border-left-width:5px;background:#0000000d}.team-icon{font-size:3rem}.team-selection-btn h3{font-size:1.5rem;margin:0;color:#333}.team-selection-btn p{margin:0;color:#666;font-size:1rem}.buzzer-header{text-align:center;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1.5rem;border-radius:20px;box-shadow:0 8px 32px #0000001a;border:1px solid rgba(255,255,255,.2);width:100%;margin-bottom:1rem}.buzzer-header h2{font-size:1.8rem;color:#333;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.buzzer-header p{color:#666;font-size:1rem;margin-bottom:1rem}.change-team-btn{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff;border:none;padding:.5rem 1rem;border-radius:10px;cursor:pointer;font-size:.9rem;transition:all .3s ease}.change-team-btn:hover{background:linear-gradient(135deg,#4b5563,#374151);transform:translateY(-1px)}.personal-buzzer{display:flex;justify-content:center;align-items:center;width:100%}.buzzer-device{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.buzzer-base{position:relative;perspective:1000px}.buzzer-button{width:350px;height:350px;border-radius:50%;border:none;cursor:pointer;position:relative;transition:all .2s ease;transform-style:preserve-3d;outline:none}.buzzer-button:active:not(:disabled){transform:translateZ(-10px)}.buzzer-button:hover:not(:disabled){transform:translateZ(5px)}.buzzer-button:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.buzzer-top{width:100%;height:100%;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative}.buzzer-surface{width:80%;height:80%;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3)}.buzzer-ready-indicator,.buzzer-cooldown-indicator{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.ready-icon,.cooldown-icon{font-size:3rem;animation:iconPulse 2s ease-in-out infinite}.ready-text,.cooldown-text{font-size:1.2rem;font-weight:700;letter-spacing:1px}.buzzer-cooldown{animation:buzzerCooldown 1s ease-in-out}@keyframes iconPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}@keyframes buzzerCooldown{0%{transform:scale(1.05) translateZ(-5px);opacity:.8}50%{transform:scale(.95) translateZ(-15px);opacity:.5}to{transform:scale(1) translateZ(0);opacity:.6}}@media (max-width: 768px){.team-selection-buttons{grid-template-columns:1fr;gap:1.5rem}.buzzer-button{width:300px;height:300px}.team-icon,.ready-icon,.cooldown-icon{font-size:2.5rem}.ready-text,.cooldown-text{font-size:1rem}.buzzer-header h2{font-size:1.5rem}}@media (max-width: 480px){.buzzer-container,.buzzer-team-selection{padding:1rem}.buzzer-button{width:280px;height:280px}.team-selection-header,.buzzer-header{padding:1.5rem}.team-selection-header h2{font-size:1.5rem}.team-selection-btn{padding:1.5rem}.team-selection-btn h3{font-size:1.3rem}.ready-icon,.cooldown-icon{font-size:2.2rem}.ready-text,.cooldown-text{font-size:.95rem}}.final-celebration-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#667eeae6,#764ba2e6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10000;display:flex;align-items:center;justify-content:center;animation:celebrationFadeIn .8s ease-out}.final-celebration-modal{background:#fffffff2;border-radius:20px;max-width:90vw;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:celebrationSlideIn .8s ease-out;position:relative}.celebration-header{text-align:center;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:20px 20px 0 0;position:relative;overflow:hidden}.celebration-confetti{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.celebration-confetti .confetti{position:absolute;width:10px;height:10px;background:linear-gradient(45deg,#ff6b6b,#feca57,#48dbfb,#ff9ff3,#54a0ff);animation:confettiFall 3s linear infinite}.celebration-confetti .confetti:nth-child(1){left:10%;animation-delay:0s}.celebration-confetti .confetti:nth-child(2){left:30%;animation-delay:.5s}.celebration-confetti .confetti:nth-child(3){left:50%;animation-delay:1s}.celebration-confetti .confetti:nth-child(4){left:70%;animation-delay:1.5s}.celebration-confetti .confetti:nth-child(5){left:90%;animation-delay:2s}.celebration-title{font-size:2.5rem;margin:0;text-shadow:2px 2px 4px rgba(0,0,0,.3);animation:titleBounce 2s ease-in-out infinite alternate}.celebration-subtitle{font-size:1.2rem;margin-top:.5rem;opacity:.9}.celebration-content{padding:2rem;display:flex;flex-direction:column;gap:2rem}.final-scores-section{text-align:center}.final-scores-grid{display:flex;align-items:center;justify-content:center;gap:2rem;margin:2rem 0}.final-team-score{background:linear-gradient(135deg,#ffffffe6,#f0f0f0e6);border-radius:15px;padding:1.5rem;min-width:200px;position:relative;transition:all .3s ease;border:3px solid transparent}.final-team-score.winner{background:linear-gradient(135deg,#ffd70033,#ffc10733);border-color:gold;transform:scale(1.05);box-shadow:0 10px 30px #ffd7004d}.final-team-score.tie{background:linear-gradient(135deg,#6c757d33,#868e9633);border-color:#6c757d}.final-team-score .team-name{font-size:1.2rem;font-weight:700;margin-bottom:.5rem}.final-team-score .final-score-number{font-size:3rem;font-weight:700;color:#333;margin:.5rem 0}.final-team-score .score-breakdown{font-size:.9rem;color:#666}.winner-crown{position:absolute;top:-10px;right:-10px;font-size:2rem;animation:crownSpin 2s linear infinite}.vs-divider{font-size:1.5rem;font-weight:700;color:#666}.winner-message,.tie-message{font-size:1.3rem;font-weight:700;margin-top:1rem;padding:1rem;border-radius:10px;background:linear-gradient(135deg,#28a7451a,#1987541a);border:2px solid rgba(40,167,69,.3)}.podium-section{text-align:center}.podium{display:flex;justify-content:center;align-items:end;gap:1rem;margin:2rem 0}.podium-place{border-radius:15px;padding:1.5rem 1rem;text-align:center;position:relative;transition:all .3s ease}.podium-place.place-1{order:2;transform:scale(1.1);border:3px solid #ffd700;animation:goldGlow 2s ease-in-out infinite alternate}.podium-place.place-2{order:1;background:linear-gradient(135deg,#c0c0c033,#a9a9a933);border:3px solid #c0c0c0}.podium-place.place-3{order:3;background:linear-gradient(135deg,#cd7f3233,#b8733333);border:3px solid #cd7f32}.podium-name{font-size:1.1rem;font-weight:700;margin-bottom:.3rem}.podium-team{font-size:.9rem;color:#666;margin-bottom:.3rem}.podium-score{font-size:1.2rem;font-weight:700;color:#333}.bottom-podium-section{text-align:center;margin-top:2rem}.bottom-podium{display:flex;justify-content:center;gap:1rem;margin:2rem 0}.bottom-podium-place{background:linear-gradient(135deg,#ffc1071a,#ffeb3b1a);border:2px solid rgba(255,193,7,.3);border-radius:15px;padding:1rem;text-align:center;max-width:150px}.bottom-podium-name{font-size:1rem;font-weight:700;margin-bottom:.3rem}.bottom-podium-score{font-size:1rem;font-weight:700;color:#333;margin-bottom:.5rem}.bottom-podium-message{font-size:.7rem;color:#888;font-style:italic}.fun-stats-section{text-align:center}.fun-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin:2rem 0}.fun-stat{background:linear-gradient(135deg,#ffffffe6,#f8f9fae6);border-radius:15px;padding:1.5rem;text-align:center;transition:all .3s ease}.fun-stat:hover{transform:translateY(-5px);box-shadow:0 10px 25px #0000001a}.fun-stat.highlight{background:linear-gradient(135deg,#ffc10733,#ffeb3b33);border:2px solid rgba(255,193,7,.5);animation:highlightPulse 2s ease-in-out infinite alternate}.fun-stat-icon{font-size:2rem;margin-bottom:.5rem}.fun-stat-value{font-size:1.3rem;font-weight:700;color:#333;margin-bottom:.3rem}.score-evolution-section{text-align:center}.evolution-bar{background:#ffffffe6;border-radius:15px;padding:2rem;margin:2rem 0}.evolution-label{min-width:120px;font-weight:700;text-align:left}.evolution-segments{flex:1;height:30px;background:#c8c8c84d;border-radius:15px;display:flex;overflow:hidden}.evolution-segment{height:100%;transition:all .8s ease}.evolution-segment.quiz{background:linear-gradient(90deg,#667eea,#764ba2)}.evolution-segment.epreuves{background:linear-gradient(90deg,#f093fb,#f5576c)}.evolution-total{min-width:60px;font-weight:700;font-size:1.2rem;text-align:right}.evolution-legend{display:flex;justify-content:center;gap:2rem;margin-top:1rem}.legend-color{width:20px;height:20px;border-radius:50%}.legend-color.quiz{background:linear-gradient(90deg,#667eea,#764ba2)}.legend-color.epreuves{background:linear-gradient(90deg,#f093fb,#f5576c)}.final-message{text-align:center;background:linear-gradient(135deg,#28a7451a,#1987541a);border:2px solid rgba(40,167,69,.3);border-radius:15px;padding:2rem;margin:2rem 0}.final-message h2{margin-bottom:1rem;color:#333}.final-message p{font-size:1.1rem;line-height:1.6;color:#555;margin-bottom:.5rem}.celebration-footer{text-align:center;padding:2rem;background:#f8f9fae6;border-radius:0 0 20px 20px}.close-celebration-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:25px;padding:1rem 2rem;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.close-celebration-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}@keyframes celebrationSlideIn{0%{transform:translateY(-50px) scale(.9);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@keyframes confettiFall{0%{transform:translateY(-100vh) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(360deg);opacity:0}}@keyframes titleBounce{0%{transform:translateY(0)}to{transform:translateY(-10px)}}@keyframes crownSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes goldGlow{0%{box-shadow:0 0 20px #ffd7004d}to{box-shadow:0 0 30px #ffd70099}}@keyframes highlightPulse{0%{transform:scale(1)}to{transform:scale(1.02)}}@media (max-width: 768px){.final-celebration-modal{max-width:95vw;max-height:95vh}.celebration-title{font-size:2rem}.final-scores-grid{flex-direction:column;gap:1rem}.podium{flex-wrap:wrap;gap:.5rem}.podium-place{min-width:120px}.fun-stats-grid{grid-template-columns:1fr}.evolution-team{flex-direction:column;align-items:stretch;gap:.5rem}.evolution-label,.evolution-total{text-align:center}.evolution-legend{flex-direction:column;gap:1rem}}.blindtest-audio-progress{margin-top:2rem;padding:1.5rem;background:#fffffff2;border-radius:16px;box-shadow:0 4px 20px #0000001a;border:2px solid #667eea}.blindtest-audio-progress .audio-indicator{text-align:center;margin-bottom:1rem;font-size:1.1rem;font-weight:600}.blindtest-audio-progress .playing-indicator,.blindtest-audio-progress .loading-indicator{color:#667eea;display:flex;align-items:center;justify-content:center;gap:1rem}.blindtest-audio-progress .audio-wave{display:flex;gap:3px;align-items:center}.blindtest-audio-progress .audio-wave span{width:4px;height:20px;background:#667eea;border-radius:2px;animation:audioWave 1.5s ease-in-out infinite}.blindtest-audio-progress .audio-wave span:nth-child(2){animation-delay:.1s}.blindtest-audio-progress .audio-wave span:nth-child(3){animation-delay:.2s}.blindtest-audio-progress .audio-wave span:nth-child(4){animation-delay:.3s}.blindtest-audio-progress .audio-progress-container{margin-top:1rem}@media (max-width: 768px){.blindtest-audio-progress{margin-top:1rem;padding:1rem}.blindtest-audio-progress .audio-indicator{font-size:1rem}.blindtest-audio-progress .playing-indicator,.blindtest-audio-progress .loading-indicator{flex-direction:column;gap:.5rem}}.celebration-modal{background:#fffffffa;border-radius:25px;box-shadow:0 30px 80px #0000004d;max-width:1000px;width:95%;max-height:90vh;overflow-y:auto;animation:celebrationSlideUp .8s ease-out .3s both;position:relative}.celebration-header{background:linear-gradient(135deg,gold,#ffed4e);padding:2rem;border-radius:25px 25px 0 0;text-align:center;position:relative;overflow:hidden}.celebration-confetti{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;overflow:hidden}.confetti{position:absolute;width:8px;height:8px;background:#ff6b6b;animation:confettiFall 3s linear infinite;border-radius:2px}.confetti:nth-child(1){left:5%;background:#ff6b6b;animation-delay:0s;animation-duration:3s;transform:rotate(45deg)}.confetti:nth-child(2){left:15%;background:#4ecdc4;animation-delay:.3s;animation-duration:2.5s;width:6px;height:12px}.confetti:nth-child(3){left:25%;background:#45b7d1;animation-delay:.6s;animation-duration:3.5s;border-radius:50%}.confetti:nth-child(4){left:35%;background:#96ceb4;animation-delay:.9s;animation-duration:2.8s;transform:rotate(30deg)}.confetti:nth-child(5){left:45%;background:#feca57;animation-delay:1.2s;animation-duration:3.2s;width:12px;height:6px}.confetti:nth-child(6){left:55%;background:#ff9ff3;animation-delay:1.5s;animation-duration:2.7s;border-radius:50%;width:10px;height:10px}.confetti:nth-child(7){left:65%;background:#54a0ff;animation-delay:1.8s;animation-duration:3.1s;transform:rotate(60deg)}.confetti:nth-child(8){left:75%;background:#5f27cd;animation-delay:2.1s;animation-duration:2.9s;width:6px;height:14px}.confetti:nth-child(9){left:85%;background:#00d2d3;animation-delay:2.4s;animation-duration:3.3s;border-radius:50%}.confetti:nth-child(10){left:95%;background:#ff3838;animation-delay:2.7s;animation-duration:2.6s;transform:rotate(90deg)}.celebration-title{font-size:3rem;color:#1a1a1a;margin:0;text-shadow:2px 2px 4px rgba(0,0,0,.1);animation:titleBounce 2s ease-in-out infinite}.celebration-subtitle{font-size:1.3rem;color:#333;margin-top:.5rem;font-weight:600}.celebration-content{padding:2rem;background:#f8fafc}.final-scores-section{margin-bottom:3rem}.final-scores-section h2{text-align:center;color:#1a1a1a;font-size:2rem;margin-bottom:2rem}.final-scores-grid{display:flex;align-items:center;justify-content:center;gap:2rem;margin-bottom:2rem}.final-team-score{background:#fff;border-radius:20px;padding:2rem;text-align:center;box-shadow:0 10px 30px #0000001a;min-width:200px;position:relative;transition:transform .3s ease}.final-team-score:hover{transform:translateY(-5px)}.final-team-score.winner{background:linear-gradient(135deg,gold,#ffed4e);transform:scale(1.1);animation:winnerGlow 2s ease-in-out infinite}.final-team-score .team-name{font-size:1.5rem;font-weight:700;color:#1a1a1a;margin-bottom:1rem}.final-score-number{font-size:3rem;font-weight:700;color:#667eea;margin-bottom:1rem}.final-team-score.winner .final-score-number{color:#1a1a1a}.score-breakdown{font-size:.9rem;color:#666;line-height:1.4}.winner-crown{position:absolute;top:-15px;right:-15px;font-size:2rem;animation:crownRotate 3s ease-in-out infinite}.vs-divider{font-size:2rem;font-weight:700;color:#667eea;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.winner-message{text-align:center;font-size:1.5rem;color:#1a1a1a;font-weight:700;background:linear-gradient(135deg,gold,#ffed4e);padding:1rem 2rem;border-radius:15px;display:inline-block;animation:winnerMessagePulse 2s ease-in-out infinite}.podium-section{margin-bottom:3rem}.podium-section h2{text-align:center;color:#1a1a1a;font-size:2rem;margin-bottom:2rem}.podium{display:flex;justify-content:center;align-items:end;gap:1rem;margin-bottom:2rem}.podium-place{background:#fff;border-radius:15px;padding:1.5rem 1rem;text-align:center;box-shadow:0 8px 25px #0000001a;transition:transform .3s ease}.podium-place:hover{transform:translateY(-5px)}.podium-place.place-1{background:linear-gradient(135deg,#ffd70033,#ffc10733);transform:scale(1.1);order:2}.podium-place.place-3{background:linear-gradient(135deg,#cd7f32,#daa520);order:3}.podium-medal{font-size:2rem;margin-bottom:.5rem}.podium-name{font-size:1.2rem;font-weight:700;color:#1a1a1a;margin-bottom:.5rem}.podium-team{font-size:.9rem;color:#666;margin-bottom:.5rem}.podium-score{font-size:1.1rem;font-weight:700;color:#667eea}.podium-participations{font-size:.8rem;color:#888;margin-top:.3rem}.bottom-podium-section{margin-bottom:3rem}.bottom-podium-section h2{text-align:center;color:#1a1a1a;font-size:1.8rem;margin-bottom:2rem}.bottom-podium{display:flex;justify-content:center;gap:1rem}.bottom-podium-place{background:#fff;border-radius:15px;padding:1.5rem 1rem;text-align:center;box-shadow:0 8px 25px #0000001a;max-width:200px}.bottom-podium-medal{font-size:1.5rem;margin-bottom:.5rem}.bottom-podium-name{font-size:1rem;font-weight:700;color:#1a1a1a;margin-bottom:.3rem}.bottom-podium-team{font-size:.8rem;color:#666;margin-bottom:.3rem}.bottom-podium-score{font-size:.9rem;font-weight:700;color:#667eea;margin-bottom:.5rem}.bottom-podium-message{font-size:.8rem;color:#888;font-style:italic}.fun-stats-section{margin-bottom:3rem}.fun-stats-section h2{text-align:center;color:#1a1a1a;font-size:2rem;margin-bottom:2rem}.fun-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.fun-stat{background:#fff;border-radius:15px;padding:1.5rem;text-align:center;box-shadow:0 8px 25px #0000001a;transition:transform .3s ease}.fun-stat:hover{transform:translateY(-5px)}.fun-stat-icon{font-size:2rem;margin-bottom:1rem}.fun-stat-value{font-size:1.8rem;font-weight:700;color:#667eea;margin-bottom:.5rem}.fun-stat-label{font-size:.9rem;color:#666}.score-evolution-section{margin-bottom:3rem}.score-evolution-section h2{text-align:center;color:#1a1a1a;font-size:2rem;margin-bottom:2rem}.score-evolution{background:#fff;border-radius:15px;padding:2rem;box-shadow:0 8px 25px #0000001a}.evolution-bar{margin-bottom:2rem}.evolution-team{display:flex;align-items:center;margin-bottom:1rem;gap:1rem}.evolution-label{min-width:80px;font-weight:700;color:#1a1a1a}.evolution-segments{flex:1;height:30px;background:#f1f5f9;border-radius:15px;display:flex;overflow:hidden;position:relative}.evolution-segment{height:100%;transition:width 2s ease-in-out}.evolution-segment.quiz{background:linear-gradient(135deg,#667eea,#764ba2)}.evolution-segment.epreuves{background:linear-gradient(135deg,#feca57,#ff9ff3)}.evolution-total{min-width:50px;text-align:center;font-weight:700;color:#667eea;font-size:1.2rem}.evolution-legend{display:flex;justify-content:center;gap:2rem}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-color{width:20px;height:20px;border-radius:10px}.legend-color.quiz{background:linear-gradient(135deg,#667eea,#764ba2)}.legend-color.epreuves{background:linear-gradient(135deg,#feca57,#ff9ff3)}.final-message{text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;border-radius:20px;margin-bottom:2rem}.final-message h2{font-size:2rem;margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.final-message p{font-size:1.1rem;margin-bottom:1rem;opacity:.9}.celebration-footer{padding:2rem;text-align:center;background:#f8fafc;border-radius:0 0 25px 25px}.close-celebration-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;padding:1rem 3rem;border-radius:50px;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 25px #667eea4d}.close-celebration-btn:hover{transform:translateY(-3px);box-shadow:0 12px 35px #667eea66}@keyframes celebrationFadeIn{0%{opacity:0}to{opacity:1}}@keyframes celebrationSlideUp{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}@keyframes confettiFall{0%{transform:translateY(-100px) rotate(0);opacity:1}10%{opacity:1}90%{opacity:.8}to{transform:translateY(500px) rotate(720deg);opacity:0}}.celebration-header:before{content:"✨";position:absolute;top:20px;left:20px;font-size:1.5rem;animation:sparkle 2s ease-in-out infinite}.celebration-header:after{content:"⭐";position:absolute;top:30px;right:30px;font-size:1.2rem;animation:sparkle 2.5s ease-in-out infinite .5s}@keyframes sparkle{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}@keyframes titleBounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}@keyframes winnerGlow{0%,to{box-shadow:0 10px 30px #ffd7004d}50%{box-shadow:0 15px 40px #ffd70099}}@keyframes crownRotate{0%,to{transform:rotate(-10deg)}50%{transform:rotate(10deg)}}@keyframes winnerMessagePulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@media (max-width: 768px){.celebration-modal{width:98%;margin:1rem}.celebration-title{font-size:2rem}.final-scores-grid{flex-direction:column;gap:1rem}.vs-divider{transform:rotate(90deg);margin:1rem 0}.podium{flex-direction:column;align-items:center}.podium-place{width:100%;max-width:300px}.bottom-podium{flex-direction:column;align-items:center}.fun-stats-grid{grid-template-columns:1fr}.evolution-legend{flex-direction:column;gap:1rem}}body.celebration-open{overflow:hidden;position:fixed;width:100%}@keyframes floatingParticles{0%{transform:translateY(0)}to{transform:translateY(-100px)}}.celebration-overlay:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(2px 2px at 20px 30px,rgba(255,255,255,.3),transparent),radial-gradient(2px 2px at 40px 70px,rgba(255,255,255,.2),transparent),radial-gradient(1px 1px at 90px 40px,rgba(255,255,255,.4),transparent),radial-gradient(1px 1px at 130px 80px,rgba(255,255,255,.3),transparent),radial-gradient(2px 2px at 160px 30px,rgba(255,255,255,.2),transparent);background-repeat:repeat;background-size:200px 100px;animation:floatingParticles 20s linear infinite;pointer-events:none}.pixel-rules{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;border-radius:16px;margin:1rem 0;box-shadow:0 8px 32px #667eea4d}.pixel-rules h3{margin:0 0 1rem;font-size:1.5rem;text-align:center;text-shadow:0 2px 4px rgba(0,0,0,.3)}.pixel-rules ul{list-style:none;padding:0;margin:0}.pixel-rules li{padding:.5rem 0;font-weight:500}.pixel-interface{background:#f8fafc;border-radius:16px;padding:2rem;margin:1rem 0;box-shadow:0 8px 32px #0000001a}.pixel-revealing{text-align:center}.pixel-image-container{position:relative;display:inline-block;margin:0 auto 1rem;border-radius:12px;overflow:hidden;box-shadow:0 8px 24px #0003}.pixel-image{width:400px;height:400px;object-fit:cover;display:block}.pixel-timer-overlay{position:absolute;top:15px;right:15px;background:#000c;border-radius:50%;width:60px;height:60px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000004d}.pixel-timer{color:gold;font-size:1.5rem;font-weight:700;text-shadow:0 0 8px rgba(255,215,0,.5)}.pixel-progress{text-align:center;margin-top:1rem}.pixel-level{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.8rem 1.5rem;border-radius:25px;font-weight:700;font-size:1.1rem;display:inline-block;box-shadow:0 4px 12px #667eea4d}.pixel-buzzer-phase{text-align:center}.pixel-buzzer-section h3{color:#1f2937;margin:1rem 0 2rem;font-size:1.4rem}.pixel-buzzer-buttons{display:flex;gap:2rem;justify-content:center;margin:2rem 0}.pixel-buzzer-btn{padding:1rem 2rem;border:none;border-radius:12px;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .3s ease;min-width:200px;box-shadow:0 4px 12px #0003}.pixel-buzzer-btn.rouge{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.pixel-buzzer-btn.bleu{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.pixel-buzzer-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.pixel-buzzer-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.pixel-buzzer-btn.buzzed{background:linear-gradient(135deg,#10b981,#059669);animation:buzzSuccess .5s ease}.pixel-buzzer-btn.cooldown{background:linear-gradient(135deg,#6b7280,#4b5563);animation:cooldownPulse 1s infinite}.pixel-buzzed-info{margin-top:1.5rem;padding:1rem;background:#10b9811a;border:2px solid #10b981;border-radius:12px;color:#047857;font-weight:700}.pixel-scoring{background:#f8fafc;border-radius:16px;padding:2rem;margin:1rem 0}.pixel-scoring h3{text-align:center;color:#1f2937;margin-bottom:2rem;font-size:1.5rem}.pixel-final-image{text-align:center;margin-bottom:2rem}.pixel-final-display{width:300px;height:300px;object-fit:cover;border-radius:12px;box-shadow:0 8px 24px #0003}.pixel-buzz-summary{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 4px 12px #0000001a}.buzz-info{padding:.8rem;border-radius:8px;margin:.5rem 0;font-weight:700}.buzz-info.rouge{background:#ef44441a;border-left:4px solid #ef4444;color:#dc2626}.buzz-info.bleu{background:#3b82f61a;border-left:4px solid #3b82f6;color:#2563eb}.no-buzz{text-align:center;color:#6b7280;font-style:italic;padding:1rem}.buzzed-indicator{background:#10b981;color:#fff;padding:.3rem .8rem;border-radius:15px;font-size:.8rem;margin-left:.5rem}@keyframes buzzSuccess{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes cooldownPulse{0%,to{opacity:.6}50%{opacity:.8}}.celebration-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#667eeaf2,#764ba2f2);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:celebrationFadeIn 1s ease-in-out;overflow-y:auto;padding:2rem 0}.install-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeInOverlay .3s ease-out}.notification-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeInOverlay .3s ease-out}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.install-modal,.notification-modal{background:linear-gradient(135deg,#fff,#f8fafc);border-radius:24px;box-shadow:0 25px 50px #00000026;max-width:480px;width:90%;max-height:90vh;overflow-y:auto;position:relative;border:1px solid rgba(255,255,255,.2);animation:slideInModal .4s ease-out}.notification-modal{border:1px solid rgba(16,185,129,.2)}@keyframes slideInModal{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.install-modal-close,.notification-modal-close{position:absolute;top:20px;right:20px;background:#6b72801a;border:none;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#6b7280;transition:all .3s ease;z-index:10}.install-modal-close:hover,.notification-modal-close:hover{background:#6b728033;color:#374151;transform:rotate(90deg)}.install-modal-content,.notification-modal-content{padding:40px 32px 32px;text-align:center}.install-modal-icon{width:80px;height:80px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;color:#fff;box-shadow:0 8px 32px #667eea4d;animation:iconPulse 2s ease-in-out infinite}.notification-modal-icon{width:80px;height:80px;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;color:#fff;box-shadow:0 8px 32px #10b9814d;animation:iconPulse 2s ease-in-out infinite}@keyframes iconPulse{0%,to{transform:scale(1);box-shadow:0 8px 32px #667eea4d}50%{transform:scale(1.05);box-shadow:0 12px 40px #667eea66}}.notification-modal-icon{animation:iconPulseGreen 2s ease-in-out infinite}@keyframes iconPulseGreen{0%,to{transform:scale(1);box-shadow:0 8px 32px #10b9814d}50%{transform:scale(1.05);box-shadow:0 12px 40px #10b98166}}.install-modal-title,.notification-modal-title{font-size:1.75rem;font-weight:700;color:#1f2937;margin:0 0 16px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.notification-modal-title{background:linear-gradient(135deg,#10b981,#059669);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.install-modal-description,.notification-modal-description{font-size:1.1rem;color:#6b7280;margin:0 0 32px;line-height:1.6}.install-modal-features,.notification-modal-features{display:flex;flex-direction:column;gap:16px;margin-bottom:32px;text-align:left}.install-feature,.notification-feature{display:flex;align-items:center;gap:16px;padding:16px;background:#667eea0d;border-radius:12px;border:1px solid rgba(102,126,234,.1);transition:all .3s ease}.notification-feature{background:#10b9810d;border:1px solid rgba(16,185,129,.1)}.install-feature:hover,.notification-feature:hover{background:#667eea14;transform:translate(4px)}.notification-feature:hover{background:#10b98114}.install-feature-icon,.notification-feature-icon{width:24px;height:24px;color:#667eea;flex-shrink:0}.notification-feature-icon{color:#10b981}.install-feature span,.notification-feature span{font-weight:500;color:#374151;font-size:1rem}.install-instructions{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:16px;padding:20px;margin:24px 0;text-align:left}.install-instructions h3{color:#92400e;font-size:1.2rem;font-weight:600;margin:0 0 16px;text-align:center}.install-steps{display:flex;flex-direction:column;gap:12px}.install-step{display:flex;align-items:center;gap:12px;padding:12px;background:#fff9;border-radius:8px;border:1px solid rgba(245,158,11,.2)}.step-icon{width:20px;height:20px;color:#d97706;flex-shrink:0}.install-step span{color:#92400e;font-weight:500;font-size:.95rem}.install-modal-actions,.notification-modal-actions{display:flex;flex-direction:column;gap:12px}.install-btn-primary,.notification-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:16px 24px;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 16px #667eea4d;position:relative;overflow:hidden}.notification-btn-primary{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 16px #10b9814d}.install-btn-primary:before,.notification-btn-primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.install-btn-primary:hover:before,.notification-btn-primary:hover:before{left:100%}.install-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #667eea66}.notification-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #10b98166}.notification-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.install-btn-secondary,.notification-btn-secondary{background:transparent;color:#6b7280;border:2px solid #e5e7eb;padding:12px 24px;border-radius:12px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease}.install-btn-secondary:hover,.notification-btn-secondary:hover{color:#374151;border-color:#d1d5db;background:#6b72800d}@media (max-width: 640px){.install-modal,.notification-modal{margin:16px;width:calc(100% - 32px)}.install-modal-content,.notification-modal-content{padding:32px 24px 24px}.install-modal-title,.notification-modal-title{font-size:1.5rem}.install-modal-description,.notification-modal-description{font-size:1rem}.install-modal-features,.notification-modal-features{gap:12px}.install-feature,.notification-feature{padding:12px}.install-feature span,.notification-feature span{font-size:.9rem}.install-instructions{padding:16px;margin:20px 0}.install-instructions h3{font-size:1.1rem}.install-step span{font-size:.9rem}}.install-prompt,.notification-prompt{position:fixed;z-index:1000;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 25px #00000026;padding:16px;max-width:320px;animation:slideIn .3s ease-out}.install-prompt{bottom:16px;right:16px}.notification-prompt{top:16px;right:16px}@media (max-width: 768px){.install-prompt,.notification-prompt{left:16px;right:16px;max-width:none}.install-prompt{bottom:16px}.notification-prompt{top:16px}}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.prompt-content{display:flex;align-items:flex-start;gap:12px}.prompt-icon{flex-shrink:0;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center}.prompt-icon.install{background-color:#dbeafe}.prompt-icon.notification{background-color:#dcfce7}.prompt-text{flex:1}.prompt-title{font-weight:600;color:#111827;font-size:14px;margin:0 0 4px}.prompt-description{color:#6b7280;font-size:12px;margin:0 0 12px;line-height:1.4}.prompt-actions{display:flex;gap:8px}.prompt-btn{padding:6px 12px;border-radius:6px;font-size:12px;font-weight:500;border:none;cursor:pointer;transition:all .2s ease}.prompt-btn.primary{background-color:#2563eb;color:#fff}.prompt-btn.primary:hover{background-color:#1d4ed8}.prompt-btn.primary.green{background-color:#16a34a}.prompt-btn.primary.green:hover{background-color:#15803d}.prompt-btn.secondary{background-color:transparent;color:#6b7280}.prompt-btn.secondary:hover{color:#374151}.prompt-btn:disabled{opacity:.5;cursor:not-allowed}.prompt-close{flex-shrink:0;background:none;border:none;color:#9ca3af;cursor:pointer;padding:4px;border-radius:4px;transition:color .2s ease}.prompt-close:hover{color:#6b7280}
