/* ==========================================================================
   NovaERM Auth + Static Pages stylesheet
   Used by: layouts/bootstrap/auth.blade.php, login/forgot/reset/2FA, terms/privacy
   ========================================================================== */

:root {
    --nx-bg-deep:      #07022c;
    --nx-bg-mid:       #160a3b;
    --nx-violet:       #6000d0;
    --nx-violet-soft:  rgba(96, 0, 208, 0.18);
    --nx-violet-glow:  rgba(96, 0, 208, 0.55);
    --nx-signal:       #f7e223;
    --nx-signal-2:     #ffe74c;
    --nx-text:         #f4f1ff;
    --nx-text-dim:     rgba(244, 241, 255, 0.72);
    --nx-text-fade:    rgba(244, 241, 255, 0.48);
    --nx-line:         rgba(255, 255, 255, 0.10);
    --nx-line-strong:  rgba(255, 255, 255, 0.18);
    --nx-card:         rgba(20, 10, 50, 0.55);
    --nx-input:        rgba(8, 4, 30, 0.55);
}

html { font-size: 16px; }

body {
    margin: 0;
    min-height: 100vh;
    color: var(--nx-text);
    font-family: "Public Sans", "Inter", system-ui, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    background: var(--nx-bg-deep);
    position: relative;
    overflow-x: hidden;
}

/* Match landing hero — radial purple glows */
body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(circle 820px at -8% 45%, rgba(85, 44, 150, 0.62), rgba(85, 44, 150, 0.25) 40%, transparent 75%),
        radial-gradient(circle 540px at 88% 60%, rgba(85, 44, 150, 0.18), transparent 72%);
    z-index: 0;
}

/* Brand plus-grid pattern (exact glyph from landing hero) */
body::after {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 128 128'><path fill='rgba(132,32,255,0.14)' transform='translate(48 48)' d='M19.4 15.4c-1.7,0-3.1-1.4-3.1-3.1V8h-1.1v4.4c0,1.7-1.4,3.1-3.1,3.1H8v1.1h4.4c1.7,0,3.1,1.4,3.1,3.1V24h1.1v-4.4c0-1.7,1.4-3.1,3.1-3.1H24v-1.1h-4.6z'/></svg>");
    background-size: 240px 240px;
    background-position: 0 0;
    mask-image: linear-gradient(180deg, transparent 0%, #000 12%, #000 88%, transparent 100%);
    -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 12%, #000 88%, transparent 100%);
    z-index: 0;
}

/* Legacy auth page bg classes — drop the JPG, use brand atmosphere */
.bg-login,
.bg-forgot-password,
.bg-reset-password,
.bg-2fa {
    background-image: none !important;
    min-height: 100vh;
}

.flex-row { position: relative; z-index: 1; }
main { position: relative; z-index: 1; }

/* ==========================================================================
   Card
   ========================================================================== */
.card.bg-white {
    background: var(--nx-card) !important;
    backdrop-filter: blur(22px) saturate(160%);
    -webkit-backdrop-filter: blur(22px) saturate(160%);
    border: 1px solid var(--nx-line-strong) !important;
    border-radius: 20px !important;
    color: var(--nx-text);
    box-shadow:
        0 30px 80px -20px rgba(0, 0, 0, 0.55),
        0 0 0 1px rgba(255, 255, 255, 0.04) inset;
    overflow: hidden;
}

.card.bg-white .card-body {
    color: var(--nx-text);
}

/* ==========================================================================
   Logo
   ========================================================================== */
.card .d-flex.justify-content-center img[alt$="Logo"],
.card .d-flex.justify-content-center img[alt$="logo"] {
    width: auto !important;
    padding: 0 !important;
}

/* ==========================================================================
   Headings + sub-titles
   ========================================================================== */
.card .text-lg,
.card h1, .card h2, .card h3 {
    color: var(--nx-text) !important;
    font-weight: 800;
    letter-spacing: -0.012em;
}

.card .text-base { color: var(--nx-text-dim) !important; }

/* ==========================================================================
   Form fields
   ========================================================================== */
.form-control,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
input[type="number"],
textarea,
select {
    background: var(--nx-input) !important;
    color: var(--nx-text) !important;
    border: 1px solid var(--nx-line-strong) !important;
    border-radius: 10px !important;
    transition: border-color .2s, box-shadow .2s, background .2s;
}

.form-control::placeholder,
input::placeholder,
textarea::placeholder {
    color: var(--nx-text-fade) !important;
}

.form-control:focus,
.focus-green:focus,
input:focus,
textarea:focus,
select:focus {
    background: rgba(8, 4, 30, 0.75) !important;
    border-color: var(--nx-violet) !important;
    box-shadow: 0 0 0 3px var(--nx-violet-soft) !important;
    outline: none !important;
    color: var(--nx-text) !important;
}

/* Floating label inside dark input */
label.absolute.bg-white,
label.bg-white {
    background: var(--nx-bg-mid) !important;
    color: var(--nx-text-dim) !important;
    border-radius: 6px;
    padding: 1px 6px !important;
    font-size: 11px !important;
}

label {
    color: var(--nx-text-dim);
    font-weight: 500;
}

/* Checkbox */
input[type="checkbox"].form-check-input,
.form-check-input.bg-white {
    background-color: var(--nx-input) !important;
    border: 1px solid var(--nx-line-strong) !important;
    border-radius: 4px !important;
    width: 1rem !important;
    height: 1rem !important;
    cursor: pointer;
}

input[type="checkbox"]:checked,
input:checked {
    background-color: var(--nx-violet) !important;
    border-color: var(--nx-violet) !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='M6 10l3 3l6-6'/%3E%3C/svg%3E") !important;
}

input[type="checkbox"]:checked:focus,
input:checked:focus {
    box-shadow: 0 0 0 3px var(--nx-violet-soft) !important;
    outline: none;
}

/* ==========================================================================
   Buttons (replace btn-green-gradient with brand yellow CTA)
   ========================================================================== */
.btn-green-gradient,
.bg-green-gradient {
    background: var(--nx-signal) !important;
    background-image: none !important;
    color: #1a0a00 !important;
    border: none !important;
    font-weight: 700 !important;
    border-radius: 12px !important;
    transition: filter .15s, box-shadow .25s !important;
    box-shadow: 0 12px 30px -10px rgba(247, 226, 35, 0.45);
}
.btn-green-gradient:hover,
.bg-green-gradient:hover {
    background: var(--nx-signal-2) !important;
    color: #1a0a00 !important;
    filter: brightness(1.05);
    box-shadow: 0 14px 36px -10px rgba(247, 226, 35, 0.55);
}
.btn-green-gradient:active,
.bg-green-gradient:active {
    filter: brightness(0.95);
}
.btn-green-gradient:focus,
.bg-green-gradient:focus {
    box-shadow: 0 0 0 3px rgba(247, 226, 35, 0.35) !important;
}

/* Generic Bootstrap btn-primary fallback */
.btn-primary {
    background: var(--nx-violet) !important;
    border-color: var(--nx-violet) !important;
}
.btn-primary:hover { filter: brightness(1.08); }

/* Divider line */
.h-1px {
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--nx-line-strong), transparent) !important;
}

/* ==========================================================================
   Links
   ========================================================================== */
a {
    color: var(--nx-signal);
    text-decoration: none;
    transition: color .15s;
}
a:hover { color: var(--nx-signal-2); }

a.underline { text-decoration: underline; }

.text-gray { color: var(--nx-text-fade) !important; }

/* Terms / Privacy footer links inside card */
.card .underline.text-gray { color: var(--nx-text-fade) !important; }
.card .underline.text-gray:hover { color: var(--nx-signal); }

/* ==========================================================================
   Static page (terms / privacy) typography
   ========================================================================== */
.card h2.h5,
.card h3.h6 {
    color: var(--nx-text) !important;
}
.card p,
.card li {
    color: var(--nx-text-dim);
    line-height: 1.65;
}
.card strong {
    color: var(--nx-text);
}

/* ==========================================================================
   Alerts
   ========================================================================== */
.alert-danger {
    background: rgba(220, 38, 38, 0.12) !important;
    border: 1px solid rgba(220, 38, 38, 0.35) !important;
    color: #fecaca !important;
    border-radius: 10px !important;
}
.alert-success {
    background: rgba(34, 197, 94, 0.10) !important;
    border: 1px solid rgba(34, 197, 94, 0.32) !important;
    color: #bbf7d0 !important;
    border-radius: 10px !important;
}

/* ==========================================================================
   Utility classes (kept from legacy)
   ========================================================================== */
.h-1px { height: 1px; }
.p-v-6 { padding-bottom: 1.5rem; padding-top: 1.5rem; }
.p-l-4 { padding-left: 1rem; }
.p-v-4 { padding-bottom: 1rem; padding-top: 1rem; }
.left-2 { left: 0.5rem; }
.-top-2 { top: -0.5rem; }
.p-h-1 { padding-left: 0.25rem; padding-right: 0.25rem; }
.uppercase { text-transform: uppercase; }
.b-700 { font-weight: 700; }
.text-lg { font-size: 1.125rem; line-height: 1.75rem; }
.text-sm { font-size: 0.875rem; }
.text-xs { font-size: .75rem; line-height: 1rem; }
.text-base { font-size: 1.0rem; line-height: 1.5rem; }
.font-sans { font-family: "Public Sans", sans-serif !important; }
.absolute { position: absolute; }
.relative { position: relative; }
.antialiased { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
.leading-6 { line-height: 1.5rem; }
.bg-white { background-color: var(--nx-card) !important; }
.border-2px { border-width: 2px; }
.m-t-6 { margin-top: 1.5rem; }
.m-l-1 { margin-left: 0.25rem; }
.letter-spacing-widest { letter-spacing: .1em; }
.underline { text-decoration: underline; }

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 576px) {
    .card.bg-white { border-radius: 16px !important; }
    .card .card-body { padding: 1.25rem !important; }
}
