@import "https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;600;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;600;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;600;700&display=swap";.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}.home-page{color:#fff;background:linear-gradient(#0f172ad9,#0f172ad9),url(/assets/background-DKMsXoKq.jpg) 50%/cover no-repeat;flex-direction:column;width:100%;min-height:100vh;display:flex;overflow-x:hidden}.home-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;background:#ffffff08;border-bottom:1px solid #ffffff1a;padding:1rem;position:sticky;top:0}.header-content{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;max-width:1200px;margin:0 auto;display:flex}.logo{white-space:nowrap;font-size:1.4rem;font-weight:700}.logo span{color:#38bdf8}.header-nav{align-items:center;gap:12px;display:flex}.login-link{color:#fff;white-space:nowrap;justify-content:center;align-items:center;padding:8px 12px;font-size:.8rem;text-decoration:none;display:flex}.register-btn{color:#0f172a;white-space:nowrap;background:#38bdf8;border-radius:8px;justify-content:center;align-items:center;padding:8px 12px;font-size:.8rem;font-weight:600;text-decoration:none;transition:all .3s;display:flex}.home-main{text-align:center;flex-direction:column;flex:1;justify-content:center;max-width:1100px;margin:0 auto;padding:40px 20px;display:flex}.hero-content h1{margin-bottom:20px;font-size:2.2rem;line-height:1.2}.hero-content h1 span{color:#38bdf8}.hero-content p{color:#cbd5e1;max-width:700px;margin:0 auto 30px;font-size:1rem;font-weight:300}.hero-btns{flex-direction:column;gap:12px;display:flex}.cta-primary,.cta-secondary{border-radius:12px;justify-content:center;align-items:center;gap:10px;width:100%;padding:14px;font-size:1rem;font-weight:700;text-decoration:none;transition:all .3s;display:flex}.cta-primary{color:#0f172a;background:#38bdf8}.cta-secondary{color:#fff;background:#ffffff1a;border:1px solid #fff3}.features-grid{grid-template-columns:1fr;gap:20px;margin-top:50px;display:grid}.feature-card{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:20px;padding:30px 20px}.feature-icon{color:#38bdf8;margin-bottom:15px;font-size:2rem}@media (width<=330px){.home-header{padding:.4rem .2rem}.header-content{gap:2px;padding:0 3px}.logo{font-size:.7rem}.header-nav{gap:1px}.login-link,.register-btn{padding:3px 4px;font-size:.55rem}}@media (width<=380px){.home-header{padding:.5rem .25rem}.header-content{gap:4px;width:100%;padding:0 5px}.logo{flex-shrink:0;font-size:.75rem;font-weight:700}.header-nav{flex-shrink:0;gap:2px;margin-left:auto}.login-link,.register-btn{padding:4px 5px;font-size:.6rem}.home-main{padding:20px 15px}.hero-content h1{margin-bottom:15px;font-size:1.5rem}.hero-content p{margin-bottom:20px;font-size:.85rem}.hero-btns{gap:10px}.cta-primary,.cta-secondary{padding:12px;font-size:.9rem}.features-grid{gap:15px;margin-top:30px}.feature-card{padding:20px 15px}}@media (width>=381px) and (width<=767px){.home-header{padding:.75rem .5rem}.header-content{gap:8px}.logo{font-size:1.1rem}.header-nav{gap:10px}.login-link,.register-btn{padding:6px 10px;font-size:.75rem}.home-main{padding:30px 20px}.hero-content h1{margin-bottom:20px;font-size:2rem}.hero-content p{margin-bottom:25px;font-size:.95rem}.hero-btns{gap:10px}.cta-primary,.cta-secondary{padding:13px;font-size:.95rem}}@media (width>=768px){.logo{font-size:1.8rem}.header-nav{gap:20px}.login-link,.register-btn{padding:10px 20px;font-size:.9rem}.hero-content h1{font-size:3.5rem}.hero-btns{flex-direction:row;justify-content:center}.cta-primary,.cta-secondary{width:auto;padding:15px 35px}.features-grid{grid-template-columns:repeat(3,1fr)}}@media (width>=1024px){.hero-content h1{font-size:3.8rem}}.about-container{color:#f8fafc;background:#0f172a;min-height:100vh;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.about-nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1e293b66;border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;padding:20px 10%;display:flex}.back-link{color:#38bdf8;align-items:center;gap:8px;font-weight:600;text-decoration:none;transition:all .3s;display:flex}.back-link:hover{color:#7dd3fc;transform:translate(-5px)}.about-logo{font-size:1.2rem;font-weight:700}.about-logo span{color:#38bdf8}.about-content{max-width:1000px;margin:0 auto;padding:60px 20px}.about-header{text-align:center;margin-bottom:60px}.header-icon{color:#38bdf8;margin-bottom:20px;font-size:3rem}.about-header h1{margin-bottom:10px;font-size:2.5rem}.about-header p{color:#94a3b8;font-size:1.1rem}.about-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px;margin-bottom:60px;display:grid}.about-card{text-align:center;background:#1e293b80;border:1px solid #ffffff1a;border-radius:16px;padding:30px;transition:all .3s}.about-card:hover{border-color:#38bdf8;transform:translateY(-5px)}.card-icon{color:#38bdf8;margin-bottom:15px;font-size:2rem}.about-card h3{margin-bottom:12px;font-size:1.3rem}.about-card p{color:#94a3b8;line-height:1.6}.dev-section{text-align:center;background:#0f172acc;border:1px dashed #38bdf84d;border-radius:20px;padding:40px}.progress-bar-container{background:#1e293b;border-radius:50px;width:100%;height:25px;margin:20px 0;overflow:hidden}.progress-bar{color:#0f172a;background:linear-gradient(90deg,#38bdf8,#818cf8);border-radius:50px;justify-content:center;align-items:center;height:100%;font-size:.8rem;font-weight:700;display:flex}.status-text{color:#94a3b8}.about-footer{text-align:center;color:#64748b;padding:40px;font-size:.9rem}@media (width<=380px){.about-nav{flex-wrap:wrap;gap:10px;padding:15px 5%}.back-link{font-size:.85rem}.about-logo{font-size:1rem}.about-content{padding:30px 12px}.about-header{margin-bottom:30px}.header-icon{font-size:2rem}.about-header h1{margin-bottom:8px;font-size:1.5rem}.about-header p{font-size:.9rem}.about-grid{grid-template-columns:1fr;gap:20px}.about-card{padding:20px}.about-card h3{font-size:1rem}.dev-section{padding:20px}.about-footer{padding:20px;font-size:.8rem}}@media (width>=381px) and (width<=600px){.about-header h1{font-size:1.8rem}.about-content{padding:30px 15px}.about-grid{grid-template-columns:repeat(2,1fr);gap:25px}.about-card,.dev-section{padding:25px}}@media (width>=601px) and (width<=1000px){.about-nav{padding:20px 5%}.about-content{padding:50px 20px}.about-header h1{font-size:2.2rem}.about-grid{grid-template-columns:repeat(3,1fr)}}@media (width>=1001px){.about-nav{padding:20px 10%}}.google-signin-container{--google-btn-height:3.25rem;--google-radius:.75rem;--google-text:#1f2937;--google-border:#dbe1e7;--google-border-hover:#c8d2dd;--google-bg-top:#fff;--google-bg-bottom:#f8fafc;--google-shadow:0 8px 18px #0f172a38;--google-shadow-hover:0 10px 22px #0f172a47;--google-ring:#38bdf866;width:100%;margin:.625rem 0;position:relative}.google-signin-container.disabled{opacity:.7;pointer-events:none}.google-btn{width:100%;min-height:var(--google-btn-height);background:linear-gradient(180deg, var(--google-bg-top), var(--google-bg-bottom));border:1px solid var(--google-border);border-radius:var(--google-radius);color:var(--google-text);letter-spacing:.01em;cursor:pointer;box-shadow:var(--google-shadow);justify-content:center;align-items:center;gap:.75rem;padding:.875rem 1rem;font-family:Poppins,sans-serif;font-size:.98rem;font-weight:600;transition:transform .2s,box-shadow .2s,border-color .2s,filter .2s;display:flex}.google-btn:hover:not(:disabled){border-color:var(--google-border-hover);box-shadow:var(--google-shadow-hover);filter:brightness(1.01);transform:translateY(-1px)}.google-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 5px 10px #0f172a2e,inset 0 1px #ffffffe6}.google-btn:focus-visible{outline-offset:2px;box-shadow:0 0 0 4px var(--google-ring), var(--google-shadow);outline:2px solid #38bdf8}.google-btn:disabled{opacity:.72;cursor:not-allowed;transform:none}.google-icon{color:#4285f4;font-size:1.1rem}.google-btn span{line-height:1.2}.disabled-overlay{min-height:var(--google-btn-height);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-radius:var(--google-radius);color:#cbd5e1;text-align:center;background:#0f172abf;justify-content:center;align-items:center;padding:.5rem .75rem;font-size:.78rem;display:flex;position:absolute;inset:0}@media (width<=480px){.google-btn{min-height:3rem;padding:.8rem .9rem;font-size:.93rem}}@media (prefers-reduced-motion:reduce){.google-btn{transition:none}.google-btn:hover:not(:disabled),.google-btn:active:not(:disabled){transform:none}}.login-page{--cta-radius:.75rem;--cta-shadow:0 8px 18px #0f172a47;--cta-shadow-hover:0 10px 24px #0f172a57;--cta-ring:#38bdf861;background:linear-gradient(#0f172acc,#0f172acc),url(/assets/background-DKMsXoKq.jpg) 50%/cover no-repeat;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:20px;display:flex}.login-card{color:#fff;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#ffffff14;border:1px solid #fff3;border-radius:20px;width:100%;max-width:420px;padding:40px;animation:.4s ease-out fadeIn;box-shadow:0 25px 45px #00000080}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.input-group input{color:#fff;background:#0003;border:2px solid #ffffff1a;border-radius:12px;outline:none;width:100%;height:50px;padding:0 45px 0 20px;font-size:16px;transition:all .3s}.input-group input.invalid-input{border-color:#ef444480}.input-group input.valid-input{border-color:#22c55e80}.input-group input:focus{background:#0006;border-color:#38bdf8}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.submit-btn{border-radius:var(--cta-radius);color:#082f49;letter-spacing:.01em;cursor:pointer;width:100%;min-height:3.25rem;box-shadow:var(--cta-shadow);background:linear-gradient(135deg,#38bdf8 0%,#0ea5e9 100%);border:1px solid #7dd3fc61;outline:none;margin-top:10px;font-size:.98rem;font-weight:700;transition:transform .2s,box-shadow .2s,filter .2s,border-color .2s}.submit-btn:hover:not(:disabled){box-shadow:var(--cta-shadow-hover);filter:brightness(1.03);border-color:#bae6fde6;transform:translateY(-1px)}.submit-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 5px 10px #0ea5e94d,inset 0 1px #fff6}.submit-btn:focus-visible{outline-offset:2px;box-shadow:0 0 0 4px var(--cta-ring), var(--cta-shadow);outline:2px solid #38bdf8}.submit-btn:disabled{color:#e2e8f0d9;cursor:not-allowed;opacity:.72;background:linear-gradient(135deg,#64748b 0%,#475569 100%);border-color:#94a3b84d}.errmsg{color:#f87171;text-align:center;background-color:#ef444426;border:1px solid #ef44444d;border-radius:10px;justify-content:center;align-items:center;gap:8px;margin-bottom:20px;padding:12px;font-size:.9rem;animation:.5s ease-in-out shake;display:flex}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.warning-msg{color:#fbbf24;text-align:center;background-color:#fbbf2426;border:1px solid #fbbf244d;border-radius:8px;justify-content:center;align-items:center;gap:8px;margin-bottom:15px;padding:10px 12px;font-size:.85rem;animation:.3s ease-out fadeIn;display:flex}.input-group input.loading-input{color:#ffffff80;cursor:not-allowed;background:#0000001a;border-color:#94a3b84d}.submit-btn.loading{color:#f1f5f9e6;cursor:not-allowed;background:linear-gradient(135deg,#64748b 0%,#475569 100%);position:relative;overflow:hidden}.submit-btn.loading:after{content:"";background:linear-gradient(90deg,#0000,#fff3,#0000);width:100%;height:100%;animation:1.5s infinite loading-shimmer;position:absolute;top:0;left:-100%}@keyframes loading-shimmer{0%{left:-100%}to{left:100%}}.divider{color:#94a3b8;align-items:center;margin:20px 0;font-size:.9rem;display:flex}.divider:before,.divider:after{content:"";border-bottom:1px solid #fff3;flex:1}.divider span{padding:0 15px}.google-signin-container{width:100%;position:relative}.google-signin-container.disabled{filter:grayscale(50%);opacity:.6;pointer-events:none}.disabled-overlay{color:#94a3b8;z-index:10;background:#0f172acc;border-radius:12px;justify-content:center;align-items:center;width:100%;height:50px;font-size:.8rem;display:flex;position:absolute;top:0;left:0}.google-auth-error{color:#f87171;text-align:center;background:#ef44441a;border:1px solid #ef444433;border-radius:6px;margin-top:10px;padding:8px;font-size:.85rem}.google-signin-btn{color:#e2e8f0;cursor:pointer;background:#ffffff14;border:1px solid #fff3;border-radius:12px;justify-content:center;align-items:center;gap:10px;width:100%;height:50px;font-family:Poppins,sans-serif;font-size:15px;font-weight:500;transition:all .3s;display:flex}.google-signin-btn:hover:not(:disabled){background:#ffffff26;border-color:#ffffff59;transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.google-signin-btn:disabled{opacity:.6;cursor:not-allowed}.google-oauth-disabled{color:#64748b;cursor:not-allowed;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;justify-content:center;align-items:center;width:100%;height:50px;font-size:.9rem;display:flex}.google-auth-error{color:#f87171;text-align:center;margin-top:8px;font-size:.8rem}.form-footer{text-align:center;margin-top:25px;font-size:14px}.form-footer a{color:#38bdf8;font-weight:600;text-decoration:none}.form-footer a:hover{text-decoration:underline}.form-footer p{color:#94a3b8;margin-top:15px}@media (width<=380px){.login-card{max-width:95%;padding:25px 15px}.brand-title{margin-bottom:20px;font-size:1.5rem}.input-group input{height:45px;padding:0 40px 0 15px;font-size:14px}.submit-btn{min-height:2.9rem;font-size:.93rem}.instructions{padding:8px;font-size:.7rem}}@media (width>=380px) and (width<=480px){.login-card{max-width:90%;padding:30px 20px}.brand-title{font-size:1.8rem}}@media (width>=481px) and (width<=768px){.login-card{max-width:400px;padding:40px 25px}.brand-title{font-size:2rem}.input-group input{padding:0 45px 0 20px;font-size:15px}}@media (width>=769px){.login-card{max-width:450px;padding:40px}}@media (prefers-reduced-motion:reduce){.submit-btn{transition:none}.submit-btn:hover:not(:disabled),.submit-btn:active:not(:disabled){filter:none;transform:none}.submit-btn.loading:after{animation:none}}*{box-sizing:border-box;margin:0;padding:0;font-family:Poppins,sans-serif}.register-page{background:linear-gradient(#0f172acc,#0f172acc),url(/assets/background-DKMsXoKq.jpg) 50%/cover no-repeat;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.register-card{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);color:#fff;background:#1e293b99;border:1px solid #ffffff1a;border-radius:20px;width:100%;max-width:450px;padding:40px;animation:.4s ease-out fadeIn;box-shadow:0 20px 50px #0006}.brand-title{text-align:center;margin-bottom:5px;font-size:2.2rem;font-weight:700}.brand-title span{color:#38bdf8}.subtitle{text-align:center;color:#94a3b8;margin-bottom:30px;font-size:.95rem}.input-group{width:100%;margin-bottom:25px;position:relative}.input-group input{color:#fff;background:0 0;border:none;border-bottom:2px solid #fff3;outline:none;width:100%;height:45px;padding:0 45px 0 10px;font-size:1rem;transition:all .3s}.input-group input.invalid-input{border-bottom-color:#ef4444}.input-group input.valid-input{border-bottom-color:#22c55e}.input-group input:focus{background:#ffffff0d;border-bottom-color:#38bdf8}.input-icon{color:#64748b;pointer-events:none;font-size:1.1rem;position:absolute;top:50%;right:15px;transform:translateY(-50%)}.instructions{color:#38bdf8;background:#0f172ae6;border-left:3px solid #38bdf8;border-radius:8px;align-items:center;gap:10px;margin-top:10px;padding:10px;font-size:.75rem;line-height:1.4;animation:.2s ease-out slideDown;display:flex}.errmsg{color:#f87171;text-align:center;background:#ef444426;border:1px solid #ef44444d;border-radius:10px;margin-bottom:20px;padding:12px;font-size:.9rem}.submit-btn{color:#0f172a;cursor:pointer;background:#38bdf8;border:none;border-radius:12px;width:100%;height:50px;margin-top:15px;font-size:1rem;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1)}.submit-btn:hover:not(:disabled){background:#7dd3fc;transform:translateY(-2px);box-shadow:0 5px 15px #38bdf866}.submit-btn:disabled{color:#94a3b8;cursor:not-allowed;opacity:.5;background:#334155}.form-footer{text-align:center;color:#94a3b8;margin-top:25px;font-size:.9rem}.reg-link{color:#38bdf8;margin-left:5px;font-weight:600;text-decoration:none}.reg-link:hover{text-decoration:underline}.success-container{text-align:center;padding:20px 0}.offscreen{display:none}@media (width<=380px){.register-card{max-width:95%;padding:25px 15px}.brand-title{margin-bottom:10px;font-size:1.5rem}.input-group input{height:40px;font-size:14px}.submit-btn{height:45px;font-size:14px}.instructions{padding:8px;font-size:.7rem}}@media (width>=380px) and (width<=480px){.register-card{max-width:90%;padding:30px 20px}.brand-title{font-size:1.8rem}}@media (width>=481px) and (width<=768px){.register-card{max-width:420px;padding:40px 25px}.brand-title{font-size:2rem}}@media (width>=769px){.register-card{max-width:450px;padding:40px}}.recover-section{background:linear-gradient(#0f172acc,#0f172acc),url(/assets/background-DKMsXoKq.jpg) 50%/cover no-repeat;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:20px;display:flex}.recover-section .wrapper{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);color:#fff;background:#ffffff14;border:1px solid #fff3;border-radius:20px;width:420px;padding:40px;animation:.4s ease-out fadeIn;box-shadow:0 25px 45px #00000080}.wrapper h1{text-align:center;color:#38bdf8;margin-bottom:15px;font-size:1.8rem}.description{text-align:center;color:#94a3b8;margin-bottom:25px;font-size:.9rem;line-height:1.5}.input-box{width:100%;height:50px;margin-bottom:20px;position:relative}.input-box input{color:#fff;background:#ffffff14;border:1px solid #fff3;border-radius:10px;outline:none;width:100%;height:100%;padding:0 45px 0 15px;font-size:1rem;transition:all .3s}.input-box input:focus{background:#ffffff1f;border-color:#fff6;box-shadow:0 0 15px #38bdf84d}.input-box input::placeholder{color:#ffffff80}.input-box .icon{color:#94a3b8;position:absolute;top:50%;right:15px;transform:translateY(-50%)}.recover-btn{color:#0f172a;cursor:pointer;background:linear-gradient(135deg,#38bdf8 0%,#0ea5e9 100%);border:none;border-radius:10px;width:100%;height:45px;margin-top:10px;font-weight:700;transition:all .3s;box-shadow:0 4px 15px #38bdf866}.recover-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #38bdf899}.recover-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 10px #38bdf866}.recover-btn:disabled{cursor:not-allowed;opacity:.6;background:#475569}.errmsg{color:#f87171;background:#ef444426;border:1px solid #ef44444d;border-radius:6px;align-items:center;gap:8px;margin-bottom:20px;padding:10px;font-size:.85rem;display:flex}.success-container{text-align:center}.success-icon{color:#22c55e;margin-bottom:20px;font-size:4rem}.btn-back-login{color:#38bdf8;align-items:center;gap:10px;margin-top:25px;font-weight:600;text-decoration:none;display:inline-flex}.login-link{text-align:center;margin-top:25px}.login-link a{color:#94a3b8;align-items:center;gap:8px;font-size:.9rem;text-decoration:none;transition:all .3s;display:inline-flex}.login-link a:hover{color:#38bdf8}@media (width<=380px){.recover-section{padding:15px}.recover-section .wrapper{width:100%;max-width:95%;padding:25px 15px}.wrapper h1{margin-bottom:12px;font-size:1.4rem}.description{margin-bottom:20px;font-size:.8rem}.input-box{height:45px;margin-bottom:15px}.input-box input{padding:0 40px 0 8px;font-size:14px}.recover-btn{height:42px;font-size:.9rem}.errmsg{padding:8px;font-size:.75rem}.success-icon{margin-bottom:15px;font-size:3rem}.btn-back-login{margin-top:20px;font-size:.85rem}.login-link a{font-size:.8rem}}@media (width>=381px) and (width<=600px){.recover-section{padding:20px}.recover-section .wrapper{width:100%;max-width:380px;padding:30px 20px}.wrapper h1{margin-bottom:15px;font-size:1.6rem}}@media (width>=601px) and (width<=768px){.recover-section .wrapper{width:380px;padding:35px}.wrapper h1{font-size:1.8rem}}@media (width>=769px){.recover-section .wrapper{width:420px;padding:40px}}.session-manager{background:#1e293b;border:1px solid #334155;border-radius:12px;align-items:center;gap:16px;padding:8px 16px;display:flex}.session-info{align-items:center;gap:20px;display:flex}.session-user{color:#f8fafc;cursor:pointer;border-radius:8px;align-items:center;gap:8px;padding:6px 8px;transition:all .2s;display:flex}.session-user:hover{background:#38bdf81a;transform:translateY(-1px)}.session-user:hover .user-icon{color:#7dd3fc;transform:scale(1.05)}.session-user .user-icon{color:#38bdf8;font-size:20px}.user-avatar-img{object-fit:cover;border:2px solid #38bdf8;border-radius:50%;width:24px;height:24px}.session-user .user-name{text-overflow:ellipsis;white-space:nowrap;max-width:150px;font-size:14px;font-weight:500;overflow:hidden}.session-timer{border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:500;display:flex}.session-timer.success{color:#22c55e;background:#22c55e33}.session-timer.warning{color:#f97316;background:#f9731633}.session-timer.danger{color:#ef4444;background:#ef444433;animation:1s infinite pulse}.session-timer.neutral{color:#94a3b8;background:#64748b33}.timer-icon{font-size:14px}.timer-label{opacity:.8}.timer-value{font-weight:600}.session-actions{gap:8px;display:flex}.session-btn{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.session-btn svg{font-size:14px}.extend-btn{color:#38bdf8;background:#38bdf833}.extend-btn:hover{background:#38bdf84d}.extend-btn:disabled{opacity:.6;cursor:not-allowed}.logout-btn{color:#ef4444;background:#ef444433;border:1px solid #ef444480}.logout-btn:hover{color:#fff;background:#ef4444}.spinning{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@media (width<=768px){.session-manager{flex-direction:column;gap:12px}.session-user .user-name{max-width:100px}}.user-manager-container{max-width:1200px;margin:0 auto;padding:20px}.user-manager-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.user-manager-header h1{color:#333;font-size:24px}.add-user-btn{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-size:14px;transition:background .3s;display:flex}.add-user-btn:hover{background:#4338ca}.error-msg{color:#dc2626;cursor:pointer;background:#fee2e2;border-radius:8px;align-items:center;gap:8px;margin-bottom:16px;padding:12px;display:flex}.search-bar{background:#fff;border:1px solid #e5e7eb;border-radius:8px;align-items:center;margin-bottom:20px;padding:8px 16px;display:flex}.search-bar .search-icon{color:#9ca3af;margin-right:8px}.search-bar input{border:none;outline:none;flex:1;font-size:14px}.loading{text-align:center;color:#6b7280;padding:40px}.users-table{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.users-table table{border-collapse:collapse;width:100%}.users-table th,.users-table td{text-align:left;border-bottom:1px solid #e5e7eb;padding:16px}.users-table th{color:#374151;background:#f9fafb;font-size:14px;font-weight:600}.users-table tr:hover{background:#f9fafb}.user-cell{flex-direction:column;display:flex}.user-nick{color:#111827;font-weight:600}.user-name{color:#6b7280;font-size:12px}.user-type-badge{border-radius:4px;align-items:center;gap:4px;padding:4px 8px;font-size:12px;font-weight:500;display:inline-flex}.status-btn{cursor:pointer;border:none;border-radius:4px;padding:4px 12px;font-size:12px;font-weight:500;transition:all .2s}.status-btn.active{color:#059669;background:#d1fae5}.status-btn.active:hover,.status-btn.disabled{color:#dc2626;background:#fee2e2}.status-btn.disabled:hover{color:#059669;background:#d1fae5}.action-btns{gap:8px;display:flex}.edit-btn,.delete-btn{cursor:pointer;border:none;border-radius:6px;padding:8px;transition:all .2s}.edit-btn{color:#4f46e5;background:#e0e7ff}.edit-btn:hover{color:#fff;background:#4f46e5}.delete-btn{color:#dc2626;background:#fee2e2}.delete-btn:hover{color:#fff;background:#dc2626}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto}.modal-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:20px;display:flex}.modal-header h2{margin:0;font-size:20px}.close-btn{cursor:pointer;color:#6b7280;background:0 0;border:none;font-size:20px}.modal-content form{padding:20px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-group{margin-bottom:16px}.form-group label{color:#374151;margin-bottom:6px;font-size:14px;font-weight:500;display:block}.form-group input,.form-group select{border:1px solid #d1d5db;border-radius:6px;outline:none;width:100%;padding:10px 12px;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus{border-color:#4f46e5}.form-group input:disabled{cursor:not-allowed;background:#f3f4f6}.modal-actions{border-top:1px solid #e5e7eb;justify-content:flex-end;gap:12px;margin-top:20px;padding-top:16px;display:flex}.modal-actions button{cursor:pointer;border-radius:6px;align-items:center;gap:6px;padding:10px 20px;font-size:14px;transition:all .2s;display:flex}.modal-actions .cancel-btn{color:#374151;background:#f3f4f6;border:none}.modal-actions .cancel-btn:hover{background:#e5e7eb}.modal-actions .save-btn{color:#fff;background:#4f46e5;border:none}.modal-actions .save-btn:hover:not(:disabled){background:#4338ca}.modal-actions .save-btn:disabled{opacity:.6;cursor:not-allowed}.dashboard-container{color:#f8fafc;background:linear-gradient(#0f172acc,#0f172acc),url(/assets/background-DKMsXoKq.jpg) 50%/cover no-repeat;min-height:100vh;font-family:Segoe UI,sans-serif;display:flex}.mobile-header{z-index:1000;background-color:#1e293b;border-bottom:1px solid #334155;justify-content:space-between;align-items:center;padding:15px 20px;display:none;position:fixed;top:0;left:0;right:0}.mobile-logo{font-size:1.3rem;font-weight:800}.mobile-logo span{color:#38bdf8}.hamburger-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:8px;font-size:1.2rem;transition:all .3s}.hamburger-btn:hover{color:#38bdf8;background-color:#334155}.hamburger-btn:focus{outline-offset:2px;outline:2px solid #38bdf8}.menu-overlay{z-index:998;background-color:#00000080;display:none;position:fixed;inset:0}.sidebar{background-color:#1e293b;border-right:1px solid #334155;flex-direction:column;width:260px;padding:30px 20px;transition:transform .3s,box-shadow .3s;display:flex;position:relative;overflow-y:auto}.sidebar-logo{text-align:center;margin-bottom:40px;font-size:1.5rem;font-weight:800}.sidebar-logo span{color:#38bdf8}.sidebar-nav{flex-direction:column;flex-grow:1;gap:10px;display:flex}.nav-item{color:#94a3b8;text-align:left;cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:12px;padding:12px 15px;font-size:1rem;transition:all .3s;display:flex}.nav-item:hover,.nav-item.active{color:#38bdf8;background-color:#334155}.logout-btn{color:#ef4444;cursor:pointer;background-color:#ef44441a;border:1px solid #ef4444;border-radius:8px;justify-content:center;align-items:center;gap:10px;margin-top:auto;padding:10px;transition:all .3s;display:flex}.logout-btn:hover{color:#fff;background-color:#ef4444}.main-content{flex-grow:1;padding:40px;overflow-y:auto}.top-bar{justify-content:space-between;align-items:center;margin-bottom:40px;display:flex}.welcome-msg h1{margin-bottom:5px;font-size:1.8rem}.welcome-msg p{color:#94a3b8}.user-profile{background:#1e293be6;border:1px solid #334155;border-radius:.9rem;grid-template-columns:auto 1fr;align-items:center;column-gap:.75rem;min-width:0;max-width:min(100%,22rem);padding:.6rem .9rem;display:grid}.user-icon{color:#38bdf8;flex-shrink:0;grid-area:1/1/span 2;font-size:1.6rem}.user-meta{flex-direction:column;grid-column:2;min-width:0;line-height:1.2;display:flex}.user-name{color:#f8fafc;white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:700;overflow:hidden}.user-email{color:#94a3b8;white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;overflow:hidden}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:25px;margin-bottom:40px;display:grid}.stat-card{background:#1e293b;border:1px solid #334155;border-radius:16px;justify-content:space-between;align-items:center;padding:25px;display:flex}.stat-info h3{color:#94a3b8;margin-bottom:10px;font-size:.9rem}.stat-number{font-size:1.5rem;font-weight:700}.stat-icon{border-radius:12px;padding:10px;font-size:2rem}.stat-icon.blue{color:#38bdf8;background:#38bdf81a}.stat-icon.green{color:#22c55e;background:#22c55e1a}.stat-icon.orange{color:#f97316;background:#f973161a}.recent-activity{background:#1e293b;border:1px solid #334155;border-radius:16px;padding:30px}.recent-activity h2{margin-bottom:20px;font-size:1.2rem}.placeholder-table{color:#64748b;border:2px dashed #334155;border-radius:8px;justify-content:center;align-items:center;height:200px;display:flex}@media (width<=768px){.mobile-header{display:flex}.menu-overlay{opacity:1;visibility:visible;display:block}.dashboard-container{flex-direction:column;padding-top:60px}.sidebar{z-index:999;width:280px;height:calc(100vh - 60px);box-shadow:none;border-bottom:1px solid #334155;border-right:none;position:fixed;top:60px;left:0;transform:translate(-100%)}.sidebar.sidebar-open{transform:translate(0);box-shadow:4px 0 20px #0000004d}.main-content{width:100%;margin-left:0;padding:20px}.top-bar{flex-direction:column;gap:15px;margin-bottom:20px}.welcome-msg h1{text-align:center;font-size:1.4rem}.user-profile{border-radius:.8rem;justify-content:flex-start;width:100%;max-width:100%;padding:.65rem .85rem}.stats-grid{grid-template-columns:1fr;gap:15px;margin-bottom:20px}.stat-card{text-align:center;flex-direction:column;gap:10px;padding:20px}.stat-info h3{font-size:.9rem}.stat-number{font-size:1.4rem}.stat-icon{padding:10px;font-size:1.8rem}.recent-activity{padding:20px}.recent-activity h2{margin-bottom:15px;font-size:1.1rem}}@media (width<=480px){.mobile-header{padding:12px 15px}.mobile-logo{font-size:1.1rem}.sidebar{width:250px;padding:20px 15px}.user-name{font-size:.9rem}.user-email{font-size:.78rem}.sidebar-logo{text-align:center;margin-bottom:25px;font-size:1.2rem}.nav-item{gap:10px;padding:12px 15px;font-size:.95rem}.main-content{padding:15px}.welcome-msg h1{font-size:1.2rem}.stat-card{padding:15px}.stat-info h3{font-size:.8rem}.stat-number{font-size:1.3rem}.stat-icon{padding:8px;font-size:1.6rem}}@media (width>=769px) and (width<=1023px){.mobile-header{display:none}.dashboard-container{padding-top:0}.sidebar{box-shadow:none;width:220px;position:static;transform:none}.main-content{padding:30px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:20px}}@media (width>=1024px){.mobile-header{display:none}.dashboard-container{padding-top:0}.sidebar{box-shadow:none;width:260px;position:static;transform:none}.main-content{padding:40px}.stats-grid{grid-template-columns:repeat(3,1fr);gap:25px}}.admin-menu-section{border-top:1px solid #334155;margin-top:10px;padding-top:10px}.admin-toggle{justify-content:flex-start;gap:10px;width:100%}.admin-toggle.active{color:#60a5fa;background:#3b82f633}.admin-submenu{margin-top:5px;margin-left:10px}.submenu-item{justify-content:flex-start!important;padding-left:20px!important;font-size:13px!important}.submenu-item.active{color:#60a5fa;background:#3b82f633}.profile-container{background:linear-gradient(#0f172acc,#0f172acc),url(/assets/background-DKMsXoKq.jpg) 50%/cover no-repeat;justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;font-family:Poppins,sans-serif;display:flex}.profile-card{color:#fff;-webkit-backdrop-filter:blur(15px);background:#ffffff14;border:1px solid #fff3;border-radius:20px;width:100%;max-width:700px;padding:2rem;animation:.4s ease-out fadeIn;box-shadow:0 25px 45px #00000080}.profile-card.loading{flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:200px;display:flex}.profile-header{border-bottom:1px solid #ffffff1a;align-items:center;gap:1.5rem;margin-bottom:2rem;padding-bottom:1.5rem;display:flex;position:relative}.profile-header.admin{border-bottom-color:#38bdf84d}.profile-avatar{background:linear-gradient(135deg,#38bdf8,#0ea5e9);border:3px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;display:flex;position:relative}.avatar-icon{color:#0f172a;font-size:2rem}.user-type-badge{border:2px solid #0f172acc;border-radius:12px;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.7rem;font-weight:600;display:flex;position:absolute;bottom:-5px;right:-5px}.user-type-badge.admin{color:#0f172a;background:linear-gradient(135deg,#f59e0b,#d97706)}.user-type-badge.normal{color:#fff;background:linear-gradient(135deg,#10b981,#059669)}.badge-icon{font-size:.6rem}.profile-title{flex:1}.profile-title h1{color:#f8fafc;margin:0 0 .25rem;font-size:1.8rem;font-weight:700}.profile-nick{color:#94a3b8;margin:0;font-size:.9rem;font-weight:500}.edit-btn{color:#38bdf8;cursor:pointer;background:#38bdf826;border:1px solid #38bdf84d;border-radius:12px;align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.9rem;font-weight:600;transition:all .3s;display:flex}.edit-btn:hover{background:#38bdf840;border-color:#38bdf880;transform:translateY(-1px)}.error-msg,.success-msg{border-radius:10px;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.9rem;animation:.3s ease-out slideDown;display:flex}.error-msg{color:#f87171;background:#ef444426;border:1px solid #ef44444d}.success-msg{color:#4ade80;background:#22c55e26;border:1px solid #22c55e4d}.msg-icon{font-size:.8rem}.profile-fields{gap:1.5rem;display:grid}.field-group{gap:.5rem;display:grid}.field-label{color:#e2e8f0;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;display:flex}.field-icon{color:#94a3b8;font-size:.8rem}.field-value{color:#f8fafc;background:#0003;border:1px solid #ffffff1a;border-radius:10px;padding:.75rem 1rem;font-size:.95rem}.input-container{gap:.5rem;display:grid}.field-input{color:#fff;background:#0000004d;border:2px solid #ffffff1a;border-radius:10px;width:100%;padding:.75rem 1rem;font-size:.95rem;transition:all .3s}.field-input:focus{background:#0006;border-color:#38bdf8;outline:none}.field-input.invalid{border-color:#ef444480}.field-error{color:#f87171;align-items:center;gap:.25rem;margin:0;font-size:.75rem;display:flex}.profile-actions{border-top:1px solid #ffffff1a;gap:1rem;margin-top:2rem;padding-top:1.5rem;display:flex}.cancel-btn,.save-btn{cursor:pointer;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.875rem 1.5rem;font-size:.95rem;font-weight:600;transition:all .3s;display:flex}.cancel-btn{color:#94a3b8;background:#94a3b826;border:1px solid #94a3b84d}.cancel-btn:hover:not(:disabled){background:#94a3b840;border-color:#94a3b880}.save-btn{color:#0f172a;background:linear-gradient(135deg,#38bdf8,#0ea5e9);border:1px solid #7dd3fc4d}.save-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #38bdf84d}.cancel-btn:disabled,.save-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.admin-section{border-top:1px solid #38bdf833;margin-top:2rem;padding-top:1.5rem}.admin-section h3{color:#38bdf8;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.1rem;display:flex}.admin-action-btn{color:#fbbf24;cursor:pointer;background:#f59e0b26;border:1px solid #f59e0b4d;border-radius:10px;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;font-size:.9rem;font-weight:600;transition:all .3s;display:flex}.admin-action-btn:hover{background:#f59e0b40;border-color:#f59e0b80;transform:translateY(-1px)}.profile-bottom-actions{border-top:1px solid #ffffff1a;justify-content:center;margin-top:2rem;padding-top:1.5rem;display:flex}.dashboard-btn{color:#38bdf8;cursor:pointer;background:#38bdf826;border:1px solid #38bdf84d;border-radius:12px;justify-content:center;align-items:center;gap:.75rem;min-width:180px;padding:.875rem 1.5rem;font-size:.95rem;font-weight:600;transition:all .3s;display:flex}.dashboard-btn:hover{background:#38bdf840;border-color:#38bdf880;transform:translateY(-1px);box-shadow:0 4px 12px #38bdf833}.loading-spinner{border:3px solid #ffffff1a;border-top-color:#38bdf8;border-radius:50%;width:3rem;height:3rem;animation:1s linear infinite spin}@media (width<=768px){.profile-container{padding:1rem .5rem}.profile-card{border-radius:15px;padding:1.5rem}.profile-header{text-align:center;flex-direction:column;gap:1rem}.profile-title h1{font-size:1.5rem}.profile-actions{flex-direction:column}.cancel-btn,.save-btn{padding:1rem}.dashboard-btn{width:100%;min-width:auto;padding:1rem}}@media (width<=480px){.profile-card{margin:.5rem;padding:1rem}.profile-avatar{width:60px;height:60px}.avatar-icon{font-size:1.5rem}.field-input{padding:.625rem .75rem;font-size:.9rem}.dashboard-btn{padding:.875rem 1rem;font-size:.9rem}}@media (prefers-reduced-motion:reduce){.profile-card,.edit-btn,.save-btn,.admin-action-btn,.dashboard-btn,.field-input{transition:none;animation:none}.edit-btn:hover,.save-btn:hover:not(:disabled),.admin-action-btn:hover,.dashboard-btn:hover{transform:none}}.auth-callback-page{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-callback-card{text-align:center;background:#fff;border-radius:16px;width:100%;max-width:400px;padding:48px;box-shadow:0 20px 60px #0003}.auth-callback-card h2{color:#333;margin:20px 0 10px;font-size:1.5rem}.auth-callback-card p{color:#666;font-size:.95rem}.spinner-icon{color:#667eea;font-size:48px;animation:1s linear infinite spin}.success-icon{color:#28a745;font-size:64px}.error-icon{color:#dc3545;font-size:64px}.retry-btn{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:8px;margin-top:24px;padding:12px 32px;font-size:1rem;transition:background .2s}.retry-btn:hover{background:#5568d3}.notfound-container{text-align:center;color:#fff;justify-content:center;align-items:center;height:80vh;display:flex}.notfound-content{-webkit-backdrop-filter:blur(4px);background-color:#ffffff0d;border:1px solid #ffffff2e;border-radius:15px;width:90%;max-width:500px;padding:3rem;box-shadow:0 8px 32px #0000005e}.notfound-icon{color:#f39c12;margin-bottom:1rem;font-size:4rem}.notfound-title{background:linear-gradient(45deg,#646cff,#535bf2);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:0;font-size:6rem;font-weight:800;line-height:1}.notfound-subtitle{color:#fff;margin-bottom:1rem;font-size:1.5rem}.notfound-text{color:#ccc;margin-bottom:2rem;font-size:1rem}.notfound-button{color:#fff;background-color:#646cff;border:none;border-radius:8px;align-items:center;padding:12px 25px;font-weight:600;text-decoration:none;transition:all .3s;display:inline-flex}.notfound-button:hover{background-color:#535bf2;transform:translateY(-2px);box-shadow:0 5px 15px #646cff66}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#242424;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}body{place-items:center;min-width:320px;min-height:100vh;margin:0;display:flex}#root{text-align:center;width:100%;max-width:1280px;margin:0 auto;padding:1rem}a{color:#646cff;-webkit-text-decoration:inherit;text-decoration:inherit;margin:0 10px;font-weight:500;transition:color .25s}a:hover{color:#535bf2}h1{font-size:1.8em;line-height:1.1}@media (width>=640px){#root{padding:1.5rem}h1{font-size:2.5em}}@media (width>=1024px){#root{padding:2rem}h1{font-size:3.2em}}button{cursor:pointer;background-color:#1a1a1a;border:1px solid #0000;border-radius:8px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;transition:border-color .25s}button:hover{border-color:#646cff}@media (prefers-color-scheme:light){:root{color:#213547;background-color:#fff}button{background-color:#f9f9f9}}
