 * {
     margin: 0;
     padding: 0;
     box-sizing: border-box;
 }

 /* Tailwind extension for landing page colors */
 :root {
     --e9: #1E1209;
     --e8: #3D2B1F;
     --e7: #6B4C35;
     --e6: #96714E;
     --e5: #A67C52;
     --e4: #C4A882;
     --e3: #D9C4A9;
     --e2: #EDE3D5;
     --e1: #F5F0E8;
     --e0: #FAF8F4;
     --coral: #E85D54;
     --coral-l: #FF9E94;
     --coral-d: #C43E36;
     --sage: #6B8B72;
     --sage-d: #4A6453;
     --sage-l: #B5CCBA;
 }

 /* Social Sign-Up Buttons */
 .social-signup {
     margin-bottom: 24px;
 }

 .social-button {
     width: 100%;
     padding: 13px 20px;
     margin-bottom: 12px;
     border: 1px solid var(--e2);
     border-radius: 8px;
     background: white;
     font-family: 'DM Sans', -apple-system, sans-serif;
     font-size: 15px;
     font-weight: 500;
     color: var(--e9);
     cursor: pointer;
     transition: all 0.2s;
     display: flex;
     align-items: center;
     justify-content: center;
     gap: 10px;
 }

 .social-button:hover {
     border-color: var(--e3);
     background: var(--e1);
 }

 .social-button:active {
     transform: scale(0.98);
 }

 .social-icon {
     width: 20px;
     height: 20px;
     display: flex;
     align-items: center;
     justify-content: center;
 }

 /* Divider */
 .divider {
     position: relative;
     text-align: center;
     margin: 24px 0;
 }

 .divider::before {
     content: '';
     position: absolute;
     top: 50%;
     left: 0;
     right: 0;
     height: 1px;
     background: var(--e2);
 }

 .divider-text {
     position: relative;
     display: inline-block;
     padding: 0 16px;
     background: white;
     font-size: 13px;
     color: var(--e5);
     font-weight: 500;
 }

 .login-container {
     width: 100%;
     max-width: 440px;
     padding: 20px;
     margin: 0 auto;
 }

 .login-card {
     background: white;
     border: 1px solid var(--e2);
     border-radius: 16px;
     padding: 48px 40px;
     box-shadow: 0 8px 32px rgba(44, 24, 16, 0.08);
 }

 .login-header {
     text-align: center;
     margin-bottom: 32px;
 }

 .login-title {
     font-family: 'Crimson Pro', Georgia, serif;
     font-size: 32px;
     font-weight: 700;
     color: var(--e9);
     margin-bottom: 8px;
     letter-spacing: -0.8px;
 }

 .login-subtitle {
     font-size: 15px;
     color: var(--e6);
 }

 .form-group {
     margin-bottom: 20px;
 }

 .form-label {
     display: block;
     font-size: 14px;
     font-weight: 600;
     color: var(--e9);
     margin-bottom: 8px;
 }

 .form-input {
     width: 100%;
     padding: 12px 16px;
     border: 1px solid var(--e2);
     border-radius: 8px;
     font-family: 'DM Sans', -apple-system, sans-serif;
     font-size: 15px;
     color: var(--e9);
     background: white;
     transition: all 0.2s;
 }

 .form-input:focus {
     outline: none;
     border-color: var(--sage);
     box-shadow: 0 0 0 3px rgba(107, 139, 114, 0.1);
 }

 .form-input::placeholder {
     color: var(--e4);
 }

 .form-input.error {
     border-color: var(--coral);
 }

 .form-error {
     font-size: 13px;
     color: var(--coral);
     margin-top: 6px;
 }

 .form-error-box {
     margin-bottom: 20px;
     padding: 12px 16px;
     background: rgba(232, 93, 84, 0.05);
     border: 1px solid var(--coral-l);
     border-radius: 8px;
     font-size: 13px;
     color: var(--coral-d);
 }

 .submit-button {
     width: 100%;
     padding: 14px 32px;
     background: linear-gradient(135deg, var(--e9), var(--e8));
     color: white;
     border: none;
     border-radius: 8px;
     font-family: 'DM Sans', -apple-system, sans-serif;
     font-size: 16px;
     font-weight: 600;
     cursor: pointer;
     transition: all 0.2s;
     box-shadow: 0 4px 12px rgba(44, 24, 16, 0.2);
 }

 .submit-button:hover:not(:disabled) {
     transform: translateY(-2px);
     box-shadow: 0 6px 16px rgba(44, 24, 16, 0.3);
 }

 .submit-button:disabled {
     opacity: 0.5;
     cursor: not-allowed;
 }

 .checkbox-label {
     display: flex;
     align-items: center;
     font-size: 14px;
     color: var(--e7);
     cursor: pointer;
     gap: 8px;
 }

 .checkbox-label input {
     width: 16px;
     height: 16px;
     border: 1px solid var(--e2);
     border-radius: 4px;
     cursor: pointer;
     accent-color: var(--sage);
 }

 .forgot-link {
     font-size: 14px;
     color: var(--sage);
     text-decoration: none;
     transition: color 0.2s;
 }

 .forgot-link:hover {
     color: var(--sage-d);
 }

 .signup-link {
     display: inline-block;
     color: var(--coral);
     text-decoration: none;
     font-weight: 600;
     transition: color 0.2s;
 }

 .signup-link:hover {
     color: var(--coral-d);
 }

 .terms-text {
     font-size: 13px;
     color: var(--e6);
     text-align: center;
     margin-top: 16px;
     line-height: 1.6;
 }

 .terms-text a {
     color: var(--coral);
     text-decoration: none;
 }

 .terms-text a:hover {
     text-decoration: underline;
 }

 @media (max-width: 768px) {
     .login-container {
         padding: 16px 12px;
     }

     .login-card {
         padding: 28px 20px;
     }

     .login-title {
         font-size: 24px;
     }
 }

 @media (max-width: 420px) {
     .login-container {
         min-height: 100vh;
         display: flex;
         flex-direction: column;
         justify-content: center;
     }

     .login-card {
         padding: 24px 16px;
         box-shadow: none;
         border: none;
     }

     .login-title {
         font-size: 20px;
     }
 }