﻿ *{margin:0;padding:0;box-sizing:border-box;}html,body{height:100%;font-family:var(--font-primary,'Segoe UI',Tahoma,Geneva,Verdana,sans-serif);}body{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem;background:linear-gradient(135deg,#1a3a52 0%,#2d5a3d 50%,#1f3a3a 100%);line-height:var(--line-height-normal);position:relative;overflow-y:auto;}body::before{content:'';position:fixed;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 20% 50%,rgba(212,161,93,0.08) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(45,90,61,0.06) 0%,transparent 50%);pointer-events:none;z-index:0;}body > *{position:relative;z-index:1;}.login-container{width:100%;max-width:420px;background:white;border-radius:1.25rem;box-shadow:0 10px 40px rgba(26,58,82,0.15);overflow:hidden;animation:slideIn 0.5s cubic-bezier(0.34,1.56,0.64,1);}@keyframes slideIn{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}.login-header{background:linear-gradient(135deg,#1a3a52 0%,#2d5a3d 100%);color:white;padding:2.5rem 2rem 1.5rem;text-align:center;position:relative;}.login-header::after{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(90deg,transparent,#d4a15d,transparent);}.login-logo{font-size:3rem;margin-bottom:1rem;display:flex;justify-content:center;align-items:center;height:80px;animation:float 3s ease-in-out infinite;}@keyframes float{0%,100%{transform:translateY(0px);}50%{transform:translateY(-8px);}}.login-logo i{color:#d4a15d;filter:drop-shadow(0 4px 8px rgba(0,0,0,0.2));}.login-header h1{font-size:1.8rem;margin-bottom:0.5rem;font-weight:800;letter-spacing:-0.5px;}.login-header p{font-size:0.9rem;opacity:0.95;margin-bottom:0.25rem;line-height:1.4;}.login-subtitle{font-size:0.8rem;opacity:0.85;display:block;}@keyframes fadeInUp{from{opacity:0;transform:translateY(30px);}to{opacity:1;transform:translateY(0);}}@keyframes slideDown{from{opacity:0;transform:translateY(-10px);}to{opacity:1;transform:translateY(0);}}@keyframes spin{to{transform:rotate(360deg);}}.login-header{background:linear-gradient( 135deg,var(--color-blue-primary,#1a3a52) 0%,var(--color-green-primary,#2d5a3d) 50%,var(--color-blue-light,#2d5080) 100% );color:var(--text-light,white);padding:1rem 0.8rem;text-align:center;position:relative;border-bottom:3px solid var(--color-gold-primary,#d4a15d);}.login-logo{font-size:clamp(1.4rem,6vw,1.8rem);margin-bottom:0.3rem;display:flex;justify-content:center;align-items:center;height:50px;animation:fadeInUp 0.8s var(--transition-base);}.login-logo i{color:var(--gold,#d4a15d);filter:drop-shadow(0 2px 4px rgba(0,0,0,0.2));}.login-header h1{font-size:clamp(1rem,2.5vw,1.2rem);margin-bottom:0.25rem;font-weight:var(--font-weight-bold,700);letter-spacing:0.3px;line-height:var(--line-height-tight);}.login-header p{font-size:clamp(0.65rem,1.1vw,0.75rem);opacity:0.95;margin:0;line-height:var(--line-height-normal);}.login-subtitle{font-size:clamp(0.6rem,0.9vw,0.7rem);opacity:0.85;margin-top:0.15rem;display:block;}.login-body{padding:0.95rem 0.8rem;}.login-welcome{background:linear-gradient(135deg,rgba(26,58,82,0.05) 0%,rgba(45,90,61,0.05) 100%);padding:0.6rem 0.7rem;border-radius:var(--radius-md,0.5rem);border-left:3px solid #1a3a52;margin-bottom:0.8rem;text-align:center;}.welcome-icon{font-size:1.6rem;margin-bottom:0.25rem;display:block;}.login-welcome h2{color:var(--color-blue-primary,#1a3a52);font-size:clamp(0.9rem,2vw,1rem);font-weight:var(--font-weight-bold,700);margin:0.3rem 0 0.3rem;letter-spacing:0.2px;}.login-welcome p{color:var(--color-text,#333);font-size:clamp(0.7rem,1.5vw,0.8rem);line-height:1.2;margin:0;}.alert{padding:var(--space-md,1rem) var(--space-lg,1.5rem);border-radius:var(--radius-md,0.5rem);margin-bottom:var(--space-lg);display:flex;align-items:flex-start;gap:var(--space-md);animation:slideDown 0.3s var(--transition-fast);font-size:var(--font-sm,0.875rem);}.alert-danger{background-color:rgba(220,53,69,0.08);color:var(--color-error,#dc3545);border-left:4px solid var(--color-error,#dc3545);}.alert-success{background-color:rgba(40,167,69,0.08);color:var(--color-success,#28a745);border-left:4px solid var(--color-success,#28a745);}.alert-info{background-color:rgba(23,162,184,0.08);color:var(--color-info,#17a2b8);border-left:4px solid var(--color-info,#17a2b8);}.alert i{flex-shrink:0;margin-top:2px;font-size:1.1em;}.form-group{margin-bottom:0.9rem;position:relative;}.form-group label{display:block;margin-bottom:0.3rem;color:var(--color-text,#333);font-weight:var(--font-weight-semibold,600);font-size:clamp(0.7rem,1.2vw,0.8rem);letter-spacing:0.2px;text-transform:none;}.field-indicator{color:#dc3545;font-weight:bold;margin-left:0.25rem;}.form-group input[type="email"],.form-group input[type="password"],.form-group input[type="text"]{width:100%;padding:0.7rem 0.9rem;border:2px solid var(--border-light,#ddd);border-radius:var(--radius-md,0.5rem);font-size:clamp(0.75rem,1.3vw,0.825rem);transition:all var(--transition-base,250ms ease-in-out);background:var(--color-bg,white);color:var(--color-text);font-family:inherit;height:44px;line-height:1.2;}.form-group input[type="email"]::placeholder,.form-group input[type="password"]::placeholder,.form-group input[type="text"]::placeholder{color:var(--color-text-light,#999);}.form-group input[type="email"]:focus,.form-group input[type="password"]:focus,.form-group input[type="text"]:focus{outline:none;border-color:var(--color-green-primary,#2d5a3d);background:rgba(45,90,61,0.01);box-shadow:0 0 0 3px rgba(45,90,61,0.1);}.form-group input[type="email"][aria-invalid="true"],.form-group input[type="password"][aria-invalid="true"],.form-group input[type="text"][aria-invalid="true"]{border-color:#dc3545;background:rgba(220,53,69,0.02);}.form-group input[type="email"][aria-invalid="true"]:focus,.form-group input[type="password"][aria-invalid="true"]:focus,.form-group input[type="text"][aria-invalid="true"]:focus{box-shadow:0 0 0 3px rgba(220,53,69,0.1);border-color:#dc3545;}.input-feedback{display:block;font-size:0.7rem;margin-top:0.25rem;min-height:15px;transition:color 200ms ease-in-out;}.input-feedback.error{color:#dc3545;font-weight:500;}.input-feedback.success{color:#28a745;font-weight:500;}.input-icon{position:relative;display:flex;align-items:center;}.input-icon > i{position:absolute;left:1rem;color:var(--color-green-primary,#2d5a3d);font-size:1em;pointer-events:none;}.input-icon input{padding-left:calc(1rem + 20px);}.input-icon.password-field input{padding-right:48px;}.password-toggle{position:absolute;right:0.75rem;top:50%;transform:translateY(-50%);cursor:pointer;color:var(--color-blue-primary,#1a3a52);background:transparent;border:none;box-shadow:none;padding:0;width:36px;height:36px;font-size:1.15em;transition:all var(--transition-fast) ease-in-out;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md,0.5rem);z-index:10;appearance:none;-webkit-appearance:none;}.password-toggle:hover{color:var(--color-green-primary,#2d5a3d);background:var(--color-green-lighter);transform:translateY(-50%) scale(1.1);}.password-toggle:focus{outline:2px solid #1a3a52;outline-offset:2px;background:rgba(26,58,82,0.15);}.password-toggle:active{transform:translateY(-50%) scale(0.92);background:rgba(26,58,82,0.2);}.toggle-icon{display:inline-flex;align-items:center;justify-content:center;transition:opacity 200ms ease-in-out,transform 200ms ease-in-out;width:20px;height:20px;}.toggle-icon i{font-size:1.2em;line-height:1;display:block;}.toggle-icon svg{width:20px;height:20px;display:block;fill:currentColor;}.form-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:0.9rem;flex-wrap:wrap;gap:0.5rem;}.remember-forgot{display:flex;gap:0.7rem;font-size:clamp(0.65rem,1.1vw,0.75rem);}.remember-forgot label{display:flex;align-items:center;margin:0;font-weight:var(--font-weight-normal);color:var(--color-text);cursor:pointer;gap:var(--space-sm);}.remember-forgot input[type="checkbox"]{width:18px;height:18px;cursor:pointer;accent-color:#2d5a3d;border-radius:var(--radius-sm);}.forgot-password-link{color:var(--color-blue-primary,#1a3a52);text-decoration:none;font-weight:var(--font-weight-semibold);transition:all var(--transition-fast);white-space:nowrap;font-size:clamp(0.75rem,1.5vw,0.8rem);}.forgot-password-link:hover{color:var(--color-green-primary,#2d5a3d);text-decoration:underline;}.btn-login{width:100%;padding:0.65rem 0.9rem;background:linear-gradient( 135deg,var(--color-blue-primary,#1a3a52) 0%,var(--color-green-primary,#2d5a3d) 100% );color:var(--text-light,white);border:none;border-radius:var(--radius-md,0.5rem);font-size:clamp(0.68rem,1.1vw,0.78rem);font-weight:var(--font-weight-semibold,600);cursor:pointer;transition:all var(--transition-base);letter-spacing:0.3px;box-shadow:0 2px 8px rgba(45,90,61,0.2);text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:0.3rem;}.btn-login:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(40,60,42,0.4);}.btn-login:not(:disabled):active{transform:translateY(0);box-shadow:0 2px 8px rgba(40,60,42,0.3);}.btn-login:disabled{opacity:0.6;cursor:not-allowed;}.btn-login i{font-size:1.1em;}.loading{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,0.3);border-radius:50%;border-top-color:white;animation:spin 0.8s linear infinite;}.login-footer{padding:0.85rem 0.95rem;background:var(--light-gray,#f5f5f5);border-top:1px solid var(--border-light,#ddd);text-align:center;font-size:clamp(0.62rem,1vw,0.68rem);color:var(--color-text-light,#666);line-height:1.2;}.login-footer p{margin:0.3rem 0;}.login-footer p:first-child{margin-top:0;}.login-footer a{color:#1a3a52;text-decoration:none;font-weight:var(--font-weight-semibold);transition:all var(--transition-fast);display:inline-flex;align-items:center;gap:var(--space-sm);}.login-footer .back-public-link{margin-top:0.35rem;padding:0.55rem 0.9rem;background:linear-gradient(135deg,#1a3a52 0%,#2d5a3d 100%);color:#fff;border-radius:0.65rem;box-shadow:0 6px 16px rgba(26,58,82,0.25);letter-spacing:0.2px;}.login-footer .back-public-link:hover{color:#fff;text-decoration:none;transform:translateY(-1px);box-shadow:0 8px 18px rgba(26,58,82,0.3);}.login-footer a:hover{color:#2d5a3d;text-decoration:underline;}@media (max-width:768px){body{padding:var(--space-md);}.login-container{max-width:100%;box-shadow:0 8px 32px rgba(26,58,82,0.2);}.login-header{padding:var(--space-xl) var(--space-lg);border-bottom-width:3px;}.login-header h1{font-size:var(--font-xl);}.login-body{padding:var(--space-xl);}.login-footer{padding:var(--space-lg);}.form-controls{flex-direction:column;align-items:flex-start;}.remember-forgot{flex-direction:column;width:100%;}.login-features{grid-template-columns:repeat(2,1fr);}}@media (max-width:480px){body{padding:var(--space-sm);background:linear-gradient( 135deg,#1a3a52 0%,#2d5a3d 50%,#1f3a3a 100% );}.login-header{padding:var(--space-xl) var(--space-md);border-bottom:2px solid var(--gold,#d4a15d);}.login-header h1{font-size:var(--font-lg);}.login-logo{height:80px;}.login-body{padding:var(--space-lg) var(--space-md);}.login-footer{padding:var(--space-md);font-size:var(--font-xs);}.form-group{margin-bottom:var(--space-lg);}.login-welcome{padding:var(--space-md,1rem);margin-bottom:var(--space-lg);border-left:3px solid #1a3a52;}.welcome-icon{font-size:2rem;}.login-welcome h2{font-size:var(--font-md,1rem);margin:var(--space-xs) 0 var(--space-sm);}.login-welcome p{font-size:var(--font-xs,0.75rem);}.login-features{grid-template-columns:1fr;gap:var(--space-md);margin-top:var(--space-lg);}.input-icon i{left:var(--space-md);font-size:1em;}.input-icon input{padding-left:calc(var(--space-md) + 20px);font-size:16px;}.password-toggle{right:var(--space-md);width:36px;height:36px;padding:var(--space-sm) 0.5rem;}.login-container{box-shadow:0 8px 32px rgba(26,58,82,0.25);}.form-group input[type="email"],.form-group input[type="password"]{font-size:16px;padding:var(--space-md,0.875rem) var(--space-lg,1.25rem);}.form-controls{flex-direction:column;gap:var(--space-md);}.btn-login{padding:var(--space-md,0.875rem);font-size:var(--font-xs,0.75rem);}}@media (max-width:375px){.login-header{padding:var(--space-lg) var(--space-sm);border-bottom:2px solid var(--gold,#d4a15d);}.login-header h1{font-size:clamp(1.25rem,5vw,1.5rem);}.login-header p{font-size:var(--font-xs,0.75rem);}.login-logo{height:70px;font-size:clamp(2rem,8vw,2.5rem);}.login-body{padding:var(--space-lg) var(--space-sm);}.form-group{margin-bottom:var(--space-md,1rem);}.welcome-icon{font-size:2rem;}.login-welcome h2{font-size:var(--font-sm,0.875rem);}.login-welcome p{font-size:var(--font-xs,0.75rem);}.form-group label{font-size:var(--font-xs,0.75rem);}.form-group input[type="email"],.form-group input[type="password"]{font-size:16px;padding:var(--space-sm) var(--space-md,0.75rem);border-radius:var(--radius-sm,0.375rem);}.password-toggle{width:32px;height:32px;right:var(--space-sm);}.input-icon i{font-size:0.95em;}.remember-forgot{font-size:var(--font-xs);}.forgot-password-link{font-size:var(--font-xs);}.btn-login{padding:var(--space-sm,0.65rem);font-size:var(--font-xs,0.75rem);}.login-container{box-shadow:0 8px 32px rgba(26,58,82,0.25);}.login-features{gap:var(--space-sm);padding-top:var(--space-md);}.login-feature{padding:var(--space-md,0.75rem);}.login-feature i{font-size:1.5rem;margin-bottom:var(--space-xs);}.login-feature-title{font-size:var(--font-xs,0.7rem);}.login-footer{padding:var(--space-sm);font-size:var(--font-xs,0.7rem);}}