﻿/* /wwwroot/css/SMSSHome/smsslogin-v2.css */

/* ── Tokens ─────────────────────────────────────────────────────── */
:root {
    --sl-teal: #1a9e9e;
    --sl-teal-dark: #137a7a;
    --sl-link: #1a8ecb;
    --sl-border: #d8dde6;
    --sl-text: #1a1a2e;
    --sl-muted: #888;
    --sl-white: #ffffff;
    --sl-font: 'Titillium Web', sans-serif;
}

/* ══════════════════════════════════════════════════════════════════
   SHARED — both Login and Register pages
══════════════════════════════════════════════════════════════════ */

/* Remove outer container padding on login page */
.smss-login-wrap {
    padding: 0 !important;
}

    .smss-login-wrap .card0 {
        border-radius: 0 !important;
        border: none !important;
        min-height: calc(100vh - 140px);
    }

    /* card1 — left / form side (LOGIN) */
    .smss-login-wrap .card1 {
        width: 45% !important;
        background: #eef0f3 !important;
        border: none !important;
        border-radius: 0 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        padding: 48px 28px !important;
    }

    /* card2 — right / hero side (BOTH pages) */
    .smss-login-wrap .card2,
    .smss-reg-section .card2 {
        width: 55% !important;
        background: linear-gradient(145deg, #051e2d 0%, #0b5363 55%, #1a9e9e 100%) !important;
        background-image: linear-gradient(145deg, #051e2d 0%, #0b5363 55%, #1a9e9e 100%) !important;
        border: none !important;
        border-radius: 0 !important;
        display: flex !important;
        align-items: center !important;
        padding: 60px 52px !important;
    }

/* ── Shared: Logo block ── */
.smss-brand-block {
    text-align: center;
    margin-bottom: 6px;
}

.smss-logo-img {
    max-height: 56px;
    width: auto;
    display: inline-block;
}

/* ── Shared: Tagline ── */
.smss-tagline {
    text-align: center;
    font-size: 14px;
    color: var(--sl-muted);
    font-family: var(--sl-font);
    margin: 0 0 20px;
}

/* ══════════════════════════════════════════════════════════════════
   LOGIN — white form box (no max-height, no overflow:hidden)
══════════════════════════════════════════════════════════════════ */
.smss-form-box {
    background: var(--sl-white);
    border-radius: 16px;
    box-shadow: 0 8px 40px rgba(0,0,0,0.11);
    padding: 36px 36px 28px;
    width: 100%;
    max-width: 400px;
    box-sizing: border-box;
}

    /* Tighten email→password gap */
    .smss-form-box .form-group {
        margin-bottom: 6px !important;
    }

    .smss-form-box .loginFormInput.mb-3 {
        margin-bottom: 4px !important;
    }

/* ── Social buttons ── */
.smss-social-btn {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    width: 100% !important;
    padding: 12px 20px !important;
    border-radius: 50px !important;
    font-family: var(--sl-font) !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    cursor: pointer;
    background-image: none !important;
    transition: background-color 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease !important;
}

.smss-social-btn--google {
    background-color: var(--sl-white) !important;
    color: #3c4043 !important;
    border: 1.5px solid var(--sl-border) !important;
    box-shadow: 0 1px 4px rgba(0,0,0,0.09) !important;
}

    .smss-social-btn--google:hover {
        background-color: #f3f6ff !important;
        border-color: #b0b8cc !important;
        box-shadow: 0 4px 12px rgba(0,0,0,0.13) !important;
        transform: translateY(-2px) !important;
        color: #202124 !important;
    }

.smss-social-btn--linkedin {
    background-color: #0077B5 !important;
    color: #fff !important;
    border: none !important;
    box-shadow: 0 1px 4px rgba(0,119,181,0.25) !important;
}

    .smss-social-btn--linkedin:hover {
        background-color: #005f93 !important;
        box-shadow: 0 4px 14px rgba(0,119,181,0.40) !important;
        transform: translateY(-2px) !important;
        color: #fff !important;
    }

/* ── Divider ── */
.smss-divider {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    color: var(--sl-muted);
    font-size: 13px;
    font-family: var(--sl-font);
}

    .smss-divider::before,
    .smss-divider::after {
        content: '';
        flex: 1;
        height: 1px;
        background: var(--sl-border);
    }

/* ── Field labels ── */
.smss-field-label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--sl-text);
    margin-bottom: 6px;
    font-family: var(--sl-font);
}

/* ── Field wrap + icons ── */
.smss-field-wrap {
    position: relative;
    display: flex;
    align-items: center;
}

.smss-field-icon {
    position: absolute;
    left: 16px;
    top: 0;
    bottom: 16px;
    display: flex;
    align-items: center;
    color: var(--sl-muted);
    font-size: 14px;
    pointer-events: none;
    z-index: 2;
}

.smss-field-icon--pw {
    bottom: 0;
}

.smss-field-wrap .loginFormInput.form-control {
    padding-left: 42px !important;
    padding-right: 46px !important;
}

/* ── Eye toggle ── */
.smss-eye-btn {
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    color: var(--sl-muted);
    font-size: 14px;
    padding: 4px;
    z-index: 2;
    line-height: 1;
}

    .smss-eye-btn:hover {
        color: var(--sl-teal);
    }

/* ── Forgot password ── */
.smss-forgot-link {
    font-size: 13px;
    font-weight: 600;
    color: var(--sl-link) !important;
    text-decoration: none !important;
    font-family: var(--sl-font);
}

    .smss-forgot-link:hover {
        text-decoration: underline !important;
        color: var(--sl-teal-dark) !important;
    }

/* ── Legal footnote ── */
.smss-legal {
    font-size: 11px;
    color: var(--sl-muted);
    text-align: center;
    line-height: 1.55;
    margin: 8px 0 0;
    font-family: var(--sl-font);
}

.smss-legal-link {
    color: var(--sl-link);
    text-decoration: none;
}

    .smss-legal-link:hover {
        text-decoration: underline;
    }

/* ══════════════════════════════════════════════════════════════════
   PROCESSING STATE — ban cursor on Login / Register buttons
══════════════════════════════════════════════════════════════════ */
.btn-color.smss-btn--processing,
.btn-color:disabled {
    cursor: not-allowed !important;
    opacity: 0.72 !important;
}

    .btn-color.smss-btn--processing:hover {
        cursor: not-allowed !important;
        transform: none !important;
        background-image: linear-gradient(to right, #61d7f7, #033b57) !important;
    }

/* ══════════════════════════════════════════════════════════════════
   HERO PANEL — shared by both pages
══════════════════════════════════════════════════════════════════ */
.smss-hero-inner {
    max-width: 480px;
}

.smss-hero-icon-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 54px;
    height: 54px;
    border-radius: 14px;
    background: rgba(255,255,255,0.13);
    border: 1.5px solid rgba(255,255,255,0.28);
    color: #7ee8e8;
    font-size: 22px;
}

.smss-hero-headline {
    font-size: clamp(28px, 2.8vw, 46px);
    font-weight: 700;
    line-height: 1.18;
    color: #fff !important;
    margin: 0 0 18px;
    letter-spacing: -0.4px;
    font-family: var(--sl-font);
}

.smss-hero-sub {
    font-size: 15px;
    font-weight: 300;
    line-height: 1.65;
    color: rgba(255,255,255,0.82) !important;
    margin: 0 0 28px;
    font-family: var(--sl-font);
}

.smss-hero-bullets {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

    .smss-hero-bullets li {
        display: flex !important;
        align-items: center !important;
        gap: 12px !important;
        color: #ffffff !important;
        font-size: 15px !important;
        font-family: var(--sl-font) !important;
        list-style: none !important;
    }

        .smss-hero-bullets li i {
            color: #5dd8d8 !important;
            font-size: 18px !important;
            flex-shrink: 0;
        }

/* ══════════════════════════════════════════════════════════════════
   REGISTER PAGE — section + card overrides
   NO max-height, NO overflow:hidden — form must show fully
══════════════════════════════════════════════════════════════════ */
.smss-reg-section {
    padding: 0 !important;
    margin: 0 !important;
}

    .smss-reg-section .card0 {
        border-radius: 0 !important;
        border: none !important;
        min-height: calc(100vh - 140px);
    }

/* card1 on register: left, grey background, auto-height */
.smss-reg-card1 {
    width: 45% !important;
    background: #eef0f3 !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
    align-items: center !important;
}

    /* White inner card for register — auto height, no clipping */
    .smss-reg-card1 .col-md-9 {
        background: var(--sl-white);
        border-radius: 16px;
        box-shadow: 0 8px 40px rgba(0,0,0,0.11);
        margin: 40px auto !important;
        /* NO max-height, NO overflow:hidden */
    }

/* ── Register tab pill switcher ── */
.smss-reg-tabs-wrap {
    background: #f0f2f5;
    border-radius: 50px;
    padding: 4px;
}

.smss-reg-nav {
    display: flex !important;
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    gap: 4px;
}

.smss-reg-nav-link {
    display: block;
    width: 100%;
    padding: 9px 16px;
    border-radius: 50px;
    font-family: var(--sl-font);
    font-size: 14px;
    font-weight: 600;
    color: #666;
    background: transparent;
    border: none;
    cursor: pointer;
    text-align: center;
    text-decoration: none !important;
    transition: all 0.25s ease;
    white-space: nowrap;
}

    .smss-reg-nav-link.active,
    .smss-reg-nav-link:hover.active {
        background: linear-gradient(to right, #61d7f7, #033b57) !important;
        color: #fff !important;
        box-shadow: 0 2px 8px rgba(3,59,87,0.25);
    }

    .smss-reg-nav-link:hover:not(.active) {
        background: #e2e6ea;
        color: #333;
    }

/* ── Register submit button: full width, no ms-5 offset ── */
.smss-reg-card1 .loginbtn {
    margin-left: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

    .smss-reg-card1 .loginbtn .btn-color {
        margin-left: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
    }

/* ══════════════════════════════════════════════════════════════════
   RESPONSIVE — both pages
══════════════════════════════════════════════════════════════════ */
@media screen and (max-width: 992px) {
    .smss-login-wrap .card1,
    .smss-login-wrap .card2,
    .smss-reg-section .card2,
    .smss-reg-card1 {
        width: 100% !important;
    }

    .smss-login-wrap .card2,
    .smss-reg-section .card2 {
        padding: 40px 32px !important;
        min-height: 200px !important;
    }

    .smss-hero-sub,
    .smss-hero-bullets {
        display: none;
    }

    .smss-form-box {
        padding: 32px 24px !important;
    }

    .smss-reg-card1 .col-md-9 {
        margin: 24px auto !important;
    }
}

@media screen and (max-width: 768px) {
    .smss-login-wrap .card1 {
        padding: 24px 16px !important;
    }

    .smss-form-box {
        padding: 24px 18px !important;
        border-radius: 10px !important;
        max-width: 100% !important;
    }

    .smss-field-wrap .loginFormInput.form-control {
        font-size: 16px !important;
    }

    .smss-reg-card1 .col-md-9 {
        border-radius: 10px !important;
        padding: 24px 18px !important;
    }
}
