*{margin:0;padding:0;box-sizing:border-box}html{-webkit-overflow-scrolling:touch}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.btn{padding:.5rem 1rem;border:none;border-radius:.25rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem}.btn-success{background:#059669;color:#fff}.btn-success:hover{background:#047857}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-start;justify-content:center;z-index:1000;padding:1rem .5rem .5rem;overflow-y:auto;-webkit-overflow-scrolling:touch}@media (min-height: 700px) and (min-width: 640px){.modal-overlay{align-items:center;padding:1rem}}.modal-content{background:#fff;border-radius:.75rem;box-shadow:0 25px 50px -12px #00000040;width:100%;max-width:400px;max-height:calc(100vh - 2rem);overflow-y:auto;position:relative;margin:0;min-height:fit-content}@media (max-width: 639px) and (max-height: 700px){.modal-content{max-width:none;margin:0;border-radius:.5rem;max-height:calc(100vh - 1rem)}}@media (min-width: 640px){.modal-content{max-width:480px;margin:1rem 0;border-radius:1rem}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1rem .5rem;border-bottom:1px solid #e5e7eb;margin-bottom:1rem;position:sticky;top:0;background:#fff;z-index:10}@media (min-width: 640px){.modal-header{padding:1.5rem 1.5rem .75rem}}.modal-title{font-size:1.25rem;font-weight:700;color:#1f2937;margin:0}@media (min-width: 640px){.modal-title{font-size:1.5rem}}.modal-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:.25rem;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;border-radius:.5rem;transition:all .2s ease;min-width:44px;min-height:44px}.modal-close:hover{background:#f3f4f6;color:#374151}.modal-close:active{background:#e5e7eb;transform:scale(.95)}.modal-body{padding:0 1rem 1rem}@media (min-width: 640px){.modal-body{padding:0 1.5rem 1.5rem}}:root{--primary: #1e293b;--secondary: #64748b;--light: #f8fafc;--border: #e2e8f0;--text: #1f2937;--shadow: 0 1px 3px 0 rgba(0, 0, 0, .1)}.form-group{margin-bottom:1rem}.form-group:last-child{margin-bottom:0}@media (min-width: 640px){.form-group{margin-bottom:1.5rem}}.form-group>div{display:flex;align-items:center;border:2px solid #d1d5db;border-radius:.75rem;background:#fff;transition:all .2s ease;margin-bottom:0;min-height:56px}.form-group>div:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #1e293b1a}.form-group>div>div:first-child{padding:1rem .5rem 1rem 1rem;display:flex;align-items:center;color:#6b7280}@media (min-width: 640px){.form-group>div>div:first-child{padding:1rem .75rem 1rem 1rem}}.form-group input{flex:1;padding:1rem 1rem 1rem .5rem;background:transparent;color:#1f2937;outline:none;border:none;font-size:1rem;font-size:16px;-webkit-appearance:none;-webkit-border-radius:0}@media (min-width: 640px){.form-group input{padding:1rem 1.5rem 1rem 1rem;font-size:1rem}}.form-group input::placeholder{color:#6b7280}@media (max-width: 639px){.form-group input::placeholder{color:#9ca3af;opacity:1}}.signin-button{width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,var(--primary) 0%,#334155 100%);color:#fff;font-weight:600;font-size:1rem;border:none;border-radius:.75rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #1e293b4d;position:relative;overflow:hidden;min-height:56px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}@media (min-width: 640px){.signin-button{font-size:1.1rem;border-radius:1rem;min-height:60px}}.signin-button:hover:not(:disabled){background:linear-gradient(135deg,#334155 0%,var(--primary) 100%);transform:translateY(-1px);box-shadow:0 6px 20px #1e293b66}@media (min-width: 1024px){.signin-button:hover:not(:disabled){transform:translateY(-2px)}}.signin-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #1e293b4d}.signin-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:0 4px 12px #1e293b33}.signin-button:focus{outline:none;box-shadow:0 4px 12px #1e293b4d,0 0 0 3px #1e293b1a}@media (max-width: 1023px){.signin-button:active:not(:disabled){transform:scale(.98);transition:transform .1s ease}}.space-y-6>*+*{margin-top:1rem}.space-y-4>*+*{margin-top:.75rem}@media (min-width: 640px){.space-y-6>*+*{margin-top:1.5rem}.space-y-4>*+*{margin-top:1rem}}@media (max-width: 639px){div[data-testid=google-login]{width:100%!important;min-height:56px!important}.flex.justify-center{width:100%}.flex.justify-center>div{width:100%!important;display:flex!important;justify-content:center!important}}@media (max-width: 639px) and (max-height: 700px){.modal-body{padding-bottom:.5rem}.space-y-6>*+*{margin-top:.75rem}.form-group{margin-bottom:.75rem}}.flex{display:flex}.items-center{align-items:center}.justify-center{justify-content:center}.w-full{width:100%}.text-center{text-align:center}.text-sm{font-size:.875rem}.text-red-600{color:#dc2626}.text-gray-500{color:#6b7280}.text-gray-600{color:#4b5563}.bg-red-50{background-color:#fef2f2}.bg-white{background:#fff}.border{border-width:1px}.border-red-200{border-color:#fecaca}.border-t{border-top-width:1px}.border-gray-300{border-color:#d1d5db}.p-4{padding:1rem}.px-2{padding-left:.5rem;padding-right:.5rem}.py-4{padding-top:1rem;padding-bottom:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.pt-4{padding-top:1rem}.mb-6{margin-bottom:1.5rem}.ml-1{margin-left:.25rem}.rounded-lg{border-radius:.5rem}.font-medium{font-weight:500}.font-bold{font-weight:700}.hover\:underline:hover{text-decoration:underline}.relative{position:relative}.absolute{position:absolute}.inset-0{inset:0}.auth-container{display:flex;align-items:center;gap:2rem}.user-info-badge{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background-color:#f3f4f6;border-radius:.5rem;border:1px solid #e5e7eb;text-decoration:none;color:inherit;transition:all .2s ease;cursor:pointer}.user-info-badge:hover{background-color:#e5e7eb;border-color:#d1d5db;text-decoration:none;color:inherit}.user-info-badge .user-icon{width:1rem;height:1rem;color:var(--primary)}.user-info-badge .user-name{font-size:.875rem;font-weight:500;color:#374151}.logout-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background-color:#dc2626;color:#fff;border:none;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s ease}.logout-button:hover:not(:disabled){background-color:#b91c1c}.logout-button:disabled{opacity:.5;cursor:not-allowed}.logout-button .logout-icon{width:1rem;height:1rem}.logout-button .logout-text{font-size:.875rem}.login-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:var(--primary);color:#fff;border:none;border-radius:.5rem;cursor:pointer;transition:all .2s ease}.login-button:hover:not(:disabled){background-color:var(--secondary)}.login-button:disabled{opacity:.5;cursor:not-allowed}.login-button .login-icon{width:1rem;height:1rem}.login-button .login-text{font-size:.875rem;font-weight:500}.user-badge-link{text-decoration:none;display:inline-flex;align-items:center;transition:all .2s ease;border-radius:.5rem}.user-badge-link:hover{text-decoration:none}@media (max-width: 1024px){.mobile-nav .user-badge-link{margin-left:auto}}
