/* ============ Admin Login — Minimalist Purple ============ */
:root {
    --al-primary: #6C5CE7;
    --al-primary-light: #a29bfe;
    --al-primary-bg: rgba(108,92,231,0.06);
    --al-text: #2d3436;
    --al-text-muted: #999;
    --al-border: #eee;
    --al-bg: #f7f8fc;
    --al-card: #ffffff;
    --al-radius: 14px;
    --al-danger: #e74c3c;
}

*, *::before, *::after { box-sizing: border-box; }

body.bg-light {
    font-family: 'Inter', -apple-system, sans-serif;
    background: var(--al-bg) !important;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
}

/* Subtle animated background orbs */
body.bg-light::before,
body.bg-light::after {
    content: '';
    position: fixed;
    border-radius: 50%;
    z-index: 0;
    pointer-events: none;
    opacity: .4;
}

body.bg-light::before {
    width: 500px; height: 500px;
    background: radial-gradient(circle, rgba(108,92,231,0.12), transparent 70%);
    top: -120px; right: -120px;
    animation: alOrbFloat 14s ease-in-out infinite;
}

body.bg-light::after {
    width: 400px; height: 400px;
    background: radial-gradient(circle, rgba(162,155,254,0.1), transparent 70%);
    bottom: -100px; left: -100px;
    animation: alOrbFloat 18s ease-in-out infinite reverse;
}

@keyframes alOrbFloat {
    0%, 100% { transform: translate(0, 0) scale(1); }
    50% { transform: translate(30px, -30px) scale(1.1); }
}

/* Container */
.container { position: relative; z-index: 1; }

/* Hide particles from old template */
.particles-container { display: none !important; }

/* Card */
.card {
    border: 1px solid var(--al-border) !important;
    border-radius: var(--al-radius) !important;
    box-shadow: 0 4px 24px rgba(0,0,0,.04) !important;
    background: var(--al-card) !important;
    animation: alCardIn .5s ease both !important;
    overflow: visible !important;
    transform-style: flat !important;
    transition: none !important;
}

.card::before { display: none !important; }
.card:hover { transform: none !important; box-shadow: 0 4px 24px rgba(0,0,0,.04) !important; }

.card-body { padding: 28px 24px !important; }

@keyframes alCardIn {
    from { opacity: 0; transform: translateY(16px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Logo */
.logo-container { position: relative; }
.logo-wrapper { display: inline-block; position: relative; }

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

.logo-icon {
    font-size: 2.4rem !important;
    background: none !important;
    -webkit-text-fill-color: unset !important;
    color: #fff !important;
    width: 56px; height: 56px;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    background-color: var(--al-primary) !important;
    border-radius: 16px;
    filter: none !important;
    animation: alIconPop .6s cubic-bezier(.68,-.55,.265,1.55) both !important;
}

.logo-icon.logo-loaded { animation: alIconPop .6s cubic-bezier(.68,-.55,.265,1.55) both !important; }

@keyframes alIconPop {
    0% { transform: scale(0); opacity: 0; }
    70% { transform: scale(1.1); }
    100% { transform: scale(1); opacity: 1; }
}

.text-center h3,
h3.title-animated,
.title-animated {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: var(--al-text) !important;
    background: none !important;
    -webkit-background-clip: unset !important;
    -webkit-text-fill-color: unset !important;
    background-clip: unset !important;
    animation: alFadeUp .5s ease .15s both !important;
}

.subtitle-animated,
.text-center p.text-muted {
    font-size: 12px !important;
    color: var(--al-text-muted) !important;
    font-weight: 400 !important;
    animation: alFadeUp .5s ease .25s both !important;
}

@keyframes alFadeUp {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Form fields */
.form-group-animated {
    animation: alFadeUp .4s ease both !important;
}

.form-label {
    font-size: 11px !important;
    font-weight: 600 !important;
    color: var(--al-text-muted) !important;
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: 6px !important;
}

.input-group {
    box-shadow: none !important;
    border-radius: 10px !important;
    overflow: visible !important;
    background: transparent !important;
    transition: none !important;
}

.input-group:hover { box-shadow: none !important; transform: none !important; }
.input-group.input-focused { box-shadow: none !important; transform: none !important; }
.input-focus-line { display: none !important; }

.input-group-text {
    background: var(--al-bg) !important;
    border: 1px solid var(--al-border) !important;
    border-right: none !important;
    border-radius: 10px 0 0 10px !important;
    color: var(--al-text-muted) !important;
    padding: 12px 14px !important;
    font-size: 15px !important;
    transition: border-color .2s, color .2s !important;
}

.icon-pulse { animation: none !important; }

.input-group .form-control {
    border: 1px solid var(--al-border) !important;
    border-left: none !important;
    border-radius: 0 10px 10px 0 !important;
    padding: 12px 14px !important;
    font-size: 14px !important;
    font-family: 'Inter', -apple-system, sans-serif !important;
    color: var(--al-text) !important;
    background: var(--al-bg) !important;
    transition: border-color .2s, background .2s !important;
}

.input-group .form-control::placeholder { color: #bbb !important; }

.input-group .form-control:focus {
    border-color: var(--al-primary) !important;
    box-shadow: 0 0 0 3px rgba(108,92,231,.08) !important;
    background: #fff !important;
}

.input-group .form-control:focus ~ .input-group-text,
.input-group:focus-within .input-group-text {
    border-color: var(--al-primary) !important;
    color: var(--al-primary) !important;
}

/* Checkbox */
.form-check-input {
    border: 1px solid var(--al-border) !important;
    width: 1.1rem !important;
    height: 1.1rem !important;
    transition: all .2s !important;
}

.form-check-input:hover { border-color: var(--al-primary) !important; box-shadow: none !important; transform: none !important; }

.form-check-input:checked {
    background-color: var(--al-primary) !important;
    border-color: var(--al-primary) !important;
    box-shadow: none !important;
    animation: none !important;
}

.form-check-input:focus { box-shadow: 0 0 0 3px rgba(108,92,231,.08) !important; border-color: var(--al-primary) !important; outline: none !important; }

.form-check-label {
    font-size: 13px !important;
    color: var(--al-text) !important;
    margin-left: .25rem !important;
}

/* Submit button */
.btn-primary,
.btn-animated {
    background: var(--al-primary) !important;
    border: none !important;
    border-radius: 10px !important;
    padding: 13px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    font-family: 'Inter', -apple-system, sans-serif !important;
    color: #fff !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
    box-shadow: none !important;
    cursor: pointer;
    transition: background .2s, transform .15s !important;
    position: relative;
    overflow: hidden;
}

.btn-wave { display: none !important; }

.btn-primary:hover,
.btn-animated:hover {
    background: #5b4bd5 !important;
    transform: none !important;
    box-shadow: none !important;
}

.btn-primary:active,
.btn-animated:active {
    transform: scale(.98) !important;
}

.btn-primary:focus { outline: none !important; box-shadow: 0 0 0 3px rgba(108,92,231,.15) !important; }

.btn-text { display: inline !important; transition: none !important; }
.btn-primary:hover .btn-text { transform: none !important; }
.btn-primary:hover i { transform: none !important; animation: none !important; }
.ripple { display: none !important; }

/* Alerts */
.alert {
    border-radius: 10px !important;
    border: none !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    box-shadow: none !important;
    padding: 10px 14px !important;
    animation: alFadeUp .3s ease both !important;
}

.alert::before { display: none !important; }

.alert-success { background: #f0fdf4 !important; color: #16a34a !important; }
.alert-danger, .alert-error { background: #fef2f2 !important; color: var(--al-danger) !important; }
.alert-warning { background: #fffbeb !important; color: #d97706 !important; }
.alert-info { background: var(--al-primary-bg) !important; color: var(--al-primary) !important; border: none !important; }

/* Footer */
.footer-text,
.text-center small.text-muted {
    font-size: 11px !important;
    color: var(--al-text-muted) !important;
    font-weight: 400 !important;
    animation: alFadeUp .4s ease .4s both !important;
}

.text-center small.text-muted:hover { transform: none !important; color: var(--al-text-muted) !important; }

/* Validation */
.was-validated .form-control:invalid,
.form-control.is-invalid {
    border-color: var(--al-danger) !important;
    animation: alShake .4s ease !important;
}

@keyframes alShake {
    0%, 100% { transform: translateX(0); }
    20%, 60% { transform: translateX(-4px); }
    40%, 80% { transform: translateX(4px); }
}

.was-validated .form-control:valid,
.form-control.is-valid {
    border-color: var(--al-primary) !important;
    animation: none !important;
}

.invalid-feedback {
    color: var(--al-danger) !important;
    font-size: 11px !important;
    font-weight: 500 !important;
}

/* Responsive */
@media (max-width: 576px) {
    .card-body { padding: 24px 20px !important; }
}
