/* Primeportal login — compact layout using the same design tokens + components as the portal */

html,
body {
  min-height: 100%;
}

html {
  overflow-x: hidden;
}

body.auth-only {
  position: relative;
  isolation: isolate;
  overflow-x: hidden;
  color: var(--pp-text);
  background-color: var(--pp-bg-midnight);
  background-image: var(--pp-bg-gradient);
}

body.auth-only::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background: var(--pp-bg-glow);
  opacity: 1;
}

body.auth-only::after {
  display: none;
}

/* --------------------------------------------------------------------------
   Buttons / actions — parity with css/design-system/_buttons.css (auth scope)
   -------------------------------------------------------------------------- */
body.auth-only a.btn,
body.auth-only a.btn:hover,
body.auth-only a.btn:visited,
body.auth-only a.btn:active {
  text-decoration: none;
}

body.auth-only .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: var(--pp-btn-height);
  border-radius: var(--pp-btn-radius);
  border: none;
  background: var(--pp-accent);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.01em;
  padding: 0 14px;
  white-space: nowrap;
  cursor: pointer;
  box-shadow: 0 4px 12px rgba(255, 45, 143, 0.24);
  transition: transform 0.1s ease, background-color 0.15s ease, box-shadow 0.15s ease;
}

body.auth-only .btn:hover {
  background: var(--pp-accent-strong);
  box-shadow: 0 6px 16px rgba(255, 45, 143, 0.3);
}

body.auth-only .btn:active {
  transform: translateY(1px);
}

body.auth-only .btn.secondary,
body.auth-only .btn.ghost {
  border: var(--pp-divider);
  background: rgba(255, 255, 255, 0.04);
  color: var(--pp-text-soft);
  box-shadow: none;
}

body.auth-only .btn.secondary:hover,
body.auth-only .btn.ghost:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--pp-text);
}

body.auth-only .btn:focus-visible {
  box-shadow: var(--pp-focus-ring);
}

body.auth-only .btn.pp-btn--primestreak-frame {
  border: none;
  background: linear-gradient(165deg, var(--pp-accent) 0%, var(--pp-accent-strong) 100%);
  box-shadow: 0 4px 12px rgba(255, 45, 143, 0.24);
}

body.auth-only .btn.pp-btn--primestreak-frame:hover {
  background: linear-gradient(165deg, var(--pp-accent-strong) 0%, var(--pp-accent) 100%);
  box-shadow: 0 6px 16px rgba(255, 45, 143, 0.3);
}

body.auth-only .btn.pp-btn--primestreak-frame:focus-visible {
  box-shadow: var(--pp-focus-ring);
}

body.auth-only .btn:disabled,
body.auth-only .btn[disabled] {
  opacity: 0.55;
  cursor: not-allowed;
  box-shadow: none;
}

body.auth-only .actions {
  margin-top: var(--pp-space-3);
  display: flex;
  flex-wrap: wrap;
  gap: var(--pp-space-2);
}

body.auth-only .auth-form .actions .btn,
body.auth-only .auth-register-cta .btn {
  width: 100%;
  box-sizing: border-box;
}

body.auth-only .topbar {
  display: none;
}

body.auth-only .wrapper {
  width: 100%;
  max-width: none;
  min-height: 100vh;
  padding: clamp(12px, 3vw, 40px);
  display: flex;
  flex-direction: column;
  gap: clamp(10px, 1.6vw, 18px);
  align-items: stretch;
  justify-content: flex-start;
}

body.auth-only .notice {
  width: min(1120px, 92vw);
  max-width: min(1120px, 92vw);
  margin: 10px auto 0;
  border-radius: var(--pp-radius-md);
  border: var(--pp-glass-border);
  background: var(--pp-glass-bg);
  backdrop-filter: blur(var(--pp-blur-panel));
  -webkit-backdrop-filter: blur(var(--pp-blur-panel));
  color: var(--pp-text);
  white-space: normal;
  overflow-wrap: anywhere;
  line-height: 1.45;
}

body.auth-only .notice + .notice {
  margin-top: 10px;
}

body.auth-only .notice.error {
  border-color: rgba(255, 45, 143, 0.44);
  background: linear-gradient(180deg, rgba(50, 15, 35, 0.72), rgba(16, 12, 22, 0.88));
}

body.auth-only .auth.auth--laser {
  position: relative;
  flex: 1 1 auto;
  min-height: 0;
  display: grid;
  place-items: center;
  overflow: visible;
}

body.auth-only .auth.auth--laser::before,
body.auth-only .auth.auth--laser::after {
  display: none;
}

body.auth-only .auth--laser .auth-shell {
  position: relative;
  width: min(720px, 92vw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(12px, 2.4vh, 22px);
  justify-items: center;
  align-items: start;
}

/* Language toggle — chip rhythm (workspace pills) */
body.auth-only .auth-lang {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: var(--pp-space-2);
  font-family: Montserrat, system-ui, sans-serif;
  font-size: var(--pp-type-meta);
  font-weight: 700;
  letter-spacing: 0.06em;
}

body.auth-only .auth-lang-link {
  color: var(--pp-text-muted);
  text-decoration: none;
  padding: 0 10px;
  min-height: var(--pp-chip-height-sm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--pp-chip-radius);
  border: var(--pp-chip-border);
  background: var(--pp-chip-bg);
  transition: color 0.15s ease, background 0.15s ease, border-color 0.15s ease;
}

body.auth-only .auth-lang-link:hover {
  color: var(--pp-text);
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(245, 247, 255, 0.14);
}

body.auth-only .auth-lang-link.is-active {
  color: var(--pp-text);
  border-color: var(--pp-chip-border-active);
  background: var(--pp-chip-bg-active);
  text-decoration: none;
}

body.auth-only .auth-lang-sep {
  color: var(--pp-text-meta);
  user-select: none;
}

@media (max-width: 600px) {
  body.auth-only .auth-lang {
    position: static;
    justify-self: end;
    margin: 0 0 4px;
  }
}

body.auth-only .auth-copy {
  width: min(640px, 100%);
  min-width: 0;
  display: grid;
  gap: clamp(8px, 1.2vw, 14px);
  justify-items: center;
  text-align: center;
}

body.auth-only .auth-copy-main {
  width: min(720px, 100%);
  gap: clamp(6px, 1.1vw, 12px);
}

/* Glass surfaces — same recipe as .pp-widget-glass, scoped to auth */
body.auth-only .pp-widget-glass {
  padding: var(--pp-space-4) var(--pp-space-5);
  background: linear-gradient(
    135deg,
    rgba(255, 45, 143, 0.06) 0%,
    rgba(255, 255, 255, 0.05) 40%,
    rgba(47, 230, 199, 0.04) 100%
  );
  border: 1px solid transparent;
  border-top-color: rgba(255, 45, 143, 0.18);
  border-bottom-color: rgba(47, 230, 199, 0.12);
  border-radius: var(--pp-card-radius-bl);
  box-shadow:
    0 4px 24px rgba(0, 0, 0, 0.2),
    0 0 40px -8px rgba(255, 45, 143, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(14px) saturate(1.2);
  -webkit-backdrop-filter: blur(14px) saturate(1.2);
}

body.auth-only .auth-card.pp-widget-glass {
  width: min(420px, 92vw);
  box-sizing: border-box;
  /* Reset legacy .card from base/_dashboard-hero.css */
  position: relative;
  overflow: hidden;
  border: 1px solid transparent;
  border-top-color: rgba(255, 45, 143, 0.18);
  border-bottom-color: rgba(47, 230, 199, 0.12);
  padding: clamp(var(--pp-space-3), 2vw, var(--pp-space-5));
}

body.auth-only .auth-brand {
  display: inline-flex;
  justify-self: center;
  width: fit-content;
}

body.auth-only .auth-brand img {
  width: clamp(132px, 22vw, 200px);
  height: auto;
  object-fit: contain;
}

body.auth-only .auth-brand-tagline {
  margin: 0;
  text-align: center;
  font-size: var(--pp-type-meta);
  letter-spacing: 0.12em;
  text-transform: none;
  color: var(--pp-accent);
}

body.auth-only .auth-title {
  margin: 2px auto 0;
  max-width: min(100%, 17ch);
  font-size: clamp(30px, 4.8vw, 46px);
  line-height: 1.12;
  letter-spacing: -0.015em;
  color: var(--pp-text);
  font-weight: 700;
  text-wrap: balance;
}

body.auth-only .auth-subtext {
  margin: 2px 0 0;
  max-width: 48ch;
  color: var(--pp-text-muted);
  font-size: clamp(13px, 1.35vw, 15px);
  line-height: 1.42;
  text-wrap: pretty;
}

body.auth-only .auth-form-wrap {
  width: 100%;
  min-width: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

body.auth-only .auth-card::before,
body.auth-only .auth-card::after {
  display: none;
}

body.auth-only .auth-card-head {
  display: grid;
  gap: var(--pp-space-2);
  margin-bottom: var(--pp-space-3);
}

body.auth-only .auth-kicker {
  display: inline-flex;
  width: fit-content;
  font-size: var(--pp-type-meta);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--pp-accent);
}

body.auth-only .auth-card-head p {
  margin: 0;
  color: var(--pp-text-muted);
  font-size: var(--pp-type-body-sm);
  line-height: 1.4;
}

body.auth-only .auth-form-errors {
  margin: 0 0 var(--pp-space-3);
  padding: var(--pp-space-3);
  list-style: none;
  border-radius: var(--pp-radius-md);
  border: 1px solid rgba(255, 45, 143, 0.35);
  background: rgba(50, 15, 35, 0.42);
  color: var(--pp-text-soft);
  font-size: var(--pp-type-helper);
  line-height: 1.45;
}

body.auth-only .auth-form-errors li + li {
  margin-top: var(--pp-space-2);
}

body.auth-only .auth-form-inline-notice {
  margin: 0 0 var(--pp-space-3);
  padding: var(--pp-space-3);
  border-radius: var(--pp-radius-md);
  border: var(--pp-border-subtle);
  background: var(--pp-surface-muted);
  color: var(--pp-text-soft);
  font-size: var(--pp-type-helper);
}

body.auth-only .auth-form {
  display: grid;
  gap: var(--pp-rhythm-field);
}

body.auth-only .auth-field {
  position: relative;
}

/* Floating labels on top of inputs — colors/radius match _form-field.css */
body.auth-only .auth-field input {
  box-sizing: border-box;
  width: 100%;
  min-width: 0;
  min-height: var(--pp-control-min-height);
  padding: var(--pp-control-pad-y) var(--pp-control-pad-x) var(--pp-control-pad-y);
  padding-top: 1.1rem;
  border-radius: var(--pp-radius-md);
  border: var(--pp-divider);
  background: var(--pp-surface-elevated);
  color: var(--pp-text);
  font-size: var(--pp-type-body-sm);
  line-height: 1.45;
  box-shadow: none;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

body.auth-only .auth-field input::placeholder {
  color: var(--pp-text-muted);
}

body.auth-only .auth-field label {
  position: absolute;
  left: var(--pp-control-pad-x);
  top: 0.65rem;
  margin: 0;
  z-index: 2;
  pointer-events: none;
  color: var(--pp-text-muted);
  font-size: var(--pp-type-label);
  font-weight: 600;
  letter-spacing: 0.02em;
  transition: transform 0.16s ease, color 0.16s ease, font-size 0.16s ease, top 0.16s ease;
}

body.auth-only .auth-field input:focus,
body.auth-only .auth-field input:focus-visible {
  outline: none;
  border-color: rgba(255, 45, 143, 0.4);
  box-shadow: 0 0 0 2px rgba(255, 45, 143, 0.1);
}

body.auth-only .auth-field input:focus + label,
body.auth-only .auth-field input:not(:placeholder-shown) + label,
body.auth-only .auth-field input:-webkit-autofill + label,
body.auth-only .auth-field.is-filled label {
  top: 5px;
  font-size: var(--pp-type-meta);
  color: var(--pp-accent);
}

body.auth-only .auth-form .actions {
  margin-top: var(--pp-space-1);
}

body.auth-only .auth-action-stack {
  display: grid;
  gap: var(--pp-space-3);
  margin-top: var(--pp-space-1);
}

body.auth-only .auth-register-cta {
  display: grid;
  gap: var(--pp-space-2);
  padding: var(--pp-space-3);
  border-radius: var(--pp-radius-md);
  border: var(--pp-chip-border);
  background: var(--pp-chip-bg);
}

body.auth-only .auth-register-cta__hint {
  margin: 0;
  font-size: var(--pp-type-meta);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--pp-text-muted);
}

body.auth-only .auth-footnote--security {
  margin: 0;
  font-size: var(--pp-type-helper);
  line-height: 1.35;
  color: var(--pp-text-meta);
}

body.auth-only .auth-footnote--links {
  margin: 0;
  text-align: center;
}

body.auth-only .auth-link-subtle {
  font-size: var(--pp-type-body-sm);
  font-weight: 600;
  color: var(--pp-text-soft);
  text-decoration: none;
  text-underline-offset: 4px;
}

body.auth-only .auth-link-subtle:hover {
  color: var(--pp-text);
  text-decoration: underline;
}

body.auth-only .auth-footnote {
  margin: var(--pp-space-2) 0 0;
  color: var(--pp-text-muted);
  overflow-wrap: anywhere;
  font-size: var(--pp-type-helper);
}

body.auth-only .auth-footnote a {
  color: var(--pp-text-soft);
  font-weight: 600;
}

body.auth-only .auth-footnote a:hover {
  color: var(--pp-accent);
}

@media (max-width: 1100px) {
  body.auth-only .auth.auth--laser {
    place-items: start center;
    min-height: auto;
    padding-bottom: 10px;
  }

  body.auth-only .auth--laser .auth-shell {
    gap: 14px;
  }

  body.auth-only .auth-form-wrap {
    justify-content: center;
  }

  body.auth-only .auth-card.pp-widget-glass {
    width: min(420px, 92vw);
  }
}

@media (max-width: 900px) {
  body.auth-only .auth-title {
    white-space: normal;
    text-wrap: balance;
  }
}

@media (max-width: 640px) {
  body.auth-only .wrapper {
    padding: 10px;
  }

  body.auth-only .notice {
    margin-top: 8px;
  }

  body.auth-only .auth-brand img {
    width: clamp(120px, 38vw, 168px);
  }

  body.auth-only .auth-title {
    max-width: min(100%, 17ch);
    font-size: clamp(26px, 7.2vw, 36px);
  }

  body.auth-only .auth-card.pp-widget-glass {
    padding: var(--pp-space-3);
  }
}

@media (max-height: 760px) {
  body.auth-only .auth.auth--laser {
    place-items: start center;
    min-height: auto;
    padding-top: 0;
    padding-bottom: 8px;
  }

  body.auth-only .auth-title {
    max-width: min(100%, 17ch);
    font-size: clamp(28px, 5.2vw, 40px);
  }

  body.auth-only .auth-subtext {
    font-size: var(--pp-type-helper);
  }
}

@media (prefers-reduced-motion: reduce) {
  body.auth-only .auth-card,
  body.auth-only .btn,
  body.auth-only .auth-field input,
  body.auth-only .auth-field label,
  body.auth-only .auth-lang-link {
    transition: none;
  }
}
