/* [project]/app/components/layout.module.css [app-client] (css) */
.layout-module__PQTT_G__layoutContainer {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--color-background);
  background-attachment: fixed;
  font-family: var(--font-primary);
}

.layout-module__PQTT_G__header {
  background: var(--color-dark-cerulean);
  color: var(--color-white);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  padding: var(--spacing-lg) var(--spacing-xl);
  text-align: center;
  box-shadow: 0 4px 20px #004f7f4d;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  border-bottom: 4px solid var(--color-black);
  font-family: var(--font-primary);
}

.layout-module__PQTT_G__headerTitle {
  text-shadow: none;
  letter-spacing: 2px;
  flex: 1;
  text-align: center;
}

.layout-module__PQTT_G__headerLogo {
  max-height: 45px;
  max-width: 280px;
  height: auto;
  object-fit: contain;
}

.layout-module__PQTT_G__hamburgerMenu {
  display: flex;
  flex-direction: column;
  background: none;
  border: none;
  cursor: pointer;
  position: absolute;
  right: var(--spacing-md);
  padding: 0;
  gap: 6px;
}

.layout-module__PQTT_G__hamburgerMenu span {
  width: 25px;
  height: 3px;
  background-color: var(--color-white);
  transition: var(--transition-normal);
  display: block;
}

.layout-module__PQTT_G__hamburgerMenu:active span:first-child {
  transform: rotate(45deg)translate(8px, 8px);
}

.layout-module__PQTT_G__hamburgerMenu:active span:nth-child(2) {
  opacity: 0;
}

.layout-module__PQTT_G__hamburgerMenu:active span:nth-child(3) {
  transform: rotate(-45deg)translate(7px, -7px);
}

.layout-module__PQTT_G__mobileMenu {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--color-dark-cerulean);
  border-top: 2px solid var(--color-black);
  flex-direction: column;
  padding: var(--spacing-md) 0;
  box-shadow: 0 8px 16px #0000004d;
  gap: 0;
  z-index: 1000;
}

.layout-module__PQTT_G__mobileMenu.layout-module__PQTT_G__menuOpen {
  display: flex;
}

.layout-module__PQTT_G__mobileLoginButton {
  background: none;
  color: var(--color-white);
  font-weight: var(--font-weight-bold);
  padding: var(--spacing-md) var(--spacing-xl);
  border: none;
  text-decoration: none;
  cursor: pointer;
  transition: var(--transition-normal);
  font-size: .9rem;
  letter-spacing: .5px;
  text-transform: uppercase;
  font-family: var(--font-primary);
  text-align: left;
  border-bottom: 1px solid #ffffff1a;
}

.layout-module__PQTT_G__mobileLoginButton:hover {
  background-color: #0003;
}

.layout-module__PQTT_G__mobileLogoutButton {
  background: none;
  color: var(--color-white);
  font-weight: var(--font-weight-bold);
  padding: var(--spacing-md) var(--spacing-xl);
  border: none;
  text-decoration: none;
  cursor: pointer;
  transition: var(--transition-normal);
  font-size: .9rem;
  letter-spacing: .5px;
  text-transform: uppercase;
  font-family: var(--font-primary);
  text-align: left;
  border-bottom: 1px solid #ffffff1a;
}

.layout-module__PQTT_G__mobileLogoutButton:hover {
  background-color: #0003;
}

.layout-module__PQTT_G__mobileMenuLink {
  background: none;
  color: var(--color-white);
  font-weight: var(--font-weight-bold);
  padding: var(--spacing-md) var(--spacing-xl);
  border: none;
  text-decoration: none;
  cursor: pointer;
  transition: var(--transition-normal);
  font-size: .9rem;
  letter-spacing: .5px;
  text-transform: uppercase;
  font-family: var(--font-primary);
  text-align: left;
  border-bottom: 1px solid #ffffff1a;
}

.layout-module__PQTT_G__mobileMenuLink:hover {
  background-color: #0003;
}

.layout-module__PQTT_G__desktopOnly {
  display: block;
}

@media (width <= 768px) {
  .layout-module__PQTT_G__desktopOnly {
    display: none;
  }
}

.layout-module__PQTT_G__loginButton {
  display: none;
}

.layout-module__PQTT_G__main {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-xl);
}

.layout-module__PQTT_G__footer {
  background: var(--color-black);
  color: var(--color-white);
  font-size: .9rem;
  padding: var(--spacing-lg) var(--spacing-xl);
  text-align: center;
  border-top: 4px solid var(--color-dark-cerulean);
  letter-spacing: .5px;
  font-family: var(--font-primary);
}

.layout-module__PQTT_G__mobileBottomNav {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--color-dark-cerulean);
  border-top: 3px solid var(--color-black);
  justify-content: space-around;
  align-items: center;
  height: 80px;
  gap: 0;
  z-index: 100;
  box-shadow: 0 -4px 12px #004f7f4d;
}

.layout-module__PQTT_G__navTab {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  flex: 1;
  height: 100%;
  text-decoration: none;
  color: var(--color-white);
  transition: all .2s;
  border-right: 1px solid #ffffff1a;
}

.layout-module__PQTT_G__navTab:last-child {
  border-right: none;
}

.layout-module__PQTT_G__navTab:hover {
  background: #0003;
}

.layout-module__PQTT_G__navTab:active {
  background: #0000004d;
}

.layout-module__PQTT_G__navTabWrapper {
  position: relative;
  flex: 1;
  display: flex;
}

.layout-module__PQTT_G__navBadge {
  position: absolute;
  top: 8px;
  left: 50%;
  transform: translateX(40%);
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 9px;
  background: #e23b3b;
  color: #fff;
  font-size: .7rem;
  font-weight: 700;
  line-height: 18px;
  text-align: center;
  box-shadow: 0 0 0 2px var(--color-primary, #004f7f);
  pointer-events: none;
  z-index: 2;
}

.layout-module__PQTT_G__navIcon {
  font-size: 1.2rem;
}

.layout-module__PQTT_G__navLabel {
  font-size: .55rem;
  font-weight: 600;
  letter-spacing: .3px;
}

@media (width <= 768px) {
  .layout-module__PQTT_G__header {
    padding: var(--spacing-md) var(--spacing-lg);
    flex-wrap: wrap;
  }

  .layout-module__PQTT_G__headerLogo {
    max-height: 50px;
    max-width: 240px;
  }

  .layout-module__PQTT_G__main {
    padding: var(--spacing-md);
    padding-bottom: 110px;
  }

  .layout-module__PQTT_G__footer {
    padding: var(--spacing-md);
    display: none;
  }

  .layout-module__PQTT_G__mobileBottomNav {
    display: flex;
  }
}


/* [project]/app/signup/signup.module.css [app-client] (css) */
.signup-module__cqMziG__signupContainer {
  min-height: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
  background: var(--color-background);
  font-family: var(--font-primary);
  padding: var(--spacing-lg);
  position: relative;
}

.signup-module__cqMziG__homeButton {
  position: absolute;
  top: var(--spacing-lg);
  left: var(--spacing-lg);
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: var(--spacing-sm) var(--spacing-md);
  background: var(--color-dark-cerulean);
  border: 2px solid var(--color-black);
  border-radius: var(--border-radius);
  color: var(--color-white);
  text-decoration: none;
  font-size: .9rem;
  font-weight: var(--font-weight-bold);
  letter-spacing: .5px;
  cursor: pointer;
  transition: var(--transition-normal);
  font-family: var(--font-primary);
}

.signup-module__cqMziG__homeButton:hover {
  box-shadow: 0 6px 20px #004f7f66;
  transform: translateY(-2px);
  background-color: var(--color-black);
}

.signup-module__cqMziG__homeButton:active {
  transform: translateY(0);
  background-color: var(--color-dark-cerulean);
}

.signup-module__cqMziG__signupForm {
  width: 100%;
  max-width: 600px;
  padding: var(--spacing-2xl);
  background: var(--color-light-gray);
  border: 3px solid var(--color-dark-cerulean);
  border-radius: var(--border-radius);
  box-shadow: 0 8px 32px #004f7f33;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
}

.signup-module__cqMziG__formHeader {
  text-align: center;
  border-bottom: 2px solid var(--color-dark-cerulean);
  padding-bottom: var(--spacing-lg);
}

.signup-module__cqMziG__title {
  margin: 0;
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-dark-cerulean);
  letter-spacing: 2px;
}

.signup-module__cqMziG__subtitle {
  margin: var(--spacing-sm) 0 0 0;
  color: var(--color-foreground);
  font-size: var(--font-size-lg);
  letter-spacing: 1px;
}

.signup-module__cqMziG__form {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
}

.signup-module__cqMziG__formRow {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-lg);
}

.signup-module__cqMziG__formGroup {
  display: flex;
  flex-direction: column;
  gap: .5rem;
}

.signup-module__cqMziG__label {
  color: var(--color-dark-cerulean);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  letter-spacing: .5px;
  text-transform: uppercase;
}

.signup-module__cqMziG__input {
  width: 100%;
  padding: var(--spacing-sm);
  background: var(--color-white);
  border: 2px solid var(--color-dark-cerulean);
  border-radius: var(--border-radius);
  color: #000;
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  transition: var(--transition-normal);
  box-sizing: border-box;
}

.signup-module__cqMziG__input:focus {
  outline: none;
  border-color: var(--color-black);
  box-shadow: 0 0 8px #004f7f4d;
}

.signup-module__cqMziG__select {
  cursor: pointer;
}

html.dark-mode .signup-module__cqMziG__input {
  background: #2a2a2a !important;
  color: #fff !important;
  border-color: #1e88e5 !important;
}

html.dark-mode .signup-module__cqMziG__input:focus {
  box-shadow: 0 0 8px #64b5f666;
  background: #3a3a3a !important;
  border-color: #64b5f6 !important;
}

html.dark-mode .signup-module__cqMziG__input::placeholder {
  color: #b0b0b0;
}

html.dark-mode .signup-module__cqMziG__select {
  background: #2a2a2a !important;
  color: #fff !important;
  border-color: #1e88e5 !important;
}

html.dark-mode .signup-module__cqMziG__select:focus {
  box-shadow: 0 0 8px #64b5f666;
  background: #3a3a3a !important;
  border-color: #64b5f6 !important;
}

.signup-module__cqMziG__inputError {
  border-color: #e74c3c;
  background-color: #e74c3c0d;
}

.signup-module__cqMziG__error {
  color: #e74c3c;
  font-size: .85rem;
  margin-top: -.25rem;
}

.signup-module__cqMziG__loadingText {
  color: #666;
  font-size: .85rem;
  margin-top: .25rem;
  font-style: italic;
}

.signup-module__cqMziG__submitButton {
  width: 100%;
  padding: var(--spacing-md);
  background: var(--color-dark-cerulean);
  color: var(--color-white);
  border: 2px solid var(--color-black);
  border-radius: var(--border-radius);
  cursor: pointer;
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  letter-spacing: 1px;
  transition: var(--transition-normal);
  box-shadow: 0 6px 20px #004f7f33;
  text-transform: uppercase;
  font-family: var(--font-primary);
}

.signup-module__cqMziG__submitButton:hover:not(:disabled) {
  box-shadow: 0 10px 30px #004f7f66;
  transform: translateY(-3px);
  background-color: var(--color-black);
}

.signup-module__cqMziG__submitButton:active:not(:disabled) {
  transform: translateY(0);
  background-color: var(--color-dark-cerulean);
}

.signup-module__cqMziG__submitButton:disabled {
  opacity: .6;
  cursor: not-allowed;
  background-color: var(--color-medium-gray);
}

.signup-module__cqMziG__errorBox {
  background: #e74c3c1a;
  border: 2px solid #e74c3c;
  padding: var(--spacing-md);
  border-radius: var(--border-radius);
  color: #c0392b;
  font-size: var(--font-size-base);
  text-align: center;
  font-weight: var(--font-weight-bold);
}

.signup-module__cqMziG__loginLink {
  text-align: center;
  border-top: 2px solid var(--color-dark-cerulean);
  padding-top: var(--spacing-lg);
}

.signup-module__cqMziG__loginLink p {
  margin: 0;
  font-size: var(--font-size-base);
  color: var(--color-foreground);
}

.signup-module__cqMziG__loginLink a {
  color: var(--color-dark-cerulean);
  text-decoration: none;
  font-weight: var(--font-weight-bold);
  transition: var(--transition-normal);
}

.signup-module__cqMziG__loginLink a:hover {
  color: var(--color-black);
  text-decoration: underline;
}

@media (width <= 768px) {
  .signup-module__cqMziG__signupContainer {
    padding: var(--spacing-md);
  }

  .signup-module__cqMziG__homeButton {
    top: var(--spacing-md);
    left: var(--spacing-md);
    padding: .5rem .75rem;
    font-size: .8rem;
  }

  .signup-module__cqMziG__signupForm {
    max-width: 100%;
    padding: var(--spacing-lg);
    gap: var(--spacing-lg);
  }

  .signup-module__cqMziG__formRow {
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
  }

  .signup-module__cqMziG__title {
    font-size: var(--font-size-xl);
  }

  .signup-module__cqMziG__subtitle {
    font-size: var(--font-size-base);
  }

  .signup-module__cqMziG__form {
    gap: var(--spacing-md);
  }

  .signup-module__cqMziG__formGroup {
    gap: .25rem;
  }

  .signup-module__cqMziG__label {
    font-size: .85rem;
  }

  .signup-module__cqMziG__input {
    padding: .6rem;
    font-size: .9rem;
  }

  .signup-module__cqMziG__submitButton {
    padding: var(--spacing-sm);
    font-size: var(--font-size-base);
  }
}

@media (width <= 480px) {
  .signup-module__cqMziG__homeButton {
    padding: .4rem .6rem;
    font-size: .75rem;
  }

  .signup-module__cqMziG__signupForm {
    padding: var(--spacing-md);
    gap: var(--spacing-md);
  }

  .signup-module__cqMziG__title {
    font-size: var(--font-size-lg);
  }

  .signup-module__cqMziG__subtitle {
    font-size: .9rem;
  }

  .signup-module__cqMziG__input {
    padding: .5rem;
  }
}

html.dark-mode .signup-module__cqMziG__signupContainer {
  background: var(--dm-bg);
  color: var(--dm-text);
}

html.dark-mode .signup-module__cqMziG__signupForm {
  background: var(--dm-surface);
  border-color: var(--dm-border-strong);
  box-shadow: var(--dm-shadow-md);
}

html.dark-mode .signup-module__cqMziG__title, html.dark-mode .signup-module__cqMziG__label {
  color: var(--dm-accent-strong);
}

html.dark-mode .signup-module__cqMziG__subtitle {
  color: var(--dm-text-muted);
}

html.dark-mode .signup-module__cqMziG__formHeader {
  border-bottom-color: var(--dm-border-strong);
}

html.dark-mode .signup-module__cqMziG__inputError {
  border-color: var(--dm-error);
  background-color: var(--dm-error-bg);
}

html.dark-mode .signup-module__cqMziG__error {
  color: var(--dm-error);
}

html.dark-mode .signup-module__cqMziG__loadingText {
  color: var(--dm-text-subtle);
}

html.dark-mode .signup-module__cqMziG__submitButton, html.dark-mode .signup-module__cqMziG__homeButton {
  background: var(--dm-accent);
  color: var(--dm-text);
  border-color: var(--dm-accent-strong);
}

html.dark-mode .signup-module__cqMziG__submitButton:hover:not(:disabled), html.dark-mode .signup-module__cqMziG__homeButton:hover {
  background: var(--dm-accent-hover);
}

html.dark-mode .signup-module__cqMziG__errorBox {
  background: var(--dm-error-bg);
  color: var(--dm-error);
  border-color: var(--dm-error);
}

html.dark-mode .signup-module__cqMziG__loginLink {
  color: var(--dm-text-muted);
}

html.dark-mode .signup-module__cqMziG__loginLink a {
  color: var(--dm-accent-strong);
}


/*# sourceMappingURL=app_51390e._.css.map*/
