/**
 * Belle Nove Affiliate System — login + forgot-password ([bas_affiliate_login]).
 *
 * Premium beauty aesthetic, self-contained (works with or without the theme
 * tokens). Mobile-first, framework-free.
 */

.bas-login {
	--bas-gold: var(--be-gold, #c47189);
	--bas-gold-dark: var(--be-gold-dark, #8b3e57);
	--bas-cream: var(--be-cream, #fce5e3);
	--bas-bg: var(--be-bg, #fdf6f3);
	--bas-ink: var(--be-ink, #2a1820);
	--bas-muted: var(--be-muted, #8a6c75);
	--bas-line: var(--be-line, #f1dee2);
	--bas-surface: var(--be-surface, #fff);
	--bas-serif: var(--be-serif, "Cormorant Garamond", Georgia, serif);
	--bas-sans: var(--be-sans, "Montserrat", -apple-system, "Segoe UI", sans-serif);
	--bas-radius: var(--be-radius-lg, 14px);
	--bas-shadow: var(--be-shadow-lg, 0 24px 64px rgba(42, 24, 32, 0.12));

	font-family: var(--bas-sans);
	color: var(--bas-ink);
	max-width: 940px;
	margin: clamp(1.5rem, 5vw, 3.5rem) auto;
	padding-inline: clamp(1rem, 4vw, 1.5rem);
	box-sizing: border-box;
}
.bas-login *, .bas-login *::before, .bas-login *::after { box-sizing: border-box; }

.bas-login__card {
	display: grid;
	grid-template-columns: 1fr;
	background: var(--bas-surface);
	border: 1px solid var(--bas-line);
	border-radius: var(--bas-radius);
	overflow: hidden;
	box-shadow: var(--bas-shadow);
}
@media (min-width: 820px) {
	.bas-login__card { grid-template-columns: 1fr 1fr; }
	.bas-login__card--narrow { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; }
}

/* Aside */
.bas-login__aside {
	position: relative; overflow: hidden; color: #fff;
	background: linear-gradient(150deg, var(--bas-gold-dark) 0%, var(--bas-gold) 55%, #d4889d 100%);
	padding: clamp(2rem, 5vw, 3.25rem);
	display: flex; align-items: center;
}
.bas-login__aside::before {
	content: ""; position: absolute; inset: 0; pointer-events: none;
	background:
		radial-gradient(45% 40% at 80% 15%, rgba(255, 255, 255, .25) 0%, transparent 60%),
		radial-gradient(50% 45% at 10% 95%, rgba(26, 14, 20, .22) 0%, transparent 60%);
}
.bas-login__aside-inner { position: relative; z-index: 1; }
.bas-login__eyebrow { margin: 0 0 1rem; font-size: .7rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: rgba(255, 255, 255, .85); }
.bas-login__aside-title { font-family: var(--bas-serif); font-weight: 500; font-size: clamp(1.7rem, 3.4vw, 2.5rem); line-height: 1.1; margin: 0 0 1rem; }
.bas-login__aside-text { color: rgba(255, 255, 255, .9); line-height: 1.6; font-size: .95rem; margin: 0; }

/* Main */
.bas-login__main { padding: clamp(1.75rem, 4vw, 3rem); }
.bas-login__title { font-family: var(--bas-serif); font-weight: 500; font-size: clamp(1.6rem, 4vw, 2.3rem); line-height: 1.1; margin: 0 0 .4rem; color: var(--bas-ink); }
.bas-login__sub { margin: 0 0 1.5rem; color: var(--bas-muted); font-size: .95rem; }

/* Alerts */
.bas-login__alert { border-radius: 10px; padding: .85rem 1.05rem; margin-bottom: 1.25rem; font-size: .9rem; }
.bas-login__alert--error { background: #fbe4e8; border: 1px solid #f3b8c4; color: #8c1d33; }
.bas-login__alert--ok { background: #e4f4ea; border: 1px solid #b6e0c6; color: #1c6b3a; }

/* Fields (shared shape with signup) */
.bas-login .bas-field { margin-bottom: 1.15rem; }
.bas-login .bas-field > label { display: block; font-size: .8rem; font-weight: 600; color: var(--bas-ink); margin-bottom: .4rem; }
.bas-login .bas-field input[type="email"],
.bas-login .bas-field input[type="password"],
.bas-login .bas-field input[type="text"] {
	width: 100%; font-family: var(--bas-sans); font-size: .95rem; color: var(--bas-ink);
	background: var(--bas-bg); border: 1px solid var(--bas-line); border-radius: 10px; padding: .8rem .95rem;
	transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.bas-login .bas-field input:focus { outline: none; background: #fff; border-color: var(--bas-gold); box-shadow: 0 0 0 3px rgba(196, 113, 137, .15); }
.bas-login .bas-field.has-error input { border-color: #e0607a; background: #fdf2f4; }
.bas-login .bas-field__err { display: none; margin-top: .35rem; font-size: .78rem; color: #c0314b; }
.bas-login .bas-field.has-error .bas-field__err { display: block; }

.bas-input-wrap { position: relative; }
.bas-input-wrap input { padding-right: 2.85rem !important; }
.bas-login__toggle {
	position: absolute; right: .5rem; top: 50%; transform: translateY(-50%);
	display: inline-flex; align-items: center; justify-content: center; width: 2rem; height: 2rem;
	background: none; border: 0; cursor: pointer; color: var(--bas-muted); border-radius: 8px;
	transition: color .2s ease, background .2s ease;
}
.bas-login__toggle:hover { color: var(--bas-gold-dark); background: var(--bas-cream); }
.bas-login__toggle.is-on { color: var(--bas-gold-dark); }

/* Row: remember + forgot */
.bas-login__row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.bas-login__remember { display: inline-flex; align-items: center; gap: .5rem; font-size: .88rem; color: var(--bas-ink); cursor: pointer; }
.bas-login__remember input { accent-color: var(--bas-gold); }
.bas-login__forgot { font-size: .85rem; color: var(--bas-gold-dark); font-weight: 600; }

/* Submit */
.bas-login__submit {
	display: inline-flex; align-items: center; justify-content: center; width: 100%;
	font-family: var(--bas-sans); font-size: .82rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
	color: #fff; background: var(--bas-gold); border: 1px solid var(--bas-gold); border-radius: 999px;
	padding: 1rem 1.5rem; cursor: pointer; text-decoration: none;
	transition: background .25s ease, border-color .25s ease, transform .2s ease;
}
.bas-login__submit:hover { background: var(--bas-gold-dark); border-color: var(--bas-gold-dark); color: #fff; transform: translateY(-1px); }

.bas-login__alt { text-align: center; margin: 1.25rem 0 0; font-size: .88rem; color: var(--bas-muted); }
.bas-login__alt a { color: var(--bas-gold-dark); font-weight: 600; }
