:root{--primary:#646cff;--primary-hover:#747bff;--bg-color:#0f172a;--card-bg:#1e293b;--text-main:#f8fafc;--text-muted:#94a3b8;--accent:#38bdf8;--danger:#ef4444;--success:#22c55e;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:var(--text-main);background-color:var(--bg-color);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,-apple-system,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);background-image:radial-gradient(circle at 0 0,#646cff0d 0%,#0000 50%),radial-gradient(circle at 100% 100%,#38bdf80d 0%,#0000 50%);min-height:100vh}#root{width:100%}a{color:var(--primary);font-weight:500;text-decoration:none;transition:color .2s}a:hover{color:var(--accent)}button{font-family:inherit}img{max-width:100%;height:auto}::selection{color:#fff;background:#646cff4d}html{scroll-behavior:smooth}section[id]{scroll-margin-top:calc(var(--nav-height) + 2rem)}:root{--nav-height:72px}.navbar{height:var(--nav-height);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:1000;background:#0f172acc;border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:0 2rem;display:flex;position:fixed;top:0;left:0;right:0}.logo-container{align-items:center;text-decoration:none;display:flex}.navbar-logo{object-fit:contain;width:185px;height:auto;max-height:52px;display:block}.logo-text{display:none}.nav-links{align-items:center;gap:2.5rem;display:flex}.nav-links a{color:var(--text-main);opacity:.8;font-size:.95rem;transition:opacity .2s,color .2s}.nav-links a:hover{opacity:1;color:var(--accent)}.hero{text-align:center;padding:8rem 1rem 6rem}.hero h1{background:linear-gradient(#fff,#94a3b8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:1.5rem;font-size:clamp(2.5rem,8vw,4.5rem);font-weight:800;line-height:1.1}.hero p{color:var(--text-muted);max-width:700px;margin:0 auto 3rem;font-size:1.25rem;line-height:1.6}.container{max-width:1200px;padding:var(--nav-height) 2rem 4rem;min-height:calc(100vh - 100px);margin:0 auto}.project-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:2.5rem;margin-top:2rem;display:grid}.project-card{background:var(--card-bg);border:1px solid #ffffff0d;border-radius:16px;flex-direction:column;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;overflow:hidden}.project-card:hover{border-color:#646cff66;transform:translateY(-8px);box-shadow:0 20px 40px -15px #00000080}.project-image{object-fit:cover;border-bottom:1px solid #ffffff0d;width:100%;height:220px}.project-info{flex-direction:column;flex-grow:1;padding:2rem;display:flex}.project-info h3{justify-content:space-between;align-items:center;margin:0 0 .75rem;font-size:1.4rem;display:flex}.project-info p{color:var(--text-muted);margin-bottom:2rem;font-size:1rem;line-height:1.6}.project-links{gap:1.5rem;margin-top:auto;display:flex}.project-links a{align-items:center;gap:6px;font-size:.9rem;display:flex}.badge-private{color:#fb923c;text-transform:uppercase;letter-spacing:.5px;background:#fb923c1a;border:1px solid #fb923c33;border-radius:20px;padding:.2rem .6rem;font-size:.7rem;font-weight:600}.btn-primary{background:var(--primary);color:#fff;border:none;border-radius:10px;padding:.8rem 1.5rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-block}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 10px 20px -10px #646cff80}.logout-btn{color:#ef4444;cursor:pointer;background:#ef44441a;border:1px solid #ef444433;border-radius:8px;padding:.5rem 1.25rem;font-weight:500;transition:all .2s}.logout-btn:hover{color:#fff;background:#ef4444}.footer{background:linear-gradient(#0000,#0f172a66);border-top:1px solid #ffffff0d;margin-top:4rem;padding:3rem 2rem}.footer-content{justify-content:center;max-width:1200px;margin:0 auto;display:flex}.footer-copyright{color:var(--text-muted);opacity:.6;text-align:center;font-size:.85rem}.login-page{justify-content:center;align-items:center;padding:4rem 1rem;display:flex}.auth-card{background:var(--card-bg);border:1px solid #ffffff14;border-radius:24px;width:100%;max-width:440px;padding:3.5rem;box-shadow:0 25px 50px -12px #00000080}.auth-header{text-align:center;margin-bottom:3rem}.auth-logo{height:80px;margin-bottom:1.5rem}.auth-header h2{margin-bottom:.5rem;font-size:1.75rem;font-weight:700}.auth-header p{color:var(--text-muted);font-size:.95rem}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--text-muted);margin-bottom:.6rem;font-size:.9rem;display:block}.form-group input{color:#fff;background:#0f172a80;border:1px solid #ffffff1a;border-radius:10px;width:100%;padding:.8rem 1rem;font-size:1rem;transition:border-color .2s}.form-group input:focus{border-color:var(--primary);outline:none}.captcha-container{background:#0f172a4d;border:1px solid #ffffff14;border-radius:12px;flex-direction:column;gap:1rem;margin-bottom:2rem;padding:1.25rem;display:flex}.captcha-box{color:var(--text-main);justify-content:space-between;align-items:center;font-size:.95rem;display:flex}.captcha-box strong{color:var(--accent);letter-spacing:1px;background:#0003;border-radius:6px;padding:.2rem .6rem;font-size:1.2rem}.captcha-input-wrapper{gap:10px;display:flex}.captcha-input-wrapper input{text-align:center;letter-spacing:2px;flex:1;font-weight:700}.refresh-captcha{color:var(--text-muted);cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex}.refresh-captcha:hover{color:#fff;background:#ffffff1a;transform:rotate(90deg)}.error-banner{color:#ef4444;text-align:center;background:#ef44441a;border:1px solid #ef444433;border-radius:10px;margin-bottom:1.5rem;padding:.8rem;font-size:.9rem}.login-submit{width:100%;margin-top:1rem}.auth-footer{text-align:center;margin-top:2rem}.auth-footer a{color:var(--text-muted);font-size:.9rem}.switch-group{background:#0003;border:1px solid #ffffff0d;border-radius:12px;flex-direction:column;gap:.8rem;padding:1.2rem;display:flex}.switch-item{cursor:pointer;justify-content:space-between;align-items:center;display:flex}.switch-label{color:var(--text-main);font-size:.95rem}.switch-toggle{background:#ffffff1a;border-radius:20px;width:44px;height:22px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.switch-toggle:after{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute;top:3px;left:3px}.switch-item.active .switch-toggle{background:var(--primary)}.switch-item.active .switch-toggle:after{left:25px}
