/* ── Proxima Nova ──────────────────────────────────────────────────── */
@font-face {
  font-family: 'Proxima Nova';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/proxima-nova/regular.woff2') format('woff2'),
       url('../fonts/proxima-nova/regular.woff')  format('woff');
}
@font-face {
  font-family: 'Proxima Nova';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/proxima-nova/semibold.woff2') format('woff2'),
       url('../fonts/proxima-nova/semibold.woff')  format('woff');
}
@font-face {
  font-family: 'Proxima Nova';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/proxima-nova/bold.woff2') format('woff2'),
       url('../fonts/proxima-nova/bold.woff')  format('woff');
}

/* ── Reset / base ──────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html, body {
  height: 100%;
  margin: 0;
  padding: 0;
  font-family: 'Proxima Nova', 'Roboto', Arial, sans-serif;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  background: linear-gradient(240deg,var(--token-4e9e8cc2-9982-46b6-9c69-a42317883336,#ff8000)0%,#e7393f 25%,#b00059 50%,#65005f 75%,var(--token-d4675c63-5217-4abc-af99-38bea55889e9,#000d4d)100%);
  background-color: #02061E;
  color: #fff;
}

/* ── Particle canvas ───────────────────────────────────────────────── */
#friss-particles {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  pointer-events: none;
}

/* ── Background shield watermark ───────────────────────────────────── */
#friss-bg-shield {
  position: fixed;
  right: 7%;
  top: 50%;
  transform: translateY(-48%);
  height: 70vh;
  width: auto;
  z-index: 1;
  pointer-events: none;
  user-select: none;
  opacity: 0.3;
  filter: brightness(0) invert(1) sepia(1) saturate(2) hue-rotate(220deg);
  mix-blend-mode: screen;
}

/* ── Page wrapper ──────────────────────────────────────────────────── */
.friss-login-page {
  position: relative;
  z-index: 2;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* ── Header ────────────────────────────────────────────────────────── */
.friss-header {
  display: flex;
  align-items: center;
  padding: 1.25rem 2rem;
}

.friss-header img {
  height: 84px;
  width: auto;
}

/* ── Main content area ─────────────────────────────────────────────── */
.friss-main {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem 1rem;
}



/* ── reCAPTCHA dark theme nudge ───────────────────────────────────── */
.g-recaptcha iframe {
  filter: invert(0.85) hue-rotate(180deg);
  border-radius: 6px;
}

/* ── Footer ────────────────────────────────────────────────────────── */
.friss-footer {
  text-align: center;
  padding: 1.25rem 1rem;
  font-size: 0.78rem;
  color: rgba(255,255,255,0.3);
  position: relative;
  z-index: 1;
}
.friss-footer a {
  color: rgba(255,255,255,0.45);
  text-decoration: none;
}
.friss-footer a:hover { color: rgba(255,255,255,0.7); }

/* ── Responsive ────────────────────────────────────────────────────── */
@media (max-width: 480px) {
  .friss-header { padding: 1rem; }
}


/* ════════════════════════════════════════════════════════════════════
   COMPAT LAYER
   Maps Material Dashboard / Bootstrap classes used in child views
   to the FRISS login design without touching the individual .cshtml files.
   ════════════════════════════════════════════════════════════════════ */

/* Center the Bootstrap grid column inside our flex friss-main */
.friss-main .container { width: 100%; max-width: none; padding: 0; }
.friss-main .row {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin: 0;
  width: 100%;
}
.friss-main .row > [class*="col-"] {
  float: none;
  padding: 0;
  width: 100%;
  max-width: 465px;
  flex: 0 0 auto;
}

/* Card — light theme */
.friss-main .card,
.friss-main .card-login {
  background: rgba(255,255,255,0.97);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border: 1px solid rgba(0,0,0,0.07);
  border-radius: 16px;
  box-shadow: 0 24px 64px rgba(0,0,0,0.35);
  padding: 0;
  margin: 0;
}
.friss-main .card-header,
.friss-main .card-header[data-background-color] {
  background: transparent !important;
  border-bottom: 1px solid rgba(0,0,0,0.07);
  padding: 1.5rem 2rem 1.25rem;
  box-shadow: none !important;
  border-radius: 0;
  margin: 0;
}
.friss-main .card-header h4,
.friss-main .card-header .card-title {
  color: #0f172a;
  font-family: 'Proxima Nova', 'Roboto', sans-serif;
  font-size: 1.4rem;
  font-weight: 700;
  margin: 0;
  text-shadow: none;
}
.friss-main .card-content {
  padding: 0.55rem 2rem 2rem;
}

/* Input group — hide the icon addon, keep the input */
.friss-main .input-group {
  display: block;
  margin-bottom: 0.8rem;
}
.friss-main .input-group-addon { display: none; }

/* Labels: convert Material's floating label to a static uppercase label */
.friss-main .form-group { margin-bottom: 1rem; position: static; }
.friss-main .form-group.is-focused .control-label,
.friss-main .form-group.label-floating .control-label,
.friss-main .form-group label.control-label {
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: none;
  color: #374151;
  margin-bottom: 0.35rem;
  transform: none !important;
  margin-top: 0.85rem !important;
}

/* Inputs */
.friss-main .form-control,
.friss-main input[type="text"]:not([class*="friss-"]),
.friss-main input[type="email"]:not([class*="friss-"]),
.friss-main input[type="password"]:not([class*="friss-"]) {
  display: block;
  width: 100%;
  padding: 0.7rem 0.9rem;
  font-family: 'Proxima Nova', 'Roboto', sans-serif;
  font-size: 1rem;
  color: #0f172a;
  background: rgba(0,0,0,0.04);
  border: 1px solid rgba(0,0,0,0.14);
  border-bottom: 1px solid rgba(0,0,0,0.14) !important;
  border-radius: 8px;
  outline: none;
  box-shadow: none !important;
  -webkit-appearance: none;
  appearance: none;
  transition: border-color 0.18s, background 0.18s;
}
.friss-main .form-control:focus,
.friss-main input[type="text"]:focus,
.friss-main input[type="email"]:focus,
.friss-main input[type="password"]:focus {
  border-color: rgba(255,128,0,0.55) !important;
  background: #fff;
  box-shadow: none !important;
}
.friss-main .form-control::placeholder { color: rgba(0,0,0,0.28); }
.friss-main .form-control:-webkit-autofill {
  -webkit-text-fill-color: #0f172a !important;
  -webkit-box-shadow: 0 0 0 100px #f9fafb inset !important;
}

/* Buttons */
.friss-main .btn { border-radius: 8px !important; font-family: 'Proxima Nova','Roboto',sans-serif !important; }
.friss-main .btn.btn-rose,
.friss-main .btn.btn-success,
.friss-main .btn.btn-primary,
.friss-main .btn.btn-simple.btn-rose {
  background: #FF8000 !important;
  border: none !important;
  color: #fff !important;
  font-weight: 700 !important;
  font-size: 0.95rem !important;
  padding: 0.7rem 2rem !important;
  text-shadow: none !important;
  box-shadow: none !important;
  letter-spacing: 0.03em !important;
}
.friss-main .btn.btn-rose:hover { background: #E55400 !important; }
.friss-main .btn.btn-danger {
  background: #dc3545 !important;
  border: none !important;
  color: #fff !important;
  font-weight: 700 !important;
  text-shadow: none !important;
  box-shadow: none !important;
}
.friss-main a.btn { text-decoration: none; }

/* Footer area inside card (holds the submit button) */
.friss-main .footer.text-center {
  margin-top: 1.25rem;
  display: block !important;
  text-align: center;
  float: none !important;
  position: static !important;
  overflow: visible;
}
.friss-main .footer.text-center .btn {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  float: none !important;
  position: static !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  box-sizing: border-box;
}

/* Aux links: forgot password, cancel */
.friss-main a.text-muted,
.friss-main a.text-muted.small {
  color: rgba(0,0,0,0.38) !important;
  font-size: 0.83rem;
  text-decoration: none;
}
.friss-main a.text-muted:hover { color: rgba(0,0,0,0.7) !important; }

/* Validation error text */
.friss-main .text-danger,
.friss-main .text-danger * { color: #dc2626 !important; }
.friss-main #errorSummary ul { list-style: none; padding: 0; }

/* Alert boxes */
.friss-main .alert {
  border-radius: 8px;
  padding: 0.85rem 1.1rem;
  font-size: 0.88rem;
}
.friss-main .alert-success {
  background: rgba(40,167,69,0.12) !important;
  border-color: rgba(40,167,69,0.3) !important;
  color: #6fcf97 !important;
}
.friss-main .alert-warning {
  background: rgba(255,193,7,0.1) !important;
  border-color: rgba(255,193,7,0.3) !important;
  color: #ffc107 !important;
}
.friss-main .alert-danger {
  background: rgba(220,53,69,0.12) !important;
  border-color: rgba(220,53,69,0.3) !important;
  color: #ff8080 !important;
}

/* Category divider text (external login) */
.friss-main .category.text-center {
  color: #374151;
  font-size: 0.8rem;
  margin: 0.75rem 0;
  text-align: center;
}
.friss-main .social-line { display: none; }

/* External provider buttons */
.friss-main .list-inline { padding: 0; margin: 1rem 0 0; list-style: none; display: flex; gap: 0.5rem; flex-wrap: wrap; justify-content: center; }
.friss-main .list-inline .btn-primary,
.friss-main .list-inline .btn-xs {
  background: rgba(255,255,255,0.10) !important;
  border: 1px solid rgba(255,255,255,0.18) !important;
  color: #fff !important;
  font-weight: 600 !important;
  padding: 0.45rem 1rem !important;
  border-radius: 8px !important;
  font-size: 0.85rem !important;
  box-shadow: none !important;
}
.friss-main .list-inline .btn-primary:hover { background: rgba(255,255,255,0.18) !important; }

/* Remember me checkbox */
.friss-main .checkbox {
  margin-left: 0 !important;
  margin-bottom: 1.25rem;
  display: flex !important;
  align-items: center;
  gap: 0.45rem;
  padding-left: 0 !important;
}
.friss-main .checkbox label {
  display: flex !important;
  align-items: center;
  gap: 0.45rem;
  color: #374151;
  font-size: 0.88rem;
  cursor: pointer;
  margin: 0;
  padding-left: 0 !important;
  min-height: auto !important;
}
.friss-main .checkbox input[type="checkbox"] {
  accent-color: #FF8000;
  width: 15px;
  height: 15px;
  margin: 0 !important;
  margin-left: 0 !important;
  float: none !important;
  position: static !important;
  flex-shrink: 0;
}

/* Info / confirmation pages (.page-header) */
.page-header {
    border: 0;
}
.friss-main .page-header {
  width: 100%;
  max-width: 500px;
  padding: 0;
  min-height: auto;
}

/* Btn group (used in edit forms) */
.friss-main .btn-group .btn { margin-right: 4px; }

/* ── Input with leading icon / trailing password toggle ────────────── */
.friss-main .input-icon-wrap {
  position: relative;
}
.friss-main .input-icon-wrap .input-icon {
  position: absolute;
  left: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1rem;
  height: 1rem;
  color: rgba(0,0,0,0.28);
  pointer-events: none;
  display: block;
}
.friss-main .input-icon-wrap .form-control {
  padding-left: 2.5rem !important;
}
.friss-main .input-icon-wrap .form-control.has-toggle {
  padding-right: 2.5rem !important;
}
.friss-main .input-icon-wrap .input-toggle {
  position: absolute;
  right: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  color: rgba(0,0,0,0.28);
  line-height: 1;
  display: flex;
  align-items: center;
}
.friss-main .input-icon-wrap .input-toggle:hover { color: rgba(0,0,0,0.65); }

/* ── Label row: label + inline link (Forgot password?) ─────────────── */
.friss-main .label-row {
  display: flex !important;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 0.35rem;
}
.friss-main .label-row .control-label { margin-bottom: 0 !important; }
.friss-main .label-row .label-link {
  font-size: 0.78rem;
  font-weight: 500;
  color: #FF8000;
  text-decoration: none;
  letter-spacing: 0;
  text-transform: none;
}
.friss-main .label-row .label-link:hover { color: #E55400; }

/* ── Card subtitle ──────────────────────────────────────────────────── */
.friss-main .card-header .card-subtitle {
  color: rgba(0,0,0,0.45);
  font-size: 0.88rem;
  font-weight: 400;
  margin: 0.3rem 0 0;
  text-transform: none;
  letter-spacing: 0;
}

/* ── Back link with arrow ───────────────────────────────────────────── */
.friss-main .back-link {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  color: rgba(0,0,0,0.38);
  font-size: 0.88rem;
  text-decoration: none;
  margin-top: 0.5rem;
}
.friss-main .back-link:hover { color: rgba(0,0,0,0.7); }
.friss-main .back-link svg { flex-shrink: 0; }

/* ── Confirmation page ──────────────────────────────────────────────── */
.friss-main .confirm-icon {
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  background: rgba(255,128,0,0.12);
  border: 1px solid rgba(255,128,0,0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.25rem;
  color: #FF8000;
}
.friss-main .confirm-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: #0f172a;
  text-align: center;
  margin: 0 0 0.6rem;
}
.friss-main .confirm-desc {
  font-size: 0.9rem;
  color: rgba(0,0,0,0.5);
  text-align: center;
  margin: 0 0 1.5rem;
  line-height: 1.6;
}
.friss-main .confirm-note {
  font-size: 0.8rem;
  color: rgba(0,0,0,0.38);
  text-align: center;
  margin-bottom: 1.25rem;
}
.friss-main .confirm-note a {
  color: rgba(255,128,0,0.85);
  text-decoration: none;
}
.friss-main .confirm-note a:hover { color: #FF8000; }

