/* ═══════════════════════════════════════════════════════════════
   ORIONIX · page-login.css
   Login · Register pages — auth-box · form · TG button
   divider · master overlay · spinner · dev-trigger
   ═══════════════════════════════════════════════════════════════ */

/* ── 7. LOGIN PAGE ─────────────────────────────────────────────────── */

.page-login {
    display: flex; align-items: center; justify-content: center;
    min-height: 100vh; padding: 20px;
    background: var(--bg);
}
.page-login .atmo {
    position: fixed; border-radius: 50%;
    filter: blur(120px); pointer-events: none; z-index: 0;
}
.page-login .atmo-1 { width: 500px; height: 500px; background: rgba(26,115,232,.06); top: -10%; left: -8%; }
.page-login .atmo-2 { width: 400px; height: 400px; background: rgba(26,115,232,.04); bottom: 5%; right: -6%; }

.auth-box {
    position: relative; z-index: 1;
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: 20px; padding: 36px 32px;
    width: 100%; max-width: 360px;
    box-shadow: var(--shadow-lg);
}
.auth-logo       { text-align: center; margin-bottom: 28px; }
.auth-logo-mark  { font-size: 1.3rem; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--tx); }
.auth-logo-mark em { color: var(--accent); font-style: normal; }
.auth-logo-sub   { font-size: .68rem; color: var(--tx-d); margin-top: 5px; letter-spacing: .5px; }

.tg-btn {
    width: 100%; padding: 11px 16px;
    background: #0088cc; color: #fff;
    border: none; border-radius: 10px;
    font-family: var(--font); font-size: .82rem; font-weight: 600;
    cursor: pointer; display: flex; align-items: center;
    justify-content: center; gap: 8px;
    transition: background .2s; margin-bottom: 6px;
}
.tg-btn:hover { background: #0077b3; }
.tg-btn svg { width: 15px; height: 15px; stroke: #fff; stroke-width: 1.3; fill: none; stroke-linecap: round; stroke-linejoin: round; }

.divider {
    display: flex; align-items: center; gap: 10px;
    color: var(--tx-d); font-size: .63rem; letter-spacing: 1px;
    text-transform: uppercase; margin: 18px 0;
}
.divider::before, .divider::after { content: ''; flex: 1; height: 1px; background: var(--border); }

.page-login .form-group { margin-bottom: 14px; }
.page-login .form-group label {
    display: block; font-size: .6rem; text-transform: uppercase;
    letter-spacing: 1.5px; color: var(--tx-d); margin-bottom: 7px; font-weight: 500;
}
.page-login .form-group input {
    width: 100%; padding: 11px 14px;
    background: var(--bg); border: 1px solid var(--border);
    border-radius: 9px; color: var(--tx); font-size: .85rem;
    font-family: var(--font); outline: none;
    transition: border-color .2s, box-shadow .2s;
}
.page-login .form-group input:focus {
    border-color: var(--accent); box-shadow: 0 0 0 3px rgba(26,115,232,.1);
}
.page-login .form-group input::placeholder { color: #bbb; }

.login-submit {
    width: 100%; padding: 12px; border-radius: 9px;
    font-family: var(--font); font-size: .82rem; font-weight: 600;
    cursor: pointer; border: none;
    background: var(--accent); color: #fff;
    transition: background .2s;
    box-shadow: 0 3px 12px rgba(26,115,232,.3); margin-bottom: 10px;
}
.login-submit:hover    { background: #1558b0; }
.login-submit:disabled { opacity: .5; cursor: not-allowed; }

.auth-error  { color: var(--red);  font-size: .7rem; text-align: center; margin-top: 8px; min-height: 18px; }
.auth-status { color: var(--tx-d); font-size: .7rem; text-align: center; margin-top: 8px; min-height: 18px; }
.auth-link   { text-align: center; margin-top: 22px; }
.auth-link a {
    font-size: .69rem; color: var(--tx-d); text-decoration: none;
    letter-spacing: .4px; border-bottom: 1px solid var(--border);
    padding-bottom: 1px; transition: color .18s, border-color .18s;
}
.auth-link a:hover { color: var(--accent); border-color: var(--accent-mid); }

.spinner {
    display: inline-block; width: 13px; height: 13px;
    border: 1.5px solid rgba(255,255,255,.3);
    border-top-color: #fff; border-radius: 50%;
    animation: spin .65s linear infinite;
    vertical-align: middle; margin-right: 6px;
}

.dev-trigger {
    position: fixed; bottom: 14px; right: 16px;
    color: rgba(0,0,0,.06); font-size: 11px;
    cursor: default; user-select: none;
}

/* Master overlay */
#master-overlay {
    display: none; position: fixed; inset: 0;
    background: rgba(0,0,0,.45); backdrop-filter: blur(6px);
    z-index: 999; align-items: center; justify-content: center;
}
#master-overlay.open { display: flex; }
#master-box {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: 16px; padding: 30px 26px; width: 300px;
    box-shadow: var(--shadow-lg);
}
#master-box h3 { color: var(--tx);  font-size: .9rem; font-weight: 500; margin-bottom: 5px; }
#master-box p  { color: var(--tx-d); font-size: .65rem; margin-bottom: 18px; }
#master-box input {
    width: 100%; padding: 11px 14px; background: var(--bg);
    border: 1px solid var(--border); border-radius: 9px;
    color: var(--tx); font-size: .85rem; font-family: var(--font);
    outline: none; margin-bottom: 12px;
}
#master-box input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(26,115,232,.1); }

#telegram-login-container { text-align: center; margin-bottom: 12px; }
#tgStatus { min-height: 18px; }

