*{box-sizing:border-box;margin:0;padding:0}body{background:linear-gradient(135deg,#2e7d32,#1b5e20 50%,#0d47a1);color:#333;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh}.card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:20px;box-shadow:0 8px 32px #00000026;margin-bottom:24px;padding:28px;transition:transform .3s ease,box-shadow .3s ease}.card:hover{box-shadow:0 12px 40px #0003;transform:translateY(-2px)}.btn{background:linear-gradient(135deg,#4caf50,#45a049);border-radius:50px;box-shadow:0 4px 15px #4caf504d;font-size:16px;letter-spacing:.5px;padding:14px 28px;text-transform:uppercase;transition:all .3s ease}.btn:hover{background:linear-gradient(135deg,#45a049,#388e3c);box-shadow:0 6px 20px #4caf5066;transform:translateY(-2px)}.btn:disabled{background:#ccc;box-shadow:none;cursor:not-allowed;transform:none}.btn-secondary{background:linear-gradient(135deg,#ff9800,#f57c00);box-shadow:0 4px 15px #ff98004d}.btn-secondary:hover{background:linear-gradient(135deg,#f57c00,#e65100);box-shadow:0 6px 20px #ff980066}.form-group{margin-bottom:24px}.form-group label{color:#2e7d32;font-size:16px;font-weight:700;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.form-group input,.form-group select{background:#ffffffe6;border:2px solid #e8f5e8;border-radius:12px;padding:16px;transition:all .3s ease}.form-group input:focus,.form-group select:focus{border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a;transform:translateY(-1px)}.rating-stars{gap:12px;margin-top:12px}.star{color:#ddd;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));font-size:28px;transition:all .3s ease}.star:hover{transform:scale(1.1)}.star.active{color:gold;filter:drop-shadow(0 2px 8px rgba(255,215,0,.5))}.player-list{grid-gap:16px;display:grid;gap:16px;margin-top:24px}.player-item{background:linear-gradient(135deg,#f8fff8,#e8f5e8);border-left:6px solid #4caf50;border-radius:16px;box-shadow:0 4px 15px #00000014;padding:20px;transition:all .3s ease}.player-item:hover{box-shadow:0 6px 20px #0000001f;transform:translateX(4px)}.player-name{color:#2e7d32;font-size:18px}.player-details{color:#666;font-weight:500}.team{background:linear-gradient(135deg,#f0f8ff,#e3f2fd);border:2px solid #e3f2fd;border-radius:20px;box-shadow:0 6px 20px #0000001a;padding:24px}.team-title{border-bottom:3px solid #4caf50;color:#1976d2;font-size:20px;letter-spacing:1px;margin-bottom:20px;text-transform:uppercase}.export-text{background:#f8fff8;border:2px solid #e8f5e8;border-radius:16px;box-shadow:inset 0 2px 8px #0000000d;font-family:Courier New,monospace;font-size:14px;line-height:1.6;margin-top:20px;padding:20px;white-space:pre-wrap}.header{color:#fff;margin-bottom:40px;text-align:center;text-shadow:0 4px 8px #0000004d}.header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#e8f5e8);-webkit-background-clip:text;background-clip:text;font-size:3.5rem;font-weight:800;margin-bottom:16px}.header p{font-size:1.4rem;font-weight:500;opacity:.95}.link-display{background:linear-gradient(135deg,#e8f5e8,#f1f8e9);border:2px dashed #4caf50;border-radius:16px;box-shadow:0 4px 15px #4caf501a;margin:24px 0;padding:20px;text-align:center}.link-display a{color:#2e7d32;font-size:16px;font-weight:700;text-decoration:none;transition:color .3s ease;word-break:break-all}.link-display a:hover{color:#1b5e20;text-decoration:underline}.cupo-ocupado{align-items:center;background:linear-gradient(135deg,#e8f5e8,#c8e6c9);border:2px solid #4caf50;border-radius:16px;box-shadow:0 4px 15px #4caf5026;display:flex;gap:16px;padding:16px;transition:all .3s ease}.cupo-ocupado:hover{box-shadow:0 6px 20px #4caf5040;transform:translateY(-2px)}.cupo-disponible{background:linear-gradient(135deg,#f5f5f5,#eee);border:2px dashed #bdbdbd;border-radius:16px;gap:16px;opacity:.8;transition:all .3s ease}.cupo-disponible:hover{border-color:#9e9e9e;opacity:1}.numero-cupo{box-shadow:0 2px 8px #0003;color:#fff}.numero-ocupado{background:linear-gradient(135deg,#4caf50,#45a049)}.numero-disponible{background:linear-gradient(135deg,#9e9e9e,#757575)}.badge-posicion{border-radius:20px;box-shadow:0 2px 8px #0003;font-size:11px;padding:6px 12px}.badge-posicion,.resumen-cupos{letter-spacing:.5px;text-transform:uppercase}.resumen-cupos{border-radius:16px;box-shadow:0 4px 15px #0000001a;font-size:16px;font-weight:700;margin-top:20px;padding:16px;text-align:center}.resumen-completo{background:linear-gradient(135deg,#e8f5e8,#c8e6c9);border:2px solid #4caf50;color:#2e7d32}.resumen-disponible{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:2px solid #2196f3;color:#1976d2}.team.team-green{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border:2px solid #4caf50}.team.team-blue{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:2px solid #1976d2}@media (max-width:768px){.teams-container{grid-template-columns:1fr}.container{padding:12px}.header h1{font-size:2.5rem}.card{padding:20px}.btn{font-size:14px;padding:12px 24px}}body{background:#181a1b;color:#fff;font-family:Montserrat,Arial,sans-serif}.fifa-title,h1,h2,h3,h4,h5,h6{color:#fff;font-family:Bebas Neue,Oswald,Montserrat,Arial,sans-serif;font-weight:700;letter-spacing:.08em;margin-top:0;text-transform:uppercase}.text-link,a{color:#00e676;text-decoration:none;transition:color .2s}.text-link:hover,a:hover{color:#1de9b6}.card,.surface{background:#23272a;border-radius:18px;box-shadow:0 2px 8px #00000040;color:#fff;padding:20px}input,select,textarea{background:#23272a;border:1px solid #33383b;border-radius:10px;color:#fff;font-family:Montserrat,Arial,sans-serif;font-size:1rem;outline:none;padding:10px 14px;transition:border .2s}input:focus,select:focus,textarea:focus{border:1.5px solid #00e676}.fifa-btn,button{background:#00e676;border:none;border-radius:12px;box-shadow:0 2px 8px #00000026;color:#181a1b;cursor:pointer;font-family:Bebas Neue,Oswald,Montserrat,Arial,sans-serif;font-size:1.1rem;font-weight:700;letter-spacing:.08em;padding:12px 28px;transition:background .2s,color .2s}.fifa-btn:hover,button:hover{background:#1de9b6;color:#181a1b}.google-btn{align-items:center!important;background:#4285f4!important;border:none!important;border-radius:12px!important;box-shadow:0 2px 8px #00000026!important;color:#fff!important;cursor:pointer!important;display:flex!important;font-family:Montserrat,Arial,sans-serif!important;font-size:1rem!important;font-weight:600!important;gap:12px!important;justify-content:center!important;letter-spacing:normal!important;padding:12px 28px!important;transition:all .2s ease!important;width:100%!important}.google-btn:hover{background:#3367d6!important;box-shadow:0 4px 12px #4285f44d!important;color:#fff!important;transform:translateY(-1px)!important}.google-btn:disabled{background:#ccc!important;box-shadow:none!important;color:#666!important;cursor:not-allowed!important;transform:none!important}.dev-btn{align-items:center!important;background:#ff6b35!important;border:none!important;border-radius:12px!important;box-shadow:0 2px 8px #00000026!important;color:#fff!important;cursor:pointer!important;display:flex!important;font-family:Montserrat,Arial,sans-serif!important;font-size:.9rem!important;font-weight:600!important;gap:12px!important;justify-content:center!important;letter-spacing:normal!important;padding:8px 28px!important;transition:all .2s ease!important;width:100%!important}.dev-btn:hover{background:#e55a2b!important;box-shadow:0 4px 12px #ff6b354d!important;color:#fff!important;transform:translateY(-1px)!important}@media (max-width:768px){.google-btn{font-size:1.08rem!important;padding:12px 0!important}.dev-btn{font-size:.95rem!important;padding:8px 0!important}}::-webkit-scrollbar{background:#23272a;width:8px}::-webkit-scrollbar-thumb{background:#33383b;border-radius:8px}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{background-color:#282c34;color:#fff;padding:20px}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.tooltip{opacity:0;transition:opacity .3s ease}.tooltip:hover,button:hover+.tooltip,div:hover .tooltip{opacity:1}@keyframes slideOutRight{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(100%)}}@keyframes slideInScale{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}:root{--primary-color:#2563eb;--primary-hover:#1d4ed8;--secondary-color:#64748b;--secondary-hover:#475569;--success-color:#10b981;--success-hover:#059669;--danger-color:#ef4444;--danger-hover:#dc2626;--warning-color:#f59e0b;--warning-hover:#d97706;--background-color:#f8fafc;--surface-color:#fff;--border-color:#e2e8f0;--border-hover:#cbd5e1;--text-primary:#1e293b;--text-secondary:#64748b;--text-muted:#94a3b8;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--radius-sm:6px;--radius-md:8px;--radius-lg:12px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;background-color:var(--background-color);color:#1e293b;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;margin:0;padding:0}@media (max-width:480px){:root{--container-padding:12px;--card-padding:16px;--button-padding:10px 16px;--font-size-small:12px;--font-size-base:14px;--font-size-large:16px}}@media (min-width:481px) and (max-width:768px){:root{--container-padding:16px;--card-padding:20px;--button-padding:12px 20px;--font-size-small:13px;--font-size-base:15px;--font-size-large:18px}}@media (min-width:769px){:root{--container-padding:20px;--card-padding:24px;--button-padding:12px 24px;--font-size-small:14px;--font-size-base:16px;--font-size-large:20px}}.container{margin:0 auto;max-width:1200px;padding:20px}.card{background:#fff;background:var(--surface-color);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;box-shadow:var(--shadow-md);margin-bottom:16px;padding:var(--card-padding);transition:all .2s ease}@media (max-width:768px){.card{border-radius:8px;border-radius:var(--radius-md);margin-bottom:12px}.card:last-child{margin-bottom:0}}.card:hover{border-color:#cbd5e1;border-color:var(--border-hover);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;box-shadow:var(--shadow-lg)}.btn{align-items:center;background:#2563eb;background:var(--primary-color);border:none;border-radius:8px;border-radius:var(--radius-md);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#fff;cursor:pointer;display:inline-flex;font-size:var(--font-size-base);font-weight:600;gap:8px;justify-content:center;min-height:44px;padding:var(--button-padding);text-decoration:none;transition:all .2s ease;white-space:nowrap}@media (max-width:768px){.btn{font-size:16px;margin-bottom:8px;width:100%}.btn:last-child{margin-bottom:0}}.btn:hover{background:#1d4ed8;background:var(--primary-hover);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-secondary{background:#64748b;background:var(--secondary-color);color:#fff}.btn-secondary:hover{background:#475569;background:var(--secondary-hover)}.btn-success{background:#10b981;background:var(--success-color)}.btn-success:hover{background:#059669;background:var(--success-hover)}.btn-danger{background:#ef4444;background:var(--danger-color)}.btn-danger:hover{background:#dc2626;background:var(--danger-hover)}.form-group{margin-bottom:20px}@media (max-width:768px){.form-group{margin-bottom:16px}}.form-group label{color:#1e293b;color:var(--text-primary);display:block;font-size:14px;font-weight:600;margin-bottom:8px}.form-group input,.form-group select{background:#fff;background:var(--surface-color);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius-md);color:#1e293b;color:var(--text-primary);font-size:16px;min-height:44px;padding:12px 16px;transition:all .2s ease;width:100%}@media (max-width:768px){.form-group input,.form-group select{font-size:16px;padding:14px 16px}}.form-group input:focus,.form-group select:focus{border-color:#2563eb;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a;outline:none}.player-list{display:flex;flex-direction:column;gap:12px}.player-item{background:#fff;background:var(--surface-color);border:2px solid #e2e8f0;border:2px solid var(--border-color);border-radius:8px;border-radius:var(--radius-md);cursor:grab;padding:16px;transition:all .2s ease}.player-item:hover{border-color:#2563eb;border-color:var(--primary-color);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;box-shadow:var(--shadow-md)}.player-item:active{cursor:grabbing}.player-name{color:#1e293b;color:var(--text-primary);font-size:16px;font-weight:700;margin-bottom:4px}.player-details{align-items:center;color:#64748b;color:var(--text-secondary);display:flex;font-size:14px;gap:8px}.teams-container{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;margin-top:24px}@media (max-width:768px){.teams-container{gap:16px;grid-template-columns:1fr}}.team{background:#fff;background:var(--surface-color);border:2px solid #e2e8f0;border:2px solid var(--border-color);border-radius:12px;border-radius:var(--radius-lg);min-height:400px;padding:20px}.team-green{background:linear-gradient(135deg,#fff,#f0f9f0);background:linear-gradient(135deg,var(--surface-color) 0,#f0f9f0 100%);border-color:#10b981;border-color:var(--success-color)}.team-blue{background:linear-gradient(135deg,#fff,#f0f6ff);background:linear-gradient(135deg,var(--surface-color) 0,#f0f6ff 100%);border-color:#2563eb;border-color:var(--primary-color)}.team-title{border-bottom:2px solid #e2e8f0;border-bottom:2px solid var(--border-color);color:#1e293b;color:var(--text-primary);font-size:18px;font-weight:700;margin-bottom:16px;padding-bottom:12px;text-align:center}.cupo-disponible{align-items:center;background:#f8fafc;border:2px dashed #e2e8f0;border:2px dashed var(--border-color);border-radius:8px;border-radius:var(--radius-md);color:#94a3b8;color:var(--text-muted);display:flex;gap:12px;padding:16px;transition:all .2s ease}.cupo-disponible:hover{background:#f0f6ff;border-color:#2563eb;border-color:var(--primary-color)}.numero-cupo{align-items:center;border-radius:50%;display:flex;font-size:14px;font-weight:700;height:32px;justify-content:center;width:32px}.numero-disponible{background:#e2e8f0;background:var(--border-color);color:#94a3b8;color:var(--text-muted)}.badge-posicion{align-items:center;border-radius:50%;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#fff;display:flex;font-size:16px;font-weight:700;height:32px;justify-content:center;text-shadow:0 1px 2px #0003;width:32px}.rating-stars{display:flex;gap:4px;margin-top:8px}.star{color:#e2e8f0;color:var(--border-color);cursor:pointer;font-size:20px;transition:color .2s ease}.star.active{color:#f59e0b;color:var(--warning-color)}.star:hover{color:#d97706;color:var(--warning-hover)}h1,h2,h3{color:#1e293b;color:var(--text-primary);margin-bottom:16px}h1{font-size:28px;font-weight:800}h2{font-size:22px;font-weight:700}h3{font-size:18px;font-weight:600}a{color:#2563eb;color:var(--primary-color);font-weight:500;text-decoration:none}a:hover{color:#1d4ed8;color:var(--primary-hover);text-decoration:underline}.fifa-card-outer{align-items:center;background:none;box-sizing:border-box;display:flex;justify-content:center;margin:0 auto;max-width:270px;min-height:430px;padding:0 10px;width:100%}.fifa-card{background:#1a1a1a;border-radius:20px;box-shadow:0 4px 24px #00000080;color:#fff;display:block;font-family:Saira Semi Condensed,Montserrat,Arial,sans-serif;height:430px;margin:auto;max-width:270px;overflow:hidden;position:relative;width:100%}#card-inner{background:#1a1a1a;height:100%}#card-inner,#card-top{left:0;position:absolute;top:0;width:100%}#card-top{background:linear-gradient(135deg,#1a1a1a,#2d2d2d);height:50%;overflow:hidden}.backfont{bottom:-22px;color:#00e676;font-size:118px;font-style:italic;font-weight:700;letter-spacing:-5px;line-height:1;opacity:.15;pointer-events:none}.backfont,.info{left:0;position:absolute}.info{bottom:0;box-sizing:border-box;height:75%;padding:0 20px;text-align:center;text-transform:uppercase;width:30%;z-index:3}.info .value{font-size:40px}.info .position,.info .value{color:#00e676;font-weight:700}.info .position{border-bottom:2px solid #00e676;font-size:20px;margin-bottom:10px;padding-bottom:5px}.image{align-items:flex-end;background-position:bottom;background-repeat:no-repeat;background-size:contain;bottom:0;display:flex;height:75%;justify-content:center;position:absolute;right:10px;width:70%;z-index:2}.fifa-card-default-avatar,.fifa-card-profile-image{background-position:50%;background-size:cover;border:3px solid #00e676;border-radius:50%;box-shadow:0 4px 12px #00e6764d;height:120px;width:120px}.fifa-card-default-avatar{filter:grayscale(100%) brightness(.7)}#card-bottom{background:linear-gradient(135deg,#1a1a1a,#2d2d2d);border-top:3px solid #00e676;bottom:0;display:flex;flex-direction:column;height:50%;justify-content:flex-start;left:0;overflow:hidden;padding-bottom:8px;position:absolute;width:100%}#card-bottom .name{color:#fff;font-size:18px;font-weight:700;letter-spacing:.5px;line-height:1.1;margin:4px 0 8px;text-align:center;text-transform:uppercase}#card-bottom .stats{align-items:flex-start;display:flex;gap:15px;justify-content:center;margin:0 15px;padding-top:5px;position:relative}#card-bottom .stats div{display:inline-block;font-size:16px;text-transform:none;vertical-align:top;width:48%}#card-bottom .stats ul{list-style:none;margin:0;padding:0}#card-bottom .stats li{align-items:center;color:#00e676;display:flex;font-weight:700;margin:0 0 4px;padding:0;position:relative}#card-bottom .stats li span:first-child{color:#00e676;font-size:24px;font-weight:800;text-align:left;width:60px}#card-bottom .stats li span:last-child{color:#ccc;font-size:13px;font-weight:600;margin-left:8px}@media (max-width:400px){.fifa-card-outer{max-width:100%;min-height:340px;padding:0 5px}#card,.fifa-card{height:340px;width:min(280px,calc(100vw - 20px))}#card-top{height:50%}#card-bottom{height:50%;padding-bottom:4px}#card-bottom .name{font-size:14px;line-height:1;margin:2px 0 6px}#card-bottom .stats{gap:12px;margin:0 12px;padding-top:8px}#card-bottom .stats div{font-size:9px;width:45%}.fifa-card-default-avatar,.fifa-card-profile-image{border-width:2px;height:80px;width:80px}.info .value{font-size:24px}.info .position{font-size:12px;margin-bottom:6px}.preferred-foot{font-size:11px!important;margin-top:2px!important}#card-bottom .stats li{margin-bottom:2px}#card-bottom .stats li span:first-child{font-size:18px;font-weight:800;width:45px}#card-bottom .stats li span:last-child{font-size:11px;margin-left:6px}.backfont{bottom:-15px;font-size:80px}}@media (max-width:320px){.fifa-card-outer{max-width:100%;min-height:300px;padding:0 5px}#card,.fifa-card{height:300px;width:min(260px,calc(100vw - 15px))}#card-bottom .name{font-size:12px;margin:1px 0 4px}.fifa-card-default-avatar,.fifa-card-profile-image{border-width:2px;height:60px;width:60px}.info .value{font-size:20px}.info .position{font-size:10px}#card-bottom .stats li span:first-child{font-size:16px;font-weight:800;width:35px}#card-bottom .stats li span:last-child{font-size:9px;margin-left:5px}.backfont{bottom:-10px;font-size:60px}}@media (max-width:280px){.fifa-card-outer{max-width:100%;min-height:280px;padding:0 2px}#card,.fifa-card{height:280px;width:calc(100vw - 10px)}.fifa-card-default-avatar,.fifa-card-profile-image{border-width:1px;height:50px;width:50px}.info .value{font-size:18px}.info .position{font-size:9px}#card-bottom .name{font-size:11px;margin:1px 0 3px}#card-bottom .stats{gap:8px;margin:0 8px;padding-top:4px}#card-bottom .stats li span:first-child{font-size:14px;font-weight:800;width:30px}#card-bottom .stats li span:last-child{font-size:8px;margin-left:4px}.backfont{bottom:-8px;font-size:50px}}.profile-page{background-color:#181a1b;color:#fff;font-family:Montserrat,Arial,sans-serif;min-height:100vh}.profile-error,.profile-loading{align-items:center;background-color:#181a1b;color:#fff;display:flex;justify-content:center;min-height:100vh}.profile-title-container{margin:30px 20px 30px 110px}.profile-title-container,.profile-title-container-mobile{align-items:center;display:flex;gap:12px;justify-content:center}.profile-title-container-mobile{margin:20px 10px}.profile-title{font-size:32px}.profile-title,.profile-title-mobile{color:#fff;font-weight:600;margin:0;text-align:center}.profile-title-mobile{font-size:24px}.profile-content{margin:20px 20px 20px 90px;padding:0 20px}.profile-content-mobile{margin:60px 0 10px;padding:0 6px}.profile-main-layout{display:flex;gap:24px;margin-bottom:30px;min-height:500px}.profile-main-column{align-items:flex-start;display:flex;flex:1 1;justify-content:center;min-height:500px}.profile-two-column-layout{display:flex;gap:24px;margin-bottom:20px}.profile-column-left{flex:2 1}.profile-column-right{flex:1 1}.profile-section-mobile{margin-bottom:20px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.match-join-history-toggle{margin:20px 0;text-align:center}.admin-only-button{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px solid #17a2b8;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#17a2b8;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .3s ease}.admin-only-button:hover{background:linear-gradient(135deg,#17a2b8,#138496);box-shadow:0 4px 8px #17a2b84d;color:#fff;transform:translateY(-2px)}.admin-only-button:active{transform:translateY(0)}.join-history-modal-overlay{align-items:center;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.join-history-modal{animation:slideUp .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:80vh;max-width:600px;overflow:hidden;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.join-history-modal-header{align-items:flex-start;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;gap:16px;justify-content:space-between;padding:24px}.modal-title-section h3{align-items:center;display:flex;font-size:1.5rem;font-weight:600;gap:10px;margin:0}.match-name{font-size:.95rem;font-weight:400;margin:8px 0 0;opacity:.9}.modal-close-button{align-items:center;background:#fff3;border:1px solid #ffffff4d;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:40px;justify-content:center;transition:all .3s ease;width:40px}.modal-close-button:hover{background:#ffffff4d;transform:scale(1.1)}.join-history-modal-content{flex:1 1;overflow-y:auto;padding:0}.join-history-summary{grid-gap:20px;background:#f8f9fa;border-bottom:1px solid #e9ecef;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));padding:24px}.summary-item{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:20px;text-align:center;transition:transform .2s ease}.summary-item:hover{transform:translateY(-2px)}.summary-label{color:#6c757d;display:block;font-size:.85rem;font-weight:500;margin-bottom:8px}.summary-value{color:#495057;display:block;font-size:2rem;font-weight:700}.join-history-table-container{border:1px solid #e9ecef;border-radius:8px;margin:0;overflow-x:auto}.join-history-table{background:#fff;border-collapse:collapse;font-size:14px;width:100%}.join-history-table thead{background:#f8f9fa;border-bottom:2px solid #dee2e6}.join-history-table th{border-bottom:1px solid #dee2e6;color:#495057;font-weight:600;padding:12px 16px;text-align:left;white-space:nowrap}.join-history-table th:last-child{text-align:right}.join-history-table td{border-bottom:1px solid #f1f3f4;padding:12px 16px;vertical-align:middle}.join-history-row:hover{background-color:#f8f9fa}.join-history-row:last-child td{border-bottom:none}.player-cell{min-width:200px;width:70%}.player-details-table{display:flex;flex-direction:column;gap:2px;min-width:0}.player-name-table{color:#212529;font-size:.85rem;font-weight:500}.player-name-table,.user-email-table{margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-email-table{color:#6c757d;font-size:.7rem}.time-cell{min-width:120px;text-align:right;width:30%}.join-time-table{color:#495057;font-size:.8rem;font-weight:500;white-space:nowrap}.modal-error,.modal-loading{padding:60px 24px;text-align:center}.modal-loading p{color:#6c757d;font-size:1rem;margin-top:16px}.modal-error .error-text{color:#dc3545;font-size:1rem;margin-bottom:16px}.no-history{color:#6c757d;padding:60px 24px;text-align:center}.no-history-icon{font-size:3rem;margin-bottom:16px;opacity:.5}.no-history p{font-size:1.1rem;font-weight:500;margin-bottom:8px}.no-history small{font-size:.9rem;opacity:.8}@media (max-width:768px){.join-history-modal{margin:10px;max-height:90vh}.join-history-modal-header{align-items:flex-start;flex-direction:row;gap:12px;justify-content:space-between;padding:16px 20px}.modal-title-section{flex:1 1;text-align:left}.modal-title-section h3{font-size:1.2rem;margin:0 0 4px}.match-name{font-size:.9rem;margin:0;opacity:.9}.modal-close-button{flex-shrink:0;font-size:16px;height:36px;width:36px}.join-history-summary{gap:16px;grid-template-columns:1fr;padding:20px}.join-history-table-container{border-radius:8px;margin:0;overflow-x:auto}.join-history-table{font-size:11px;min-width:100%}.join-history-table td,.join-history-table th{padding:6px 8px}.join-history-table td:first-child,.join-history-table th:first-child{padding-left:12px}.join-history-table td:last-child,.join-history-table th:last-child{padding-right:12px}.player-cell{max-width:65%;min-width:100px;width:65%}.player-name-table{font-size:.75rem}.user-email-table{font-size:.6rem}.time-cell{max-width:35%;min-width:70px;width:35%}.join-time-table{font-size:.7rem}}@media (max-width:480px){.join-history-modal{border-radius:12px;margin:5px;width:calc(100% - 10px)}.join-history-modal-header{align-items:flex-start;flex-direction:row;gap:8px;justify-content:space-between;padding:12px}.modal-title-section{flex:1 1;text-align:left}.modal-title-section h3{font-size:1rem;margin:0 0 2px}.match-name{font-size:.8rem;margin:0;opacity:.9}.modal-close-button{flex-shrink:0;font-size:14px;height:32px;width:32px}.join-history-modal-content,.join-history-summary{padding:12px}.summary-item{padding:16px}.summary-value{font-size:1.5rem}.join-history-table-container{overflow-x:auto}.join-history-table{font-size:10px;min-width:100%}.join-history-table td,.join-history-table th{padding:4px 6px}.join-history-table td:first-child,.join-history-table th:first-child{padding-left:12px}.join-history-table td:last-child,.join-history-table th:last-child{padding-right:12px}.player-cell{max-width:60%;min-width:80px;width:60%}.player-name-table{font-size:.7rem}.user-email-table{font-size:.55rem}.time-cell{max-width:40%;min-width:60px;width:40%}.join-time-table{font-size:.7rem}}.tactical-field-container{background-color:#23272a;border:1px solid #33383b;border-radius:18px;margin:20px 0;padding:20px}.tactical-field-container.mobile{padding:15px 10px}.formation-selectors{display:flex;gap:20px;justify-content:space-between;margin-bottom:20px}.formation-selector{flex:1 1;text-align:center}.formation-selector label{color:#fff;display:block;font-size:16px;font-weight:600;margin-bottom:8px}.formation-selector select{background-color:#2c2f33;border:2px solid #4caf50;border-radius:12px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;min-width:180px;padding:10px 15px}.formation-selector select:focus{border-color:#00e676;box-shadow:0 0 0 2px #00e67633;outline:none}.tactical-field{-webkit-backface-visibility:hidden;backface-visibility:hidden;background:linear-gradient(135deg,#2d5a2d,#4a7c4a 50%,#2d5a2d);border:3px solid #fff;border-radius:8px;contain:none;cursor:crosshair;height:0;isolation:auto;margin-bottom:40px;overflow:visible;padding-bottom:calc(45% + 20px);padding-top:20px;position:relative;transform:translateZ(0);width:100%;will-change:auto}.tactical-field-container.mobile .tactical-field{padding-bottom:150%}.field-lines{left:0;pointer-events:none;width:100%}.center-line,.field-lines{height:100%;position:absolute;top:0}.center-line{background-color:#fff;left:50%;transform:translateX(-50%);width:2px}.field-half{height:100%;pointer-events:none;position:absolute;top:0;width:50%}.field-half-left{background-color:#00e6760d;border-right:2px dashed #00e6764d;left:0}.field-half-right{background-color:#2196f30d;border-left:2px dashed #2196f34d;right:0}.center-circle{border:2px solid #fff;height:40px;width:40px}.center-circle,.center-circle:after{border-radius:50%;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.center-circle:after{background-color:#fff;content:"";height:6px;width:6px}.penalty-area{background-color:#ffffff0d;border:2px solid #fff;height:40%;position:absolute;width:20%}.penalty-area-left{border-bottom-right-radius:0;border-right:none;border-top-right-radius:0;left:0;top:30%}.penalty-area-right{border-bottom-left-radius:0;border-left:none;border-top-left-radius:0;right:0;top:30%}.penalty-area-left:before{right:0}.penalty-area-left:before,.penalty-area-right:before{background-color:#fff;content:"";height:100%;position:absolute;top:0;width:2px}.penalty-area-right:before{left:0}.goal-area{background-color:#ffffff1a;border:2px solid #fff;height:20%;position:absolute;width:8%}.goal-area-left{border-bottom-right-radius:0;border-top-right-radius:0;left:0;top:40%}.goal-area-right{border-bottom-left-radius:0;border-top-left-radius:0;right:0;top:40%}.penalty-spot{background-color:#fff;border-radius:50%;height:8px;position:absolute;top:50%;transform:translateY(-50%);width:8px}.penalty-spot-left{left:12%}.penalty-spot-right{right:12%}.corner-arc{background-color:initial;border:2px solid #fff;border-radius:50%;height:20px;position:absolute;width:20px}.corner-arc-top-left{border-top-left-radius:20px}.corner-arc-top-right{border-top-right-radius:20px}.corner-arc-bottom-left{border-bottom-left-radius:20px}.corner-arc-bottom-right{border-bottom-right-radius:20px}.tactical-player{align-items:center;-webkit-backface-visibility:hidden;backface-visibility:hidden;border-radius:50%;box-shadow:0 2px 8px #0000004d;contain:none;cursor:grab;display:flex;flex-direction:column;height:50px;isolation:auto;justify-content:center;padding-bottom:25px;position:absolute;transform:translate(-50%,-50%);transform-origin:center center;transition:all .2s ease;width:50px;will-change:transform;z-index:10}.tactical-player:hover{box-shadow:0 4px 12px #0006;transform:translate(-50%,-50%) scale(1.1);transform-origin:center center}.tactical-player:active{cursor:grabbing}.tactical-player .player-number{align-items:center;display:flex;font-size:18px;font-weight:700;height:100%;justify-content:center;line-height:1;top:50%;transform:translate(-50%,-50%);width:100%}.tactical-player .player-name,.tactical-player .player-number{color:#fff;left:50%;position:absolute;text-shadow:1px 1px 2px #000c}.tactical-player .player-name{background-color:#000000e6;border:1px solid #fff3;border-radius:4px;display:block!important;font-size:12px;height:auto;line-height:1.2;margin-top:8px;max-width:80px;min-height:20px;min-width:-webkit-max-content;min-width:max-content;opacity:1!important;overflow:visible;padding:4px 8px;pointer-events:none;text-align:center;text-overflow:clip;top:100%;transform:translateX(-50%);visibility:visible!important;white-space:nowrap;z-index:1001}.field-legend{display:flex;gap:30px;justify-content:center;margin-top:20px}.legend-item{align-items:center;display:flex;gap:10px}.legend-color{border:2px solid #fff;border-radius:50%;height:20px;width:20px}.team1-color{background-color:#00e676}.team2-color{background-color:#2196f3}.legend-item span{color:#fff;font-size:14px;font-weight:600}@media (min-width:769px){.tactical-field-container.desktop{margin:20px 0;padding:20px}.tactical-field-container.desktop .tactical-field{margin-bottom:50px;padding-bottom:calc(45% + 30px)}.tactical-field-container.desktop .tactical-player{height:45px;padding-bottom:30px;width:45px;z-index:100}.tactical-field-container.desktop .tactical-player .player-number{font-size:16px;font-weight:700}.tactical-field-container.desktop .tactical-player .player-name{background-color:#000000e6;border:1px solid #fff3;display:block!important;font-size:11px;height:auto;margin-top:6px;max-width:none;min-height:20px;min-width:-webkit-max-content;min-width:max-content;opacity:1!important;padding:3px 6px;pointer-events:none;top:calc(100% + 2px);visibility:visible!important;z-index:1001}.tactical-field-container.desktop .tactical-player:hover .player-name{z-index:1002}}@media (max-width:768px){.tactical-field-container{margin:15px 0;padding:15px 10px}.formation-selector select{font-size:13px;min-width:150px}.tactical-player{height:40px;width:40px}.tactical-player .player-number{font-size:14px}.tactical-player .player-name{display:block!important;font-size:10px!important;margin-top:8px!important;max-width:70px!important;opacity:1!important;padding:3px 6px!important;visibility:visible!important}.center-circle{height:40px;width:40px}.center-circle:after{height:6px;width:6px}.field-legend{gap:20px}.legend-color{height:16px;width:16px}.legend-item span{font-size:13px}}@keyframes playerAppear{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.tactical-player{animation:playerAppear .3s ease-out}.tactical-field.dragging{cursor:grabbing}.tactical-player.dragging{opacity:.5;transform:translate(-50%,-50%) scale(1.2)}.tactical-field:hover{box-shadow:0 0 20px #ffffff1a}.export-button-container{display:flex;justify-content:center;margin-bottom:20px}.export-button{align-items:center;background:linear-gradient(135deg,#4caf50,#00e676);border:none;border-radius:25px;box-shadow:0 4px 15px #4caf504d;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;min-width:180px;padding:12px 24px;transition:all .3s ease}.export-button:disabled{background:linear-gradient(135deg,#666,#999);cursor:not-allowed;opacity:.7}.export-button:hover{background:linear-gradient(135deg,#00e676,#4caf50);box-shadow:0 6px 20px #4caf5066;transform:translateY(-2px)}.export-button:active{transform:translateY(0)}@media (max-width:768px){.formation-selector{margin-bottom:15px}.formation-selector label{font-size:14px;margin-bottom:6px}.formation-selector select{font-size:13px;min-width:140px;padding:8px 12px}.export-button{font-size:14px;padding:10px 20px}}.tactical-field-mobile-container{background-color:#23272a;border:1px solid #33383b;border-radius:18px;margin:15px 0;padding:15px 10px}.formation-selector-mobile{margin-bottom:15px;text-align:center}.team-selector-mobile{margin-bottom:15px}.team-selector-mobile label{color:#fff;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.team-buttons-mobile{display:flex;gap:10px;justify-content:center}.team-button-mobile{background-color:#2c2f33;border:2px solid #4caf50;border-radius:12px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .2s ease}.team-button-mobile.active,.team-button-mobile:hover{background-color:#4caf50;border-color:#00e676}.team-button-mobile.active{box-shadow:0 0 0 2px #00e67633}.formation-select-mobile{margin-top:15px}.formation-selector-mobile label{color:#fff;display:block;font-size:14px;font-weight:600;margin-bottom:6px}.formation-selector-mobile select{background-color:#2c2f33;border:2px solid #4caf50;border-radius:12px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;min-width:140px;padding:8px 12px}.formation-selector-mobile select:focus{border-color:#00e676;box-shadow:0 0 0 2px #00e67633;outline:none}.tactical-field-mobile{background:linear-gradient(135deg,#2d5a2d,#4a7c4a 50%,#2d5a2d);border:3px solid #fff;border-radius:8px;cursor:crosshair;height:0;overflow:hidden;padding-bottom:150%;position:relative;width:100%}.field-lines-mobile{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.center-line-mobile{background-color:#fff;height:2px;left:0;position:absolute;top:50%;transform:translateY(-50%);width:100%}.field-half-mobile{height:50%;left:0;pointer-events:none;position:absolute;width:100%}.field-half-top-mobile{background-color:#00e6760d;border-bottom:2px dashed #00e6764d;top:0}.field-half-bottom-mobile{background-color:#2196f30d;border-top:2px dashed #2196f34d;bottom:0}.center-circle-mobile{border:2px solid #fff;height:40px;width:40px}.center-circle-mobile,.center-circle-mobile:after{border-radius:50%;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.center-circle-mobile:after{background-color:#fff;content:"";height:6px;width:6px}.penalty-area-mobile{background-color:#ffffff0d;border:2px solid #fff;height:20%;position:absolute;width:40%}.penalty-area-top{border-bottom:none;border-top-left-radius:0;border-top-right-radius:0;left:30%;top:0}.penalty-area-bottom{border-bottom-left-radius:0;border-bottom-right-radius:0;border-top:none;bottom:0;left:30%}.penalty-area-top:before{bottom:0}.penalty-area-bottom:before,.penalty-area-top:before{background-color:#fff;content:"";height:2px;left:0;position:absolute;width:100%}.penalty-area-bottom:before{top:0}.goal-area-mobile{background-color:#ffffff1a;border:2px solid #fff;height:8%;position:absolute;width:20%}.goal-area-top{border-top-left-radius:0;border-top-right-radius:0;left:40%;top:0}.goal-area-bottom{border-bottom-left-radius:0;border-bottom-right-radius:0;bottom:0;left:40%}.penalty-spot-mobile{background-color:#fff;border-radius:50%;height:6px;left:50%;position:absolute;transform:translateX(-50%);width:6px}.penalty-spot-top{top:12%}.penalty-spot-bottom{bottom:12%}.corner-arc-mobile{background-color:initial;border:2px solid #fff;border-radius:50%;height:16px;position:absolute;width:16px}.corner-arc-top-left{border-bottom:none;border-right:none;border-top-left-radius:16px;left:0;top:0}.corner-arc-top-right{border-bottom:none;border-left:none;border-top-right-radius:16px;right:0;top:0}.corner-arc-bottom-left{border-bottom-left-radius:16px;border-right:none;border-top:none;bottom:0;left:0}.corner-arc-bottom-right{border-bottom-right-radius:16px;border-left:none;border-top:none;bottom:0;right:0}.tactical-player-mobile{align-items:center;border-radius:50%;box-shadow:0 2px 8px #0000004d;cursor:grab;display:flex;flex-direction:column;height:40px;justify-content:center;position:absolute;transform:translate(-50%,-50%);transition:all .2s ease;width:40px;z-index:10}.tactical-player-mobile:hover{box-shadow:0 4px 12px #0006;transform:translate(-50%,-50%) scale(1.1)}.tactical-player-mobile:active{cursor:grabbing}.tactical-player-mobile .player-number-mobile{align-items:center;color:#fff;display:flex;font-size:14px;font-weight:700;height:100%;justify-content:center;left:50%;line-height:1;position:absolute;text-shadow:1px 1px 2px #000c;top:50%;transform:translate(-50%,-50%);width:100%}.tactical-player-mobile .player-name-mobile{background-color:#000c;border-radius:4px;color:#fff;font-size:11px;left:50%;line-height:1.1;margin-top:6px;max-width:70px;overflow:hidden;padding:3px 6px;position:absolute;text-align:center;text-overflow:ellipsis;text-shadow:1px 1px 2px #000c;top:100%;transform:translateX(-50%);white-space:nowrap;z-index:1000}.field-legend-mobile{display:flex;gap:20px;justify-content:center;margin-top:15px}.legend-item-mobile{align-items:center;display:flex;gap:8px}.legend-color-mobile{border:2px solid #fff;border-radius:50%;height:16px;width:16px}.team1-color-mobile{background-color:#00e676}.team2-color-mobile{background-color:#2196f3}.legend-item-mobile span{color:#fff;font-size:13px;font-weight:600}@keyframes playerAppearMobile{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.tactical-player-mobile{animation:playerAppearMobile .3s ease-out}.tactical-field-mobile.dragging{cursor:grabbing}.tactical-player-mobile.dragging{opacity:.5;transform:translate(-50%,-50%) scale(1.2)}.tactical-field-mobile:hover{box-shadow:0 0 15px #ffffff1a}@media (max-width:480px){.tactical-field-mobile-container{padding:10px 8px}.formation-selector-mobile select{font-size:12px;min-width:120px;padding:6px 10px}.tactical-player-mobile{height:35px;width:35px}.tactical-player-mobile .player-number-mobile{font-size:12px}.tactical-player-mobile .player-name-mobile{font-size:9px;margin-top:6px;max-width:none;overflow:visible;padding:2px 5px;text-overflow:clip;white-space:normal}.center-circle-mobile{height:35px;width:35px}.center-circle-mobile:after{height:5px;width:5px}.field-legend-mobile{gap:15px}.legend-color-mobile{height:14px;width:14px}.legend-item-mobile span{font-size:12px}}.export-button-container-mobile{display:flex;justify-content:center;margin-bottom:15px}.export-button-mobile{align-items:center;background:linear-gradient(135deg,#4caf50,#00e676);border:none;border-radius:20px;box-shadow:0 3px 12px #4caf504d;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:6px;padding:10px 20px;transition:all .3s ease}.export-button-mobile:hover{background:linear-gradient(135deg,#00e676,#4caf50);box-shadow:0 4px 15px #4caf5066;transform:translateY(-1px)}.export-button-mobile:active{transform:translateY(0)}@media (max-width:480px){.export-button-mobile{font-size:13px;padding:8px 16px}}
/*# sourceMappingURL=main.a9233b74.css.map*/