/* ============================================
   Sun Stories — Auth Pages
   (login, register, forgot-password, verify-otp,
    change-password, confirmations)
   ============================================ */

/* --- Design Tokens --- */
:root {
    --color-accent:         #D8927C;
    --color-primary:        #2D2420;
    --color-border:         #F2E9DD;
    --color-bg:             #FBFAF7;
    --color-white:          #FFFFFF;
    --color-placeholder:    #7F7F7F;
    --color-error:          #FF383C;
    --color-text:           #2D2420;
    --color-text-secondary: #2D2420;
    --color-link:           #2D2420;
    --color-step-inactive:  #F2E9DD;
    --black-text:           #000000;
    --font-sans:            "Figtree", sans-serif;
    --font-serif:           "Nanum Myeongjo", serif;
    --form-card-max:        600px;
    --border-radius:        4px;
    --input-height:         48px;
    --transition:           0.2s ease;
}

/* --- Auth Wrapper
       Replaces .my-full-container + .page-content.
       Centres the form card; no outer padding from theme needed.
   --- */
.ssc-auth {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding: 18px 0 60px;
}

/* --- Form Card --- */
.ssc-auth .form-card {
    width: 100%;
    max-width: var(--form-card-max);
    border: 1px solid var(--color-border);
    padding: 25px 26px;
    background: var(--color-white);
}

.ssc-auth .form-card-wide {
    max-width: 600px;
}

/* --- Typography --- */
.ssc-auth .form-title {
    font-family: var(--font-sans);
    font-size: clamp(1.375rem, 1.272rem + 0.392vw, 1.625rem);
    font-weight: 600;
    color: var(--color-primary);
    text-align: center;
    margin-bottom: 10px;
    line-height: 1.3;
    margin-top: 0;
}

.ssc-auth .form-subtitle {
    font-family: var(--font-sans);
    font-size: 1rem;
    color: var(--color-text-secondary);
    text-align: center;
    margin-bottom: 40px;
    line-height: 1.5;
}

.ssc-auth .section-label {
    font-family: var(--font-sans);
    font-size: 0.875rem;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--color-primary);
    margin-bottom: 20px;
}

.ssc-auth .mb-0 { margin-bottom: 0; }

/* --- Form Groups --- */
.ssc-auth .form-group {
    margin-bottom: 20px;
}

.ssc-auth .form-group:last-of-type {
    margin-bottom: 20px;
}

.ssc-auth .form-group label {
    display: block;
    font-family: var(--font-sans);
    font-size: 1rem;
    font-weight: 400;
    color: var(--color-primary);
    margin-bottom: 7px;
}

.ssc-auth .form-input {
    width: 100%;
    height: var(--input-height);
    padding: 9px 14px;
    font-family: var(--font-sans);
    font-size: 1rem;
    font-weight: 400;
    color: var(--black-text);
    background: var(--color-white);
    border: 1px solid var(--color-primary);
    border-radius: 0;
    outline: none;
    transition: border-color var(--transition);
}

.ssc-auth .form-input::placeholder {
    color: var(--color-placeholder);
}

.ssc-auth .form-input:focus {
    border-color: var(--color-accent);
}

.ssc-auth .form-input.error {
    border-color: var(--color-error);
}

.ssc-auth textarea.form-input {
    height: var(--input-height);
    resize: none;
    overflow: hidden;
}

/* --- Password Input Wrapper --- */
.ssc-auth .input-wrapper {
    position: relative;
}

.ssc-auth .input-wrapper .form-input {
    padding-right: 48px;
}

.ssc-auth .toggle-password {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-secondary);
}

.ssc-auth .toggle-password svg {
    width: 20px;
    height: 20px;
}

.ssc-auth .toggle-password:hover,
.ssc-auth .toggle-password:focus,
.ssc-auth .toggle-password:active {
    background-color: transparent;
    color: var(--color-primary);
}

input[type="password"]::-ms-reveal,
input[type="password"]::-ms-clear {
    display: none;
}

/* --- Phone Group --- */
.ssc-auth .phone-group {
    display: flex;
    border: 1px solid var(--color-primary);
    overflow: hidden;
}

.ssc-auth .phone-group .country-code {
    width: 72px;
    min-width: 72px;
    height: var(--input-height);
    padding: 9px 16px 9px 10px;
    font-family: var(--font-sans);
    font-size: 1rem;
    color: var(--black-text);
    background: var(--color-white);
    border: none;
    border-right: 1px solid var(--color-primary);
    outline: none;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    border-radius: 0;
    background-image: url('../../icons/arrow-down.svg');
    background-repeat: no-repeat;
    background-position: right 8px center;
    background-size: 14px;
}

.ssc-auth .phone-group .phone-input {
    flex: 1;
    height: var(--input-height);
    padding: 9px 14px;
    font-family: var(--font-sans);
    font-size: 1rem;
    color: var(--color-text);
    background: var(--color-white);
    border: none;
    border-radius: 0;
    outline: none;
}

.ssc-auth .phone-group .phone-input::placeholder {
    color: var(--color-placeholder);
}

/* --- Two-Column Form Row --- */
.ssc-auth .form-row {
    display: flex;
    gap: 19px;
}

.ssc-auth .form-row .form-group {
    flex: 1;
    min-width: 0;
}

/* --- Checkbox --- */
.ssc-auth .checkbox-group {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 0px;
}

.ssc-auth .checkbox-group input[type="checkbox"] {
    width: 20px;
    height: 20px;
    min-width: 20px;
    accent-color: var(--color-primary);
    cursor: pointer;
}

.ssc-auth .checkbox-group input#ssc-reg-terms {
    border-radius: 4px;
}

.ssc-auth .checkbox-group label {
    font-family: var(--font-sans);
    font-size: 1rem;
    font-weight: 400;
    color: var(--color-text);
    cursor: pointer;
    line-height: 1.5;
}

.ssc-auth .checkbox-group label a {
    color: var(--color-text);
    font-weight: 600;
    text-decoration: underline;
}

/* --- Radio Group --- */
.ssc-auth .radio-group {
    display: flex;
    flex-direction: row;
    justify-content: start;
    margin-bottom: 22px;
    white-space: nowrap;
    flex-wrap: wrap;
    column-gap: 20px;
    row-gap: 10px;
}

.ssc-auth #ssc-register-step2 .radio-group {
    row-gap: 15.5px;
}

.ssc-auth .radio-group label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-sans);
    font-size: 1rem;
    color: var(--color-text);
    cursor: pointer;
}

.ssc-auth .radio-group input[type="radio"] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 20px;
    height: 20px;
    min-width: 20px;
    margin: 0;
    border: 1px solid #292D32;
    border-radius: 50%;
    background: #fff;
    cursor: pointer;
    position: relative;
}

.ssc-auth .radio-group input[type="radio"]:checked {
    background: #292D32;
}

.ssc-auth .radio-group input[type="radio"]:checked::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 4px;
    height: 4px;
    background: #fff;
    border-radius: 3px;
}

/* --- Form Options (Remember Me + Forgot) --- */
.ssc-auth .form-options {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 20px;
}

.ssc-auth .form-options .checkbox-group {
    margin-bottom: 0;
}

.ssc-auth .form-options a {
    font-size: 0.875rem;
    font-weight: 400;
    color: var(--color-text);
    white-space: nowrap;
}

/* --- Step Indicator --- */
.ssc-auth .step-indicator {
    display: flex;
    align-items: center;
    gap: 9px;
}

.ssc-auth .step-indicator .step {
    width: 40px;
    height: 6px;
    background-color: var(--color-step-inactive);
}

.ssc-auth .step-indicator .step.active {
    background-color: var(--color-accent);
}

.ssc-auth .section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 23px;
}

/* --- Buttons --- */
.ssc-auth .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 42px;
    padding: 11.5px 20px;
    font-family: var(--font-sans);
    font-size: 0.875rem;
    font-weight: 500;
    border: 1px solid transparent;
    cursor: pointer;
    transition: opacity var(--transition), background-color var(--transition);
    text-decoration: none;
    line-height: 1;
}

.ssc-auth .btn:hover {
    opacity: 0.85;
}

.ssc-auth .btn-primary {
    width: 100%;
    font-size: 1rem;
    font-weight: 400;
    background-color: var(--color-primary)!important;
    color: var(--color-white)!important;
    border-color: var(--color-primary)!important;
    border-radius: 0;
    margin-top: 0;
}

.ssc-auth #ssc-register-step1 .btn-primary {
    margin-top: 30px;
}

.ssc-auth .btn-primary:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.ssc-auth .btn-primary .btn-spinner {
    display: none;
    width: 16px;
    height: 16px;
    border: 2px solid rgba(255, 255, 255, 0.4);
    border-top-color: #fff;
    border-radius: 50%;
    animation: ssc-spin 0.6s linear infinite;
    margin-right: 8px;
}

.ssc-auth .btn-primary.is-loading .btn-spinner {
    display: inline-block;
}

@keyframes ssc-spin {
    to { transform: rotate(360deg); }
}

.ssc-auth .btn-outline {
    background-color: transparent;
    color: var(--color-primary);
    border-color: var(--color-primary);
    border-radius: 0;
}

.ssc-auth .btn-group {
    display: flex;
    gap: 10px;
    justify-content: center;
    flex-wrap: wrap;
}

.ssc-auth .btn-group .btn {
    width: auto;
    font-size: 1rem;
    padding: 11.5px 20px;
    border-radius: 0;
    min-width: 128px;
}

/* --- OTP Inputs --- */
.ssc-auth .otp-group {
    display: flex;
    gap: 20px;
    justify-content: center;
    margin-bottom: 20px;
}

.ssc-auth .ssc-otp-input {
    width: 75px;
    height: 40px;
    text-align: center;
    font-family: var(--font-sans);
    font-size: 1rem;
    font-weight: 400;
    color: var(--color-text);
    border: 1px solid var(--color-primary);
    border-radius: 0;
    background: var(--color-white);
    outline: none;
    transition: border-color var(--transition);
}

.ssc-auth .ssc-otp-input:focus {
    border-color: var(--color-accent);
}

/* --- Form Footer Links --- */
.ssc-auth .form-footer {
    text-align: center;
    margin-top: 27px;
    font-size: 1rem;
    color: var(--color-text-secondary);
}



.ssc-auth .form-footer a {
    color: var(--color-text);
    font-weight: 500;
    text-decoration: underline;
}

.ssc-auth .form-footer-secondary {
    text-align: center;
    margin-top: 40px;
    font-size: 1rem;
    color: var(--color-text-secondary);
}

.ssc-auth .form-footer-secondary a {
    color: var(--color-text);
    font-weight: 500;
    text-decoration: underline;
}

/* --- Confirmation Content --- */
.ssc-auth .confirmation-content {
    max-width: 500px;
    text-align: center;
    padding: 40px 0 20px;
}

.ssc-auth .confirmation-content .form-title {
    font-weight: 600;
    margin-bottom: 10px;
}

.ssc-auth .confirmation-content .form-subtitle {
    font-size: 1rem;
    margin-bottom: 40px;
}

/* --- Error Messages --- */
.ssc-auth .error-message {
    display: none;
    font-family: var(--font-sans);
    font-size: 0.75rem;
    color: var(--color-error);
    margin-top: 3px;
    line-height: 130%;
}

.ssc-auth .error-message.visible {
    display: block;
}

/* --- Form Content Wrapper (spacing above submit) --- */
.ssc-auth .form-content-wrapper {
    margin-bottom: 30px;
}

/* --- Address Type label --- */
.ssc-auth .checkout-section-title {
    font-family: var(--font-sans);
    font-size: 1rem;
    font-weight: 500;
    margin-bottom: 10px;
    color: var(--color-text);
}

.ssc-auth #ssc-register-step2 .checkout-section-title {
    margin-bottom: 12px;
}

/* --- Back Button (Step 2 of register) --- */
.ssc-auth .ssc-back-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: none;
    border: none;
    cursor: pointer;
    font-family: var(--font-sans);
    font-size: 0.875rem;
    color: var(--color-text);
    padding: 0;
    margin-top: 16px;
    text-decoration: none;
}

.ssc-auth .ssc-back-btn:hover {
    opacity: 0.75;
}

/* --- Responsive --- */
@media (max-width: 600px) {
    .ssc-auth .form-card {
        padding: 24px 15px;
    }

    .ssc-auth-login .form-card, 
    .ssc-auth-forgot-password .form-card{
        padding: 24px 15px 35px;
    }

    .ssc-auth-otp-verify .form-card {
        padding: 24px 15px 30px;
    }

    .ssc-auth-set-new-password .form-card {
        padding: 24px 15px 20px;
    }

    .ssc-auth-otp-verify .form-footer {
        margin-top: 35px;
    }

    .ssc-auth-otp-verify .form-footer-secondary {
        margin-top: 20px;
    }

    .ssc-auth-forgot-password .form-subtitle {
        line-height: 1.35;
        margin-bottom: 17px;
    }

    #ssc-forgot-form button[type="submit"] {
        margin-top: 5px;
    }

    .ssc-auth {
        --input-height: 40px;
        padding: 20px 0 60px;
    }

    .ssc-auth .form-subtitle {
        line-height: 1.35;
        margin-bottom: 23px;
    }

    .ssc-auth .section-header {
        margin-bottom: 26px;
    }

    .ssc-auth #ssc-register-step2 .section-header {
        margin-bottom: 15px;
    }

    .custom-hide-in-sm {
        display: none;
    }

    .ssc-auth .form-group.register-postcode{
        margin-bottom: 0;
    }


    .ssc-auth .form-group {
        margin-bottom: 15px;
    }

    .ssc-auth .form-group:last-of-type {
        margin-bottom: 15px;
    }

    .ssc-auth .form-group label {
        font-size: 0.875rem;
    }

    .ssc-auth .confirmation-content {
        max-width: 320px;
        padding: 30px 0 20px;
    }

    .ssc-auth .form-options {
        margin-bottom: 30px;
    }

    .ssc-auth .form-options a {
        font-size: 1rem;
    }    

    .ssc-auth .form-footer {
        margin-top: 35px;
    }

    .ssc-auth-otp-verify .form-footer {
        margin-top: 20px;
    }

    .ssc-auth-set-new-password .form-footer {
        margin-top: 20px;
    }





    .ssc-auth .checkbox-group {
        margin-bottom: 0;
    }

    .ssc-auth #ssc-register-step1 .btn-primary {
        margin-top: 39px;
    }

    .ssc-auth .form-row {
        flex-direction: column;
        gap: 0;
    }

    .ssc-auth .form-row.form-row-col-sm-6 {
        flex-direction: row;
        gap: 11px;
    }

    

    .ssc-auth .otp-group {
        gap: 10px;
    }

    .ssc-auth .ssc-otp-input {
        width: 44px;
    }

    .ssc-auth textarea.form-input {
        height: 70px;
        overflow: auto;
    }

    .ssc-auth-login .form-subtitle {
        margin-bottom: 36px;
    }
}
