:root {
  --fr-red: #ed1d23;
  --fr-dark: #585a5e;
  --fr-mid: #b7bcc0;
  --fr-orange: #f05c2b;
  --fr-peach: #f6b261;
  --fr-light: #f3f4f6;
  --fr-green: #80c391;
  --fr-white: #ffffff;
  --logo-d-height: 40px;
  --logo-padding: 12px;
}

body {
  font-family: Inter, system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
  background: var(--fr-light);
  margin: 0;
}

table { border-collapse: collapse; width: 100%; }
th, td { text-align: left; padding: 8px; }
th { background: #f0f2f4; }

/* Palette-mapped overrides for existing utility classes (layout unchanged) */
.bg-gray-100 { background-color: var(--fr-light) !important; }
.hover\:bg-gray-50:hover { background-color: #eef1f3 !important; }

.bg-blue-700,
.bg-blue-600 { background-color: var(--fr-dark) !important; color: #fff !important; }
.hover\:bg-blue-700:hover,
.hover\:bg-blue-600:hover { background-color: #44464a !important; }
.bg-blue-500 { background-color: var(--fr-orange) !important; color: #fff !important; }
.border-blue-500 { border-color: var(--fr-green) !important; }
.text-blue-600 { color: var(--fr-green) !important; }
.hover\:bg-blue-50:hover { background-color: #f3f5f7 !important; }

.bg-green-600 { background-color: var(--fr-green) !important; color: #1f1f1f !important; }
.bg-green-500 { background-color: var(--fr-green) !important; color: #fff !important; }
.hover\:bg-green-700:hover { background-color: #0d882a !important; color: #fff !important; }

.bg-red-600,
.bg-red-500 { background-color: var(--fr-red) !important; color: #fff !important; }
.hover\:bg-red-700:hover { background-color: #c1161d !important; }
.border-red-500 { border-color: var(--fr-red) !important; }
.text-red-600 { color: var(--fr-red) !important; }
.hover\:bg-red-50:hover { background-color: #fff1f1 !important; }

.border-gray-200 { border-color: #e3e6e9 !important; }
.text-gray-700 { color: #374151 !important; }
.text-gray-500 { color: #6b7280 !important; }
.text-white {color:#ffffff !important;}
.text-uploading { color: var(--fr-red) !important; font-weight: 600; }
.spinner-win7 {
  display: inline-block;
  width: 14px;
  height: 14px;
  margin-right: 8px;
  border: 2px solid rgba(237, 29, 35, 0.35);
  border-top-color: var(--fr-red);
  border-radius: 50%;
  animation: fr-spin 0.8s linear infinite;
  vertical-align: middle;
}
@keyframes fr-spin { to { transform: rotate(360deg); } }
.spinner-win7.spinner-lg {
  width: 32px;
  height: 32px;
  border-width: 3px;
  margin: 0 auto 10px auto;
}

.fr-loading-overlay {
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.85);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 30;
  backdrop-filter: blur(1px);
}
.fr-loading-overlay.fr-show { display: flex; }
.fr-loading-box {
  background: #ffffff;
  border: 1px solid #e3e6e9;
  border-radius: 12px;
  padding: 16px 20px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
  color: #374151;
  font-weight: 600;
  text-align: center;
  min-width: 190px;
}
.fr-loading-text { margin: 0; font-size: 14px; }

/* Navbar-specific override to improve logo contrast */
nav.bg-blue-700 { background-color: var(--fr-white) !important; color: #1f1f1f !important; }
nav.bg-blue-700 a,
nav.bg-blue-700 span { color: #1f1f1f !important; }

.logo-small { height: var(--logo-d-height); width: auto; display: block; }
.logo-padding { display: inline-flex; align-items: center; justify-content: center; padding: var(--logo-padding); }
/* Ensure logout link stays white despite navbar overrides */
nav.bg-blue-700 a.logout-link { color: #fff !important; }

.fr-nav-menu {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
}
.fr-nav-greeting {
  font-size: 0.95rem;
  white-space: nowrap;
}
.fr-menu-toggle {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  width: 42px;
  height: 42px;
  border: 1px solid #d1d5db;
  border-radius: 10px;
  background: #ffffff;
  cursor: pointer;
}
.fr-menu-toggle-line {
  display: block;
  width: 18px;
  height: 2px;
  background: #1f1f1f;
  border-radius: 999px;
}
.fr-top-menu {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  min-width: 220px;
  padding: 8px;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: #ffffff;
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.1);
  display: flex;
  flex-direction: column;
  gap: 4px;
  z-index: 40;
}
.fr-top-menu a,
.fr-top-menu .fr-menu-greeting {
  display: block;
  padding: 8px 10px;
  border-radius: 8px;
}
.fr-top-menu a:hover {
  background: #f3f4f6;
}
.fr-top-menu .logout-link:hover {
  background: #c1161d !important;
}
.fr-help-link {
  display: block;
  padding: 8px 10px;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  background: #f9fafb;
  color: #374151;
}
.fr-help-link:hover {
  background: #f3f4f6;
}
.fr-help-figure {
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  overflow: hidden;
  background: #ffffff;
}
.fr-help-image {
  display: block;
  width: 100%;
  height: auto;
}
.fr-help-caption {
  font-size: 12px;
  color: #6b7280;
  padding: 8px 10px;
  border-top: 1px solid #e5e7eb;
  background: #f9fafb;
}

.form-stack { display: flex; flex-direction: column; gap: 12px; }
.form-stack p {
  margin: 0;
}
.form-stack p.form-field {
  padding: 10px;
  border: 1px solid var(--fr-dark);
  border-radius: 12px;
  background: #ffffff;
}
.form-stack p br { display: block; margin-bottom: 6px; }
.errorlist {
  margin: 6px 0 0 0;
  padding-left: 16px;
  color: var(--fr-red);
}
.errorlist li { margin: 2px 0; }
.field-status {
  display: block;
  margin-top: 6px;
  font-size: 0.9rem;
  color: #6b7280;
}
.field-status.error { color: var(--fr-red); }
.field-status.ok { color: var(--fr-green); }
.form-stack input,
.form-stack select,
.form-stack textarea {
  appearance: none;
  border: 2px solid var(--fr-dark) !important;
  border-radius: 10px;
  padding: 8px 10px;
  background: #ffffff;
  outline: none !important;
  box-shadow: none !important;
  box-sizing: border-box;
  height: 40px;
  line-height: 22px;
  width: 100%;
}
.form-stack input:focus,
.form-stack select:focus,
.form-stack textarea:focus {
  outline: none !important;
  border-color: var(--fr-dark) !important;
  box-shadow: none !important;
}

.password-rules {
  list-style: none;
  padding-left: 0;
  margin: 8px 0 0 0;
  font-size: 0.9rem;
}
.password-rules li {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #6b7280;
  margin: 4px 0;
}
.password-rules .rule-icon {
  width: 18px;
  height: 18px;
  border: 1px solid #cbd5e1;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  line-height: 1;
  color: #6b7280;
  background: #ffffff;
}
.password-rules li.rule-met {
  color: var(--fr-green);
}
.password-rules li.rule-met .rule-icon {
  border-color: var(--fr-green);
  background: var(--fr-green);
  color: #1f1f1f;
}
.password-strength {
  margin-top: 8px;
}
.password-strength-bar {
  width: 100%;
  height: 10px;
  border-radius: 999px;
  border: 1px solid #cbd5e1;
  background: #e5e7eb;
  overflow: hidden;
}
.password-strength-fill {
  height: 100%;
  width: 0%;
  border-radius: 999px;
  background: var(--fr-red);
  transition: width 0.15s ease-in-out;
}
.password-strength-fill.strength-1 { background: #f59e0b; }
.password-strength-fill.strength-2 { background: #f6b261; }
.password-strength-fill.strength-3 { background: #80c391; }
.password-strength-fill.strength-4 { background: #2e7d32; }
.password-strength-fill.strength-5 { background: #1b5e20; }

/* Clamp long feedback text in the inbox list to keep actions visible */
.fr-message-preview {
  white-space: pre-wrap;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  max-height: 4.5em;
}

.fr-flash-wrap {
  position: fixed;
  top: 12px;
  left: 50%;
  transform: translateX(-50%);
  width: min(92vw, 720px);
  display: flex;
  flex-direction: column;
  gap: 8px;
  z-index: 70;
  pointer-events: none;
}

.fr-flash-message {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  border: 1px solid transparent;
  border-radius: 12px;
  padding: 10px 12px;
  box-shadow: 0 10px 28px rgba(17, 24, 39, 0.15);
  transform: translateY(-14px);
  opacity: 0;
  transition: transform 0.2s ease, opacity 0.2s ease;
  pointer-events: auto;
}

.fr-flash-message.fr-flash-show {
  transform: translateY(0);
  opacity: 1;
}

.fr-flash-message.fr-flash-hide {
  transform: translateY(-12px);
  opacity: 0;
}

.fr-flash-success {
  background: #f0fdf4;
  border-color: #86efac;
  color: #166534;
}

.fr-flash-error {
  background: #fef2f2;
  border-color: #fca5a5;
  color: #991b1b;
}

.fr-flash-warning {
  background: #fffbeb;
  border-color: #fcd34d;
  color: #92400e;
}

.fr-flash-info {
  background: #eff6ff;
  border-color: #93c5fd;
  color: #1e3a8a;
}

.fr-flash-close {
  border: 0;
  background: transparent;
  color: inherit;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  padding: 0 2px;
}
