:root{
  --village-teal:#14b8a6;
  --village-teal-dark:#0d9b8c;
  --commons-indigo:#6366f1;
  --earth-black:#0b0d0e;
  --paper-white:#fcfcff;
  --soft-yellow:#fef9c3;
  --gray-300:#d1d5db;
  --gray-400:#9ca3af;
  --gray-500:#6b7280;
  --gray-600:#4b5563;
  --gray-700:#374151;
  --gray-800:#1f2937;
  --gray-900:#111315;
  --spacing-xs:8px;
  --spacing-sm:12px;
  --spacing-md:16px;
  --spacing-lg:24px;
  --spacing-xl:32px;
  --spacing-2xl:48px;
  --radius-sm:6px;
  --radius-md:8px;
  --radius-lg:12px;
  --font-family:"Atkinson Hyperlegible", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}
*{
  box-sizing:border-box;
  margin:0;
  padding:0;
}

body{
  font-family:var(--font-family);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
.sr-only{
  height:1px;
  margin:-1px;
  overflow:hidden;
  padding:0;
  position:absolute;
  width:1px;
  clip:rect(0, 0, 0, 0);
  border-width:0;
  white-space:nowrap;
}
.village-login-page{
  align-items:center;
  background:linear-gradient(135deg, var(--village-teal) 0, var(--soft-yellow) 100%);
  display:flex;
  flex-direction:column;
  min-height:100vh;
  overflow-x:hidden;
  padding:var(--spacing-2xl) var(--spacing-md);
  position:relative;
}
.village-login-page:before{
  background-image:radial-gradient(circle at 50% 45%, transparent 280px, hsla(0,0%,100%,.05) 281px, transparent 282px), radial-gradient(circle at 50% 45%, transparent 420px, hsla(0,0%,100%,.05) 421px, transparent 422px), radial-gradient(circle at 50% 45%, transparent 620px, hsla(0,0%,100%,.05) 621px, transparent 622px);
  bottom:0;
  content:"";
  left:0;
  pointer-events:none;
  position:absolute;
  right:0;
  top:0;
  z-index:0;
}

.village-login-container{
  gap:var(--spacing-2xl);
  max-width:520px;
  position:relative;
  width:100%;
  z-index:1;
}
.village-header,.village-login-container{
  align-items:center;
  display:flex;
  flex-direction:column;
}
.village-header{
  gap:var(--spacing-md);
  text-align:center;
}

.village-icon{
  animation:gentle-pulse 4s ease-in-out infinite;
  height:80px;
  width:80px;
}

.village-wordmark{
  color:var(--commons-indigo);
  font-size:40px;
  font-weight:700;
  letter-spacing:.01em;
  line-height:1;
}

.village-tagline{
  color:var(--gray-600);
  font-size:18px;
  font-weight:400;
  max-width:520px;
}
@keyframes gentle-pulse{
  0%,to{
    opacity:1;
    transform:scale(1);
  }
  50%{
    opacity:.95;
    transform:scale(1.02);
  }
}
.village-login-card{
  background:#fff;
  border-radius:var(--radius-lg);
  box-shadow:0 4px 12px rgba(0,0,0,.08);
  display:flex;
  flex-direction:column;
  gap:var(--spacing-lg);
  max-width:420px;
  padding:var(--spacing-2xl);
  width:100%;
}
.village-form-group{
  display:flex;
  flex-direction:column;
  gap:var(--spacing-xs);
}

.village-label{
  color:var(--gray-700);
  display:block;
  font-size:14px;
  font-weight:500;
}

.village-input{
  background:#fff;
  border:1px solid var(--gray-300);
  border-radius:var(--radius-md);
  color:var(--gray-900);
  font-family:var(--font-family);
  font-size:16px;
  height:48px;
  padding:12px 14px;
  transition:all .12s ease;
  width:100%;
}

.village-input::placeholder{
  color:var(--gray-400);
}

.village-input:focus{
  border-color:var(--village-teal);
  outline:2px solid var(--village-teal);
  outline-offset:2px;
}

.village-input:disabled{
  background:var(--gray-100);
  cursor:not-allowed;
  opacity:.6;
}
.village-password-wrapper{
  position:relative;
  width:100%;
}

.village-password-wrapper .village-input{
  padding-right:48px;
}

.village-password-toggle{
  align-items:center;
  background:transparent;
  border:none;
  border-radius:var(--radius-sm);
  color:var(--gray-600);
  cursor:pointer;
  display:flex;
  height:44px;
  justify-content:center;
  position:absolute;
  right:12px;
  top:50%;
  transform:translateY(-50%);
  transition:color .12s ease;
  width:44px;
}

.village-password-toggle:hover{
  color:var(--village-teal);
}

.village-password-toggle:focus{
  color:var(--village-teal);
  outline:2px solid var(--village-teal);
  outline-offset:2px;
}
.village-remember-row{
  align-items:center;
  display:flex;
  flex-wrap:wrap;
  gap:var(--spacing-sm);
  justify-content:space-between;
}

.village-remember-label{
  align-items:center;
  color:var(--gray-700);
  cursor:pointer;
  display:flex;
  font-size:14px;
  gap:var(--spacing-xs);
}

.village-checkbox{
  accent-color:var(--village-teal);
  border:1px solid var(--gray-300);
  border-radius:4px;
  cursor:pointer;
  height:18px;
  width:18px;
}

.village-checkbox:focus{
  outline:2px solid var(--village-teal);
  outline-offset:2px;
}

.village-link{
  color:var(--commons-indigo);
  font-size:14px;
  text-decoration:none;
  transition:all .12s ease;
}

.village-link:hover{
  color:var(--village-teal);
  text-decoration:underline;
}

.village-link:focus{
  border-radius:2px;
  outline:2px solid var(--village-teal);
  outline-offset:2px;
}
.village-btn-primary{
  align-items:center;
  background:linear-gradient(to right, var(--village-teal), var(--village-teal-dark));
  border:none;
  border-radius:var(--radius-md);
  box-shadow:0 1px 3px rgba(0,0,0,.1);
  color:#fff;
  cursor:pointer;
  display:flex;
  font-family:var(--font-family);
  font-size:16px;
  font-weight:700;
  gap:var(--spacing-xs);
  height:48px;
  justify-content:center;
  transition:all .12s ease;
  width:100%;
}

.village-btn-primary:hover:not(:disabled){
  box-shadow:0 4px 12px rgba(20,184,166,.3);
  transform:translateY(-2px);
}

.village-btn-primary:active:not(:disabled){
  box-shadow:0 1px 3px rgba(0,0,0,.1);
  transform:translateY(0);
}

.village-btn-primary:focus{
  outline:2px solid var(--village-teal);
  outline-offset:2px;
}

.village-btn-primary:disabled{
  box-shadow:none;
  cursor:not-allowed;
  opacity:.4;
  transform:none;
}
.village-spinner{
  animation:spin .6s linear infinite;
  border:2px solid hsla(0,0%,100%,.3);
  border-radius:50%;
  border-top-color:#fff;
  height:20px;
  width:20px;
}

@keyframes spin{
  to{
    transform:rotate(1turn);
  }
}
.village-signup-text{
  color:var(--gray-700);
  font-size:14px;
  margin:0;
  text-align:center;
}

.village-signup-text .village-link{
  font-weight:500;
}
.village-alert{
  border-radius:var(--radius-md);
  font-size:14px;
  margin-bottom:var(--spacing-lg);
  padding:var(--spacing-md);
}

.village-alert-error{
  background:#fef2f2;
  border:1px solid #fecaca;
  color:#991b1b;
}

.village-alert-success{
  background:#f0fdf4;
  border:1px solid #bbf7d0;
  color:#166534;
}
.village-footer{
  align-items:center;
  display:flex;
  flex-direction:column;
  gap:var(--spacing-md);
  margin-top:auto;
  padding:var(--spacing-lg) 0;
  text-align:center;
}

.village-footer-text{
  color:var(--gray-600);
  font-size:14px;
  margin:0;
}

.village-footer-links{
  display:flex;
  flex-wrap:wrap;
  gap:var(--spacing-lg);
  justify-content:center;
}

.village-footer-link{
  color:var(--commons-indigo);
  font-size:14px;
  text-decoration:none;
  transition:all .12s ease;
}

.village-footer-link:hover{
  color:var(--village-teal);
  text-decoration:underline;
}

.village-footer-link:focus{
  border-radius:2px;
  outline:2px solid var(--village-teal);
  outline-offset:2px;
}
@media (prefers-color-scheme:dark){
  .village-login-page{
    background:var(--earth-black);
    background-image:radial-gradient(circle at 50% 40%, rgba(20,184,166,.15) 0, transparent 50%);
  }

  .village-login-page:before{
    background-image:radial-gradient(circle at 50% 45%, transparent 280px, hsla(0,0%,100%,.03) 281px, transparent 282px), radial-gradient(circle at 50% 45%, transparent 420px, hsla(0,0%,100%,.03) 421px, transparent 422px), radial-gradient(circle at 50% 45%, transparent 620px, hsla(0,0%,100%,.03) 621px, transparent 622px);
  }

  .village-wordmark{
    color:#fff;
  }

  .village-tagline{
    color:var(--gray-300);
  }

  .village-login-card{
    background:var(--gray-900);
    border:1px solid var(--gray-800);
    box-shadow:0 4px 12px rgba(0,0,0,.3);
  }

  .village-label{
    color:var(--gray-300);
  }

  .village-input{
    background:var(--gray-800);
    border-color:var(--gray-700);
    color:#fff;
  }

  .village-input::placeholder{
    color:var(--gray-500);
  }

  .village-input:focus{
    background:var(--gray-800);
  }

  .village-remember-label{
    color:var(--gray-300);
  }

  .village-link{
    color:var(--village-teal);
  }

  .village-link:hover{
    color:var(--commons-indigo);
  }

  .village-signup-text{
    color:var(--gray-300);
  }

  .village-footer-text{
    color:var(--gray-400);
  }

  .village-footer-link{
    color:var(--village-teal);
  }

  .village-footer-link:hover{
    color:var(--commons-indigo);
  }
}
@media (prefers-reduced-motion:reduce){
  *,:after,:before{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
  }

  .village-icon{
    animation:none;
  }

  .village-btn-primary:active:not(:disabled),.village-btn-primary:hover:not(:disabled){
    transform:none;
  }
}
.village-tenant-selection{
  align-items:center;
  background:#fff;
  border-radius:var(--radius-lg);
  box-shadow:0 4px 12px rgba(0,0,0,.08);
  display:flex;
  flex-direction:column;
  gap:var(--spacing-lg);
  max-width:520px;
  padding:var(--spacing-2xl);
  width:100%;
}

.village-tenant-title{
  color:var(--commons-indigo);
  font-size:24px;
  font-weight:700;
  margin:0;
}

.village-tenant-subtitle{
  color:var(--gray-600);
  font-size:14px;
  margin:0;
  text-align:center;
}

.village-tenant-grid{
  display:grid;
  gap:var(--spacing-md);
  grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));
  width:100%;
}

.village-tenant-card{
  align-items:center;
  background:#f9fafb;
  border:2px solid var(--gray-300);
  border-radius:var(--radius-md);
  cursor:pointer;
  display:flex;
  flex-direction:column;
  font-family:var(--font-family);
  gap:var(--spacing-xs);
  padding:var(--spacing-lg);
  transition:all .15s ease;
}

.village-tenant-card:hover{
  background:#f0fdfa;
  border-color:var(--village-teal);
  box-shadow:0 4px 12px rgba(20,184,166,.15);
  transform:translateY(-2px);
}

.village-tenant-card:focus{
  outline:2px solid var(--village-teal);
  outline-offset:2px;
}

.village-tenant-card.current{
  background:#f0fdfa;
  border-color:var(--village-teal);
}

.village-tenant-icon{
  font-size:32px;
}

.village-tenant-name{
  color:var(--gray-800);
  font-size:16px;
  font-weight:600;
}

.village-tenant-role{
  color:var(--gray-500);
  font-size:12px;
  text-transform:capitalize;
}

.village-tenant-current{
  color:var(--village-teal);
  font-size:11px;
  font-weight:500;
}

.village-btn-secondary{
  background:#fff;
  border:2px solid var(--gray-300);
  border-radius:var(--radius-md);
  color:var(--gray-700);
  cursor:pointer;
  font-family:var(--font-family);
  font-size:14px;
  font-weight:500;
  margin-top:var(--spacing-md);
  padding:12px 24px;
  transition:all .12s ease;
  width:auto;
}

.village-btn-secondary:hover{
  background:#f9fafb;
  border-color:var(--gray-400);
}

.village-btn-secondary:focus{
  outline:2px solid var(--village-teal);
  outline-offset:2px;
}
@media (prefers-color-scheme:dark){
  .village-tenant-selection{
    background:var(--gray-900);
    border:1px solid var(--gray-800);
  }

  .village-tenant-title{
    color:#fff;
  }

  .village-tenant-subtitle{
    color:var(--gray-400);
  }

  .village-tenant-card{
    background:var(--gray-800);
    border-color:var(--gray-700);
  }

  .village-tenant-card.current,.village-tenant-card:hover{
    background:var(--gray-700);
    border-color:var(--village-teal);
  }

  .village-tenant-name{
    color:#fff;
  }

  .village-tenant-role{
    color:var(--gray-400);
  }

  .village-btn-secondary{
    background:var(--gray-800);
    border-color:var(--gray-700);
    color:var(--gray-300);
  }

  .village-btn-secondary:hover{
    background:var(--gray-700);
    border-color:var(--gray-600);
  }
}
.village-switch-link{
  margin-top:var(--spacing-lg);
  text-align:center;
}

.village-switch-link button{
  font-family:var(--font-family);
}
.village-last-village-prompt{
  background:#fff;
  border:2px solid var(--village-teal);
  border-radius:var(--radius-lg);
  box-shadow:0 4px 12px rgba(0,0,0,.08);
  margin-top:var(--spacing-lg);
  max-width:420px;
  padding:var(--spacing-lg);
  text-align:center;
  width:100%;
}

.village-last-village-prompt p{
  color:var(--gray-700);
  font-size:14px;
  margin:0 0 var(--spacing-md) 0;
}

.village-last-village-prompt strong{
  color:var(--commons-indigo);
}

.village-prompt-buttons{
  display:flex;
  flex-wrap:wrap;
  gap:var(--spacing-sm);
  justify-content:center;
}

.village-btn-sm{
  font-size:14px;
  height:40px;
  padding:0 var(--spacing-lg);
}
.village-modal-overlay{
  align-items:center;
  backdrop-filter:blur(4px);
  background:rgba(0,0,0,.5);
  bottom:0;
  display:flex;
  justify-content:center;
  left:0;
  padding:var(--spacing-md);
  position:fixed;
  right:0;
  top:0;
  z-index:1000;
}

.village-modal-content{
  background:#fff;
  border-radius:var(--radius-lg);
  box-shadow:0 20px 40px rgba(0,0,0,.2);
  max-width:420px;
  padding:var(--spacing-2xl);
  position:relative;
  width:100%;
}

.village-modal-close{
  align-items:center;
  background:transparent;
  border:none;
  border-radius:var(--radius-sm);
  color:var(--gray-500);
  cursor:pointer;
  display:flex;
  height:40px;
  justify-content:center;
  position:absolute;
  right:var(--spacing-md);
  top:var(--spacing-md);
  transition:all .12s ease;
  width:40px;
}

.village-modal-close:hover{
  background:var(--gray-100, #f3f4f6);
  color:var(--gray-700);
}

.village-modal-close:focus{
  outline:2px solid var(--village-teal);
  outline-offset:2px;
}

.village-modal-title{
  color:var(--commons-indigo);
  font-size:24px;
  font-weight:700;
  margin:0 0 var(--spacing-sm) 0;
  text-align:center;
}

.village-modal-subtitle{
  color:var(--gray-600);
  font-size:14px;
  margin:0 0 var(--spacing-lg) 0;
  text-align:center;
}

.village-modal-subtitle strong{
  color:var(--village-teal);
}

.village-input-hint{
  color:var(--gray-500);
  font-size:12px;
  margin-top:4px;
}

.village-modal-footer-text{
  color:var(--gray-600);
  font-size:13px;
  margin:var(--spacing-lg) 0 0 0;
  text-align:center;
}
.village-captcha-container{
  align-items:center;
  display:flex;
  flex-direction:column;
  margin:var(--spacing-lg) 0;
}

.village-captcha-error{
  color:#991b1b;
  font-size:13px;
  margin-top:var(--spacing-xs);
}
.village-attempts-warning{
  background:#fef3c7;
  border:1px solid #fcd34d;
  border-radius:var(--radius-sm);
  margin-top:var(--spacing-sm);
  padding:var(--spacing-sm);
  text-align:center;
}

.village-attempts-warning p{
  color:#92400e;
  font-size:13px;
  margin:0;
}
.modal-enter{
  transition:opacity .2s ease-out;
}

.modal-enter-start{
  opacity:0;
}

.modal-enter-end{
  opacity:1;
}

.modal-leave{
  transition:opacity .15s ease-in;
}

.modal-leave-start{
  opacity:1;
}

.modal-leave-end{
  opacity:0;
}
@media (prefers-color-scheme:dark){
  .village-last-village-prompt{
    background:var(--gray-900);
    border-color:var(--village-teal);
  }

  .village-last-village-prompt p{
    color:var(--gray-300);
  }

  .village-last-village-prompt strong{
    color:var(--village-teal);
  }

  .village-modal-overlay{
    background:rgba(0,0,0,.7);
  }

  .village-modal-content{
    background:var(--gray-900);
    border:1px solid var(--gray-800);
  }

  .village-modal-close{
    color:var(--gray-400);
  }

  .village-modal-close:hover{
    background:var(--gray-800);
    color:var(--gray-200);
  }

  .village-modal-title{
    color:#fff;
  }

  .village-modal-subtitle{
    color:var(--gray-400);
  }

  .village-input-hint{
    color:var(--gray-500);
  }

  .village-modal-footer-text{
    color:var(--gray-400);
  }

  .village-attempts-warning{
    background:hsla(48,96%,89%,.1);
    border-color:rgba(252,211,77,.3);
  }

  .village-attempts-warning p{
    color:#fcd34d;
  }
  .h-captcha iframe{
    color-scheme:dark;
  }
}
@media (max-width:768px){
  .village-login-page{
    padding:var(--spacing-xl) var(--spacing-md);
  }

  .village-icon{
    height:64px;
    width:64px;
  }

  .village-wordmark{
    font-size:32px;
  }

  .village-tagline{
    font-size:16px;
  }

  .village-login-card{
    padding:var(--spacing-xl);
  }

  .village-login-container{
    gap:var(--spacing-xl);
  }
}
@media (max-width:480px){
  .village-login-page{
    padding:var(--spacing-lg) var(--spacing-md);
  }

  .village-icon{
    height:56px;
    width:56px;
  }

  .village-wordmark{
    font-size:28px;
  }

  .village-tagline{
    font-size:14px;
  }

  .village-login-card{
    padding:var(--spacing-lg);
  }

  .village-remember-row{
    align-items:flex-start;
    flex-direction:column;
  }

  .village-footer-links{
    flex-direction:column;
    gap:var(--spacing-sm);
  }
}

/*# sourceMappingURL=login.min.css.map */