/**

 * IL Privacy Banner Styles

 * RTL/LTR ready, accessible, compact, multilingual

 */



/* Banner container */

.il-privacy-banner {

	position: fixed;

	bottom: 20px;

	max-width: 400px;

	background: #fff;

	border-radius: 8px;

	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);

	padding: 16px;

	z-index: 999999;

	font-family: "Rubik", -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;

	font-size: 13px;

	line-height: 1.4;

}



/* RTL support */

.il-privacy-banner[dir="rtl"],

html[dir="rtl"] .il-privacy-banner {

	direction: rtl;

	text-align: right;

	border-right: 4px solid var(--il-primary-color, #0073aa);

	border-left: none;

}



/* LTR support */

.il-privacy-banner[dir="ltr"],

html[dir="ltr"] .il-privacy-banner {

	direction: ltr;

	text-align: left;

	border-left: 4px solid var(--il-primary-color, #0073aa);

	border-right: none;

}



.il-privacy-banner[data-position="left"] {

	left: 20px;

}



.il-privacy-banner[data-position="right"] {

	right: 20px;

}



.il-privacy-banner[data-position="center"] {

	left: 50%;

	transform: translateX(-50%);

}



/* Banner content */

.il-privacy-banner__title {

	margin: 0 0 8px 0;

	font-size: 16px;

	font-weight: 600;

	color: #1a1a1a;

}



.il-privacy-banner__text {

	margin: 0 0 12px 0;

	color: #666;

	font-size: 14px;

}



.il-privacy-banner__text a {

	color: #0073aa;

	text-decoration: underline;

}



/* Buttons */

.il-privacy-banner__buttons {

	display: flex;

	flex-direction: row;

	flex-wrap: wrap;

	gap: 8px;

}



.il-privacy-banner__button {

	padding: 10px 16px;

	border: 1px solid #244368;

	border-radius: 3px;

	font-size: 14px;

	font-weight: 500;

	cursor: pointer;

	transition: all 0.2s ease;

	text-align: center;

	flex-grow: 1;

	background: transparent;

	color: #244368;

}



.il-privacy-banner__button:hover,

.il-privacy-banner__button:focus {

	color: white;

	background: #244368;

	outline: 2px solid #244368;

	outline-offset: 2px;

}



.il-privacy-banner__button--primary {

	background: var(--il-primary-color, #0073aa);

	color: #fff;

	border-color: var(--il-primary-color, #0073aa);

}



.il-privacy-banner__button--primary:hover,

.il-privacy-banner__button--primary:focus {

	background: var(--il-primary-color-hover, #005a87);

	border-color: var(--il-primary-color-hover, #005a87);

	outline: 2px solid var(--il-primary-color, #0073aa);

	outline-offset: 2px;

}



.il-privacy-banner__button--secondary {

	background: #f0f0f0;

	color: #244368;

	border: 1px solid #244368;

}



.il-privacy-banner__button--secondary:hover,

.il-privacy-banner__button--secondary:focus {

	color: white;

	background: #244368;

	outline: 2px solid #244368;

	outline-offset: 2px;

}



.il-privacy-banner__button--link {

	background: transparent;

	color: #244368;

	border: 1px solid #244368;

	text-decoration: none;

	padding: 10px 16px;

}



.il-privacy-banner__button--link:hover,

.il-privacy-banner__button--link:focus {

	color: white;

	background: #244368;

	outline: 2px solid #244368;

	outline-offset: 2px;

}



/* Modal */

.il-privacy-modal {

	position: fixed;

	top: 0;

	left: 0;

	width: 100%;

	height: 100%;

	background: rgba(0, 0, 0, 0.5);

	z-index: 1000000;

	display: flex;

	align-items: center;

	justify-content: center;

	padding: 20px;

}



.il-privacy-modal__content {

	background: #fff;

	border-radius: 8px;

	max-width: 600px;

	width: 100%;

	max-height: 80vh;

	overflow-y: auto;

	padding: 32px;

	position: relative;

}



/* RTL support for modal */

.il-privacy-modal[dir="rtl"] .il-privacy-modal__content,

html[dir="rtl"] .il-privacy-modal__content {

	direction: rtl;

	text-align: right;

}



/* LTR support for modal */

.il-privacy-modal[dir="ltr"] .il-privacy-modal__content,

html[dir="ltr"] .il-privacy-modal__content {

	direction: ltr;

	text-align: left;

}



.il-privacy-modal__header {

	display: flex;

	justify-content: space-between;

	align-items: center;

	margin-bottom: 24px;

	padding-bottom: 16px;

	border-bottom: 1px solid #e0e0e0;

}



.il-privacy-modal__title {

	margin: 0;

	font-size: 24px;

	font-weight: 600;

	color: #1a1a1a;

}



.il-privacy-modal__close {

	background: transparent;

	border: none;

	font-size: 24px;

	cursor: pointer;

	padding: 0;

	width: 32px;

	height: 32px;

	display: flex;

	align-items: center;

	justify-content: center;

	border-radius: 4px;

	color: #666;

}



.il-privacy-modal__close:hover,

.il-privacy-modal__close:focus {

	background: #f0f0f0;

	color: #000;

	outline: 2px solid #0073aa;

}



/* Categories */

.il-privacy-category {

	margin-bottom: 20px;

	padding: 16px;

	border: 1px solid #e0e0e0;

	border-radius: 4px;

}



.il-privacy-category__header {

	display: flex;

	justify-content: space-between;

	align-items: center;

	margin-bottom: 8px;

}



.il-privacy-category__label {

	font-weight: 600;

	color: #1a1a1a;

	margin: 0;

}



.il-privacy-category__description {

	color: #666;

	font-size: 13px;

	margin: 0;

}



/* Toggle switch */

.il-privacy-toggle {

	position: relative;

	display: inline-block;

	width: 48px;

	height: 24px;

}



.il-privacy-toggle input {

	opacity: 0;

	width: 0;

	height: 0;

}



.il-privacy-toggle__slider {

	position: absolute;

	cursor: pointer;

	top: 0;

	left: 0;

	right: 0;

	bottom: 0;

	background-color: #ccc;

	transition: 0.3s;

	border-radius: 24px;

}



.il-privacy-toggle__slider:before {

	position: absolute;

	content: "";

	height: 18px;

	width: 18px;

	left: 3px;

	bottom: 3px;

	background-color: white;

	transition: 0.3s;

	border-radius: 50%;

}



.il-privacy-toggle input:checked + .il-privacy-toggle__slider {

	background-color: var(--il-primary-color, #0073aa);

}



.il-privacy-toggle input:checked + .il-privacy-toggle__slider:before {

	transform: translateX(24px);

}



.il-privacy-toggle input:disabled + .il-privacy-toggle__slider {

	opacity: 0.5;

	cursor: not-allowed;

}



.il-privacy-toggle input:focus + .il-privacy-toggle__slider {

	outline: 2px solid var(--il-primary-color, #0073aa);

	outline-offset: 2px;

}



/* Footer link */

.il-privacy-footer-link {

	position: fixed;

	bottom: 10px;

	z-index: 999998;

}



/* RTL: footer link on right */

html[dir="rtl"] .il-privacy-footer-link {

	right: 10px;

	left: auto;

}



/* LTR: footer link on left */

html[dir="ltr"] .il-privacy-footer-link {

	left: 10px;

	right: auto;

}



.il-privacy-footer-link a {

	font-size: 12px;

	color: #666;

	text-decoration: underline;

	background: rgba(255, 255, 255, 0.9);

	padding: 6px 12px;

	border-radius: 4px;

	display: inline-block;

}



.il-privacy-footer-link a:hover,

.il-privacy-footer-link a:focus {

	color: #333;

	background: rgba(255, 255, 255, 1);

	outline: 2px solid #0073aa;

}



/* Mobile responsive */

@media (max-width: 768px) {

	.il-privacy-banner {

		left: 10px !important;

		right: 10px !important;

		bottom: 10px;

		max-width: none;

		transform: none !important;

	}



	.il-privacy-modal__content {

		padding: 20px;

		max-height: 90vh;

	}



	.il-privacy-modal__title {

		font-size: 20px;

	}

}



/* Accessibility - high contrast mode */

@media (prefers-contrast: high) {

	.il-privacy-banner,

	.il-privacy-modal__content {

		border: 2px solid #000;

	}



	.il-privacy-banner__button--primary {

		border: 2px solid #000;

	}

}



/* Reduced motion */

@media (prefers-reduced-motion: reduce) {

	.il-privacy-banner,

	.il-privacy-banner__button,

	.il-privacy-toggle__slider,

	.il-privacy-toggle__slider:before {

		transition: none;

	}

}



/* Print - hide banner */

@media print {

	.il-privacy-banner,

	.il-privacy-modal,

	.il-privacy-footer-link {

		display: none !important;

	}

}



