@import url("https://fonts.googleapis.com/css2?family=Anton&family=Francois+One&family=Newsreader:opsz,wght@6..72,400;6..72,600&family=Noto+Sans:wght@400;500;600;700&display=swap");

:root {
  --rns-brand-primary: #a31d1d;
  --rns-brand-primary-dark: #8b1919;
  --rns-brand-primary-light: #c42b2b;
  --rns-brand-brown: #433625;
  --rns-brand-olive: #3e4539;
  --rns-bg-white: #ffffff;
  --rns-bg-light: #f5f5f5;
  --rns-bg-gray: #e6e6e6;
  --rns-bg-dark: #333333;
  --rns-text-primary: #000000;
  --rns-text-body: #333333;
  --rns-text-muted: rgba(0, 0, 0, 0.6);
  --rns-text-light: #ffffff;
  --rns-text-subtle: #52504e;
  --rns-border: #eae8e6;
  --rns-border-dark: #e6e6e6;
  --rns-border-input: rgba(67, 54, 37, 0.15);
  --rns-color-error: #8b0000;
  --rns-color-success: #006400;
  --rns-color-outofstock: #c8c8c8;
  --rns-shadow-button: 0 2px 3px rgb(0 0 0 / 20%);
  --rns-shadow-card: 0 4px 16px rgb(0 0 0 / 10%);
  --rns-shadow-elevated: 0 10px 40px rgb(0 0 0 / 15%);
  --rns-font-heading: "Anton", sans-serif;
  --rns-font-body: "Noto Sans", sans-serif;
  --rns-font-accent: "Francois One", sans-serif;
  --rns-font-subheading: "Newsreader", serif;
  --rns-radius-sm: 4px;
  --rns-radius-md: 6px;
  --rns-radius-lg: 8px;
  --rns-spacing-xs: 0.25rem;
  --rns-spacing-sm: 0.5rem;
  --rns-spacing-md: 0.75rem;
  --rns-spacing-lg: 1rem;
  --rns-spacing-xl: 1.5rem;
  --rns-spacing-2xl: 2rem;
  --rns-spacing-3xl: 3rem;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  min-height: 100%;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  min-height: 100%;
  margin: 0;
  font-family: var(--rns-font-body);
  color: var(--rns-text-body);
  background:
    radial-gradient(circle at top left, rgb(255 255 255 / 0.12), transparent 28%),
    linear-gradient(135deg, var(--rns-brand-primary) 0%, var(--rns-bg-dark) 60%, var(--rns-brand-olive) 100%);
}

button,
input,
textarea,
select {
  font: inherit;
}

a {
  color: var(--rns-brand-primary);
}


app-password-recovery {
  display: block;
  min-height: 100vh;
}

app-password-recovery .account-shell {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px 20px;
}

app-password-recovery .account-shell__panel {
  width: 100%;
  max-width: 1120px;
  position: relative;
}

app-password-recovery .account-shell__brandbar {
  position: absolute;
  inset: 0 auto auto 0;
  width: 220px;
  height: 220px;
  border-radius: 999px;
  background: radial-gradient(circle, rgb(255 255 255 / 0.18) 0%, rgb(255 255 255 / 0) 72%);
  transform: translate(-18%, -28%);
  pointer-events: none;
}

app-password-recovery .recovery-card {
  position: relative;
  max-width: 520px;
  margin: 0 auto;
  padding: 32px;
  background: var(--rns-bg-white);
  border-radius: var(--rns-radius-lg);
  border-top: 4px solid var(--rns-brand-primary);
  box-shadow: var(--rns-shadow-elevated);
}

app-password-recovery .recovery-card__header {
  margin-bottom: 28px;
}

app-password-recovery .recovery-card__logo {
  width: 84px;
  height: 84px;
  margin-bottom: 20px;
}

app-password-recovery .recovery-card__eyebrow,
app-password-recovery .section-label,
app-password-recovery .state-panel__eyebrow {
  margin: 0;
  font-family: var(--rns-font-accent);
  font-size: 0.75rem;
  line-height: 1;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--rns-brand-primary);
}

app-password-recovery .recovery-card__title,
app-password-recovery .state-panel__title {
  margin: 12px 0 14px;
  font-family: var(--rns-font-heading);
  font-size: clamp(2rem, 6vw, 2.5rem);
  line-height: 1.05;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--rns-brand-primary);
}

app-password-recovery .recovery-card__intro,
app-password-recovery .recovery-summary p,
app-password-recovery .state-panel__copy {
  margin: 0;
  font-size: 1rem;
  line-height: 1.7;
  color: var(--rns-text-body);
}

app-password-recovery .recovery-summary {
  margin-bottom: 24px;
  padding: 20px 22px;
  border: 1px solid var(--rns-border);
  border-radius: var(--rns-radius-lg);
  background: linear-gradient(180deg, rgb(245 245 245 / 0.9) 0%, rgb(255 255 255 / 1) 100%);
  box-shadow: var(--rns-shadow-card);
}

app-password-recovery .recovery-summary__hint {
  margin-top: 8px !important;
  color: var(--rns-text-subtle) !important;
  font-size: 0.9375rem !important;
}

app-password-recovery .recovery-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

app-password-recovery .field-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

app-password-recovery .field-group__label {
  font-family: var(--rns-font-accent);
  font-size: 0.875rem;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--rns-text-body);
}

app-password-recovery .captcha-block {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding-top: 4px;
}

app-password-recovery .form-error {
  margin: 0;
  color: var(--rns-color-error);
  font-size: 0.875rem;
  font-weight: 600;
}

app-password-recovery .status-banner {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 14px 16px;
  border-radius: var(--rns-radius-sm);
  font-size: 0.9375rem;
  line-height: 1.5;
}

app-password-recovery .status-banner--error {
  background: #fce4e4;
  border: 1px solid var(--rns-brand-primary);
  border-left: 4px solid var(--rns-color-error);
  color: var(--rns-color-error);
}

app-password-recovery .recovery-actions {
  padding-top: 4px;
}

app-password-recovery .state-panel {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  padding: 8px 0;
}

app-password-recovery .state-panel--loading {
  align-items: center;
  text-align: center;
  padding: 28px 0 12px;
}

app-password-recovery .state-panel__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  font-size: 1.75rem;
}

app-password-recovery .state-panel__icon--success {
  color: var(--rns-color-success);
  background: rgb(0 100 0 / 0.08);
}

app-password-recovery .state-panel__icon--error {
  color: var(--rns-color-error);
  background: rgb(139 0 0 / 0.08);
}

app-password-recovery .recovery-password {
  position: relative;
  display: flex;
  align-items: center;
}

app-password-recovery .recovery-password,
app-password-recovery .recovery-password .recovery-input {
  width: 100%;
}

app-password-recovery .recovery-input,
app-password-recovery .recovery-password .recovery-input {
  width: 100%;
  padding: 0.875rem 3rem 0.875rem 0.9375rem;
  border: 1px solid var(--rns-border-input);
  border-radius: var(--rns-radius-sm);
  color: var(--rns-brand-brown);
  background: var(--rns-bg-white);
  box-shadow: none;
  outline: none;
}

app-password-recovery .recovery-input:hover {
  border-color: var(--rns-brand-primary);
}

app-password-recovery .recovery-input:focus {
  border-color: var(--rns-brand-primary);
  box-shadow: 0 0 0 3px rgb(163 29 29 / 0.12);
}

app-password-recovery .password-toggle-btn {
  position: absolute;
  right: 0.625rem;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--rns-brand-primary);
  padding: 0.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--rns-radius-sm);
  flex-shrink: 0;
}

app-password-recovery .password-toggle-btn:focus-visible {
  outline: 2px solid var(--rns-brand-primary);
  outline-offset: 2px;
}

app-password-recovery .password-toggle-btn svg {
  width: 20px;
  height: 20px;
}

app-password-recovery .recovery-btn {
  width: 100%;
  padding: 0.875rem 1rem;
  border: none;
  border-radius: var(--rns-radius-sm);
  background: var(--rns-brand-primary);
  box-shadow: var(--rns-shadow-button);
  color: var(--rns-text-light);
  font-family: var(--rns-font-accent);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
}

app-password-recovery .recovery-btn:not(:disabled):hover {
  background: var(--rns-brand-primary-dark);
}

app-password-recovery .recovery-btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgb(163 29 29 / 0.12);
}

app-password-recovery .recovery-btn:disabled {
  background: var(--rns-color-outofstock);
  cursor: not-allowed;
}

app-password-recovery .status-banner__icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  margin-top: 2px;
}

@keyframes spinner-rotate {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

app-password-recovery .progress-spinner {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 54px;
  height: 54px;
}

app-password-recovery .progress-spinner__circle {
  width: 44px;
  height: 44px;
  border: 3px solid rgb(163 29 29 / 0.15);
  border-top-color: var(--rns-brand-primary);
  border-radius: 50%;
  animation: spinner-rotate 0.8s linear infinite;
}

app-password-recovery .state-panel__icon svg {
  width: 32px;
  height: 32px;
}

@media (max-width: 640px) {
  app-password-recovery .account-shell {
    padding: 18px 14px;
  }

  app-password-recovery .recovery-card {
    padding: 24px 20px;
  }

  app-password-recovery .recovery-card__logo {
    width: 72px;
    height: 72px;
  }

  app-password-recovery .recovery-card__title,
  app-password-recovery .state-panel__title {
    font-size: 1.875rem;
  }
}


