@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#fff;background:#0a0a14;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#ffffff08}::-webkit-scrollbar-thumb{background:#22c55e4d;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#22c55e80}.login-container{background:#0a0a14;justify-content:center;align-items:center;min-height:100vh;font-family:Inter,sans-serif;display:flex;position:relative;overflow:hidden}.login-bg{z-index:0;position:absolute;inset:0}.blob{filter:blur(90px);opacity:.4;border-radius:50%;animation:8s ease-in-out infinite alternate blobFloat;position:absolute}.blob-1{background:radial-gradient(circle,#22c55e,#16a34a);width:450px;height:450px;animation-delay:0s;top:-100px;left:-100px}.blob-2{background:radial-gradient(circle,#4ade80,#059669);width:350px;height:350px;animation-delay:-3s;bottom:-80px;right:-80px}.blob-3{background:radial-gradient(circle,#6ee7b7,#10b981);width:250px;height:250px;animation-delay:-5s;top:50%;left:55%}@keyframes blobFloat{0%{transform:translate(0)scale(1)}to{transform:translate(30px,30px)scale(1.1)}}.login-card{z-index:1;-webkit-backdrop-filter:blur(24px);text-align:center;background:#0f141ebf;border:1px solid #ffffff14;border-radius:24px;width:100%;max-width:420px;padding:48px 40px;animation:.6s cubic-bezier(.16,1,.3,1) forwards cardEntrance;position:relative;box-shadow:0 0 0 1px #22c55e1a,0 40px 80px #0009}@keyframes cardEntrance{0%{opacity:0;transform:translateY(30px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.login-logo{margin-bottom:20px}.logo-icon{filter:drop-shadow(0 0 20px #22c55e99);font-size:52px;animation:2.5s ease-in-out infinite iconBounce;display:inline-block}@keyframes iconBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.login-title{color:#fff;letter-spacing:-.03em;background:linear-gradient(135deg,#fff 0%,#a3e635 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 8px;font-size:2rem;font-weight:800}.login-subtitle{color:#ffffff80;margin:0 0 32px;font-size:.95rem;line-height:1.5}.login-divider{align-items:center;gap:12px;margin-bottom:24px;display:flex}.login-divider:before,.login-divider:after{content:"";background:#ffffff1a;flex:1;height:1px}.login-divider span{color:#ffffff59;white-space:nowrap;text-transform:uppercase;letter-spacing:.08em;font-size:.78rem}.google-btn{color:#fff;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1f;border-radius:14px;justify-content:center;align-items:center;gap:12px;width:100%;padding:14px 24px;font-size:.95rem;font-weight:600;transition:all .25s cubic-bezier(.16,1,.3,1);display:flex;position:relative;overflow:hidden}.google-btn:before{content:"";opacity:0;background:linear-gradient(135deg,#22c55e26,#10b9811a);transition:opacity .3s;position:absolute;inset:0}.google-btn:hover:not(:disabled):before{opacity:1}.google-btn:hover:not(:disabled){border-color:#22c55e66;transform:translateY(-2px);box-shadow:0 12px 32px #0000004d,0 0 0 1px #22c55e33}.google-btn:active:not(:disabled){transform:translateY(0)}.google-btn:disabled{opacity:.6;cursor:not-allowed}.google-btn.loading{background:#22c55e1a;border-color:#22c55e4d}.google-icon{flex-shrink:0;width:20px;height:20px}.spinner{border:2px solid #fff3;border-top-color:#22c55e;border-radius:50%;flex-shrink:0;width:20px;height:20px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-error{color:#f87171;background:#ef44441a;border:1px solid #ef444440;border-radius:10px;margin-top:16px;padding:12px 16px;font-size:.85rem}.login-footer{color:#ffffff4d;margin-top:28px;font-size:.78rem;line-height:1.6}.login-footer a{color:#4ade80b3;text-decoration:none;transition:color .2s}.login-footer a:hover{color:#4ade80}.scanner-overlay{z-index:1000;background:#000000e6;justify-content:center;align-items:center;animation:.3s ease-in fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.scanner-container{background:#1a1a2e;border-radius:16px;flex-direction:column;width:90%;max-width:500px;max-height:90vh;animation:.3s ease-out slideUp;display:flex;overflow:hidden;box-shadow:0 20px 60px #000c}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.scanner-header{background:linear-gradient(135deg,#22c55e1a 0%,#3b82f61a 100%);border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;padding:20px;display:flex}.scanner-header h2{color:#fff;margin:0;font-size:1.5rem;font-weight:600}.close-btn{color:#999;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:1.5rem;transition:all .2s;display:flex}.close-btn:hover{color:#fff;background:#ffffff1a}.scanner-content{flex-direction:column;flex:1;display:flex;overflow:hidden}#qr-reader{flex:1;min-height:300px}.scanner-instructions{color:#a3e635;background:#22c55e1a;border-top:1px solid #22c55e33;padding:16px;font-size:.875rem;line-height:1.5}.scanner-instructions p{text-align:center;margin:6px 0}.scanner-result{justify-content:center;align-items:center;min-height:350px;padding:20px;display:flex}.result-content{text-align:center}.result-icon{margin-bottom:16px;font-size:3rem;animation:.6s ease-in-out bounce}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.result-content h3{color:#fff;margin:0 0 8px;font-size:1.5rem}.result-code{color:#a3e635;word-break:break-all;background:#22c55e1a;border-radius:8px;margin:0 0 20px;padding:12px 16px;font-family:monospace;font-size:.875rem}.result-actions{flex-direction:column;gap:12px;display:flex}.btn-primary{color:#fff;cursor:pointer;background:linear-gradient(135deg,#22c55e 0%,#16a34a 100%);border:none;border-radius:8px;padding:12px 24px;font-size:1rem;font-weight:600;transition:all .2s}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #22c55e4d}.btn-primary:active{transform:translateY(0)}.btn-secondary{color:#3b82f6;cursor:pointer;background:#3b82f61a;border:1px solid #3b82f6;border-radius:8px;padding:12px 24px;font-size:1rem;font-weight:600;transition:all .2s}.btn-secondary:hover{background:#3b82f633;transform:translateY(-2px)}.btn-secondary:active{transform:translateY(0)}.btn-close{color:#999;cursor:pointer;background:#ffffff0d;border:none;border-top:1px solid #ffffff1a;width:100%;padding:12px;font-size:1rem;transition:all .2s}.btn-close:hover{color:#fff;background:#ffffff1a}@media (width<=600px){.scanner-container{max-width:95vw;max-height:95vh}.scanner-header h2{font-size:1.25rem}.result-icon{font-size:2.5rem}.result-content h3{font-size:1.25rem}.result-actions{flex-direction:column}}.dashboard{color:#fff;background:#0a0a14;min-height:100vh;font-family:Inter,sans-serif}.dash-header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:100;background:#0f141ecc;border-bottom:1px solid #ffffff12;justify-content:space-between;align-items:center;padding:16px 32px;display:flex;position:sticky;top:0}.dash-logo{align-items:center;gap:10px;font-size:1.5rem;display:flex}.dash-logo span:first-child{font-size:1.8rem}.dash-logo-text{background:linear-gradient(135deg,#fff,#a3e635);-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;font-size:1.2rem;font-weight:800}.dash-user{align-items:center;gap:12px;display:flex}.user-avatar{object-fit:cover;border:2px solid #22c55e66;border-radius:50%;width:38px;height:38px}.user-info{text-align:right;flex-direction:column;display:flex}.user-name{color:#fff;font-size:.9rem;font-weight:600}.user-email{color:#fff6;font-size:.75rem}.logout-btn{color:#f87171;cursor:pointer;background:#ef44441a;border:1px solid #ef444440;border-radius:10px;padding:8px 18px;font-size:.85rem;font-weight:600;transition:all .2s}.logout-btn:hover{background:#ef444433;border-color:#ef444480;transform:translateY(-1px)}.dash-main{max-width:1100px;margin:0 auto;padding:40px 32px}.welcome-banner{background:#22c55e12;border:1px solid #22c55e26;border-radius:20px;justify-content:space-between;align-items:center;margin-bottom:36px;padding:32px 40px;display:flex}.welcome-text h1{background:linear-gradient(135deg,#fff,#a3e635);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 8px;font-size:1.8rem;font-weight:800}.welcome-text p{color:#ffffff80;margin:0;font-size:.95rem}.welcome-emoji{font-size:4rem;animation:3s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.dash-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;display:grid}.dash-card{background:#0f141e99;border:1px solid #ffffff12;border-radius:18px;padding:28px;transition:all .3s cubic-bezier(.16,1,.3,1)}.dash-card:hover{border-color:#22c55e40;transform:translateY(-4px);box-shadow:0 20px 40px #0006,0 0 0 1px #22c55e1a}.card-icon{margin-bottom:16px;font-size:2.5rem}.dash-card h3{color:#fff;margin:0 0 8px;font-size:1.1rem;font-weight:700}.dash-card p{color:#ffffff73;margin:0 0 20px;font-size:.875rem;line-height:1.6}.card-btn{color:#4ade80;cursor:pointer;background:#22c55e1a;border:1px solid #22c55e40;border-radius:10px;padding:9px 20px;font-size:.85rem;font-weight:600;transition:all .2s}.card-btn:hover{background:#22c55e33;border-color:#22c55e80}@media (width<=640px){.dash-header{padding:12px 16px}.user-info{display:none}.dash-main{padding:24px 16px}.welcome-banner{padding:24px}.welcome-emoji{font-size:3rem}.welcome-text h1{font-size:1.4rem}}
