:root {
	/* colors */
	--rillion-green: #0F3732;
	--white: #FFFFFF;
	--text-danger: #C3250B;
	--input-border-danger: #EF3213;
	--bg: var(--white);
	--ink: #424242;
	--muted: #6b7280;
	--green: var(--rillion-green);
	--btn-hover: #14695a;
	--btn-focus: #2ab7a9;
	--border: var(--white);
	--primary-color: #62985d;
	--input-border: rgba(0, 0, 0, .12);
	--input-bg: #F0F0F070;
	--select-bg-hover: #f3f4f6;
	--select-bg-selected: #D4F3EA;
	--title: var(--rillion-green);
	--radius: 6px;

	/* Size variables (like Tailwind) */
	--size-1: 0.25rem; /* 4px */
	--size-2: 0.5rem; /* 8px */
	--size-3: 0.75rem; /* 12px */
	--size-4: 1rem; /* 16px */
	--size-5: 1.25rem; /* 20px */
	--size-6: 1.5rem; /* 24px */
	--size-8: 2rem; /* 32px */
	--size-10: 2.5rem; /* 40px */
	--size-12: 3rem; /* 48px */


	/* Button colors */
	--btn-border-color: var(--rillion-green);

	/* other */
	--max-width-panel: 500px;
}

html, body {
	height: 100%;
	margin: 0;
	padding: 0;
	background: var(--bg); /* eliminate gray band at bottom */
	font-family: 'Open Sans', ui-sans-serif, sans-serif, -apple-system, Segoe UI, Roboto !important;
}

* {
	box-sizing: border-box;
}

body {
	color: var(--ink);
}

.page, main {
	min-height: 100vh;
	background: var(--bg);
}

/* Layout:
   [vit bakgrund] [centrerad panel med maxbredd] [bild som fyller resten] */
.page {
	display: grid;
	grid-template-columns: 1fr 1fr;
}

/* Bilden ligger i högra kolumnen och får ta all plats där */
.imageContainer {
	position: relative;
	background: #eee url("../images/loginpage/hero_image.jpg?q=80&w=800&auto=format") no-repeat center;
	background-size: cover;
	height: 100%;
	width: 100%;
}

/* “rillion”-märke över bilden */
.brand {
	position: absolute;
	top: 50px;
	left: 50px;
	display: flex;
	gap: var(--size-3);
	flex-direction: column;
	filter: drop-shadow(0 4px 10px rgba(0, 0, 0, 0.35)) drop-shadow(0 2px 4px rgba(0, 0, 0, 0.25));
	padding: var(--size-3);
}

.brand .logo {
	width: 124px;
	height: 44px;
	background-image: url('../images/rillion/logos/rillion_logo_lime.svg');
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	display: inline-block;
}

.brand .whiteLabelLogo {
	width: 250px;
	height: 100px;
}

/* Panelen ligger i mittenkolumnen och är alltid centrerad */
.panel {
	display: grid;
	grid-template-rows: 1fr auto;
	justify-items: center;
	align-items: center;
	height: 100vh;
	width: 100%;
	background: white;
	overflow-y: auto;
	overflow-x: hidden;
	min-width: var(--max-width-panel);
}

/* make sure the signInPanel doesn't stretch too wide */
.panel .loginPanel {
	width: var(--max-width-panel);
}

.card {
	margin: var(--size-4) 0;
	padding: 0 var(--size-12);
	width: var(--max-width-panel);
}

.card .card-title {
	display: flex;
	flex-direction: column;
	font-size: 45px;
	line-height: 1.5;
	text-align: center;
	font-weight: 700;
	color: var(--title);
	margin-bottom: var(--size-4);
}

.card .logo {
	height: 65px;
	background-image: url('../images/rillion/logos/rillion_logo_green.svg');
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	width: 100%;
	margin-bottom: var(--size-6);
	display: none;
}

/* Form */
.form-login {
	display: flex;
	flex-direction: column;
	gap: var(--size-3)
}

.form-label {
	display: block;
	font-size: 14px;
	margin-bottom: var(--size-2);
}

.req::after {
	content: "*";
	color: var(--text-danger);
}

.is-invalid {
	border: 1px solid var(--input-border-danger) !important;
}

input.is-invalid:focus {
	border: 1px solid var(--input-border-danger) !important;
	box-shadow: 0 0 0 1px var(--input-border-danger) !important;
}

input[type="text"],
input[type="password"],
select {
	width: 100%;
	height: 44px;
	padding: 10px var(--size-3);
	border-radius: var(--radius);
	border: 1px solid var(--input-border);
	font-size: 16px;
	background: var(--input-bg);
	outline: none;
	transition: box-shadow .15s, border-color .15s;
}

select {
	background: var(--white);
}

input[type="text"]:focus,
input[type="password"]:focus,
select:focus {
	border: 1px solid var(--primary-color);
	box-shadow: 0 0 0 1px var(--primary-color);
}

input[type="radio"],
input[type="checkbox"] {
	accent-color: var(--rillion-green);
}

.field-error {
	color: var(--text-danger);
	font-size: 14px;
	margin-top: 2px;
}

input[type="text"].field-error:focus,
input[type="password"].field-error:focus {
	border: 1px solid var(--input-border-danger);
	box-shadow: 0 0 0 1px var(--input-border-danger);
}

.field-error.wrapper {
	margin: var(--size-6) 0 var(--size-4);
	padding: 0;
}

.field-error ul.feedbackPanel {
	list-style: none;
	margin: 0;
	padding: 0;
}

.field-error ul.feedbackPanel li.feedbackPanelERROR {
	list-style: none;
	margin: var(--size-2) var(--size-2) 0;
	text-align: left;
}

.row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--size-3);
	margin: 10px 0 18px;
	font-size: 14px;
	color: var(--muted);
}

.row a {
	color: var(--muted);
	text-decoration: none;
}

.row a:focus,
.row a:hover {
	text-decoration: underline;
	outline: none;
}

/* Buttons */
.btn {
	width: 100%;
	height: 44px;
	border: 0;
	border-radius: var(--radius);
	font-weight: 700;
	font-size: 14px;
	cursor: pointer;
	transition: transform .02s ease-in, background .15s, box-shadow .15s;
	font-family: 'Open Sans', ui-sans-serif, sans-serif, -apple-system, Segoe UI, Roboto !important;
}

.btn:focus-visible {
	outline: none;
	box-shadow: none;
}

.btn:active {
	transform: translateY(1px);
}

.btn-primary {
	background: var(--green);
	color: #fff;
	box-shadow: inset 0 -2px 0 rgba(0, 0, 0, .15);
}

.btn-primary:focus{
	background: var(--btn-focus);
}
.btn-primary:hover {
	background: var(--btn-hover);
}

.btn-ghost {
	background: #fff;
	color: var(--green);
	border: 1px solid var(--btn-border-color);
}

.btn-ghost:focus,
.btn-ghost:hover {
	background: #eaf2ef;
}

/* Language */
.select-wrap {
	width: 100%;
}

.select-box {
	position: relative;
	display: block;
	width: 100%;
	background: transparent;
}

.select-box option:checked {
	background: var(--select-bg-selected);
}


.select-box::after {
	content: "";
	position: absolute;
	right: 12px;
	top: 50%;
	width: 0;
	height: 0;
	pointer-events: none;
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 7px solid var(--green, #333);
	transform: translateY(-50%);
}

.select-box select {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	padding-right: 34px;
	border-radius: 6px;
	border: 1px solid var(--input-border);
	font-weight: normal;
	color: var(--ink);
	font-family: 'Open Sans', ui-sans-serif, sans-serif, -apple-system, Segoe UI, Roboto !important;
}

.select-box select:focus {
	border: 1px solid var(--primary-color) !important;
	box-shadow: 0 0 0 1px var(--primary-color) !important;
}

/* Style for select options with checkmark */
.select-box option {
	padding: 10px 30px 10px 10px;
	background: #fff;
	color: var(--ink);
	font-weight: normal;
}

.select-box option:checked {
	background: var(--select-bg-selected);
	font-weight: 600;
	position: relative;
}

.login-OR-text {
	text-transform: uppercase;
	text-align: center;
	font-size: 14px;
	font-weight: bold;
	color: var(--muted);
	margin: 0;
}

.choose-lang-wrap {
	width: 100%;
}

.intuitLoginButton {
	height: 37px;
	background: no-repeat url('../images/quickbooks/Sign_in_transparent_btn_med_default.png');
	cursor: pointer;
	width: 161px;
}

.intuitLoginButton:hover {
	background: no-repeat url('../images/quickbooks/Sign_in_transparent_btn_med_hover.png');
}

.adLogin {
	width: 100%;
}

.adLoginButton {
	background: url('../images/ad_login.png') no-repeat center center;
	background-size: 55%;
	height: 40px;
	transition: filter 0.2s ease;
}

.adLoginButton:hover {
	background: url('../images/ad_login.png') no-repeat center center;
	background-size: 55%;
	cursor: pointer;
	filter: brightness(0.85);
}

.extra-setting-container {
	margin: 0 50px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--size-3);
}

.alternative-login-methods {
	margin-top: var(--size-3);
	display: flex;
	flex-direction: column;
	gap: var(--size-3);
	width: 100%;
	align-items: center;
}

.mobil-container {
	display: none;
	width: 100%;
	text-align: center;
}

.mobil-container label:first-of-type {
	margin-right: var(--size-4);
}

#submitComponentContainer {
	width: 100%;
}

.footer {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: var(--size-2) var(--size-6);
	color: var(--muted);
	font-size: 14px;
	margin-bottom: var(--size-4);
}

.footer > div {
	display: flex;
	gap: var(--size-2);
	flex: 0 1 auto;
	white-space: nowrap;
	min-width: 0;
}

.footer a {
	color: inherit;
}

.footer a:focus {
	font-weight: bold;
	text-decoration: underline;
	outline: none;
}

.footer .version-and-date {
	display: block;
}

/* Hidde Image because logo should not float out over login panel */
@media (min-width: 835px) and (max-width: 900px) {
	.page {
		grid-template-columns: 1fr;
	}

	.imageContainer {
		display: none; /* bilden försvinner */
	}

	.panel {
		grid-column: 1 / -1;
		padding: 0 var(--size-6);
	}

	.card .card-title {
		font-size: 24px;
		display: flex;
		flex-direction: row;
		gap: var(--size-2);
		justify-content: center;
		flex-wrap: wrap;
	}

	.card .logo {
		display: inline-flex;
	}
}

/* MOBIL */
@media (max-width: 834px) {
	.page {
		grid-template-columns: 1fr;
	}

	.imageContainer {
		display: none;
	}

	.mobil-container {
		display: block;
		width: 100%;
	}

	.panel {
		min-width: unset;
	}

	.panel .loginPanel {
		width: 100%;
		max-width: var(--max-width-panel);
	}

	.card {
		width: 100%;
	}

	.card .logo {
		display: inline-flex;
	}

	.alternative-login-methods {
		display: none;
	}

	.choose-lang-wrap {
		margin: var(--size-3);
	}

	.card .card-title {
		font-size: 24px;
		display: flex;
		flex-direction: row;
		gap: var(--size-2);
		justify-content: center;
		flex-wrap: wrap;
	}

	.extra-setting-container {
		margin: 0 var(--size-5);
	}

	.footer .version-and-date {
		display: none;
	}
}


/* WIDE */
@media (min-width: 2566px) {
	.page {
		grid-template-columns: 2fr 3fr;
	}
}