@import url('https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Rajdhani:wght@400;500;600;700&display=swap');

/* ═══════════════════════════════════════════════
   DESERET — Auth Portal Theme
   Targeting caddy-security Tailwind classes
   ═══════════════════════════════════════════════ */

/* ── Page background ── */
html, html.h-full, body, body.h-full {
  background: #0a0c10 !important;
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(51,209,122,0.02) 2px, rgba(51,209,122,0.02) 4px),
    linear-gradient(rgba(26,34,51,0.2) 1px, transparent 1px),
    linear-gradient(90deg, rgba(26,34,51,0.2) 1px, transparent 1px) !important;
  background-size: 100% 100%, 60px 60px, 60px 60px !important;
}

/* ── Main app container ── */
.app-page {
  min-height: 100vh !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.app-content {
  width: 100% !important;
  max-width: 400px !important;
  padding: 20px !important;
}

.app-container {
  background: linear-gradient(180deg, #111720 0%, #0e1119 100%) !important;
  border: 1px solid #1a2233 !important;
  border-radius: 0 !important;
  box-shadow: 0 4px 60px rgba(0,0,0,0.6) !important;
  padding: 32px 28px !important;
  position: relative !important;
}

.app-container::before {
  content: '' !important;
  position: absolute !important;
  top: -1px !important;
  left: 15% !important;
  right: 15% !important;
  height: 1px !important;
  background: linear-gradient(90deg, transparent, rgba(51,209,122,0.5), transparent) !important;
}

/* ── Logo box ── */
.logo-box {
  text-align: center !important;
  margin-bottom: 28px !important;
  padding-bottom: 20px !important;
  border-bottom: 1px solid #1a2233 !important;
}

.logo-img {
  display: none !important;
}

.logo-box::before {
  content: 'DESERET' !important;
  display: block !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 42px !important;
  font-weight: 700 !important;
  letter-spacing: 12px !important;
  color: #d0d8e8 !important;
  margin-bottom: 4px !important;
}

/* ── Replace "Sign In" / "Authentication" text ── */
.logo-txt {
  font-size: 0 !important;
  font-weight: 400 !important;
}

.logo-txt::after {
  content: 'AUTHENTICATION REQUIRED' !important;
  font-size: 10px !important;
  font-family: 'Share Tech Mono', monospace !important;
  letter-spacing: 3px !important;
  color: #4a5a70 !important;
}

/* ── Form labels ── */
label, .app-inp-lbl, .block.text-center,
label.app-inp-lbl {
  font-family: 'Share Tech Mono', monospace !important;
  font-size: 10px !important;
  letter-spacing: 2px !important;
  color: #4a5a70 !important;
  text-transform: uppercase !important;
  text-align: left !important;
  display: block !important;
  padding-bottom: 6px !important;
}

/* ── Replace username label text ── */
label[for="username"] {
  font-size: 0 !important;
}

label[for="username"]::after {
  content: 'OPERATOR ID' !important;
  font-size: 10px !important;
  font-family: 'Share Tech Mono', monospace !important;
  letter-spacing: 2px !important;
  color: #4a5a70 !important;
}

/* ── Replace password label text ── */
label[for="secret"], label[for="password"] {
  font-size: 0 !important;
}

label[for="secret"]::after, label[for="password"]::after {
  content: 'ACCESS CODE' !important;
  font-size: 10px !important;
  font-family: 'Share Tech Mono', monospace !important;
  letter-spacing: 2px !important;
  color: #4a5a70 !important;
}

/* ── Input container ── */
.app-inp-box {
  display: flex !important;
  background: #0a0c10 !important;
  border: 1px solid #1a2233 !important;
  border-radius: 0 !important;
  overflow: hidden !important;
  transition: border-color 0.3s ease, box-shadow 0.3s ease !important;
}

.app-inp-box:focus-within {
  border-color: #33d17a !important;
  box-shadow: 0 0 12px rgba(51, 209, 122, 0.15) !important;
}

/* ── Input icon prefix ── */
.app-inp-prf-img {
  display: flex !important;
  align-items: center !important;
  padding: 0 12px !important;
  color: #33d17a !important;
  background: #0a0c10 !important;
}

.app-inp-prf-img i {
  color: #33d17a !important;
  font-size: 16px !important;
}

.app-inp-prf-img svg {
  color: #33d17a !important;
  stroke: #33d17a !important;
  width: 18px !important;
  height: 18px !important;
}

/* ── Input field — CRITICAL: text color fix ── */
.app-inp-txt,
input.app-inp-txt,
input[type="text"].app-inp-txt,
input[type="password"].app-inp-txt,
input#username,
input#secret,
input#password {
  background: #0a0c10 !important;
  border: none !important;
  color: #d0d8e8 !important;
  caret-color: #33d17a !important;
  font-family: 'Share Tech Mono', monospace !important;
  font-size: 14px !important;
  letter-spacing: 1px !important;
  padding: 12px 14px 12px 0 !important;
  outline: none !important;
  width: 100% !important;
  -webkit-appearance: none !important;
  -webkit-text-fill-color: #d0d8e8 !important;
}

.app-inp-txt::placeholder {
  color: #2a3344 !important;
  -webkit-text-fill-color: #2a3344 !important;
}

/* ── Autofill (Chrome) — fix invisible text ── */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
  -webkit-text-fill-color: #d0d8e8 !important;
  -webkit-box-shadow: 0 0 0px 1000px #0a0c10 inset !important;
  transition: background-color 5000s ease-in-out 0s !important;
  color: #d0d8e8 !important;
  caret-color: #33d17a !important;
}

/* ── HIDE home and reset buttons on password page ── */
.app-btn-sec,
button[type="reset"],
a[href*="terminate"] button,
a[href*="terminate"],
button[name="reset"] {
  display: none !important;
}

/* ── Also hide the flex containers holding them ── */
.flex.gap-4 > .flex-none {
  display: none !important;
}

/* ── Make the submit button container take full width ── */
.flex.gap-4 > .grow {
  flex: 1 !important;
  width: 100% !important;
}

.flex.gap-4 {
  display: flex !important;
  margin-top: 24px !important;
}

/* ── Submit button ── */
.app-btn-pri {
  background: transparent !important;
  border: 1px solid #33d17a !important;
  color: #33d17a !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  letter-spacing: 4px !important;
  text-transform: uppercase !important;
  padding: 12px 20px !important;
  border-radius: 0 !important;
  cursor: pointer !important;
  transition: all 0.3s ease !important;
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.app-btn-pri:hover {
  background: rgba(51, 209, 122, 0.1) !important;
  box-shadow: 0 0 20px rgba(51, 209, 122, 0.2) !important;
}

.app-btn-pri:active {
  transform: scale(0.98) !important;
}

.app-btn-pri svg {
  stroke: #33d17a !important;
  width: 20px !important;
  height: 20px !important;
}

.app-btn-pri span {
  color: #33d17a !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 15px !important;
  letter-spacing: 4px !important;
}

/* ── Checkmark icon in submit button ── */
.app-btn-pri > div:first-child svg {
  stroke: #33d17a !important;
}

/* ── Hide QR code, bookmarks, user actions ── */
#bookmarks, #qr, #qrcode,
#user_actions, #user_register_link,
#forgot_username_link, #contact_support_link {
  display: none !important;
}

/* ── Error messages ── */
.app-alert, .alert, [class*="bg-red"], [class*="text-red"],
.error-message, .flash-message {
  background: rgba(224, 72, 72, 0.1) !important;
  border: 1px solid rgba(224, 72, 72, 0.3) !important;
  color: #e04848 !important;
  font-family: 'Share Tech Mono', monospace !important;
  font-size: 11px !important;
  letter-spacing: 1px !important;
  border-radius: 0 !important;
  padding: 10px 14px !important;
  margin-bottom: 16px !important;
}

/* ── Spacing ── */
.space-y-6 > * + * {
  margin-top: 20px !important;
}

/* ── All text defaults ── */
*, *::before, *::after {
  color: inherit;
}

/* ── Portal page links ── */
.portal-links a, .app-container a[href*="grid-sec"] {
  display: block !important;
  background: #111720 !important;
  border: 1px solid #1a2233 !important;
  color: #d0d8e8 !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 15px !important;
  letter-spacing: 2px !important;
  padding: 14px 18px !important;
  margin-bottom: 8px !important;
  text-decoration: none !important;
  transition: all 0.2s ease !important;
}

.portal-links a:hover {
  background: #161d2a !important;
  border-color: #33d17a !important;
  color: #33d17a !important;
}
