*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:Inter,SF Pro Text,Helvetica Neue,Arial,sans-serif;background:#f3f3f3;color:#111827}#app{min-height:100vh}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:48px 20px;background:radial-gradient(circle at 50% 55%,#d5dbe8,#f3f3f3 55%,#f3f3f3)}.login-card{width:100%;max-width:420px;background:#fff;border-radius:20px;padding:36px 32px 30px;box-shadow:0 20px 50px #0f172a14;text-align:center}.logo-wrap{display:flex;justify-content:center;margin:6px 0 18px}.login-logo{width:68px;height:68px;margin:0;display:block}.login-title{font-size:20px;font-weight:600;margin:0 0 18px;color:#111827}.login-subtitle{font-size:16px;color:#6b7280;margin:0 0 16px;font-weight:500}.login-subtitle.single{color:#111827}.google-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;border:1px solid #e5e7eb;background:#fff;border-radius:12px;padding:12px 14px;font-weight:500;cursor:pointer;transition:box-shadow .2s ease,border-color .2s ease}.google-btn:hover{border-color:#cfd6e3;box-shadow:0 8px 20px #0f172a14}.divider{display:flex;align-items:center;gap:10px;color:#9ca3af;font-size:12px;margin:18px 0 20px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#e5e7eb}.input-group{display:flex;flex-direction:column;gap:14px;text-align:left}.input-group input{width:100%;border:1px solid #e5e7eb;background:#f9fafb;border-radius:12px;padding:13px 14px;font-size:14px;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.input-group input:focus{border-color:#c7d2fe;box-shadow:0 0 0 3px #6366f11f;background:#fff}.row{display:flex;align-items:center;justify-content:space-between;margin-top:16px;font-size:13px;color:#6b7280}.remember{display:flex;align-items:center;gap:8px}.remember input{width:16px;height:16px;border-radius:6px;accent-color:#2563eb}.link{color:#111827;text-decoration:none;cursor:pointer}.link:hover{opacity:.7}.primary-btn{width:100%;margin-top:18px;border:none;border-radius:12px;padding:13px 16px;background:linear-gradient(180deg,#1f2937,#0f172a);color:#fff;font-weight:600;cursor:pointer;box-shadow:0 12px 24px #0f172a33}.primary-btn:hover{filter:brightness(1.05)}.footer{margin-top:16px;font-size:13px;color:#6b7280}.footer .link{font-weight:600}.message{margin-top:10px;font-size:13px;text-align:left}.message.center{text-align:center;margin-top:14px}.message.error{color:#b91c1c}.message.success{color:#0f766e}
