.coteia-login-module {
  width: 100%;
  padding: clamp(44px, 7vw, 86px) 18px;
  position: relative;
  overflow: hidden;
  background: var(--coteia-login-bg, var(--coteia-bg));
  color: var(--coteia-text);
}

.coteia-login-module::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: var(--coteia-login-overlay, #000);
  opacity: var(--coteia-login-overlay-opacity, 0);
  pointer-events: none;
}

.coteia-login-bg-glass {
  backdrop-filter: blur(var(--coteia-login-page-blur, 0));
}

.coteia-login-card {
  width: min(100%, 520px);
  margin: 0 auto;
  padding: clamp(20px, 5vw, var(--coteia-login-card-padding, 38px));
  position: relative;
  z-index: 1;
  border: 1px solid var(--coteia-login-card-border, rgba(15, 23, 42, .08));
  border-radius: var(--coteia-login-card-radius, 18px);
  background: var(--coteia-login-card, #fff);
  opacity: var(--coteia-login-card-opacity, 1);
  box-shadow:
    0 24px 70px rgba(15, 23, 42, var(--coteia-login-card-shadow, .10)),
    0 0 0 1px color-mix(in srgb, var(--coteia-login-accent, var(--coteia-accent)) calc(var(--coteia-login-card-glow, 0) * 100%), transparent);
  backdrop-filter: blur(var(--coteia-login-card-blur, 0));
  transition: transform .18s ease, box-shadow .18s ease;
}

.coteia-login-head {
  margin-bottom: 24px;
  text-align: center;
}

.coteia-login-icon {
  width: calc(var(--coteia-login-icon-size, 22px) + 30px);
  height: calc(var(--coteia-login-icon-size, 22px) + 30px);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--coteia-login-icon-spacing, 14px);
  border-radius: 16px;
  background: color-mix(in srgb, var(--coteia-login-accent, var(--coteia-accent)) 24%, transparent);
  color: var(--coteia-login-icon-color, var(--coteia-primary));
  font-size: var(--coteia-login-icon-size, 22px);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--coteia-login-accent, var(--coteia-accent)) 42%, transparent);
}

.coteia-login-icon-left .coteia-login-head,
.coteia-login-icon-right .coteia-login-head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: var(--coteia-login-icon-spacing, 14px);
  text-align: left;
}

.coteia-login-icon-right .coteia-login-head {
  grid-template-columns: minmax(0, 1fr) auto;
}

.coteia-login-icon-left .coteia-login-icon,
.coteia-login-icon-right .coteia-login-icon {
  margin-bottom: 0;
}

.coteia-login-icon-right .coteia-login-icon {
  grid-column: 2;
  grid-row: 1 / span 2;
}

.coteia-login-icon-left .coteia-login-head h1,
.coteia-login-icon-left .coteia-login-head p {
  grid-column: 2;
}

.coteia-login-icon-right .coteia-login-head h1,
.coteia-login-icon-right .coteia-login-head p {
  grid-column: 1;
}

.coteia-login-head h1 {
  margin: 0;
  color: var(--coteia-login-title, var(--coteia-text));
  font-family: var(--coteia-font-heading);
  font-size: clamp(28px, 4vw, 38px);
  font-weight: var(--coteia-font-heading-weight);
  line-height: 1.08;
}

.coteia-login-head p {
  max-width: 42ch;
  margin: 12px auto 0;
  color: var(--coteia-login-text, var(--coteia-muted));
  font-family: var(--coteia-font-body);
  font-size: 15px;
  line-height: 1.6;
}

.coteia-login-form {
  display: grid;
  gap: var(--coteia-login-field-spacing, 14px);
}

.coteia-login-form label {
  display: grid;
  gap: 7px;
  color: var(--coteia-login-label, var(--coteia-text));
  font-family: var(--coteia-font-menu);
  font-size: 13px;
  font-weight: 800;
}

.coteia-login-form input[type="text"],
.coteia-login-form input[type="email"],
.coteia-login-form input[type="password"] {
  width: 100%;
  min-height: 48px;
  border: 1px solid var(--coteia-login-input-border, rgba(15, 23, 42, .12));
  border-radius: var(--coteia-login-field-radius, 12px);
  padding: 12px 14px;
  background: var(--coteia-login-input-bg, #fff);
  color: var(--coteia-login-input-text, var(--coteia-text));
  font: inherit;
  font-weight: 600;
  outline: none;
  transition: border-color .18s ease, box-shadow .18s ease;
}

.coteia-login-form input:focus {
  border-color: var(--coteia-login-focus, var(--coteia-primary));
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--coteia-login-focus, var(--coteia-primary)) 18%, transparent);
}

.coteia-login-form input::placeholder {
  color: var(--coteia-login-placeholder, #98a2b3);
}

.coteia-login-check {
  display: inline-flex !important;
  grid-template-columns: auto 1fr;
  align-items: center;
  justify-content: flex-start;
  gap: 8px !important;
  color: var(--coteia-muted) !important;
  font-weight: 700 !important;
}

.coteia-login-form button,
.coteia-account-actions a {
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: var(--coteia-login-button-radius, 12px);
  padding: 12px 18px;
  background: var(--coteia-login-button, var(--coteia-primary));
  color: #fff;
  font-family: var(--coteia-font-button);
  font-size: 14px;
  font-weight: var(--coteia-font-button-weight);
  text-decoration: none;
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease;
}

.coteia-login-form button:hover,
.coteia-account-actions a:hover {
  transform: translateY(-1px);
  background: var(--coteia-login-button-hover, var(--coteia-login-button, var(--coteia-primary)));
  box-shadow:
    0 12px 28px color-mix(in srgb, var(--coteia-login-button, var(--coteia-primary)) calc(var(--coteia-login-button-shadow, .14) * 100%), transparent),
    0 0 24px color-mix(in srgb, var(--coteia-login-accent, var(--coteia-accent)) calc(var(--coteia-login-button-glow, 0) * 100%), transparent);
}

.coteia-login-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  margin-top: 18px;
}

.coteia-login-links a {
  color: var(--coteia-login-link, var(--coteia-primary));
  font-weight: 800;
  text-decoration: none;
}

.coteia-login-message {
  margin-bottom: 16px;
  border-radius: 12px;
  padding: 12px 14px;
  font-weight: 800;
  line-height: 1.45;
}

.coteia-login-message-error {
  background: var(--coteia-login-error-bg, #fef3f2);
  color: var(--coteia-login-error-text, #b42318);
}

.coteia-login-message-success {
  background: var(--coteia-login-success-bg, #ecfdf3);
  color: var(--coteia-login-success-text, #027a48);
}

.coteia-account-panel {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 18px;
  align-items: center;
}

.coteia-account-avatar img {
  border-radius: 18px;
}

.coteia-account-panel h2 {
  margin: 0;
  color: var(--coteia-text);
  font-family: var(--coteia-font-heading);
  font-size: 24px;
}

.coteia-account-panel p {
  margin: 5px 0 0;
  color: var(--coteia-muted);
}

.coteia-account-actions {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.coteia-account-actions .coteia-account-logout {
  background: #b42318;
}

@media (max-width: 640px) {
  .coteia-login-module {
    padding: 34px 14px;
  }

  .coteia-login-card {
    border-radius: 14px;
    padding: 22px;
  }

  .coteia-account-panel,
  .coteia-account-actions {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .coteia-account-avatar {
    justify-self: center;
  }
}
