.portal-page {
  min-height: 100dvh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-bg);
}

[data-theme='dark'] .portal-page {
  background: #0E0E0C;
}

.portal-login-card {
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: 20px;
  padding: clamp(2rem, 4vw, 3rem);
  width: 100%;
  max-width: 420px;
  box-shadow: var(--shadow-xl);
}

/* Full-width layout for employee/partner portal pages */
.doc-portal-page {
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  background: var(--color-bg);
}

[data-theme='dark'] .doc-portal-page {
  background: #0E0E0C;
}

.doc-portal-page .portal-docs-card {
  max-width: none !important;
  border-radius: 0 !important;
  border: none !important;
  box-shadow: none !important;
  background: #161614 !important;
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 2rem;
}

.doc-portal-page .portal-docs-card .portal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
}

.doc-portal-page .portal-docs-card .portal-header .portal-login-card__sub {
  text-align: left;
  margin: 0 !important;
  padding: 0;
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  line-height: 1;
  margin-bottom: 0 !important;
}

.doc-portal-page .portal-docs-card .portal-header form {
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
}

.doc-portal-page .portal-docs-card .portal-header .portal-back-link {
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1 !important;
  font-size: 0.75rem !important;
  display: inline !important;
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  color: var(--color-text-muted) !important;
}



.portal-login-card__sub {
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  text-align: center;
  margin-bottom: 2rem;
}

.portal-login-card__error {
  background: rgba(220,53,69,0.1);
  border: 1px solid rgba(220,53,69,0.3);
  color: #dc3545;
  border-radius: var(--radius-md);
  padding: 0.75rem 1rem;
  font-size: var(--text-sm);
  margin-bottom: 1rem;
  display: none;
}

.portal-login-card__error.visible {
  display: block;
}

.portal-messages {
  margin-bottom: 1rem;
}

.portal-login-card__alert {
  border-radius: var(--radius-md);
  padding: 0.75rem 1rem;
  font-size: var(--text-sm);
  margin-bottom: 1rem;
  display: none;
}

.portal-login-card__alert.visible {
  display: block;
}

.portal-login-card__alert--error {
  background: rgba(220,53,69,0.1);
  border: 1px solid rgba(220,53,69,0.3);
  color: #dc3545;
}

.portal-login-card__alert--success,
.portal-login-card__alert--info {
  background: rgba(255,193,7,0.1);
  border: 1px solid rgba(255,193,7,0.3);
  color: #ffc107;
}

.portal-login-card__alert--warning {
  background: rgba(255,193,7,0.1);
  border: 1px solid rgba(255,193,7,0.3);
  color: #ffc107;
}

.portal-login-card form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.portal-login-card .form-group label {
  font-size: var(--text-sm);
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--color-text);
}

.portal-login-card .form-group input {
  padding: 0.8rem 1rem;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
  color: var(--color-text);
  font-size: var(--text-base);
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
  width: 100%;
}

.portal-login-card .form-group input:focus {
  outline: none;
  border-color: var(--el-green-dark, #168543);
  box-shadow: 0 0 0 3px rgba(22,133,67,0.12);
}

.portal-login-card .btn {
  justify-content: center;
  margin-top: 0.5rem;
}

.portal-login-card .btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

.portal-back-link {
  display: block;
  text-align: left;
  margin-top: 1.25rem;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  text-decoration: none;
}

.portal-back-link:hover {
  color: var(--el-green, #A0CC4E);
}

/* Logged-in state */
.portal-logged-in {
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: var(--color-bg);
  text-align: center;
  padding: 2rem;
}

[data-theme='dark'] .portal-logged-in {
  background: #0E0E0C;
}

.portal-welcome {
  max-width: 480px;
}

.portal-welcome__icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(160,204,78,0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.5rem;
  font-size: 1.75rem;
  color: var(--el-green, #A0CC4E);
}

.portal-welcome__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  text-transform: uppercase;
  color: var(--color-text);
  margin-bottom: 0.75rem;
}

.portal-welcome__title em {
  font-style: normal;
  color: var(--el-green, #A0CC4E);
}

.portal-welcome__user {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: 2rem;
}

.portal-welcome__logout {
  justify-content: center;
}

/* Django form error highlighting */
.portal-login-card .form-group input.error {
  border-color: #dc3545;
  box-shadow: 0 0 0 3px rgba(220,53,69,0.12);
}
