@import url("form-input.css");

:root {
  --text: #1a1917;
  --text-tertiary: #aaa;
}

.nav-auth-btn {
  background: none;
  border: none;
  font: inherit;
  font-size: clamp(11px, 1vw, 13px);
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 3px;
  color: #aaa;
  padding: 0;
  margin: 0;
  appearance: none;
  -webkit-appearance: none;
  flex-shrink: 0;
}
.nav-auth-btn:hover { color: #1a1917; }
.nav-auth-btn[hidden] { display: none !important; }

.user-menu-wrap {
  position: relative;
  display: flex;
  align-items: center;
  flex-shrink: 0;
  font-size: clamp(11px, 1vw, 13px);
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1;
  color: #aaa;
}
.user-menu-wrap[hidden] { display: none !important; }

.user-menu-btn {
  background: none;
  border: none;
  font: inherit;
  font-size: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
  line-height: 1;
  color: inherit;
  padding: 0;
  margin: 0;
  cursor: pointer;
  max-width: 160px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  appearance: none;
  -webkit-appearance: none;
}
.user-menu-btn:hover { color: #1a1917; }

.user-menu-popout {
  position: absolute;
  right: 0;
  top: calc(100% + 6px);
  min-width: 180px;
  background: #faf8f3;
  border: 1.5px solid #1a1917;
  border-radius: 10px;
  padding: 6px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  z-index: 50;
  box-shadow: 0 8px 24px rgba(0,0,0,.08);
}
.user-menu-popout[hidden] { display: none; }
.user-menu-popout a,
.user-menu-popout button {
  display: block;
  width: 100%;
  text-align: left;
  background: none;
  border: none;
  font: inherit;
  font-size: 13px;
  padding: 8px 10px;
  border-radius: 6px;
  cursor: pointer;
  color: inherit;
  text-decoration: none;
}
.user-menu-popout a:hover,
.user-menu-popout button:hover { background: rgba(0,0,0,.06); }

.auth-user-overlay {
  position: fixed;
  inset: 0;
  z-index: 1200;
  background: rgba(26,25,23,.45);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.auth-user-overlay.auth-user-overlay--gate { z-index: 10001; }
.auth-user-overlay[hidden] { display: none; }
.auth-user-panel {
  position: relative;
  width: min(420px, 100%);
  background: #faf8f3;
  border: 1.5px solid #1a1917;
  border-radius: 14px;
  padding: 24px 22px 20px;
}
.auth-user-close {
  position: absolute;
  top: 10px;
  right: 12px;
  background: none;
  border: none;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
}
.auth-user-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 16px;
}
.auth-user-tab {
  flex: 1;
  background: none;
  border: 1.5px solid #1a1917;
  border-radius: 999px;
  font: inherit;
  font-size: 13px;
  font-weight: 600;
  padding: 8px 12px;
  cursor: pointer;
}
.auth-user-tab.active { background: #1a1917; color: #faf8f3; }
.auth-registration-gate-notice {
  margin: 0 0 14px;
  padding: 12px 14px;
  border-radius: 10px;
  background: #FAEEDA;
  border-left: 3px solid #EF9F27;
  font-size: 13px;
  line-height: 1.55;
  color: #854F0B;
}
.auth-registration-gate-notice[hidden] { display: none; }
@media (prefers-color-scheme: dark) {
  .auth-registration-gate-notice { background: #2a1d08; color: #EF9F27; }
}
.auth-user-form { display: flex; flex-direction: column; gap: 12px; }
.auth-user-form[hidden] { display: none; }
.auth-user-label { display: flex; flex-direction: column; gap: 4px; font-size: 13px; font-weight: 600; }
.auth-user-panel .btn-support { width: 100%; text-align: center; }
.auth-forgot-link, .auth-forgot-back, .auth-resend-btn {
  background: none; border: none; padding: 0; font: inherit; font-size: 13px;
  color: var(--text-tertiary); cursor: pointer; text-align: left; margin-top: 4px;
}
.auth-forgot-link:hover, .auth-forgot-back:hover, .auth-resend-btn:hover { color: var(--text); }
.auth-forgot-title { margin: 0 0 4px; font-size: 15px; font-weight: 700; }
.auth-user-ok { margin-top: 10px; font-size: 13px; color: #166534; }
.auth-user-ok[hidden] { display: none; }
.auth-user-err { margin-top: 10px; font-size: 13px; color: #b91c1c; }
.auth-user-err[hidden] { display: none; }
.auth-consent-label {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.45;
  color: #444;
  cursor: pointer;
}
.auth-consent-label input { margin-top: 3px; flex-shrink: 0; }
.auth-consent-label a { color: #1a1917; }

.site-nav .nav-right {
  display: flex;
  align-items: center;
  gap: 2vw;
}
