/* BEUNIQ Social Login — Astra style guide */
.beuniq-sl-wrap {
    --bm-primary: #FF7A3D;
    --bm-primary-h: #FF5100;
    --bm-heading: #1E1810;
    --bm-text: #575250;
    --bm-border: #E5E1DE;
    --bm-light: #F6F7F8;
    --bm-navy: #242A56;

    max-width: 440px;
    margin: 40px auto;
    padding: 40px 30px;
    background: #fff;
    font-family: 'Work Sans', sans-serif;
    color: var(--bm-text);
}
.beuniq-sl-wrap * { box-sizing: border-box; }

.beuniq-sl-title {
    font-family: 'Open Sans', sans-serif;
    font-size: 26px;
    font-weight: 700;
    color: var(--bm-heading);
    margin: 0 0 30px;
    text-align: center;
}

.beuniq-sl-form { margin-bottom: 20px; }
.beuniq-sl-field { margin-bottom: 14px; }
.beuniq-sl-field label {
    display: block;
    font-size: 13px;
    color: var(--bm-heading);
    font-weight: 600;
    margin-bottom: 6px;
}
.beuniq-sl-field input[type=text],
.beuniq-sl-field input[type=email],
.beuniq-sl-field input[type=password] {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid var(--bm-border);
    background: #fff;
    font-family: inherit;
    font-size: 14px;
    border-radius: 0;
    transition: border-color .2s;
}
.beuniq-sl-field input:focus { outline: none; border-color: var(--bm-navy); }
.beuniq-sl-hint { display: block; margin-top: 4px; font-size: 12px; color: #999; }
.beuniq-sl-hint.is-ok { color: #2E7D32; }
.beuniq-sl-hint.is-error { color: #C62828; }
.beuniq-sl-remember label { display: flex; align-items: center; gap: 6px; font-weight: 400; font-size: 13px; }

.beuniq-sl-req { color: #E53935; margin-left: 2px; }
.beuniq-sl-req-tag { color: #E53935; font-style: normal; font-weight: 600; margin-right: 4px; }

.beuniq-sl-terms {
    padding: 14px 16px;
    background: var(--bm-light);
    margin: 18px 0 20px;
    border-left: 3px solid var(--bm-primary);
}
.beuniq-sl-terms label { display: flex; align-items: flex-start; gap: 8px; cursor: pointer; font-size: 13px; color: var(--bm-heading); }
.beuniq-sl-terms input { margin-top: 3px; }
.beuniq-sl-terms-all { padding-bottom: 10px; border-bottom: 1px solid var(--bm-border); margin-bottom: 10px; }
.beuniq-sl-terms-list { display: flex; flex-direction: column; gap: 8px; }

.beuniq-sl-submit {
    width: 100%;
    padding: 14px;
    background: var(--bm-primary);
    border: 1px solid var(--bm-primary);
    color: #fff;
    font-family: 'Open Sans', sans-serif;
    font-weight: 700;
    font-size: 15px;
    border-radius: 0;
    cursor: pointer;
    transition: all .2s;
}
.beuniq-sl-submit:hover { background: var(--bm-primary-h); border-color: var(--bm-primary-h); }

.beuniq-sl-links {
    text-align: center;
    margin: 18px 0 30px;
    font-size: 13px;
}
.beuniq-sl-links a { color: var(--bm-text); text-decoration: none; margin: 0 8px; }
.beuniq-sl-links a:hover { color: var(--bm-primary); }
.beuniq-sl-links span { color: var(--bm-border); }

.beuniq-sl-divider {
    position: relative;
    text-align: center;
    margin: 28px 0 20px;
}
.beuniq-sl-divider::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0; right: 0;
    height: 1px;
    background: var(--bm-border);
}
.beuniq-sl-divider span {
    position: relative;
    background: #fff;
    padding: 0 16px;
    color: #999;
    font-size: 13px;
}

.beuniq-sl-error {
    padding: 12px 14px;
    margin-bottom: 20px;
    background: #FFEBEE;
    color: #C62828;
    border-left: 3px solid #F44336;
    font-size: 13px;
}
.beuniq-sl-msg {
    padding: 20px;
    text-align: center;
    background: var(--bm-light);
    color: var(--bm-heading);
    font-size: 14px;
}
.beuniq-sl-msg a { color: var(--bm-primary); margin-left: 8px; }

/* Circle social buttons */
.beuniq-sl-buttons {
    display: flex;
    justify-content: center;
    gap: 14px;
    margin-top: 6px;
}
.beuniq-sl-btn {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    transition: transform .15s, box-shadow .15s;
    border: 1px solid transparent;
}
.beuniq-sl-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.12);
}
.beuniq-sl-btn-kakao  { background: #FEE500; }
.beuniq-sl-btn-naver  { background: #03C75A; }
.beuniq-sl-btn-google { background: #FFFFFF; border-color: #E5E1DE; }
