*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,sans-serif}#root{min-height:100vh}:root{--primary-color: #646cff;--primary-hover: #535bf2;--background: #ffffff;--surface: #f9f9f9;--text: #213547;--text-secondary: #666;--border: #e0e0e0;--shadow: 0 2px 8px rgba(0,0,0,.1);--shadow-hover: 0 4px 16px rgba(0,0,0,.15);--border-radius: 12px;--spacing: 1rem;--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease}.dark-mode{--primary-color: #7c7cff;--primary-hover: #9999ff;--background: #1a1a1a;--surface: #2d2d2d;--text: #ffffff;--text-secondary: #cccccc;--border: #404040;--shadow: 0 2px 8px rgba(0,0,0,.3);--shadow-hover: 0 4px 16px rgba(0,0,0,.4)}.dark-mode .auth-container{background:linear-gradient(135deg,#1a1a1a,#2d1b69)}.dark-mode .auth-card{background:var(--surface);border:1px solid var(--border)}.dark-mode .auth-input,.dark-mode .profile-button{background:var(--background);border-color:var(--border);color:var(--text)}.dark-mode .nav-link{color:var(--text)}.dark-mode .nav-link:hover{background:var(--background)}*{box-sizing:border-box;transition:background-color var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}body{margin:0;font-family:Inter,system-ui,sans-serif;background:var(--background);color:var(--text)}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing)}.navbar{width:100%;z-index:1000;padding:1rem 2rem;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);box-shadow:var(--shadow)}.navbar-flex{display:flex;align-items:center;justify-content:space-between;width:100%;gap:1.5rem}.navbar-brand:hover{transform:scale(1.05)}.nav-link{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:var(--border-radius);text-decoration:none;color:var(--text);font-weight:500;font-size:1rem;transition:all var(--transition-fast);background:none;border:none}.mobile-footer{display:none;position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--surface);border-top:1px solid var(--border);box-shadow:var(--shadow);z-index:1200;align-items:center;justify-content:space-around;gap:.25rem;padding:.25rem .5rem}.mobile-button{background:none;border:none;color:var(--text);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;text-decoration:none;font-weight:600;padding:.1rem .5rem;min-width:56px;cursor:pointer}.mobile-button:active{transform:translateY(-1px)}.mobile-icon{font-size:1.3rem;line-height:1}.mobile-label{font-size:.65rem}.mobile-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;border:2px solid var(--primary-color)}@media (max-width: 1024px){.navbar{display:none}.mobile-footer{display:flex}body{padding-bottom:74px}}.dark-mode .mobile-footer{background:var(--surface);color:var(--text);border-top-color:var(--border)}.brand-icon{font-size:2rem}.brand-text{display:flex;flex-direction:row;line-height:1;gap:.25rem}.brand-skill{font-size:1rem;font-weight:700;color:var(--primary-color)}.brand-challenge{font-size:1rem;font-weight:500;color:var(--text-secondary);margin-top:0}.btn{padding:.75rem 1.5rem;border:none;border-radius:var(--border-radius);font-weight:500;cursor:pointer;transition:all var(--transition-fast);text-decoration:none;display:inline-block;text-align:center;position:relative;overflow:hidden}.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 var(--transition-slow)}.btn:hover:before{left:100%}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:#f0f0f0;transform:translateY(-1px)}.btn:active{transform:translateY(0)}.vote-btn{background:linear-gradient(135deg,#e637ab,#7a1dd1);color:#fff;border:none;box-shadow:0 4px 12px #8a2be240;margin-left:.7rem}.vote-btn:hover{filter:brightness(1.05);transform:translateY(-1px)}.vote-btn:active{transform:translateY(0)}.vote-btn[disabled]{background:linear-gradient(135deg,#a73d83,#5c278d);color:#cfcfcf;box-shadow:none;cursor:not-allowed;filter:none}.vote-btn.dimmed{background:linear-gradient(135deg,#a73d83,#5c278d);color:#ececec;box-shadow:none;filter:grayscale(40%) brightness(.9)}.vote-btn.dimmed:hover{filter:grayscale(20%) brightness(1)}.result-item.dimmed{opacity:.55;filter:grayscale(40%);transition:opacity .2s ease,filter .2s ease}.vote-btn.voted{box-shadow:0 6px 16px #8a2be259}.vote-btn.voted:hover{filter:brightness(1.08)}.challenge-details-base{max-width:500px;margin:2em auto;padding:24;border:1px solid #ccc;border-radius:8px;padding:10px;display:flex;flex-direction:column}.results-list{display:flex;flex-direction:column;justify-content:center;gap:.75rem;padding:0}.result-item{list-style:none}.result-card{background:#fff;border:1px solid #ececec;border-radius:14px;padding:14px;box-shadow:0 6px 20px #0000000f;margin-bottom:1rem}.result-card--muted{opacity:.85;background:linear-gradient(180deg,#fafafa,#f7f7f7)}.result-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.result-user{display:flex;align-items:center;gap:10px}.user-name{font-weight:700;letter-spacing:.2px}.avatar-circle{display:inline-block;padding:6px 12px;border-radius:10px;font-weight:700;color:#fff;line-height:1.2;white-space:nowrap;max-width:100%}.result-user,.result-actions{display:flex;align-items:center;gap:10px}.vote-badge{white-space:nowrap;background:#f3e9ff;color:#5a2bb3;font-weight:700;border-radius:999px;padding:6px 10px;line-height:1;box-shadow:inset 0 0 0 1px #8a2be240}.result-media{margin-top:12px;overflow:hidden;border-radius:12px}.result-media iframe,.result-media img,.result-media video{width:100%;max-width:760px;height:auto;display:block;border-radius:12px}.media-fallback{padding:12px;color:#666}.result-freetext{margin-top:10px}.pdf-link{display:inline-block;padding:10px 12px;margin:6px 0;background:#fff;border:1px solid #e6e6e6;border-radius:10px;text-decoration:none}.dark-mode .result-card{background:#1f1f1f;border-color:#2a2a2a;box-shadow:0 6px 20px #00000040}.dark-mode .vote-badge{background:#2a1f3f;color:#d8c9ff;box-shadow:inset 0 0 0 1px #d8c9ff2e}.winners-banner{display:flex;align-items:center;justify-content:center;gap:10px;width:max-content;margin:8px auto 16px;padding:10px 16px;border-radius:14px;background:linear-gradient(135deg,#f6c,#8a2be2);color:#fff;font-weight:900;border:none;box-shadow:0 8px 24px #8a2be240}.winners-banner .trophy{font-size:1.3rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.winners-banner .winners-text{letter-spacing:.3px;text-shadow:0 1px 1px rgba(0,0,0,.15)}.result-card--winner{border-color:#eabfff!important;box-shadow:0 8px 24px #8a2be21f}.challenge-meta-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px;box-shadow:var(--shadow);margin:.75rem 0 1.25rem}.status-badge{display:inline-block;font-weight:700;font-size:.85rem;padding:6px 10px;border-radius:999px;margin-bottom:10px;line-height:1;box-shadow:inset 0 0 0 1px #0000000f}.status-open{background:#e7f7ef;color:#0e7a4b;box-shadow:inset 0 0 0 1px #0e7a4b33}.status-closed{background:#f3e9ff;color:#5a2bb3;box-shadow:inset 0 0 0 1px #8a2be240}.status-finished{background:#eef0f3;color:#525866;box-shadow:inset 0 0 0 1px #52586633}.description-box{background:var(--background);border:1px solid var(--border);border-radius:12px;padding:12px;margin-bottom:12px}.meta-description{white-space:pre-wrap;color:var(--text-secondary);line-height:1.5}.meta-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}@media (max-width: 640px){.meta-grid{grid-template-columns:1fr}}.meta-item{background:var(--background);border:1px solid var(--border);border-radius:12px;padding:10px 12px}.meta-label{font-size:.8rem;color:var(--text-secondary);margin-bottom:4px}.meta-value{font-weight:700;color:var(--text)}.participants-count{display:inline-block;margin-right:8px}.participants-bar{display:inline-flex;align-items:center;width:100%;height:10px;border-radius:999px;background:#ececec;overflow:hidden;vertical-align:middle}.participants-fill{height:100%;background:linear-gradient(135deg,#e637ab,#7a1dd1);width:0%;transition:width .4s ease}.section-title{margin:.8rem 0 2rem;font-size:2.7rem;font-weight:800;letter-spacing:.2px;background:linear-gradient(135deg,var(--primary-color),#9333ea);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center}.profile-card-container{display:flex;justify-content:center}.profile-card{margin-top:1rem;width:98%;max-width:none;border-radius:var(--border-radius);box-shadow:var(--shadow);padding:1.5rem 0;background:#fff;border:1px solid var(--border)}.profile-header{text-align:center;margin-bottom:2rem}@media (max-width: 480px){.profile-card{padding:1rem 0;border-radius:0}}.profile-actions{display:flex}.profile-buttons{width:100%;display:flex;justify-content:space-evenly}@media (max-width: 1024px){.profile-buttons{flex-direction:column;gap:1rem;align-items:center}}.notification-settings{margin:2rem 0;border:1px solid #bbb;border-radius:10px;width:98%;margin-left:auto;margin-right:auto;box-sizing:0 2px 8px rgba(0,0,0,.04);display:flex;flex-direction:column;align-items:center}.notification-checkbox-row{display:flex;flex-direction:row;gap:2rem;justify-content:center;width:100%;margin-bottom:.5rem}@media (max-width: 1024px){.notification-checkbox-row{flex-direction:column;gap:1rem;align-items:center}}.notification-label{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.card{background:#fff;border-radius:var(--border-radius);box-shadow:var(--shadow);padding:1.5rem;transition:all var(--transition-normal);border:1px solid var(--border)}.card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px) translateZ(0)}.challenge-card{display:flex;flex-direction:column;align-items:center;text-align:center;cursor:pointer;min-height:280px;max-width:250px;width:100%}.challenge-card img{width:100%;height:180px;object-fit:cover;border-radius:8px;margin-bottom:1rem;transition:transform var(--transition-normal)}.challenge-card:hover img{transform:scale(1.05)}.challenge-title{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.challenge-meta{font-size:.9rem;color:var(--text-secondary)}.form-container{max-width:400px;margin:2rem auto;padding:2rem;background:#fff;border-radius:var(--border-radius);box-shadow:var(--shadow)}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500}.form-control{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:8px;font-size:1rem;background:var(--background);color:var(--text);transition:all var(--transition-fast)}.form-control:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #646cff1a}.skeleton-card{background:#fff;border-radius:var(--border-radius);padding:1.5rem;box-shadow:var(--shadow);animation:pulse 1.5s ease-in-out infinite alternate}.skeleton-image{width:100%;height:180px;background:#e0e0e0;border-radius:8px;margin-bottom:1rem}.skeleton-text{height:16px;background:#e0e0e0;border-radius:4px;margin-bottom:.5rem}.skeleton-title{height:20px;width:80%}.skeleton-meta{height:14px;width:60%}.skeleton-profile{text-align:center;padding:2rem}.skeleton-avatar{width:100px;height:100px;border-radius:50%;background:#e0e0e0;margin:0 auto 1rem}.skeleton-name{width:150px;margin:0 auto .5rem}.toast-container{position:fixed;top:100px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:.5rem}.toast{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;border-radius:var(--border-radius);box-shadow:var(--shadow-hover);cursor:pointer;animation:slideIn .3s ease-out;min-width:300px;max-width:400px;will-change:transform,opacity;transform:translateZ(0)}.toast-success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.toast-error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.toast-warning{background:#fff3cd;border:1px solid #ffeaa7;color:#856404}.toast-info{background:#d1ecf1;border:1px solid #bee5eb;color:#0c5460}.toast-message{flex:1;font-weight:500}.toast-close{background:none;border:none;font-size:1.5rem;cursor:pointer;opacity:.7;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.toast-close:hover{opacity:1}.clear-all-toasts{background:var(--primary-color);color:#fff;border:none;border-radius:var(--border-radius);padding:.5rem 1rem;font-size:.8rem;cursor:pointer;margin-bottom:.5rem;transition:all var(--transition-fast);align-self:flex-end}.clear-all-toasts:hover{background:var(--primary-hover);transform:translateY(-1px)}.search-filter-container{background:#fff;padding:1.5rem;border-radius:var(--border-radius);box-shadow:var(--shadow);margin-bottom:2rem;margin-top:1rem}.search-bar{position:relative;margin-bottom:1rem}.search-input{padding-left:2.5rem}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:#666}.filter-controls{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.filter-select{min-width:150px}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500}.checkbox-label input[type=checkbox]{width:auto}.theme-toggle{background:none;border:2px solid var(--border);border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-normal);margin-left:.5rem}.theme-toggle:hover{border-color:var(--primary-color);transform:rotate(180deg)}.theme-icon{font-size:1.2rem;transition:transform var(--transition-normal)}.theme-toggle:hover .theme-icon{transform:scale(1.1)}.my-profile{background:none;border:none;padding:0;margin-left:1rem}.user-icon{width:32px;height:32px;border-radius:50%;transition:transform var(--transition-fast)}.user-icon:hover{transform:scale(1.1)}.user-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid var(--primary-color)}.user-name{font-weight:600;font-size:.9rem;display:none}.user-detail{width:100%;padding:0 12px}.user-profile-header{display:grid;place-items:center;gap:10px;margin:10px 0 6px}.avatar-outer{display:grid;place-items:center}.avatar-circle-fade{width:180px;height:180px;object-fit:cover;border-radius:50%;-webkit-mask-image:radial-gradient(circle at center,rgba(0,0,0,1) 72%,rgba(0,0,0,0) 100%);mask-image:radial-gradient(circle at center,#000 72%,#0000);box-shadow:0 10px 28px #8a2be233}.user-name-title{margin:0;font-size:3rem;font-weight:900;background:linear-gradient(135deg,var(--primary-color),#ff66cc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(305px,1fr));gap:14px;width:100%;margin:0 auto 1.25rem}.category-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:12px;box-shadow:var(--shadow)}.dark-mode .category-card{background:#1f1f1f;border-color:#2a2a2a;box-shadow:0 6px 20px #00000040}.category-image{width:100%;height:30%;object-fit:cover;border-radius:12px;border:1px solid var(--border)}.category-image.placeholder{display:grid;place-items:center;background:linear-gradient(135deg,#ffd1e8,#d9c3ff);color:#5a2bb3;font-weight:900;font-size:1.05rem;border:1px solid #e6d9ff}.category-title{font-weight:800;font-size:1.3rem;letter-spacing:.2px;margin:10px;color:var(--primary-color);text-align:center;white-space:nowrap}.subratings{list-style:none;margin:0;padding:0;display:grid;gap:8px}.subrating-row{display:grid;grid-template-columns:1fr auto;align-items:center;padding:8px 10px;border-radius:10px;background:var(--background)}.empty-note{color:var(--text-secondary);font-size:.95rem;padding:6px 0}.sub-name{display:inline-flex;align-items:center;gap:8px;min-width:0}.subcat-icon{width:26px;height:26px;border-radius:50%;object-fit:cover;flex:0 0 26px;border:1px solid var(--border, #ececec);box-shadow:0 2px 6px #0000000d}.subcat-icon.placeholder{display:grid;place-items:center;background:linear-gradient(135deg,#ffd1e8,#d9c3ff);color:#5a2bb3;font-weight:800;font-size:.85rem}.subcat-label{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin:2rem auto}.fade-in{animation:fadeIn var(--transition-slow) ease-in}.slide-in-left{animation:slideInLeft var(--transition-normal) ease-out}.slide-in-right{animation:slideInRight var(--transition-normal) ease-out}.bounce-in{animation:bounceIn .6s ease-out}.pulse{animation:pulse 2s infinite}.shake{animation:shake .5s ease-in-out}.stagger-item{opacity:0;transform:translateY(20px);animation:staggerIn .5s ease-out forwards}.stagger-item:nth-child(1){animation-delay:.1s}.stagger-item:nth-child(2){animation-delay:.2s}.stagger-item:nth-child(3){animation-delay:.3s}.stagger-item:nth-child(4){animation-delay:.4s}.stagger-item:nth-child(5){animation-delay:.5s}.stagger-item:nth-child(6){animation-delay:.6s}@keyframes pulse{0%{opacity:1}to{opacity:.6}}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes bounceIn{0%{transform:scale(.3);opacity:0}50%{transform:scale(1.05)}70%{transform:scale(.9)}to{transform:scale(1);opacity:1}}@keyframes staggerIn{to{opacity:1;transform:translateY(0)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.dark-mode body{background:var(--background);color:var(--text)}.dark-mode .navbar{background:#2d2d2df2;border-bottom-color:var(--border)}.dark-mode .card{background:var(--surface);border-color:var(--border)}.dark-mode .profile-card{background:var(--surface);color:var(--text);border-color:var(--border)}.dark-mode .form-control{background:var(--surface);border-color:var(--border);color:var(--text)}.dark-mode .form-control:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #7c7cff1a}.dark-mode .btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border)}.dark-mode .btn-secondary:hover,.dark-mode .skeleton-image,.dark-mode .skeleton-text{background:#404040}.dark-mode .search-filter-container{background:var(--surface)}.dark-mode .toast-success{background:#1e4d3a;border-color:#2d5a3d;color:#a3d9b1}.dark-mode .toast-error{background:#4d1e1e;border-color:#5a2d2d;color:#d9a3a3}.dark-mode .toast-warning{background:#4d3d1e;border-color:#5a4a2d;color:#d9c3a3}.dark-mode .toast-info{background:#1e3d4d;border-color:#2d4a5a;color:#a3c3d9}@media (max-width: 1024px){.navbar-flex{flex-direction:column;align-items:stretch;gap:.5rem}.nav-link,.btn,.profile-button{width:100%;justify-content:center;font-size:1rem;padding:.75rem .5rem}.user-name{display:none}}.nav-link:hover{background:var(--surface);transform:translateY(-2px)}.nav-link:after{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background:var(--primary-color);transition:all var(--transition-normal);transform:translate(-50%)}.nav-link:hover:after{width:80%}.nav-icon{font-size:1.1rem}.user-menu{display:flex;align-items:center;flex-direction:column;gap:.5rem}.profile-button{display:flex;align-items:center;gap:.75rem;background:var(--surface);border:2px solid var(--border);border-radius:50px;padding:.5rem 1rem .5rem .5rem;cursor:pointer;transition:all var(--transition-normal);text-decoration:none;color:var(--text)}.profile-button:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.btn{padding:.5rem 1rem;font-size:.9rem}.challenge-card{max-width:100%}.three-column-challenges{display:grid;grid-template-columns:1fr 1fr 1fr;gap:2rem;max-width:1200px;margin:2rem auto;align-items:start}.challenge-column{display:flex;flex-direction:column;gap:1rem;align-items:center}.challenge-header{text-align:center;margin-bottom:1rem;font-size:1.2rem;font-weight:700}@media (max-width: 900px){.three-column-challenges{grid-template-columns:1fr;gap:1.5rem}}.search-filter-container{padding:1rem}.filter-controls{flex-direction:column;gap:.75rem}.form-container{margin:1rem auto;padding:1.5rem}@media (max-width: 768px){.auth-card{padding:2rem 1.5rem;margin:1rem}.stagger-item{animation:none;opacity:1;transform:none}.card:hover{transform:none}}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}img{max-width:100%;height:auto}.auth-container{min-height:calc(100vh - 94px);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-color) 0%,#9333ea 100%)}.auth-card{background:#fff;border-radius:20px;box-shadow:0 20px 40px #0000001a;padding:3rem;width:100%;max-width:450px;animation:slideUp .6s ease-out}.auth-header{text-align:center;margin-bottom:2rem}.auth-title{font-size:1.5rem;font-weight:700;color:var(--text);margin-bottom:.5rem;background:linear-gradient(135deg,var(--primary-color),#9333ea);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-subtitle{color:var(--text-secondary);font-size:1rem;margin:0}.auth-form{margin-bottom:2rem}.auth-buttons{display:flex;align-items:center;gap:.75rem}.btn-outline{background:transparent;color:var(--text);border:2px solid var(--border)}.btn-outline:hover{background:var(--surface);border-color:var(--primary-color);color:var(--primary-color)}.logout-btn{font-size:.9rem;padding:.5rem 1rem}.input-wrapper{position:relative;margin-bottom:1rem}.input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);font-size:1.2rem;z-index:2}.auth-input{padding-left:3rem!important;height:3rem;border:2px solid var(--border);transition:all var(--transition-normal);font-size:1rem}.auth-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 4px #646cff1a;transform:translateY(-2px)}.auth-submit{width:100%;height:3rem;font-size:1.1rem;font-weight:600;margin-top:1rem;position:relative;overflow:hidden}.auth-submit.loading{pointer-events:none}.spinner{width:20px;height:20px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite;margin-right:.5rem;display:inline-block}.auth-footer{text-align:center;padding-top:1rem;border-top:1px solid var(--border)}.forgot-password{text-align:center;margin-bottom:1rem}.modal-backdrop{text-align:center}.link-button{background:none;border:none;color:var(--primary-color);font-weight:600;cursor:pointer;text-decoration:underline;margin-left:.5rem;transition:color var(--transition-fast)}.link-button:hover{color:var(--primary-hover)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.about-container{display:flex;justify-content:center;align-items:flex-start;min-height:60vh;padding:2rem 1rem}.about-card{background:var(--surface);border-radius:var(--border-radius);box-shadow:var(--shadow);padding:2.5rem 2rem;max-width:1000px;width:100%;border:1px solid var(--border);animation:fadeIn .7s}.about-title{font-size:2rem;font-weight:700;margin-bottom:1.5rem;text-align:center;letter-spacing:-1px}.about-list{list-style:disc inside;color:var(--text-secondary);font-size:1.1rem;margin-bottom:2rem;padding-left:1rem}.about-list li{margin-bottom:.75rem;line-height:1.6}.about-contact{text-align:center;font-size:1rem;color:var(--primary-color);margin-top:1.5rem;font-weight:500}.dark-mode .about-card{background:var(--surface);color:var(--text);border-color:var(--border)}.dark-mode .about-list{color:var(--text-secondary)}.challenge-footer-buttons{display:flex;justify-content:center;gap:1rem;margin:3rem 0 1.5rem}.footer-btn{display:flex;align-items:center;gap:.5rem;background:var(--primary-color);color:#fff;border:none;border-radius:var(--border-radius);padding:.75rem 1.5rem;font-size:1rem;font-weight:500;text-decoration:none;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast);box-shadow:var(--shadow)}.footer-btn:hover{background:var(--primary-hover);transform:translateY(-2px)}.footer-btn-icon{font-size:1.2rem}.user-link{color:var(--primary-color);text-decoration:none;font-weight:600;cursor:pointer}.user-link:hover{text-decoration:underline}.result-uploaded{color:green;margin-left:8px;font-weight:700}.upload-container{display:flex;justify-content:center;padding:12px}.upload-card{background:#fff;border:1px solid var(--border, #ececec);border-radius:14px;padding:16px;box-shadow:0 6px 20px #0000000f;width:100%;max-width:720px}.upload-type-toggle{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0 14px;justify-content:space-evenly}.toggle-btn{background:#f7f7f9;color:#444;border:1px solid #e6e6e9;border-radius:999px;padding:8px 12px}.toggle-btn.active{background:linear-gradient(135deg,#f6c,#8a2be2);color:#fff;border-color:transparent;box-shadow:0 4px 12px #8a2be240}.form-group{display:grid;gap:6px;margin-bottom:14px}.form-label{font-size:.85rem;color:var(--text-secondary, #6b7280)}.input,.textarea{width:100%;border:1px solid #e6e6e6;border-radius:10px;padding:10px 12px;outline:none;transition:border-color .15s ease,box-shadow .15s ease;background:#fff;color:var(--text, #111827)}.input:focus,.textarea:focus{border-color:#d4b7ff;box-shadow:0 0 0 3px #8a2be226}.textarea{min-height:120px;resize:vertical}.input-file{border:1px dashed #d6d6d6;border-radius:10px;padding:10px;background:#fafafa}.file-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;margin-top:8px;background:#f8f4ff;color:#5a2bb3;border:1px solid #e4d8ff;border-radius:999px;font-weight:600}.file-size{color:#7c7c7c;font-weight:500}.helper-text{font-size:.8rem;color:#888}.submit-btn{width:100%;margin-top:6px;background:linear-gradient(135deg,#f6c,#8a2be2);color:#fff;border:none;box-shadow:0 6px 16px #8a2be240}.submit-btn[disabled]{background:#4a4a4a;color:#cfcfcf;box-shadow:none;cursor:not-allowed}.status-msg{margin-top:10px;padding:10px 12px;border-radius:10px;font-weight:600}.status-msg.success{background:#e7f7ef;color:#0e7a4b;border:1px solid rgba(14,122,75,.2)}.status-msg.error{background:#fee;color:#9b1c1c;border:1px solid rgba(155,28,28,.2)}.dark-mode .upload-card{background:#1f1f1f;border-color:#2a2a2a;box-shadow:0 6px 20px #00000040}.dark-mode .toggle-btn{background:#2a2a2f;color:#dcdcdc;border-color:#3a3a3f}.dark-mode .input,.dark-mode .textarea,.dark-mode .input-file{background:#222;color:#f0f0f0;border-color:#2f2f2f}.dark-mode .file-pill{background:#2a1f3f;color:#d8c9ff;border-color:#d8c9ff2e}
