*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh;overflow-x:hidden}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{margin:0 auto;max-width:1200px;padding:10px}.card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:16px;box-shadow:0 8px 32px #0000004d;margin-bottom:20px;padding:20px}.btn{-webkit-tap-highlight-color:transparent;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 15px #667eea66;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;touch-action:manipulation;transition:all .3s ease}.btn:hover{box-shadow:0 8px 25px #0003;transform:translateY(-2px)}.btn:active{transform:translateY(0)}.btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.input-group{margin-bottom:20px}.input-group label{font-size:14px;font-weight:600;margin-bottom:8px}.input-group input,.input-group select{appearance:none;background:#ffffff1a;border:2px solid #fff3;border-radius:12px;color:#fff;font-size:16px;padding:12px;transition:all .3s ease;width:100%}.input-group input::placeholder{color:#fff9}.input-group select option{background:#1a1a2e;color:#fff}.input-group input:focus,.input-group select:focus{background:#ffffff26;border-color:#667eea;box-shadow:0 0 0 3px #667eea4d;outline:none}.loading{color:#fff;padding:40px;text-align:center}.error{background:#dc354540;border-left:4px solid #ff6b6b}.error,.success{font-size:16px;margin-bottom:20px;text-shadow:0 1px 2px #0000004d}.success{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#28a74540;border-left:4px solid #51cf66;border-radius:12px;color:#51cf66;font-weight:600;padding:15px}@media (max-width:768px){.container{padding:5px}.card{border-radius:12px;margin-bottom:15px;padding:15px}.btn{font-size:16px;margin-top:10px;padding:15px 20px;width:100%}.input-group label{font-size:14px;margin-bottom:6px}.input-group input,.input-group select{font-size:16px;padding:15px}.error,.success{font-size:15px;font-weight:600;padding:12px}}@media (max-width:480px){.container{padding:3px}.card{margin-bottom:12px;padding:12px}.btn{font-size:16px;padding:16px 20px}}.home{background:linear-gradient(135deg,#0a0a0a,#1a1a1a 25%,#2d2d2d 50%,#1a1a1a 75%,#0a0a0a);color:#fff;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh;overflow-x:hidden;position:relative}.home:before{background:radial-gradient(circle at 20% 80%,#ffd7001a 0,#0000 50%),radial-gradient(circle at 80% 20%,#8b00001a 0,#0000 50%),radial-gradient(circle at 40% 40%,#ffd7000d 0,#0000 50%);content:"";height:100%;left:0;pointer-events:none;position:fixed;top:0;width:100%;z-index:0}.home-container{margin:0 auto;max-width:1200px;padding:20px;position:relative;z-index:1}.home-header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:25px;box-shadow:0 20px 40px #0000004d;margin-bottom:40px;overflow:hidden;padding:60px 0 40px;position:relative;text-align:center}.home-header:before{background:linear-gradient(90deg,gold,#ffed4e,gold);content:"";height:3px;left:0;position:absolute;right:0;top:0}.home-header h1{-webkit-text-fill-color:#0000;animation:glow 3s ease-in-out infinite alternate;background:linear-gradient(135deg,gold,#ffed4e 50%,gold);-webkit-background-clip:text;background-clip:text;font-size:4rem;font-weight:900;letter-spacing:3px;margin:0 0 15px;text-shadow:0 8px 16px #0006}@keyframes glow{0%{filter:drop-shadow(0 0 20px rgba(255,215,0,.3))}to{filter:drop-shadow(0 0 30px rgba(255,215,0,.6))}}.home-header p{color:#e0e0e0;font-size:1.5rem;font-weight:600;letter-spacing:2px;margin:0;text-shadow:0 4px 8px #00000080}.btn-logout{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#dc3545,#c82333);border:1px solid #ffffff1a;border-radius:12px;box-shadow:0 6px 20px #dc354566;color:#fff;cursor:pointer;font-size:14px;font-weight:700;padding:12px 24px;position:absolute;right:25px;top:25px;transition:all .4s ease}.btn-logout:hover{box-shadow:0 10px 30px #dc354599;transform:translateY(-3px) scale(1.05)}.tools-section{margin-bottom:80px;margin-top:40px}.tools-section h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#e0e0e0);-webkit-background-clip:text;background-clip:text;color:#fff;font-size:2.5rem;font-weight:800;margin:0 0 40px;text-align:center;text-shadow:0 4px 8px #0009}.tools-grid{grid-gap:35px;display:grid;gap:35px;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));margin-bottom:50px}.tool-card{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);background:#ffffff14;border:1px solid #ffffff26;border-radius:25px;box-shadow:0 15px 35px #0000004d;cursor:pointer;overflow:hidden;padding:40px 30px;position:relative;text-align:center;transition:all .4s ease}.tool-card:before{background:linear-gradient(90deg,#0000,#ffffff1a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s ease;width:100%}.tool-card:hover:before{left:100%}.tool-card:hover{background:#ffffff1f;border-color:#ffd70099;box-shadow:0 25px 50px #0006;transform:translateY(-12px) scale(1.02)}.tool-icon{display:block;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3));font-size:5rem;margin-bottom:25px;transition:all .3s ease}.tool-card:hover .tool-icon{filter:drop-shadow(0 8px 16px rgba(255,215,0,.3));transform:scale(1.1) rotate(5deg)}.tool-card h4{color:#fff;font-size:1.8rem;font-weight:800;margin:0 0 20px;text-shadow:0 2px 4px #00000080}.tool-card p{color:#d0d0d0;font-size:1.1rem;font-weight:500;line-height:1.7;margin:0 0 30px}.btn-tool{background:linear-gradient(135deg,#28a745,#20c997 50%,#28a745);border:none;border-radius:12px;box-shadow:0 6px 20px #28a74566;color:#fff;cursor:pointer;font-size:16px;font-weight:700;min-width:140px;overflow:hidden;padding:15px 30px;position:relative;transition:all .4s ease}.btn-tool:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.btn-tool:hover:before{left:100%}.btn-tool:hover{box-shadow:0 10px 30px #28a74599;transform:translateY(-3px) scale(1.05)}.login-card{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);background:#ffffff14;border:1px solid #ffffff26;border-radius:25px;box-shadow:0 20px 40px #0000004d;max-width:450px;overflow:hidden;padding:50px 40px;position:relative}.login-card:before{background:linear-gradient(90deg,gold,#ffed4e,gold);content:"";height:3px;left:0;position:absolute;right:0;top:0}.login-card h2{font-size:2.2rem;font-weight:800;margin:0 0 15px;text-align:center;text-shadow:0 4px 8px #00000080}.login-card p{color:#d0d0d0;font-size:1.1rem;font-weight:500;margin:0 0 35px;text-align:center}.input-group{margin-bottom:25px}.input-group label{color:#fff;display:block;font-size:1.1rem;font-weight:700;margin-bottom:10px;text-shadow:0 2px 4px #00000080}.input-group input{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff14;border:2px solid #fff3;border-radius:12px;box-sizing:border-box;color:#fff;font-size:16px;padding:15px 20px;transition:all .3s ease;width:100%}.input-group input:focus{-webkit-text-fill-color:#fff!important;background-color:#ffffff1f!important;border-color:#28a745;box-shadow:0 0 0 4px #28a74533;color:#fff!important;outline:none;transform:translateY(-2px)}.input-group input::placeholder{-webkit-text-fill-color:#fff9!important;color:#fff9!important}.btn-primary{padding:18px}.error{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#dc354526;border:2px solid #dc354566;border-radius:12px;box-shadow:0 4px 15px #dc354533;color:#ff6b6b;font-weight:600;margin-bottom:25px;padding:15px;text-align:center}.footer-content p{font-size:15px;font-weight:500;line-height:1.6;margin:0 0 10px}.footer-content p:last-child{font-size:13px}@media (max-width:768px){.home-container{padding:15px}.home-header{margin-bottom:30px;padding:40px 20px 30px}.home-header h1{font-size:2.8rem;letter-spacing:2px}.home-header p{font-size:1.2rem;letter-spacing:1px}.btn-logout{display:inline-block;margin-top:20px;position:static;width:auto}.tools-grid{gap:25px;grid-template-columns:1fr}.tool-card{padding:30px 25px}.tool-icon{font-size:4rem}.tool-card h4{font-size:1.6rem}.tool-card p{font-size:1rem}.tools-section h3{font-size:2rem;margin-bottom:30px}.login-card{margin:0 10px;padding:40px 25px}.login-card h2{font-size:1.8rem}.login-card p{font-size:1rem}.input-group input{font-size:16px;padding:12px 15px}.btn-primary{font-size:16px;padding:15px}}@media (max-width:480px){.home-header h1{font-size:2.2rem;letter-spacing:1px}.home-header p{font-size:1rem}.tools-section h3{font-size:1.8rem}.tool-card{padding:25px 20px}.tool-icon{font-size:3.5rem}.tool-card h4{font-size:1.4rem}.tool-card p{font-size:.95rem}.login-card{padding:30px 20px}.login-card h2{font-size:1.6rem}.login-card p{font-size:.9rem}.input-group label{font-size:1rem}.input-group input{font-size:16px;padding:10px 12px}.btn-primary{font-size:16px;padding:12px}.footer-content p{font-size:13px}.footer-content p:last-child{font-size:11px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.tool-card{animation:fadeInUp .6s ease-out}.tool-card:nth-child(2){animation-delay:.1s}.tool-card:nth-child(3){animation-delay:.2s}html{scroll-behavior:smooth}::selection{background:#ffd7004d;color:#fff}::-moz-selection{background:#ffd7004d;color:#fff}.history-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr;margin-top:30px}.history-card{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);background:#ffffff14;border:1px solid #ffffff26;border-radius:20px;box-shadow:0 15px 35px #0000004d;display:flex;min-height:200px;overflow:hidden;padding:0;position:relative;transition:all .4s ease}.history-card:before{background:linear-gradient(90deg,#0000,#ffffff1a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s ease;width:100%}.history-card:hover:before{left:100%}.history-card:hover{background:#ffffff1f;border-color:#ffd70099;box-shadow:0 25px 50px #0006;transform:translateY(-8px) scale(1.02)}.history-content{flex:1 1;flex-direction:column;padding:20px}.history-content,.history-header{display:flex;justify-content:space-between}.history-header{align-items:center;border-bottom:1px solid #ffffff1a;margin-bottom:15px;padding-bottom:15px}.history-header h3{color:#fff;font-size:1.4rem;font-weight:700;margin:0;text-shadow:0 2px 4px #00000080}.history-date{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:8px;color:#ccc;font-size:.9rem;font-weight:500;padding:5px 10px}.history-image{background:#0003;border-radius:0;height:200px;min-width:200px;overflow:hidden;position:relative;width:200px}.history-image img{height:100%;object-fit:cover;transition:all .3s ease;width:100%}.history-image:hover img{transform:scale(1.05)}.image-error{align-items:center;background:#ffffff0d;color:#ccc;display:flex;font-style:italic;height:100%;justify-content:center}.history-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:auto}.history-actions .btn{border-radius:10px;flex:1 1;font-size:14px;font-weight:600;min-width:120px;overflow:hidden;padding:10px 15px;position:relative;transition:all .3s ease}.history-actions .btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .4s ease;width:100%}.history-actions .btn:hover:before{left:100%}.history-actions .btn:hover{transform:translateY(-2px) scale(1.05)}.btn-download{background:linear-gradient(135deg,#28a745,#20c997 50%,#28a745);box-shadow:0 4px 15px #28a74566}.btn-download:hover{box-shadow:0 6px 20px #28a74599}.btn-secondary{background:linear-gradient(135deg,#6c757d,#495057 50%,#6c757d);box-shadow:0 4px 15px #6c757d66}.btn-secondary:hover:not(:disabled){box-shadow:0 6px 20px #6c757d99}.btn-secondary:disabled{box-shadow:none!important;cursor:not-allowed;opacity:.5;transform:none!important}.no-data{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:15px;color:#ccc;font-size:1.1rem;font-style:italic;padding:60px 20px;text-align:center}@media (max-width:768px){.history-grid{gap:20px;grid-template-columns:1fr}.history-card{flex-direction:column;min-height:auto}.history-image{height:150px;min-width:auto;width:100%}.history-content{padding:15px}.history-header{align-items:flex-start;flex-direction:column;gap:10px}.history-header h3{font-size:1.2rem}.history-date{font-size:.8rem}.history-actions{flex-direction:column;margin-top:15px}.history-actions .btn{min-width:auto;width:100%}}@media (max-width:480px){.history-card{flex-direction:column;min-height:auto}.history-image{height:120px;min-width:auto;width:100%}.history-content{padding:12px}.history-header h3{font-size:1.1rem}.history-date{font-size:.75rem;padding:4px 8px}.history-actions{margin-top:12px}}.App{background:linear-gradient(135deg,#0a0a0a,#1a1a1a 25%,#2d2d2d 50%,#1a1a1a 75%,#0a0a0a);background-attachment:fixed;min-height:100vh;overflow-x:hidden;padding:10px;position:relative}.App:before{background:radial-gradient(circle at 20% 80%,#ffd7001a 0,#0000 50%),radial-gradient(circle at 80% 20%,#8b00001a 0,#0000 50%),radial-gradient(circle at 40% 40%,#ffd7000d 0,#0000 50%);content:"";height:100%;left:0;pointer-events:none;position:fixed;top:0;width:100%;z-index:0}.header{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);background:#ffffff14;border:1px solid #ffffff26;border-radius:25px;box-shadow:0 20px 40px #0000004d;color:#fff;margin-bottom:40px;overflow:hidden;padding:40px 30px;position:relative;text-align:center}.header:before{background:linear-gradient(90deg,gold,#ffed4e,gold);content:"";height:3px;left:0;position:absolute;right:0;top:0}.header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#e0e0e0);-webkit-background-clip:text;background-clip:text;color:#fff;font-size:2.8rem;font-weight:900;letter-spacing:2px;margin-bottom:15px;text-shadow:0 6px 12px #0009}.header p{color:#e0e0e0;font-size:1.3rem;font-weight:600;letter-spacing:1px;opacity:1;text-shadow:0 3px 6px #00000080}.form-row{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr;margin-bottom:15px}.btn-primary{background:linear-gradient(135deg,#28a745,#20c997 50%,#28a745);border:none;border-radius:12px;box-shadow:0 8px 25px #28a74566;color:#fff;cursor:pointer;font-size:18px;font-weight:700;margin-top:10px;overflow:hidden;padding:18px 25px;position:relative;text-shadow:0 2px 4px #0000004d;transition:all .4s ease;width:100%}.btn-primary:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.btn-primary:hover:before{left:100%}.btn-primary:hover{box-shadow:0 12px 35px #28a74599;transform:translateY(-3px) scale(1.02)}.btn-secondary{background:linear-gradient(135deg,#2f4f4f,#556b6b);border:none;border-radius:6px;font-weight:500}.btn-danger,.btn-secondary{color:#fff;font-size:14px;padding:8px 16px}.btn-danger{background:linear-gradient(135deg,#ff6b6b,#ee5a52)}.positions-actions-container{display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin:20px 0}.positions-actions-container .btn{border-radius:12px;font-size:16px;min-width:140px;padding:12px 24px}.btn-generate{background:linear-gradient(135deg,#28a745,#20c997 50%,#28a745);box-shadow:0 6px 20px #28a74566;overflow:hidden;position:relative}.btn-generate:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.btn-generate:hover:not(:disabled):before{left:100%}.btn-generate:hover:not(:disabled){box-shadow:0 10px 30px #28a74599;transform:translateY(-3px) scale(1.05)}.btn-disabled{background:linear-gradient(135deg,#6c757d,#495057);box-shadow:none;cursor:not-allowed;opacity:.6}.btn-disabled:hover{box-shadow:none;transform:none}.generate-image-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;margin:20px 0;padding:20px;text-align:center}.generate-image-container .btn-generate{background:linear-gradient(135deg,#228b22,#32cd32);border-radius:10px;box-shadow:0 6px 20px #228b2266;font-size:20px;font-weight:700;min-width:220px;padding:18px 35px;text-shadow:0 1px 2px #0000004d;transition:all .3s ease}.generate-image-container .btn-generate:hover{box-shadow:0 8px 25px #228b2299;transform:translateY(-2px)}.table-header{align-items:stretch;display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.table-header h2{color:#fff;font-size:20px;font-weight:700;margin:0;text-align:center;text-shadow:0 2px 4px #00000080}.race-info{color:#666;font-size:14px;font-weight:400;margin:5px 0 0;text-align:center}.table-container{-webkit-overflow-scrolling:touch;border-radius:8px;box-shadow:0 4px 16px #0000001a;overflow-x:auto}.race-table{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);background:#ffffff14;border:1px solid #ffffff26;border-collapse:collapse;border-radius:16px;box-shadow:0 15px 35px #0000004d;font-size:12px;min-width:500px;overflow:hidden;position:relative;width:100%}.race-table td,.race-table th{border-bottom:1px solid #fff3;color:#fff;font-weight:500;padding:12px 10px;text-align:left;text-shadow:0 1px 2px #00000080;vertical-align:middle}.race-table th{background:linear-gradient(135deg,gold,#ffed4e);box-shadow:0 4px 15px #ffd7004d;color:#333;font-size:13px;font-weight:800;letter-spacing:.5px;position:sticky;text-shadow:0 2px 4px #0000004d;top:0;white-space:nowrap;z-index:10}.race-table tr{cursor:pointer;transition:all .2s ease;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.race-table tr:hover{background-color:#ffffff1f;border-left:3px solid #ffd70099;box-shadow:0 4px 15px #0000004d;transform:translateY(-2px)}.race-table tr.selected{background-color:#ffd70026;border-left:4px solid gold;box-shadow:0 2px 8px #ffd70033}.race-table tr.dragging{box-shadow:0 8px 25px #0003;opacity:.5;transform:rotate(2deg)}.race-table td:first-child{color:#fff;font-weight:600;min-width:50px;text-align:center}.race-table .position-indicator{background:linear-gradient(135deg,#8b0000,brown);border-radius:50%;box-shadow:0 2px 8px #8b00004d;color:#fff;display:inline-block;font-size:12px;font-weight:700;height:24px;line-height:24px;margin-right:8px;text-align:center;width:24px}.race-table .position-1{background:linear-gradient(135deg,gold,#ffed4e);color:#333}.race-table .position-2{background:linear-gradient(135deg,silver,#e0e0e0);color:#333}.race-table .position-3{background:linear-gradient(135deg,#cd7f32,#daa520);color:#fff}.race-table .position-4{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.spinner{animation:spin 1s linear infinite;border:4px solid #fff3;border-radius:50%;border-top-color:#667eea;height:40px;margin:0 auto 20px;width:40px}.loading p{color:#fff;font-size:16px}.positions-section{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);background:#ffffff14;border:1px solid #ffffff26;border-radius:20px;box-shadow:0 20px 40px #0000004d;margin-top:20px;overflow:hidden;padding:30px;position:relative}.positions-section:before{background:linear-gradient(90deg,gold,#ffed4e,gold);content:"";height:3px;left:0;position:absolute;right:0;top:0}.positions-section h3{color:#fff;font-size:20px;font-weight:700;margin-bottom:15px;text-shadow:0 2px 4px #00000080}.positions-controls{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.position-buttons{display:flex;flex-wrap:wrap;gap:5px}.position-info{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-left:4px solid #667eea;border-radius:12px;margin-bottom:15px;padding:15px}.position-info h4{color:#fff;font-size:16px;margin:0 0 10px}.position-info p{color:#fffc;font-size:14px;margin:5px 0}.positions-table-container{-webkit-overflow-scrolling:touch;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;box-shadow:0 4px 16px #0000004d;margin-bottom:20px;max-width:100%;overflow-x:auto}.table-actions{background:#ffffff0d;border-bottom:1px solid #ffffff1a;padding:20px}.edit-actions,.table-actions{display:flex;gap:15px;justify-content:center}.edit-actions{width:100%}.btn-edit{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#28a745,#20c997 50%,#28a745);border:1px solid #ffffff1a;border-radius:12px;box-shadow:0 6px 20px #28a74566;color:#fff;cursor:pointer;font-size:16px;font-weight:700;min-width:150px;overflow:hidden;padding:15px 25px;position:relative;transition:all .4s ease}.btn-edit:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.btn-edit:hover:before{left:100%}.btn-edit:hover{box-shadow:0 10px 30px #28a74599;transform:translateY(-3px) scale(1.05)}.btn-edit-off{background:linear-gradient(135deg,#dc3545,#c82333);border:none;border-radius:8px;box-shadow:0 4px 12px #dc35454d;color:#fff;cursor:pointer;font-size:16px;font-weight:700;min-width:150px;padding:12px 20px;transition:all .3s ease}.btn-edit-off:hover{box-shadow:0 6px 20px #dc354580;transform:translateY(-2px)}.btn-save{background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:8px;box-shadow:0 4px 12px #28a7454d;color:#fff;cursor:pointer;font-size:16px;font-weight:700;min-width:150px;padding:12px 20px;transition:all .3s ease}.btn-save:hover{box-shadow:0 6px 20px #28a74580;transform:translateY(-2px)}.btn-cancel{background:linear-gradient(135deg,#6c757d,#495057);border:none;border-radius:8px;box-shadow:0 4px 12px #6c757d4d;color:#fff;cursor:pointer;font-size:16px;font-weight:700;min-width:150px;padding:12px 20px;transition:all .3s ease}.btn-cancel:hover{box-shadow:0 6px 20px #6c757d80;transform:translateY(-2px)}.btn-back-home{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#6c757d,#495057);border:1px solid #ffffff1a;border-radius:15px;box-shadow:0 6px 20px #6c757d66;color:#fff;cursor:pointer;display:inline-block;font-size:16px;font-weight:700;margin-bottom:20px;overflow:hidden;padding:15px 30px;position:relative;transition:all .4s ease}.btn-back-home:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.btn-back-home:hover:before{left:100%}.btn-back-home:hover{box-shadow:0 10px 30px #6c757d99;transform:translateY(-3px) scale(1.05)}.home .tool-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff1a;border:1px solid #fff3;border-radius:20px;box-shadow:0 8px 32px #0000004d;margin-bottom:30px;padding:30px;transition:all .3s ease}.home .tool-card:hover{border-color:#ffd7004d;box-shadow:0 12px 40px #0006;transform:translateY(-4px)}.home .tool-card h2{font-size:1.8rem;margin:0 0 20px}.home .tool-card h2,.home .tool-card h3{color:#fff;font-weight:700;text-shadow:0 2px 4px #00000080}.home .tool-card h3{font-size:1.5rem;margin:0 0 15px}.home .tool-card p{color:#ccc;font-size:1rem;line-height:1.6;margin:0 0 15px}.home .tool-card label{color:#fff;font-weight:600;text-shadow:0 1px 2px #00000080}.home .tool-card input,.home .tool-card select{appearance:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #ffffff4d;color:#fff}.home .tool-card input[type=date],.home .tool-card input[type=number]{-webkit-text-fill-color:#fff!important;background-color:#2d2d2d!important;border:1px solid #ffffff4d!important;color:#fff!important}.home .tool-card input[type=date]::-webkit-datetime-edit,.home .tool-card input[type=date]::-webkit-datetime-edit-day-field,.home .tool-card input[type=date]::-webkit-datetime-edit-fields-wrapper,.home .tool-card input[type=date]::-webkit-datetime-edit-month-field,.home .tool-card input[type=date]::-webkit-datetime-edit-text,.home .tool-card input[type=date]::-webkit-datetime-edit-year-field{background-color:#2d2d2d!important;color:#fff!important}.home .tool-card input[type=number]::-webkit-inner-spin-button,.home .tool-card input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.home .tool-card input[type=number]{-moz-appearance:textfield}.home .tool-card select{-webkit-text-fill-color:#fff!important;border:1px solid #ffffff4d!important}.home .tool-card select,.home .tool-card select option{background-color:#2d2d2d!important;color:#fff!important}.home .tool-card input::placeholder{-webkit-text-fill-color:#fff9!important;color:#fff9!important}.home .tool-card input:focus{-webkit-text-fill-color:#fff!important;background-color:#1a1a1a!important;border-color:#28a745!important;color:#fff!important}.home .tool-card input:focus,.home .tool-card select:focus{border-color:#28a745;box-shadow:0 0 0 3px #28a74533}.home .tool-card input::placeholder{color:#fff9}.home .table-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#e0e0e0);-webkit-background-clip:text;background-clip:text;color:#fff;font-size:2.2rem;font-weight:800;letter-spacing:1px;margin:0 0 15px;text-shadow:0 4px 8px #0009}.home .race-info{color:#e0e0e0;font-size:1.2rem;font-weight:600;letter-spacing:.5px;margin:0 0 25px;text-shadow:0 2px 4px #00000080}.home .positions-section h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#e0e0e0);-webkit-background-clip:text;background-clip:text;color:#fff;font-size:1.8rem;font-weight:800;letter-spacing:1px;margin:0 0 25px;text-shadow:0 4px 8px #0009}.home .positions-section:before{background:linear-gradient(90deg,gold,#ffed4e,gold)}.home .positions-table-container{background:#ffffff14;border:1px solid #ffffff26;border-radius:20px;box-shadow:0 15px 35px #0000004d;margin-bottom:25px;padding:25px}.home .positions-table th{background:linear-gradient(135deg,#ffd70033,#ffd7001a);color:#fff;font-weight:700;text-shadow:0 1px 2px #00000080}.home .positions-table td{border-bottom:1px solid #ffffff1a;color:#fff}.home .positions-table tr:hover{background:#ffffff0d}.home .race-table th{background:linear-gradient(135deg,gold,#ffed4e);box-shadow:0 4px 15px #ffd7004d;color:#333;font-weight:800;letter-spacing:.5px;text-shadow:0 2px 4px #0000004d}.home .race-table td{border-bottom:1px solid #ffffff1a;color:#fff}.home .race-table tr:hover{background:#ffffff1f;border-left:3px solid #ffd70099;box-shadow:0 4px 15px #0000004d;transform:translateY(-2px)}.home .race-table tr.selected{background:#ffd70026;border-left:4px solid gold;box-shadow:0 2px 8px #ffd70033}.home .error{background:#dc354526;border:2px solid #dc354566;border-radius:12px;box-shadow:0 4px 15px #dc354533;color:#ff6b6b}.home .error,.home .success{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-weight:600;margin-bottom:25px;padding:15px;text-align:center}.home .success{background:#28a74526;border:2px solid #28a74566;border-radius:12px;box-shadow:0 4px 15px #28a74533;color:#6bcf7f}.home .loading{color:#fff;padding:40px 20px;text-align:center}.home .loading p{color:#e0e0e0;font-size:1.2rem;font-weight:600;margin-top:20px;text-shadow:0 2px 4px #00000080}.home .home-header{gap:20px;margin-bottom:30px;text-align:center}.home .header-content,.home .home-header{align-items:center;display:flex;flex-direction:column}.home .header-content{gap:10px}.home .header-content h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#e0e0e0);-webkit-background-clip:text;background-clip:text;color:#fff;font-size:2.8rem;font-weight:800;letter-spacing:2px;margin:0;text-shadow:0 4px 8px #0009}.home .header-content p{color:#e0e0e0;font-size:1.3rem;font-weight:600;letter-spacing:1px;margin:0;text-shadow:0 2px 4px #00000080}@media (max-width:768px){.home .home-header{gap:15px;margin-bottom:25px}.home .header-content h1{font-size:2rem}.home .header-content p{font-size:1rem}.btn-back-home{font-size:13px;padding:10px 20px}}@media (max-width:480px){.home .home-header{gap:12px;margin-bottom:20px}.home .header-content h1{font-size:1.8rem}.home .header-content p{font-size:.9rem}.btn-back-home{font-size:12px;padding:8px 16px}}.btn-edit-row{background:linear-gradient(135deg,#ffc107,#ffca2c);border:none;border-radius:8px;box-shadow:0 2px 8px #ffc1074d;color:#333;cursor:pointer;font-size:12px;font-weight:700;overflow:hidden;padding:6px 12px;position:relative;transition:all .3s ease}.btn-edit-row:before{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .4s ease;width:100%}.btn-edit-row:hover:before{left:100%}.btn-edit-row:hover{box-shadow:0 4px 12px #ffc10780;transform:translateY(-2px) scale(1.05)}.btn-done{background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:8px;box-shadow:0 2px 8px #28a7454d;color:#fff;cursor:pointer;font-size:12px;font-weight:700;overflow:hidden;padding:6px 12px;position:relative;transition:all .3s ease}.btn-done:before{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .4s ease;width:100%}.btn-done:hover:before{left:100%}.btn-done:hover{box-shadow:0 4px 12px #28a74580;transform:translateY(-2px) scale(1.05)}.edit-input{background:#fffffff2;border:2px solid #ffffff80;border-radius:8px;box-shadow:0 2px 8px #0000001a;box-sizing:border-box;color:#333;font-size:14px;font-weight:500;padding:10px 12px;transition:all .3s ease;width:100%}.edit-input:focus{background:#fff;border-color:#28a745;box-shadow:0 0 0 4px #28a7454d,0 4px 12px #00000026;outline:none;transform:translateY(-1px)}.edit-input::placeholder{color:#666;font-style:italic}.editing-row{background-color:#28a74526!important;border-left:4px solid #28a745;box-shadow:0 4px 12px #28a7454d;transform:translateY(-1px)}.editing-row:hover{background-color:#28a74533!important;box-shadow:0 6px 16px #28a74566}.selectable-row{transition:all .3s ease}.selectable-row:hover{background-color:#ffd7001a!important;border-left:3px solid #ffd70099;box-shadow:0 4px 12px #ffd7004d;transform:translateY(-2px)}.selectable-row:active{background-color:#ffd70033!important;box-shadow:0 2px 8px #ffd70066;transform:translateY(-1px)}.edit-modal{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.edit-modal-content{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);background:#ffffff14;border:1px solid #ffffff26;border-radius:25px;box-shadow:0 25px 70px #0009;max-height:90vh;max-width:90vw;overflow:hidden;position:relative}.edit-modal-content:before{background:linear-gradient(90deg,gold,#ffed4e,gold);content:"";height:3px;left:0;position:absolute;right:0;top:0}.edit-modal-header{align-items:center;background:#ffffff0d;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:25px 30px;position:relative}.edit-modal-header:before{background:linear-gradient(90deg,gold,#ffed4e,gold);content:"";height:2px;left:0;position:absolute;right:0;top:0}.edit-modal-header h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#e0e0e0);-webkit-background-clip:text;background-clip:text;color:#fff;font-size:22px;font-weight:800;letter-spacing:1px;margin:0;text-shadow:0 4px 8px #0009}.close-edit-btn{align-items:center;background:none;border:none;border-radius:50%;color:#ffffffb3;cursor:pointer;display:flex;font-size:30px;height:40px;justify-content:center;overflow:hidden;padding:0;position:relative;transition:all .3s ease;width:40px}.close-edit-btn:before{background:radial-gradient(circle,#ffffff1a 0,#0000 70%);content:"";height:100%;left:0;position:absolute;top:0;transform:scale(0);transition:transform .3s ease;width:100%}.close-edit-btn:hover:before{transform:scale(1)}.close-edit-btn:hover{background:#ffffff1a;color:#fff;transform:scale(1.1)}.edit-modal-body{background:#ffffff05;max-height:50vh;overflow-y:auto;padding:30px}.edit-form{gap:25px}.edit-field,.edit-form{display:flex;flex-direction:column}.edit-field{gap:10px}.edit-field label{color:#fff;font-size:15px;font-weight:700;letter-spacing:.5px;text-shadow:0 2px 4px #00000080}.field-display{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:10px;box-shadow:0 2px 8px #0000001a;color:#fff;font-weight:600;padding:15px 18px;transition:all .3s ease}.field-display:hover{background:#ffffff26;box-shadow:0 4px 12px #0003}.position-display{align-items:center;border-radius:8px;display:flex;gap:12px;padding:5px;transition:all .3s ease}.position-display:hover{background:#ffffff0d;transform:translateX(5px)}.edit-modal-input{background:#fffffff2;border:2px solid #ffffff4d;border-radius:10px;box-shadow:0 2px 8px #0000001a;color:#333;font-size:16px;font-weight:500;padding:15px 18px;transition:all .3s ease}.edit-modal-input:focus{background:#fff;border-color:#28a745;box-shadow:0 0 0 4px #28a7454d,0 4px 12px #00000026;outline:none;transform:translateY(-1px)}.edit-modal-input::placeholder{color:#666;font-style:italic}.edit-modal-footer{background:#ffffff0d;border-top:1px solid #ffffff1a;display:flex;gap:20px;justify-content:flex-end;padding:25px 30px;position:relative}.edit-modal-footer:before{background:linear-gradient(90deg,gold,#ffed4e,gold);content:"";height:2px;left:0;position:absolute;right:0;top:0}.btn-select-position{background:linear-gradient(135deg,#007bff,#0056b3);border:none;border-radius:8px;box-shadow:0 3px 10px #007bff66;color:#fff;cursor:pointer;font-size:12px;font-weight:700;overflow:hidden;padding:8px 16px;position:relative;transition:all .3s ease}.btn-select-position:before{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .4s ease;width:100%}.btn-select-position:hover:before{left:100%}.btn-select-position:hover{box-shadow:0 5px 15px #007bff80;transform:translateY(-2px) scale(1.05)}.positions-table{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);background:#ffffff14;border:1px solid #ffffff26;border-collapse:collapse;border-radius:16px;box-shadow:0 15px 35px #0000004d;color:#fff;font-size:13px;min-width:400px;overflow:hidden;table-layout:fixed;width:100%}.positions-table td,.positions-table th{word-wrap:break-word;border-bottom:1px solid #fff3;color:#fff!important;font-weight:500;overflow:hidden;padding:12px 10px;text-align:left;text-overflow:ellipsis;text-shadow:0 1px 2px #00000080;vertical-align:middle;white-space:nowrap}.positions-table th:first-child{width:12%}.positions-table th:nth-child(2){width:10%}.positions-table th:nth-child(3){width:25%}.positions-table th:nth-child(4),.positions-table th:nth-child(5){width:18%}.positions-table th:nth-child(6){width:17%}.positions-table th{background:linear-gradient(135deg,gold,#ffed4e);box-shadow:0 4px 15px #ffd7004d;color:#333;font-size:13px;font-weight:800;letter-spacing:.8px;padding:15px 12px;position:sticky;text-shadow:0 2px 4px #0000004d;text-transform:uppercase;top:0;white-space:nowrap;z-index:10}.positions-table tr{transition:all .2s ease;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.positions-table tr:nth-child(2n){background-color:#ffffff0d}.positions-table tr{height:auto;min-height:40px}.positions-table tr:hover{background-color:#ffffff1f;border-left:3px solid #ffd70099;box-shadow:0 4px 15px #0000004d;transform:translateY(-2px)}.positions-table td:first-child{color:#667eea!important;font-weight:600;min-width:80px;text-align:center}.positions-table .position-indicator{background:linear-gradient(135deg,#8b0000,brown);border-radius:50%;box-shadow:0 3px 10px #8b000066;color:#fff;display:inline-block;font-size:13px;font-weight:700;height:28px;line-height:28px;margin-right:10px;text-align:center;transition:all .3s ease;width:28px}.positions-table .position-indicator:hover{box-shadow:0 5px 15px #8b000099;transform:scale(1.1)}.positions-table .position-1{background:linear-gradient(135deg,gold,#ffed4e);box-shadow:0 4px 15px #ffd70080;color:#333}.positions-table .position-2{background:linear-gradient(135deg,silver,#e0e0e0);box-shadow:0 4px 15px #c0c0c080;color:#333}.positions-table .position-3{background:linear-gradient(135deg,#cd7f32,#daa520);box-shadow:0 4px 15px #cd7f3280;color:#fff}.positions-table .position-4{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 15px #667eea80;color:#fff}.positions-actions{display:flex;flex-wrap:wrap;gap:10px}.positions-actions .btn{flex:1 1;min-width:120px}.selection-instructions{background:linear-gradient(135deg,#e3f2fd,#f3e5f5);border-left:4px solid #2196f3;border-radius:8px;margin-bottom:20px;padding:15px}.selection-instructions h4{color:#1976d2;font-size:16px;margin:0 0 10px}.selection-instructions ul{color:#424242;margin:0;padding-left:20px}.selection-instructions li{font-size:14px;margin:5px 0}@media (max-width:768px){.header h1{font-size:1.5rem}.header p{font-size:.85rem}.table-header h2{font-size:16px}.race-info,.race-table{font-size:12px}.race-table{min-width:350px}.race-table td,.race-table th{font-weight:500;padding:10px 8px}.positions-table{font-size:11px;min-width:350px}.positions-table td,.positions-table th{word-wrap:break-word;font-weight:500;padding:10px 6px;white-space:normal}.positions-table th{font-size:11px;padding:8px 6px}.positions-table th:first-child{width:15%}.positions-table th:nth-child(2){width:12%}.positions-table th:nth-child(3){width:25%}.positions-table th:nth-child(4),.positions-table th:nth-child(5),.positions-table th:nth-child(6){width:16%}.positions-actions-container{flex-direction:column;gap:10px}.positions-actions-container .btn{min-width:auto;width:100%}.positions-table-container{margin:15px 0}.positions-section{margin-top:18px;padding:18px}.positions-section h3{font-size:17px;margin-bottom:12px}.table-actions{padding:15px}.edit-actions,.table-actions{flex-direction:column;gap:10px}.btn-cancel,.btn-edit,.btn-edit-off,.btn-save{font-size:16px;min-width:auto;padding:12px 16px;width:100%}.edit-input{border-radius:8px;font-size:16px;padding:8px 10px}.edit-modal{padding:10px}.edit-modal-content{max-height:90vh;max-width:95vw}.edit-modal-header{padding:15px 20px}.edit-modal-header h3{font-size:18px}.edit-modal-body{max-height:55vh;padding:15px}.edit-modal-footer{flex-direction:column;gap:10px;padding:15px 20px}.edit-modal-footer .btn{font-size:16px;padding:12px 16px;width:100%}.edit-modal-input{font-size:16px;padding:12px 15px}@media (min-width:769px){.edit-modal{padding:20px}.edit-modal-content{max-height:80vh;max-width:500px;width:500px}.edit-modal-header{padding:25px 30px}.edit-modal-header h3{font-size:24px}.edit-modal-body{max-height:45vh;padding:25px}.edit-modal-footer{flex-direction:row;gap:15px;padding:20px 30px}.edit-modal-footer .btn{font-size:16px;min-width:120px;padding:15px 25px}.edit-modal-input{font-size:16px;padding:15px 18px}}@media (min-width:481px) and (max-width:768px){.edit-modal{padding:20px}.edit-modal-content{max-height:85vh;max-width:500px;width:500px}.edit-modal-header{padding:20px 25px}.edit-modal-header h3{font-size:20px}.edit-modal-body{max-height:50vh;padding:20px}.edit-modal-footer{flex-direction:row;gap:12px;padding:18px 25px}.edit-modal-footer .btn{font-size:15px;min-width:100px;padding:12px 20px}.edit-modal-input{font-size:15px;padding:12px 16px}}@media (max-width:480px){.race-table{font-size:10px;min-width:300px}.positions-table{font-size:9px;min-width:300px}.race-table td,.race-table th{padding:6px 4px}.positions-table td,.positions-table th{word-wrap:break-word;padding:6px 3px;white-space:normal}.positions-table th{font-size:10px;padding:6px 4px}.positions-table tr{min-height:36px}.positions-table th:first-child{width:18%}.positions-table th:nth-child(2){width:15%}.positions-table th:nth-child(3){width:22%}.positions-table th:nth-child(4),.positions-table th:nth-child(5),.positions-table th:nth-child(6){width:15%}.positions-table-container{margin:12px 0}.positions-section{margin-top:16px;padding:16px}.positions-section h3{font-size:16px;margin-bottom:11px}.table-actions{padding:12px}.btn-cancel,.btn-edit,.btn-edit-off,.btn-save{font-size:14px;padding:10px 12px}.edit-input{font-size:14px;padding:6px 8px}.edit-modal{padding:5px}.edit-modal-content{max-height:92vh;max-width:98vw}.edit-modal-header{padding:12px 15px}.edit-modal-header h3{font-size:16px}.edit-modal-body{max-height:60vh;padding:12px}.edit-modal-footer{padding:12px 15px}.edit-modal-input{font-size:14px;padding:10px 12px}}@media (max-width:360px){.edit-modal{padding:3px}.edit-modal-content{max-height:94vh;max-width:99vw}.edit-modal-header{padding:10px 12px}.edit-modal-header h3{font-size:14px}.edit-modal-body{max-height:65vh;padding:10px}.edit-modal-footer{flex-direction:column;gap:8px;padding:10px 12px}.edit-modal-footer .btn{font-size:13px;padding:10px 12px;width:100%}.edit-modal-input{font-size:13px;padding:8px 10px}.race-table{font-size:9px;min-width:280px}.positions-table{font-size:8px;min-width:280px}.positions-table td,.positions-table th{word-wrap:break-word;white-space:normal}.positions-table td,.positions-table th,.race-table td,.race-table th{padding:4px 2px}.positions-table th{font-size:9px;padding:4px 3px}.positions-table tr{min-height:32px}.positions-table th:first-child{width:20%}.positions-table th:nth-child(2){width:18%}.positions-table th:nth-child(3){width:20%}.positions-table th:nth-child(4),.positions-table th:nth-child(5),.positions-table th:nth-child(6){width:14%}.positions-table-container{border-radius:8px;margin:10px 0}.positions-section{margin-top:15px;padding:15px}.positions-section h3{font-size:16px;margin-bottom:10px}}.generate-image-container{margin:15px 0;padding:15px}.generate-image-container .btn-generate{font-size:16px;min-width:auto;padding:12px 20px;width:100%}.footer{margin-top:20px;padding:15px 0}.footer-content{padding:0 15px}.footer-content p{font-size:12px}.login-card{margin:0 10px;max-width:100%}.login-card h2{font-size:20px}.login-card p{font-size:14px}}.image-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.image-modal{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);background:#ffffff14;border:1px solid #ffffff26;border-radius:25px;box-shadow:0 25px 70px #0009;max-height:90vh;max-width:90vw;overflow:hidden;position:relative}.image-modal:before{background:linear-gradient(90deg,gold,#ffed4e,gold);content:"";height:3px;left:0;position:absolute;right:0;top:0}.loading-container{color:#fff;padding:60px 40px;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#667eea;height:60px;margin:0 auto 30px;width:60px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-container h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#e0e0e0);-webkit-background-clip:text;background-clip:text;color:#fff;font-size:26px;font-weight:800;letter-spacing:1px;margin-bottom:20px;text-shadow:0 4px 8px #0009}.loading-container p{color:#fffc;font-size:16px}.error-container{color:#fff;padding:60px 40px;text-align:center}.error-icon{font-size:48px;margin-bottom:20px}.error-container h3{color:#fff;font-size:24px;margin-bottom:15px}.error-message{color:#fffc;font-size:16px;line-height:1.5;margin-bottom:30px}.error-actions{display:flex;flex-wrap:wrap;gap:15px;justify-content:center}.btn-retry{background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:12px;box-shadow:0 6px 20px #28a74566;color:#fff;cursor:pointer;font-size:14px;font-weight:700;overflow:hidden;padding:15px 30px;position:relative;transition:all .4s ease}.btn-retry:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.btn-retry:hover:before{left:100%}.btn-retry:hover{box-shadow:0 10px 30px #28a74599;transform:translateY(-3px) scale(1.05)}.image-content{display:flex;flex-direction:column;max-height:90vh}.image-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:25px 35px;position:relative}.image-header:before{background:linear-gradient(90deg,gold,#ffed4e,gold);content:"";height:2px;left:0;position:absolute;right:0;top:0}.image-header h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#e0e0e0);-webkit-background-clip:text;background-clip:text;color:#fff;font-size:26px;font-weight:800;letter-spacing:1px;margin:0;text-shadow:0 4px 8px #0009}.close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#ffffffb3;cursor:pointer;display:flex;font-size:34px;height:45px;justify-content:center;overflow:hidden;padding:0;position:relative;transition:all .3s ease;width:45px}.close-btn:before{background:radial-gradient(circle,#ffffff1a 0,#0000 70%);content:"";height:100%;left:0;position:absolute;top:0;transform:scale(0);transition:transform .3s ease;width:100%}.close-btn:hover:before{transform:scale(1)}.close-btn:hover{background:#ffffff1a;color:#fff;transform:scale(1.1)}.image-display{background:#ffffff05;flex:1 1;overflow:auto;padding:35px;text-align:center}.modal-image{border:2px solid #ffffff1a;border-radius:16px;box-shadow:0 15px 40px #0006;height:auto;max-height:60vh;max-width:100%;transition:all .3s ease}.modal-image:hover{box-shadow:0 20px 50px #00000080;transform:scale(1.02)}.image-actions{background:#ffffff05;border-top:1px solid #ffffff1a;padding:25px 35px;position:relative;text-align:center}.image-actions:before{background:linear-gradient(90deg,gold,#ffed4e,gold);bottom:0;content:"";height:2px;left:0;position:absolute;right:0}.image-timestamp{color:#fffc;font-size:15px;font-weight:600;letter-spacing:.5px;margin-bottom:25px;text-shadow:0 2px 4px #00000080}.action-buttons{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin-top:10px}.btn-download{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 6px 20px #667eea66;color:#fff;cursor:pointer;font-size:14px;font-weight:700;overflow:hidden;padding:15px 30px;position:relative;transition:all .4s ease}.btn-download:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.btn-download:hover:not(:disabled):before{left:100%}.btn-download:hover:not(:disabled){box-shadow:0 10px 30px #667eea99;transform:translateY(-3px) scale(1.05)}.btn-download:disabled{box-shadow:none;cursor:not-allowed;opacity:.7;transform:none}.btn-back,.btn-download:disabled{background:linear-gradient(135deg,#6c757d,#495057)}.btn-back{border:none;border-radius:12px;box-shadow:0 6px 20px #6c757d66;color:#fff;cursor:pointer;font-size:14px;font-weight:700;overflow:hidden;padding:15px 30px;position:relative;transition:all .4s ease}.btn-back:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.btn-back:hover:before{left:100%}.btn-back:hover{box-shadow:0 10px 30px #6c757d99;transform:translateY(-3px) scale(1.05)}@media (hover:none) and (pointer:coarse){.race-table tr{min-height:44px}.positions-table tr{min-height:40px}.btn{min-height:44px}.race-table tr:active{background-color:#e3f2fd;transform:scale(.98)}.positions-table tr:active{background-color:#667eea4d;transform:scale(.98)}}.footer{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0d;border-top:1px solid #ffffff1a;margin-top:60px;padding:30px 0;position:relative}.footer:before{background:linear-gradient(90deg,gold,#ffed4e,gold);content:"";height:2px;left:0;position:absolute;right:0;top:0}.footer-content{margin:0 auto;max-width:1200px;padding:0 20px;text-align:center}.footer-content p{color:#fffc;font-size:14px;line-height:1.5;margin:0 0 8px;text-align:center}.footer-content p:last-child{font-size:12px;margin-bottom:0;opacity:.7}.footer-content a{color:gold;font-weight:700;text-decoration:none;text-shadow:0 2px 4px #0000004d;transition:all .3s ease}.footer-content a:hover{color:#ffed4e;text-decoration:underline;transform:translateY(-1px)}.login-card{margin:0 auto;max-width:400px;text-align:center}.login-card h2{color:#fff;font-size:24px;margin-bottom:10px}.login-card p{color:#fffc;font-size:16px;margin-bottom:30px}.login-card .input-group{margin-bottom:25px}.login-card .btn{font-size:16px;padding:15px;width:100%}@media (max-width:768px){.image-modal-overlay{padding:10px}.image-modal{max-height:95vh;max-width:95vw}.loading-container{padding:40px 20px}.loading-spinner{height:50px;margin-bottom:20px;width:50px}.loading-container h3{font-size:20px}.loading-container p{font-size:14px}.image-header{padding:15px 20px}.image-header h3{font-size:20px}.close-btn{font-size:28px;height:35px;width:35px}.image-display{padding:20px}.modal-image{max-height:50vh}.image-actions{padding:15px 20px}.action-buttons{flex-direction:column;gap:10px}.btn-back,.btn-download{font-size:14px;padding:12px 20px;width:100%}.btn-download:disabled{opacity:.6}.error-container{padding:40px 20px}.error-icon{font-size:40px;margin-bottom:15px}.error-container h3{font-size:20px}.error-message{font-size:14px}.error-actions{flex-direction:column;gap:10px}.btn-retry{font-size:14px;padding:12px 20px;width:100%}}
/*# sourceMappingURL=main.c4ade27e.css.map*/