.container { display: flex; min-height: 100dvh; font-family: "DM Sans", sans-serif; color: var(--color-bg); } @supports not (min-height: 100dvh) { .container { min-height: 100vh; } } .mainContent { flex: 1; display: flex; flex-direction: column; padding: 2.5rem 2rem; background-color: var(--color-bg); } .loginSection { display: flex; flex-direction: column; align-items: center; width: 100%; flex: 1; } .logo { display: flex; justify-content: center; align-items: center; width: 100%; } .logoImage { height: 44px; width: auto; object-fit: contain; } .loginBox { background-color: var(--color-bg); width: min(100%, 460px); height: auto; margin-top: 2rem; padding: 2rem; border-radius: 25px; border: 1px solid color-mix(in srgb, var(--color-primary) 15%, transparent); box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02), 0 0 10px rgba(0, 0, 0, 0.1); } .title { font-family: "DM Sans", sans-serif; color: var(--color-text); } .loginForm { display: flex; flex-direction: column; gap: 1rem; } .floatingLabelInput { position: relative; } .label { position: absolute; left: 16px; top: 50%; transform: translateY(-50%); color: var(--color-primary); font-size: 1rem; pointer-events: none; transition: all 0.3s ease; background-color: transparent; font-family: var(--font-family); } .focusedLabel { position: absolute; left: 12px; top: -8px; transform: translateY(0); color: var(--color-secondary); font-size: 0.85rem; pointer-events: none; transition: all 0.3s ease; background-color: var(--color-bg); padding: 0 4px; font-family: var(--font-family); font-weight: 500; } .input { width: 100%; height: 50px; padding: 12px 16px; border: 1px solid var(--color-gray-disabled); border-radius: 25px; font-size: 1rem; transition: all 0.2s ease; background-color: var(--color-bg); color: var(--color-text); font-family: var(--font-family); } .input:focus { outline: none; border-color: var(--color-secondary); box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-secondary) 10%, transparent); } .input::placeholder { color: transparent; } /* Fix browser autocomplete styling */ .input:-webkit-autofill, .input:-webkit-autofill:hover, .input:-webkit-autofill:focus, .input:-webkit-autofill:active { -webkit-box-shadow: 0 0 0 30px var(--color-bg) inset !important; -webkit-text-fill-color: var(--color-text) !important; background-color: var(--color-bg) !important; transition: background-color 5000s ease-in-out 0s; } /* Ensure label background matches when autofilled */ .input:-webkit-autofill + .label, .input:-webkit-autofill + .focusedLabel { background-color: var(--color-bg) !important; } .disclaimer { font-size: 0.8rem; color: var(--color-text); text-align: center; } .button { width: 100%; height: 50px; padding: 12px 20px; border-radius: 25px; font-size: 1rem; font-weight: 500; cursor: pointer; transition: all 0.2s ease; border: none; text-align: center; } .buttonContent { display: flex; align-items: center; justify-content: center; gap: 8px; } .microsoftIcon { width: 18px; height: 18px; } .loginButton { background-color: var(--color-secondary); color: var(--color-text); } .loginButton:hover { background-color: var(--color-secondary-hover); } .microsoftButton { background-color: var(--color-primary); color: var(--color-bg); } .microsoftButton:hover { background-color: var(--color-primary-hover); } .googleButton { background-color: var(--color-primary); color: var(--color-bg); } .googleButton:hover { background-color: var(--color-primary-hover); } .divider { display: flex; align-items: center; text-align: center; } .divider::before, .divider::after { content: ''; flex: 1; border-bottom: 1px solid var(--color-gray-disabled); } .divider span { padding: 0 1rem; color: var(--color-text); font-size: 0.8rem; } .registerLink { display: flex; align-items: center; justify-content: center; gap: 0.5rem; } .registerLink span { color: var(--color-text); font-size: 0.8rem; } .textButton { background: none; border: none; color: var(--color-secondary); font-weight: 500; cursor: pointer; padding: 0; font-size: 0.9rem; font-family: var(--font-family); } .textButton:hover { text-decoration: underline; } .ctaSection { display: flex; gap: 0.75rem; width: 100%; } .ctaPrimary { flex: 1; height: 46px; padding: 10px 16px; border-radius: 25px; font-size: 0.95rem; font-weight: 600; cursor: pointer; border: none; background-color: var(--color-secondary); color: var(--color-text); transition: all 0.2s ease; font-family: var(--font-family); } .ctaPrimary:hover { background-color: var(--color-secondary-hover); } .ctaSecondary { flex: 1; height: 46px; padding: 10px 16px; border-radius: 25px; font-size: 0.95rem; font-weight: 600; cursor: pointer; border: 1px solid var(--color-secondary); background-color: transparent; color: var(--color-secondary); transition: all 0.2s ease; font-family: var(--font-family); } .ctaSecondary:hover { background-color: color-mix(in srgb, var(--color-secondary) 10%, transparent); } button:disabled { opacity: 0.7; cursor: not-allowed; } .error { color: var(--color-red); background-color: var(--color-red-disabled); border: 1px solid var(--color-red); border-radius: 8px; padding: 12px; font-size: 0.9rem; text-align: center; font-family: var(--font-family); } .invitationNotice { display: flex; align-items: center; gap: 12px; padding: 12px 16px; background-color: rgba(59, 130, 246, 0.1); border: 1px solid rgba(59, 130, 246, 0.3); border-radius: 8px; margin-bottom: 16px; font-size: 0.9rem; color: #93c5fd; } .invitationIcon { flex-shrink: 0; font-size: 1.2rem; color: #3b82f6; } .passwordResetLink { display: flex; justify-content: center; margin-top: -0.5rem; } .passwordResetLink .textButton { color: var(--color-gray-disabled); font-size: 0.85rem; } .passwordResetLink .textButton:hover { color: var(--color-secondary); } @media (max-width: 768px) { .mainContent { padding: 1rem; } .logoImage { height: 40px; } .loginBox { width: 100%; margin-top: 1.25rem; padding: 1.25rem; border-radius: 20px; } .registerLink { flex-wrap: wrap; text-align: center; } } @media (max-width: 420px) { .mainContent { padding: 0.75rem; } .loginBox { padding: 1rem; border-radius: 16px; } .input, .button { height: 48px; } }