/*
 * Captain Greek checkout account gate.
 * Scoped to cart, account create, and account login pages.
 */

body.checkout-cart-index .amsl-cart-page {
    display: none !important;
}

/* Cart account gate */
.cg-cart-auth-gate {
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 28px;
    margin: 34px 0 18px;
    padding: 28px;
    border: 1px solid rgba(39, 49, 140, .12);
    border-radius: 22px;
    background:
        radial-gradient(circle at top left, rgba(193, 160, 103, .18), transparent 35%),
        linear-gradient(135deg, #ffffff 0%, #f8f9ff 100%);
    box-shadow: 0 18px 45px rgba(25, 32, 92, .10);
}

.cg-cart-auth-gate:before {
    content: "";
    position: absolute;
    inset: 0;
    border-top: 4px solid #c1a067;
    pointer-events: none;
}

.cg-cart-auth-gate__content {
    position: relative;
    max-width: 720px;
}

.cg-cart-auth-gate__badge,
.cg-checkout-intent__eyebrow {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    margin-bottom: 10px;
    padding: 6px 11px;
    border-radius: 999px;
    background: rgba(39, 49, 140, .08);
    color: #27318c;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.cg-cart-auth-gate h2 {
    margin: 0 0 9px;
    color: #111827;
    font-size: 26px;
    line-height: 1.18;
    font-weight: 800;
}

.cg-cart-auth-gate p {
    margin: 0;
    color: #4b5563;
    font-size: 15px;
    line-height: 1.65;
}

.cg-cart-auth-gate__trust {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 18px;
}

.cg-cart-auth-gate__trust span {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 7px 11px;
    border: 1px solid rgba(39, 49, 140, .12);
    border-radius: 999px;
    background: rgba(255, 255, 255, .75);
    color: #27318c;
    font-size: 13px;
    font-weight: 700;
}

.cg-cart-auth-gate__trust span:before {
    content: "✓";
    color: #c1a067;
    font-weight: 900;
}

.cg-cart-auth-gate__actions {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-width: 260px;
}

.cg-auth-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 13px 20px;
    border-radius: 13px;
    font-size: 15px;
    font-weight: 800;
    text-align: center;
    text-decoration: none !important;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.cg-auth-btn:hover {
    transform: translateY(-1px);
}

.cg-auth-btn--primary {
    border: 1px solid #c1a067;
    background: linear-gradient(135deg, #c1a067, #b69252);
    color: #ffffff !important;
    box-shadow: 0 12px 24px rgba(193, 160, 103, .28);
}

.cg-auth-btn--secondary {
    border: 1px solid rgba(39, 49, 140, .22);
    background: #ffffff;
    color: #27318c !important;
}

/* Checkout intent banner on login/register pages */
.cg-checkout-intent {
    position: relative;
    overflow: hidden;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 22px;
    margin: 0 auto 28px;
    padding: 26px;
    border-radius: 24px;
    background:
        radial-gradient(circle at top left, rgba(193, 160, 103, .35), transparent 30%),
        linear-gradient(135deg, #111a59 0%, #27318c 62%, #1d255f 100%);
    color: #ffffff;
    box-shadow: 0 22px 50px rgba(25, 32, 92, .22);
}

.cg-checkout-intent:after {
    content: "";
    position: absolute;
    right: -80px;
    top: -80px;
    width: 220px;
    height: 220px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .08);
    pointer-events: none;
}

.cg-checkout-intent__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 54px;
    height: 54px;
    border-radius: 18px;
    background: #c1a067;
    color: #ffffff;
    font-size: 22px;
    font-weight: 900;
    box-shadow: 0 12px 26px rgba(0, 0, 0, .18);
}

.cg-checkout-intent__main {
    position: relative;
    z-index: 1;
}

.cg-checkout-intent__eyebrow {
    margin-bottom: 8px;
    background: rgba(255, 255, 255, .14);
    color: #ffffff;
}

.cg-checkout-intent h1 {
    margin: 0 0 8px;
    color: #ffffff;
    font-size: 30px;
    line-height: 1.15;
    font-weight: 900;
}

.cg-checkout-intent p {
    max-width: 760px;
    margin: 0;
    color: rgba(255, 255, 255, .88);
    font-size: 15px;
    line-height: 1.65;
}

.cg-checkout-intent__steps {
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
    margin-top: 16px;
}

.cg-checkout-intent__steps span {
    padding: 7px 11px;
    border: 1px solid rgba(255, 255, 255, .20);
    border-radius: 999px;
    background: rgba(255, 255, 255, .10);
    color: #ffffff;
    font-size: 12px;
    font-weight: 800;
}

.cg-checkout-intent__actions {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    gap: 10px;
    min-width: 180px;
}

.cg-checkout-intent__actions a {
    display: inline-flex;
    justify-content: center;
    padding: 11px 14px;
    border-radius: 12px;
    background: rgba(255, 255, 255, .12);
    color: #ffffff !important;
    font-size: 13px;
    font-weight: 800;
    text-decoration: none !important;
}

.cg-checkout-intent__actions a:first-child {
    background: #ffffff;
    color: #27318c !important;
}

/* Modernized account form feel */
body.customer-account-create .page-main,
body.customer-account-login .page-main {
    max-width: 1180px;
}

body.customer-account-create .form-create-account,
body.customer-account-login .form-login {
    border: 1px solid rgba(39, 49, 140, .10);
    border-radius: 22px;
    background: #ffffff;
    box-shadow: 0 16px 42px rgba(25, 32, 92, .08);
}

body.customer-account-create .form-create-account {
    padding: 26px;
}

body.customer-account-login .form-login {
    padding: 24px;
}

body.customer-account-create .form-create-account .fieldset,
body.customer-account-login .form-login .fieldset {
    border: 0;
}

body.customer-account-create .form-create-account .legend,
body.customer-account-login .form-login .legend {
    color: #111827;
    font-weight: 900;
}

body.customer-account-create .form-create-account .field,
body.customer-account-login .form-login .field {
    margin-bottom: 15px;
}

body.customer-account-create .form-create-account label,
body.customer-account-login .form-login label {
    color: #111827;
    font-weight: 700;
}

body.customer-account-create .form-create-account input.input-text,
body.customer-account-login .form-login input.input-text,
body.customer-account-create .form-create-account select,
body.customer-account-login .form-login select {
    min-height: 48px;
    border: 1px solid #dfe3f0;
    border-radius: 13px;
    background: #ffffff;
    color: #111827;
    box-shadow: none;
}

body.customer-account-create .form-create-account input.input-text:focus,
body.customer-account-login .form-login input.input-text:focus {
    border-color: #27318c;
    box-shadow: 0 0 0 3px rgba(39, 49, 140, .10);
}

body.customer-account-create .form-create-account .action.primary,
body.customer-account-login .form-login .action.primary,
body.customer-account-create .form-create-account button.primary,
body.customer-account-login .form-login button.primary {
    min-height: 48px;
    padding: 12px 22px;
    border: 1px solid #c1a067 !important;
    border-radius: 13px;
    background: linear-gradient(135deg, #c1a067, #b69252) !important;
    color: #ffffff !important;
    font-weight: 900;
    box-shadow: 0 12px 24px rgba(193, 160, 103, .24);
}

body.customer-account-create .form-create-account .action.primary:hover,
body.customer-account-login .form-login .action.primary:hover,
body.customer-account-create .form-create-account button.primary:hover,
body.customer-account-login .form-login button.primary:hover {
    filter: brightness(.98);
    transform: translateY(-1px);
}

/* Make existing Amasty social area feel less dominant on account pages */
body.customer-account-create .amsl-social-wrapper,
body.customer-account-login .amsl-social-wrapper {
    margin-bottom: 20px;
}

body.customer-account-create .amsl-title,
body.customer-account-login .amsl-title {
    color: #27318c;
    font-weight: 800;
}

/* Responsive */
@media (max-width: 900px) {
    .cg-cart-auth-gate,
    .cg-checkout-intent {
        grid-template-columns: 1fr;
        flex-direction: column;
        align-items: stretch;
        text-align: left;
    }

    .cg-cart-auth-gate__actions,
    .cg-checkout-intent__actions {
        width: 100%;
        min-width: 0;
    }

    .cg-checkout-intent h1 {
        font-size: 24px;
    }

    .cg-cart-auth-gate h2 {
        font-size: 22px;
    }
}

@media (max-width: 540px) {
    .cg-cart-auth-gate,
    .cg-checkout-intent {
        padding: 20px;
        border-radius: 18px;
    }

    .cg-cart-auth-gate__trust {
        display: none;
    }

    body.customer-account-create .form-create-account,
    body.customer-account-login .form-login {
        padding: 18px;
        border-radius: 18px;
    }
}


/* ==========================================================
   Captain Greek checkout account flow patch
   Fixes: centered layout + premium simplified account pages
   ========================================================== */

.cg-checkout-loading {
    opacity: .72;
    pointer-events: none;
}

/* Only special checkout-required login/register pages */
body.cg-checkout-account-flow.customer-account-create,
body.cg-checkout-account-flow.customer-account-login {
    background: #f6f7fb;
}

body.cg-checkout-account-flow.customer-account-create .page-main,
body.cg-checkout-account-flow.customer-account-login .page-main {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 28px 0 56px !important;
    background:
        radial-gradient(circle at top left, rgba(193, 160, 103, .10), transparent 30%),
        linear-gradient(180deg, #ffffff 0%, #f6f7fb 42%, #f6f7fb 100%);
}

body.cg-checkout-account-flow.customer-account-create .page-main > .container,
body.cg-checkout-account-flow.customer-account-login .page-main > .container,
body.cg-checkout-account-flow.customer-account-create .main-container,
body.cg-checkout-account-flow.customer-account-login .main-container {
    width: calc(100% - 40px) !important;
    max-width: 1180px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    box-sizing: border-box;
}

body.cg-checkout-account-flow.customer-account-create .page-title-wrapper,
body.cg-checkout-account-flow.customer-account-login .page-title-wrapper {
    display: none !important;
}

body.cg-checkout-account-flow.customer-account-create .columns.row,
body.cg-checkout-account-flow.customer-account-login .columns.row {
    display: flex !important;
    justify-content: center !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

body.cg-checkout-account-flow.customer-account-create .column.main,
body.cg-checkout-account-flow.customer-account-login .column.main,
body.cg-checkout-account-flow.customer-account-create .main-wrap,
body.cg-checkout-account-flow.customer-account-login .main-wrap {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    float: none !important;
    width: 100% !important;
    max-width: 1180px !important;
    flex: 0 0 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Premium centered hero */
body.cg-checkout-account-flow .cg-checkout-intent {
    order: 1;
    width: 100% !important;
    max-width: 1100px !important;
    margin: 0 auto 32px !important;
    padding: 30px 34px !important;
    border: 1px solid rgba(255, 255, 255, .16);
    border-radius: 24px;
    background:
        radial-gradient(circle at 88% 12%, rgba(255, 255, 255, .13), transparent 20%),
        radial-gradient(circle at 0% 0%, rgba(193, 160, 103, .35), transparent 28%),
        linear-gradient(135deg, #101756 0%, #27318c 58%, #1b235e 100%);
    box-shadow: 0 24px 70px rgba(18, 25, 89, .22);
    box-sizing: border-box;
}

body.cg-checkout-account-flow .cg-checkout-intent h1 {
    font-size: clamp(26px, 2.2vw, 36px);
    letter-spacing: -.03em;
}

body.cg-checkout-account-flow .cg-checkout-intent p {
    max-width: 760px;
    font-size: 15.5px;
}

/* Put email/password form before social login on the create-account flow */
body.cg-checkout-account-flow.customer-account-create .block-new-customer {
    order: 2;
    width: 100% !important;
    max-width: 640px !important;
    margin: 0 auto 28px !important;
}

body.cg-checkout-account-flow.customer-account-create .block-new-customer .block-content {
    width: 100%;
}

body.cg-checkout-account-flow.customer-account-create .form-create-account {
    width: 100% !important;
    max-width: 640px !important;
    margin: 0 auto !important;
    padding: 30px !important;
    border: 1px solid rgba(39, 49, 140, .10);
    border-radius: 24px;
    background: #ffffff;
    box-shadow: 0 22px 60px rgba(18, 25, 89, .10);
    box-sizing: border-box;
}

/* Login page form centering */
body.cg-checkout-account-flow.customer-account-login .login-container,
body.cg-checkout-account-flow.customer-account-login .block-customer-login {
    order: 2;
    width: 100% !important;
    max-width: 560px !important;
    margin: 0 auto 28px !important;
}

body.cg-checkout-account-flow.customer-account-login .form-login {
    width: 100% !important;
    max-width: 560px !important;
    margin: 0 auto !important;
    padding: 30px !important;
    border: 1px solid rgba(39, 49, 140, .10);
    border-radius: 24px;
    background: #ffffff;
    box-shadow: 0 22px 60px rgba(18, 25, 89, .10);
    box-sizing: border-box;
}

/* Demote social login below the real email/password path */
body.cg-checkout-account-flow .amsl-registration-page,
body.cg-checkout-account-flow .amsl-login-page {
    order: 3;
    width: 100% !important;
    max-width: 640px !important;
    margin: 0 auto 30px !important;
    padding: 0 !important;
    text-align: center;
    background: transparent !important;
}

body.cg-checkout-account-flow .amsl-note.-top,
body.cg-checkout-account-flow .amsl-note.-bottom,
body.cg-checkout-account-flow .amsl-separator {
    display: none !important;
}

body.cg-checkout-account-flow .amsl-registration-page:before,
body.cg-checkout-account-flow .amsl-login-page:before {
    content: "Prefer social sign-in?";
    display: block;
    width: 100%;
    margin: 0 auto 16px;
    padding: 15px 18px;
    border-left: 4px solid #c1a067;
    border-radius: 14px;
    background: #ffffff;
    color: #111827;
    font-size: 15px;
    font-weight: 900;
    letter-spacing: -.01em;
    box-shadow: 0 12px 35px rgba(18, 25, 89, .07);
    box-sizing: border-box;
}

body.cg-checkout-account-flow .amsl-social-wrapper {
    width: 100%;
    max-width: 380px;
    margin: 0 auto !important;
}

body.cg-checkout-account-flow .amsl-social-login {
    width: 100%;
}

body.cg-checkout-account-flow .amsl-buttons {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 11px;
}

body.cg-checkout-account-flow .amsl-button-wrapper {
    width: 100%;
    margin: 0 !important;
}

body.cg-checkout-account-flow .amsl-button {
    min-height: 48px;
    border-radius: 13px !important;
}

/* Form polish */
body.cg-checkout-account-flow .form-create-account .block-title,
body.cg-checkout-account-flow .form-login .legend,
body.cg-checkout-account-flow .block-customer-login .block-title {
    text-align: center;
}

body.cg-checkout-account-flow .form-create-account .block-title strong,
body.cg-checkout-account-flow .block-customer-login .block-title strong {
    color: #27318c;
    font-size: 24px;
    font-weight: 900;
    letter-spacing: -.03em;
}

body.cg-checkout-account-flow .form-create-account > p,
body.cg-checkout-account-flow .block-customer-login .block-content > p {
    max-width: 440px;
    margin-left: auto;
    margin-right: auto;
    color: #4b5563;
    text-align: center;
    line-height: 1.6;
}

body.cg-checkout-account-flow .form-create-account .fieldset,
body.cg-checkout-account-flow .form-login .fieldset {
    margin-bottom: 20px;
}

body.cg-checkout-account-flow .form-create-account .field,
body.cg-checkout-account-flow .form-login .field {
    margin-bottom: 16px;
}

body.cg-checkout-account-flow .form-create-account .label,
body.cg-checkout-account-flow .form-login .label {
    color: #1f2937;
    font-size: 13px;
    font-weight: 800;
}

body.cg-checkout-account-flow .form-create-account input.input-text,
body.cg-checkout-account-flow .form-login input.input-text,
body.cg-checkout-account-flow .form-create-account select,
body.cg-checkout-account-flow .form-login select {
    min-height: 50px;
    border: 1px solid #dbe1ef;
    border-radius: 14px;
    background: #ffffff;
    color: #111827;
    font-size: 15px;
    box-shadow: none;
}

body.cg-checkout-account-flow .form-create-account input.input-text:focus,
body.cg-checkout-account-flow .form-login input.input-text:focus {
    border-color: #27318c;
    box-shadow: 0 0 0 4px rgba(39, 49, 140, .10);
}

body.cg-checkout-account-flow .form-create-account .note,
body.cg-checkout-account-flow .form-login .note {
    margin-top: 7px;
    color: #6b7280;
    font-size: 12.5px;
    line-height: 1.55;
}

body.cg-checkout-account-flow .form-create-account .actions-toolbar,
body.cg-checkout-account-flow .form-login .actions-toolbar {
    margin-top: 22px;
}

body.cg-checkout-account-flow .form-create-account .actions-toolbar .primary,
body.cg-checkout-account-flow .form-login .actions-toolbar .primary {
    width: 100%;
}

body.cg-checkout-account-flow .form-create-account .actions-toolbar .primary .action.primary,
body.cg-checkout-account-flow .form-login .actions-toolbar .primary .action.primary,
body.cg-checkout-account-flow .form-create-account button.action.primary,
body.cg-checkout-account-flow .form-login button.action.primary {
    width: 100%;
    min-height: 52px;
    border: 0 !important;
    border-radius: 14px;
    background: linear-gradient(135deg, #c1a067, #b18d4e) !important;
    color: #ffffff !important;
    font-size: 15px;
    font-weight: 900;
    box-shadow: 0 16px 30px rgba(193, 160, 103, .28);
}

body.cg-checkout-account-flow .form-create-account .actions-toolbar .secondary,
body.cg-checkout-account-flow .form-login .actions-toolbar .secondary {
    width: 100%;
    margin-top: 12px;
    text-align: center;
}

/* Cloudflare Turnstile centering */
body.cg-checkout-account-flow .cf-turnstile {
    display: flex;
    justify-content: center;
    margin: 18px auto 8px;
}

/* Make checkbox rows cleaner */
body.cg-checkout-account-flow .field.choice {
    padding: 12px 14px;
    border: 1px solid rgba(39, 49, 140, .08);
    border-radius: 14px;
    background: #f8f9ff;
}

body.cg-checkout-account-flow .privacy-container-customer .field.choice {
    background: #fffaf1;
    border-color: rgba(193, 160, 103, .25);
}

/* Mobile */
@media (max-width: 768px) {
    body.cg-checkout-account-flow.customer-account-create .page-main > .container,
    body.cg-checkout-account-flow.customer-account-login .page-main > .container,
    body.cg-checkout-account-flow.customer-account-create .main-container,
    body.cg-checkout-account-flow.customer-account-login .main-container {
        width: calc(100% - 24px) !important;
    }

    body.cg-checkout-account-flow .cg-checkout-intent {
        grid-template-columns: 1fr !important;
        padding: 22px !important;
        text-align: left;
    }

    body.cg-checkout-account-flow .cg-checkout-intent__actions {
        width: 100%;
        min-width: 0;
    }

    body.cg-checkout-account-flow.customer-account-create .form-create-account,
    body.cg-checkout-account-flow.customer-account-login .form-login {
        padding: 22px !important;
        border-radius: 20px;
    }
}


/* ==========================================================
   Captain Greek social-login cleanup
   Fixes Amasty social-login styling after checkout auth flow
   ========================================================== */

/*
 * Scope this only to the new checkout-account flow.
 * This prevents normal login/register pages from being affected.
 */
body.cg-checkout-account-flow .amsl-registration-page,
body.cg-checkout-account-flow .amsl-login-page,
body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page,
body.customer-account-login .cg-checkout-intent ~ .amsl-login-page {
    width: 100% !important;
    max-width: 520px !important;
    margin: 0 auto 32px !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    text-align: center !important;
}

/* Remove the custom pseudo-card from the previous CSS */
body.cg-checkout-account-flow .amsl-registration-page:before,
body.cg-checkout-account-flow .amsl-login-page:before,
body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page:before,
body.customer-account-login .cg-checkout-intent ~ .amsl-login-page:before {
    content: none !important;
    display: none !important;
}

/* Hide the old Amasty top/bottom copy because email/password is now the main path */
body.cg-checkout-account-flow .amsl-note.-top,
body.cg-checkout-account-flow .amsl-note.-bottom,
body.cg-checkout-account-flow .amsl-separator,
body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page .amsl-note.-top,
body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page .amsl-note.-bottom,
body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page .amsl-separator,
body.customer-account-login .cg-checkout-intent ~ .amsl-login-page .amsl-note.-top,
body.customer-account-login .cg-checkout-intent ~ .amsl-login-page .amsl-note.-bottom,
body.customer-account-login .cg-checkout-intent ~ .amsl-login-page .amsl-separator {
    display: none !important;
}

/* New clean heading above social buttons */
body.cg-checkout-account-flow .amsl-social-wrapper:before,
body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page .amsl-social-wrapper:before,
body.customer-account-login .cg-checkout-intent ~ .amsl-login-page .amsl-social-wrapper:before {
    content: "Or continue with social sign-in";
    display: block;
    width: 100%;
    margin: 0 auto 16px;
    padding: 14px 18px;
    border: 1px solid rgba(39, 49, 140, .10);
    border-left: 4px solid #c1a067;
    border-radius: 14px;
    background: #ffffff;
    color: #111827;
    font-size: 15px;
    font-weight: 900;
    line-height: 1.35;
    letter-spacing: -.01em;
    box-shadow: 0 12px 34px rgba(18, 25, 89, .07);
    box-sizing: border-box;
}

/* Social wrapper */
body.cg-checkout-account-flow .amsl-social-wrapper,
body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page .amsl-social-wrapper,
body.customer-account-login .cg-checkout-intent ~ .amsl-login-page .amsl-social-wrapper {
    width: 100% !important;
    max-width: 390px !important;
    margin: 0 auto !important;
    padding: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

/* Inner Amasty block reset */
body.cg-checkout-account-flow .amsl-social-login,
body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page .amsl-social-login,
body.customer-account-login .cg-checkout-intent ~ .amsl-login-page .amsl-social-login {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

/* Hide redundant Amasty title inside the social block */
body.cg-checkout-account-flow .amsl-title,
body.cg-checkout-account-flow .amsl-title.-short,
body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page .amsl-title,
body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page .amsl-title.-short,
body.customer-account-login .cg-checkout-intent ~ .amsl-login-page .amsl-title,
body.customer-account-login .cg-checkout-intent ~ .amsl-login-page .amsl-title.-short {
    display: none !important;
}

/* Button stack */
body.cg-checkout-account-flow .amsl-buttons,
body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page .amsl-buttons,
body.customer-account-login .cg-checkout-intent ~ .amsl-login-page .amsl-buttons {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 12px !important;
    width: 100% !important;
    margin: 0 !important;
}

/* Button wrappers */
body.cg-checkout-account-flow .amsl-button-wrapper,
body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page .amsl-button-wrapper,
body.customer-account-login .cg-checkout-intent ~ .amsl-login-page .amsl-button-wrapper {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Core button shape */
body.cg-checkout-account-flow a.amsl-button,
body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page a.amsl-button,
body.customer-account-login .cg-checkout-intent ~ .amsl-login-page a.amsl-button {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    min-height: 50px !important;
    padding: 0 18px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    text-align: center !important;
    text-decoration: none !important;
    box-sizing: border-box !important;
    box-shadow: 0 12px 26px rgba(18, 25, 89, .10) !important;
    transition: transform .18s ease, box-shadow .18s ease, filter .18s ease !important;
}

body.cg-checkout-account-flow a.amsl-button:hover,
body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page a.amsl-button:hover,
body.customer-account-login .cg-checkout-intent ~ .amsl-login-page a.amsl-button:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 16px 34px rgba(18, 25, 89, .14) !important;
}

/* Keep icon aligned and preserve Amasty's icon graphics */
body.cg-checkout-account-flow a.amsl-button .amsl-social-icon,
body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page a.amsl-button .amsl-social-icon,
body.customer-account-login .cg-checkout-intent ~ .amsl-login-page a.amsl-button .amsl-social-icon {
    position: absolute !important;
    left: 16px !important;
    top: 50% !important;
    margin: 0 !important;
    transform: translateY(-50%) !important;
}

body.cg-checkout-account-flow a.amsl-button .amsl-text,
body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page a.amsl-button .amsl-text,
body.customer-account-login .cg-checkout-intent ~ .amsl-login-page a.amsl-button .amsl-text {
    display: block !important;
    width: 100% !important;
    padding: 0 24px !important;
    color: inherit !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    line-height: 1.1 !important;
    text-align: center !important;
    box-sizing: border-box !important;
}

/* Brand button colors */
body.cg-checkout-account-flow a.amsl-button.-google,
body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page a.amsl-button.-google,
body.customer-account-login .cg-checkout-intent ~ .amsl-login-page a.amsl-button.-google {
    border: 1px solid #3b76dc !important;
    background: #3b76dc !important;
    color: #ffffff !important;
}

body.cg-checkout-account-flow a.amsl-button.-apple,
body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page a.amsl-button.-apple,
body.customer-account-login .cg-checkout-intent ~ .amsl-login-page a.amsl-button.-apple {
    border: 1px solid #050505 !important;
    background: #050505 !important;
    color: #ffffff !important;
}

body.cg-checkout-account-flow a.amsl-button.-microsoftgraph,
body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page a.amsl-button.-microsoftgraph,
body.customer-account-login .cg-checkout-intent ~ .amsl-login-page a.amsl-button.-microsoftgraph {
    border: 1px solid #d7dce8 !important;
    background: #ffffff !important;
    color: #4b5563 !important;
}

/* Mobile */
@media (max-width: 540px) {
    body.cg-checkout-account-flow .amsl-registration-page,
    body.cg-checkout-account-flow .amsl-login-page,
    body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page,
    body.customer-account-login .cg-checkout-intent ~ .amsl-login-page {
        max-width: 100% !important;
        margin-bottom: 24px !important;
    }

    body.cg-checkout-account-flow .amsl-social-wrapper,
    body.customer-account-create .cg-checkout-intent ~ .amsl-registration-page .amsl-social-wrapper,
    body.customer-account-login .cg-checkout-intent ~ .amsl-login-page .amsl-social-wrapper {
        max-width: 100% !important;
    }
}


/* ==========================================================
   Captain Greek checkout registration two-column layout
   Scope: create-account page only, checkout account flow only
   Layout: form left, social sign-in right
   ========================================================== */

body.cg-checkout-account-flow.customer-account-create .page-main > .container,
body.cg-checkout-account-flow.customer-account-create .main-container {
    max-width: 1240px !important;
}

/*
 * The page currently renders:
 * 1. cg-checkout-intent hero
 * 2. amsl-registration-page social login
 * 3. block-new-customer registration form
 *
 * CSS Grid lets us visually place the form left and social login right
 * without editing Amasty or Magento templates.
 */
body.cg-checkout-account-flow.customer-account-create .column.main {
    display: grid !important;
    grid-template-columns: minmax(0, 700px) minmax(340px, 420px) !important;
    grid-template-rows: auto auto !important;
    gap: 34px !important;
    align-items: start !important;
    justify-content: center !important;
    width: 100% !important;
    max-width: 1240px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Hero stays full-width above both columns */
body.cg-checkout-account-flow.customer-account-create .column.main > .cg-checkout-intent {
    grid-column: 1 / -1 !important;
    grid-row: 1 !important;
    width: 100% !important;
    max-width: 1180px !important;
    margin: 0 auto 2px !important;
}

/* Registration form: left column */
body.cg-checkout-account-flow.customer-account-create .column.main > .block-new-customer {
    grid-column: 1 !important;
    grid-row: 2 !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    align-self: start !important;
}

body.cg-checkout-account-flow.customer-account-create .column.main > .block-new-customer .block-content {
    width: 100% !important;
}

body.cg-checkout-account-flow.customer-account-create .column.main > .block-new-customer .form-create-account {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 34px !important;
    border: 1px solid rgba(39, 49, 140, .10) !important;
    border-radius: 26px !important;
    background:
        radial-gradient(circle at 0% 0%, rgba(193, 160, 103, .08), transparent 28%),
        #ffffff !important;
    box-shadow: 0 24px 70px rgba(18, 25, 89, .11) !important;
}

/* Social login: right column */
body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page {
    grid-column: 2 !important;
    grid-row: 2 !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 28px !important;
    border: 1px solid rgba(39, 49, 140, .10) !important;
    border-radius: 26px !important;
    background:
        radial-gradient(circle at top right, rgba(193, 160, 103, .16), transparent 30%),
        linear-gradient(180deg, #ffffff 0%, #fbfbff 100%) !important;
    box-shadow: 0 24px 70px rgba(18, 25, 89, .10) !important;
    text-align: left !important;
    box-sizing: border-box !important;
}

/* Premium social-card heading */
body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page:before {
    content: "Faster account creation";
    display: block !important;
    margin: 0 0 8px !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    color: #27318c !important;
    font-size: 23px !important;
    font-weight: 900 !important;
    line-height: 1.15 !important;
    letter-spacing: -.035em !important;
    box-shadow: none !important;
}

/* Premium social-card helper text */
body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page:after {
    content: "Your cart stays saved. After signing in, you’ll continue directly to checkout.";
    display: block !important;
    margin: 18px 0 0 !important;
    padding: 15px 16px !important;
    border: 1px solid rgba(193, 160, 103, .22) !important;
    border-radius: 16px !important;
    background: #fffaf1 !important;
    color: #5b4a28 !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    line-height: 1.55 !important;
    box-sizing: border-box !important;
}

/* Hide Amasty's original notes/separator on this page only */
body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page .amsl-note,
body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page .amsl-separator {
    display: none !important;
}

/* Remove previous social wrapper heading because the side-card now has its own title */
body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page .amsl-social-wrapper:before {
    content: none !important;
    display: none !important;
}

/* Social wrapper reset inside the premium side card */
body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page .amsl-social-wrapper {
    width: 100% !important;
    max-width: none !important;
    margin: 18px 0 0 !important;
    padding: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page .amsl-social-login {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

/* Optional small label inside social card */
body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page .amsl-social-login:before {
    content: "Continue with one of these options:";
    display: block !important;
    margin: 0 0 14px !important;
    color: #4b5563 !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    line-height: 1.45 !important;
}

/* Keep Amasty's redundant internal titles hidden */
body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page .amsl-title,
body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page .amsl-title.-short {
    display: none !important;
}

/* Button stack inside right column */
body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page .amsl-buttons {
    display: flex !important;
    flex-direction: column !important;
    gap: 13px !important;
    width: 100% !important;
    margin: 0 !important;
}

body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page .amsl-button-wrapper {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page a.amsl-button {
    min-height: 52px !important;
    border-radius: 15px !important;
    box-shadow: 0 14px 28px rgba(18, 25, 89, .10) !important;
}

/* Add visual divider between form and social on wide screens */
@media (min-width: 1024px) {
    body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page {
        position: sticky !important;
        top: 24px !important;
    }

    body.cg-checkout-account-flow.customer-account-create .column.main > .block-new-customer {
        position: relative !important;
    }

    body.cg-checkout-account-flow.customer-account-create .column.main > .block-new-customer:after {
        content: "";
        position: absolute;
        top: 22px;
        right: -17px;
        width: 1px;
        height: calc(100% - 44px);
        background: linear-gradient(
            180deg,
            transparent 0%,
            rgba(39, 49, 140, .12) 18%,
            rgba(193, 160, 103, .24) 50%,
            rgba(39, 49, 140, .12) 82%,
            transparent 100%
        );
        pointer-events: none;
    }
}

/* Tablet/mobile: stack form first, social second */
@media (max-width: 1023px) {
    body.cg-checkout-account-flow.customer-account-create .column.main {
        grid-template-columns: 1fr !important;
        gap: 24px !important;
        max-width: 720px !important;
    }

    body.cg-checkout-account-flow.customer-account-create .column.main > .cg-checkout-intent {
        grid-column: 1 !important;
        grid-row: 1 !important;
    }

    body.cg-checkout-account-flow.customer-account-create .column.main > .block-new-customer {
        grid-column: 1 !important;
        grid-row: 2 !important;
    }

    body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page {
        grid-column: 1 !important;
        grid-row: 3 !important;
        position: static !important;
    }

    body.cg-checkout-account-flow.customer-account-create .column.main > .block-new-customer:after {
        display: none !important;
    }
}

@media (max-width: 540px) {
    body.cg-checkout-account-flow.customer-account-create .column.main {
        gap: 18px !important;
    }

    body.cg-checkout-account-flow.customer-account-create .column.main > .block-new-customer .form-create-account,
    body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page {
        padding: 22px !important;
        border-radius: 20px !important;
    }

    body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page:before {
        font-size: 21px !important;
    }
}


/* ==========================================================
   Final premium OR divider polish
   Scope: checkout create-account page only
   Change: lower social card + add premium OR badge on divider
   ========================================================== */

@media (min-width: 1024px) {
    body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page {
        margin-top: 58px !important;
        top: 82px !important;
    }

    body.cg-checkout-account-flow.customer-account-create .column.main > .block-new-customer {
        position: relative !important;
    }

    body.cg-checkout-account-flow.customer-account-create .column.main > .block-new-customer:after {
        content: "";
        position: absolute;
        top: 24px;
        right: -17px;
        width: 1px;
        height: calc(100% - 48px);
        background: linear-gradient(
            180deg,
            transparent 0%,
            rgba(39, 49, 140, .10) 10%,
            rgba(193, 160, 103, .34) 42%,
            rgba(193, 160, 103, .48) 50%,
            rgba(193, 160, 103, .34) 58%,
            rgba(39, 49, 140, .10) 90%,
            transparent 100%
        );
        pointer-events: none;
        z-index: 1;
    }

    body.cg-checkout-account-flow.customer-account-create .column.main > .block-new-customer:before {
        content: "OR";
        position: absolute;
        top: 232px;
        left: calc(100% + 17px);
        transform: translate(-50%, -50%);
        display: flex;
        align-items: center;
        justify-content: center;
        width: 58px;
        height: 58px;
        border: 1px solid rgba(193, 160, 103, .55);
        border-radius: 999px;
        background:
            radial-gradient(circle at 32% 20%, rgba(255, 255, 255, 1) 0%, rgba(255, 250, 241, 1) 48%, rgba(245, 235, 216, 1) 100%);
        color: #27318c;
        font-size: 12px;
        font-weight: 950;
        line-height: 1;
        letter-spacing: .18em;
        text-indent: .18em;
        box-shadow:
            0 18px 38px rgba(18, 25, 89, .14),
            0 0 0 8px rgba(255, 255, 255, .88),
            0 0 0 9px rgba(193, 160, 103, .12),
            inset 0 1px 0 rgba(255, 255, 255, .95);
        z-index: 4;
        pointer-events: none;
    }
}

@media (max-width: 1023px) {
    body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page {
        margin-top: 0 !important;
    }

    body.cg-checkout-account-flow.customer-account-create .column.main > .block-new-customer:before {
        display: none !important;
    }
}


/* ==========================================================
   Final alignment tweak only
   Scope: checkout create-account page only
   Change: vertically center social card + OR badge to form middle
   ========================================================== */

@media (min-width: 1024px) {
    body.cg-checkout-account-flow.customer-account-create .column.main > .amsl-registration-page {
        align-self: center !important;
        margin-top: 0 !important;
        top: 24px !important;
    }

    body.cg-checkout-account-flow.customer-account-create .column.main > .block-new-customer:before {
        top: 50% !important;
        transform: translate(-50%, -50%) !important;
    }

    body.cg-checkout-account-flow.customer-account-create .column.main > .block-new-customer:after {
        top: 24px !important;
        height: calc(100% - 48px) !important;
    }
}
