/**
 * PrivacyTech CMP – Banner Styles
 * WCAG 2.1 AA compliant, responsive, themeable via CSS custom properties.
 *
 * Copyright (C) 2024 Alessandro Fiorentino – GPL v3 or later
 */

/* ============================================================
   CSS CUSTOM PROPERTIES (overridable per admin settings)
   ============================================================ */
:root {
	--ptcmp-primary:       #1a73e8;
	--ptcmp-primary-dark:  #1557b0;
	--ptcmp-secondary:     #5f6368;
	--ptcmp-bg:            #ffffff;
	--ptcmp-text:          #202124;
	--ptcmp-border:        #dadce0;
	--ptcmp-shadow:        0 4px 24px rgba(0,0,0,.14), 0 2px 8px rgba(0,0,0,.08);
	--ptcmp-radius:        12px;
	--ptcmp-radius-sm:     6px;
	--ptcmp-font:          -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
	--ptcmp-z:             999999;
	--ptcmp-transition:    220ms cubic-bezier(.4,0,.2,1);
	--ptcmp-toggle-size:   24px;
	--ptcmp-focus-ring:    0 0 0 3px rgba(26,115,232,.35);
}

/* ============================================================
   BANNER CONTAINER
   Full isolation – prevents any theme style from bleeding in.
   ============================================================ */
#ptcmp-banner {
	/* Layout */
	position: fixed;
	z-index: var(--ptcmp-z);
	box-sizing: border-box;
	max-height: 90vh;
	overflow-y: auto;
	overscroll-behavior: contain;

	/* Background – explicit fallback + variable, both declared */
	background-color: #ffffff;
	background-color: var(--ptcmp-bg, #ffffff);
	background-image: none;

	/* Text */
	color: #202124;
	color: var(--ptcmp-text, #202124);
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
	font-family: var(--ptcmp-font);
	font-size: 14px;
	line-height: 1.5;
	font-weight: 400;
	letter-spacing: normal;
	text-align: left;
	text-transform: none;

	/* Decoration */
	box-shadow: var(--ptcmp-shadow);
	border: none;
	outline: none;
	padding: 0;
	margin: 0;

	/* Animation */
	transition: transform var(--ptcmp-transition), opacity var(--ptcmp-transition);
}

/* Force correct background on inner views so theme div{background}
   rules cannot bleed through */
#ptcmp-banner .ptcmp-view-main,
#ptcmp-banner .ptcmp-view-preferences {
	background-color: #ffffff;
	background-color: var(--ptcmp-bg, #ffffff);
	background-image: none;
	color: #202124;
	color: var(--ptcmp-text, #202124);
}

/* box-sizing reset for all children */
#ptcmp-banner *,
#ptcmp-banner *::before,
#ptcmp-banner *::after {
	box-sizing: border-box;
}

/* Reset p/h/list margins that themes often set */
#ptcmp-banner p,
#ptcmp-banner h2,
#ptcmp-banner ul,
#ptcmp-banner li {
	margin: 0;
	padding: 0;
}

#ptcmp-banner a {
	color: var(--ptcmp-primary, #1a73e8);
}

#ptcmp-banner[hidden] {
	display: none !important;
}

/* Positions */
.ptcmp-position-bottom {
	bottom: 0;
	left: 0;
	right: 0;
	border-radius: var(--ptcmp-radius) var(--ptcmp-radius) 0 0;
}

.ptcmp-position-top {
	top: 0;
	left: 0;
	right: 0;
	border-radius: 0 0 var(--ptcmp-radius) var(--ptcmp-radius);
}

.ptcmp-position-center {
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	max-width: 640px;
	width: calc(100% - 32px);
	border-radius: var(--ptcmp-radius);
}

/* Overlay for center layout */
.ptcmp-position-center::before {
	content: '';
	position: fixed;
	inset: 0;
	background: rgba(0,0,0,.45);
	z-index: -1;
}

/* Layouts */
.ptcmp-layout-bar .ptcmp-view-main {
	display: flex;
	align-items: center;
	gap: 20px;
	padding: 16px 24px;
	flex-wrap: wrap;
}

.ptcmp-layout-bar .ptcmp-banner-content {
	flex: 1;
	min-width: 240px;
}

.ptcmp-layout-bar .ptcmp-banner-actions {
	display: flex;
	gap: 8px;
	flex-shrink: 0;
}

.ptcmp-layout-box .ptcmp-view-main {
	padding: 28px 32px;
	max-width: 560px;
	margin: 0 auto;
}

.ptcmp-layout-box .ptcmp-banner-actions {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	margin-top: 20px;
}

/* ============================================================
   BANNER HEADER
   ============================================================ */
.ptcmp-banner-header {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 8px;
	flex-wrap: wrap;
}

/* Site logo inside the banner */
.ptcmp-site-logo {
	display: block;
	max-height: 48px;
	width: auto;
	height: auto;
	object-fit: contain;
	flex-shrink: 0;
	/* No filter – show logo in its original colours */
}

/* When a logo is present, push the title to a new line on small screens */
@media (max-width: 480px) {
	.ptcmp-site-logo {
		max-height: 36px;
	}
}

.ptcmp-logo {
	font-size: 20px;
	flex-shrink: 0;
}

.ptcmp-banner-title {
	font-size: 16px;
	font-weight: 600;
	margin: 0;
	color: var(--ptcmp-text);
	line-height: 1.3;
}

.ptcmp-banner-desc {
	font-size: 13px;
	color: #5f6368;
	margin: 0;
}

.ptcmp-legal-links {
	margin-top: 6px;
	font-size: 12px;
}

.ptcmp-legal-links a {
	color: var(--ptcmp-primary);
	text-decoration: underline;
	margin-right: 12px;
}

.ptcmp-legal-links a:hover {
	text-decoration: none;
}

.ptcmp-powered-by {
	margin-top: 12px;
	font-size: 11px;
	color: #9aa0a6;
	text-align: right;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.ptcmp-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 9px 18px;
	border-radius: var(--ptcmp-radius-sm);
	font-family: var(--ptcmp-font);
	font-size: 13px;
	font-weight: 500;
	line-height: 1;
	cursor: pointer;
	border: 2px solid transparent;
	transition: background var(--ptcmp-transition), color var(--ptcmp-transition), border-color var(--ptcmp-transition), box-shadow var(--ptcmp-transition);
	white-space: nowrap;
	text-decoration: none;
}

.ptcmp-btn:focus-visible {
	outline: none;
	box-shadow: var(--ptcmp-focus-ring);
}

.ptcmp-btn-primary {
	background: var(--ptcmp-primary);
	color: #fff;
	border-color: var(--ptcmp-primary);
}

.ptcmp-btn-primary:hover {
	background: var(--ptcmp-primary-dark);
	border-color: var(--ptcmp-primary-dark);
}

/* Principle 4: reject must be as prominent as accept */
.ptcmp-btn-secondary {
	background: transparent;
	color: var(--ptcmp-text);
	border-color: var(--ptcmp-border);
}

.ptcmp-btn-secondary:hover {
	background: #f1f3f4;
}

.ptcmp-btn-outline {
	background: transparent;
	color: var(--ptcmp-primary);
	border-color: var(--ptcmp-primary);
}

.ptcmp-btn-outline:hover {
	background: rgba(26,115,232,.06);
}

.ptcmp-btn-back {
	background: none;
	border: none;
	color: var(--ptcmp-primary);
	font-size: 13px;
	cursor: pointer;
	padding: 4px 0;
	font-family: var(--ptcmp-font);
}

.ptcmp-btn-back:focus-visible {
	outline: none;
	box-shadow: var(--ptcmp-focus-ring);
	border-radius: 2px;
}

/* ============================================================
   PREFERENCES VIEW
   ============================================================ */
.ptcmp-view-preferences {
	padding: 24px;
	max-width: 700px;
	margin: 0 auto;
}

.ptcmp-prefs-header {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 20px;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--ptcmp-border);
}

.ptcmp-prefs-title {
	font-size: 18px;
	font-weight: 600;
	margin: 0;
	color: var(--ptcmp-text);
}

/* ============================================================
   CATEGORIES
   ============================================================ */
.ptcmp-categories {
	display: flex;
	flex-direction: column;
	gap: 12px;
	margin-bottom: 24px;
}

.ptcmp-category {
	border: 1px solid var(--ptcmp-border);
	border-radius: var(--ptcmp-radius-sm);
	padding: 16px;
	transition: border-color var(--ptcmp-transition);
}

.ptcmp-category:focus-within {
	border-color: var(--ptcmp-primary);
}

.ptcmp-category-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}

.ptcmp-cat-info {
	display: flex;
	align-items: center;
	gap: 8px;
	flex: 1;
	min-width: 0;
}

.ptcmp-cat-name {
	font-weight: 600;
	font-size: 14px;
	color: var(--ptcmp-text);
}

.ptcmp-badge-required {
	font-size: 11px;
	font-weight: 400;
	color: #188038;
	background: #e6f4ea;
	padding: 2px 8px;
	border-radius: 100px;
}

.ptcmp-cat-desc {
	font-size: 12px;
	color: #5f6368;
	margin: 8px 0 0;
}

/* ============================================================
   TOGGLE SWITCH
   Structure: <label class="ptcmp-toggle-wrap">
                <input type="checkbox" class="ptcmp-toggle-input">
                <span class="ptcmp-toggle-switch"></span>
              </label>
   ============================================================ */
.ptcmp-toggle-wrap {
	/* label acting as the visual toggle container */
	display: inline-flex;
	align-items: center;
	flex-shrink: 0;
	position: relative;
	width: 44px;
	height: 24px;
	cursor: pointer;
}

.ptcmp-toggle-input {
	/* visually hidden but fully accessible */
	position: absolute;
	inset: 0;
	opacity: 0;
	width: 100%;
	height: 100%;
	cursor: pointer;
	margin: 0;
	z-index: 1;
}

.ptcmp-toggle-input:disabled {
	cursor: default;
}

.ptcmp-toggle-switch {
	/* the pill track */
	display: block;
	width: 44px;
	height: 24px;
	border-radius: 100px;
	background: var(--ptcmp-border, #dadce0);
	transition: background var(--ptcmp-transition);
	position: relative;
	pointer-events: none; /* clicks go to the input above */
}

.ptcmp-toggle-switch::after {
	/* the sliding knob */
	content: '';
	position: absolute;
	top: 3px;
	left: 3px;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: #fff;
	box-shadow: 0 1px 3px rgba(0,0,0,.3);
	transition: left var(--ptcmp-transition);
}

.ptcmp-toggle-input:checked + .ptcmp-toggle-switch {
	background: var(--ptcmp-primary, #1a73e8);
}

.ptcmp-toggle-input:checked + .ptcmp-toggle-switch::after {
	left: 23px;
}

.ptcmp-toggle-input:focus-visible + .ptcmp-toggle-switch {
	box-shadow: var(--ptcmp-focus-ring);
}

.ptcmp-toggle-input:disabled + .ptcmp-toggle-switch {
	background: #34a853; /* necessary = always green */
	opacity: .85;
}

/* ============================================================
   SERVICES ACCORDION
   ============================================================ */
.ptcmp-services-accordion {
	margin-top: 10px;
}

.ptcmp-services-toggle {
	/* Reset */
	background: none;
	border: none;
	padding: 5px 10px 5px 8px;
	font-family: var(--ptcmp-font);
	font-size: 12px;
	font-weight: 500;
	cursor: pointer;

	/* Style */
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: var(--ptcmp-primary, #1a73e8);
	border-radius: 4px;
	transition: background 150ms, color 150ms;
}

.ptcmp-services-toggle:hover {
	background: rgba(26, 115, 232, 0.07);
}

.ptcmp-services-toggle:focus-visible {
	outline: none;
	box-shadow: var(--ptcmp-focus-ring);
}

/* Chevron icon via ::after pseudo-element */
.ptcmp-services-toggle::before {
	content: '';
	display: inline-block;
	width: 14px;
	height: 14px;
	background-color: currentColor;
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 18 15 12 9 6'%3E%3C/polyline%3E%3C/svg%3E");
	mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 18 15 12 9 6'%3E%3C/polyline%3E%3C/svg%3E");
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-position: center;
	mask-position: center;
	-webkit-mask-size: contain;
	mask-size: contain;
	flex-shrink: 0;
	transition: transform 200ms ease;
}

/* Rotate chevron when open */
.ptcmp-services-toggle[aria-expanded="true"]::before {
	transform: rotate(90deg);
}

.ptcmp-services-list {
	list-style: none;
	margin: 8px 0 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

/* IMPORTANT: must come after display:flex declaration to override it */
.ptcmp-services-list[hidden] {
	display: none !important;
}

.ptcmp-service-item {
	font-size: 12px;
	color: #5f6368;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.ptcmp-service-label {
	font-weight: 500;
}

.ptcmp-service-cookies {
	font-family: monospace;
	font-size: 11px;
	color: #9aa0a6;
}

/* ============================================================
   PREFERENCES ACTIONS
   ============================================================ */
.ptcmp-prefs-actions {
	display: flex;
	gap: 10px;
	justify-content: flex-end;
	padding-top: 16px;
	border-top: 1px solid var(--ptcmp-border);
}

/* ============================================================
   MANAGE BUTTON (floating – principle 3)
   ============================================================ */
#ptcmp-manage-btn {
	position: fixed;
	bottom: 20px;
	left: 20px;
	z-index: calc(var(--ptcmp-z) - 1);
	background: var(--ptcmp-bg);
	color: var(--ptcmp-text);
	border: 1px solid var(--ptcmp-border);
	border-radius: 100px;
	padding: 8px 14px;
	font-size: 12px;
	font-family: var(--ptcmp-font);
	cursor: pointer;
	box-shadow: 0 2px 8px rgba(0,0,0,.12);
	display: flex;
	align-items: center;
	gap: 6px;
	transition: box-shadow var(--ptcmp-transition), background var(--ptcmp-transition);
}

#ptcmp-manage-btn:hover {
	background: #f1f3f4;
	box-shadow: 0 4px 16px rgba(0,0,0,.16);
}

#ptcmp-manage-btn:focus-visible {
	outline: none;
	box-shadow: var(--ptcmp-focus-ring);
}

#ptcmp-manage-btn[hidden] {
	display: none !important;
}

/* ============================================================
   MEDIA PLACEHOLDER
   ============================================================ */
.ptcmp-media-placeholder {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background: #f1f3f4;
	border: 1px dashed var(--ptcmp-border);
	border-radius: var(--ptcmp-radius-sm);
	padding: 24px;
	width: 100%;
	height: auto;
	min-height: 0;
	box-sizing: border-box;
	text-align: center;
	gap: 12px;
}

.ptcmp-media-placeholder p {
	font-size: 13px;
	color: #5f6368;
	margin: 0;
}

.ptcmp-accept-service {
	padding: 8px 16px;
	background: var(--ptcmp-primary);
	color: #fff;
	border: none;
	border-radius: var(--ptcmp-radius-sm);
	font-size: 13px;
	cursor: pointer;
	font-family: var(--ptcmp-font);
}

/* ============================================================
   TOAST NOTIFICATION
   ============================================================ */
#ptcmp-toast {
	position: fixed;
	bottom: 24px;
	right: 24px;
	z-index: calc(var(--ptcmp-z) + 1);
	background: #202124;
	color: #fff;
	padding: 12px 20px;
	border-radius: var(--ptcmp-radius-sm);
	font-size: 13px;
	font-family: var(--ptcmp-font);
	box-shadow: var(--ptcmp-shadow);
	opacity: 0;
	transform: translateY(8px);
	transition: opacity 300ms, transform 300ms;
	pointer-events: none;
}

#ptcmp-toast.ptcmp-toast-visible {
	opacity: 1;
	transform: translateY(0);
}

/* ============================================================
   LEGAL DOCUMENT STYLES (shortcode output)
   ============================================================ */
.ptcmp-legal-doc {
	font-family: var(--ptcmp-font);
	font-size: 15px;
	line-height: 1.7;
	color: var(--ptcmp-text);
}

.ptcmp-legal-doc h2 {
	font-size: 22px;
	margin-top: 0;
}

.ptcmp-legal-doc h3 {
	font-size: 16px;
	margin-top: 28px;
	padding-bottom: 6px;
	border-bottom: 1px solid var(--ptcmp-border);
}

.ptcmp-doc-meta {
	font-size: 12px;
	color: #9aa0a6;
	margin-top: 32px;
}

.ptcmp-cookie-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 13px;
}

.ptcmp-cookie-table th,
.ptcmp-cookie-table td {
	padding: 8px 12px;
	text-align: left;
	border: 1px solid var(--ptcmp-border);
}

.ptcmp-cookie-table th {
	background: #f8f9fa;
	font-weight: 600;
}

.ptcmp-cookie-table tr:nth-child(even) td {
	background: #f8f9fa;
}

/* ============================================================
   COOKIE LIST IN ACCORDION (scanned cookies)
   ============================================================ */

.ptcmp-service-item {
	font-size: 12px;
	color: var(--ptcmp-text, #202124);
}

.ptcmp-service-label {
	display: block;
	font-weight: 600;
	font-size: 12px;
	color: var(--ptcmp-text, #202124);
	margin-bottom: 4px;
	text-transform: capitalize;
}

.ptcmp-cookie-list {
	list-style: none;
	margin: 0;
	padding: 0 0 0 10px;
	border-left: 2px solid var(--ptcmp-border, #dadce0);
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.ptcmp-cookie-row {
	display: grid;
	grid-template-columns: auto 1fr;
	grid-template-rows: auto auto;
	column-gap: 8px;
	row-gap: 1px;
}

.ptcmp-cookie-name {
	font-family: monospace;
	font-size: 11px;
	font-weight: 600;
	color: var(--ptcmp-text, #202124);
	grid-column: 1;
	grid-row: 1;
	word-break: break-all;
}

.ptcmp-cookie-duration {
	font-size: 10px;
	color: #9aa0a6;
	background: #f1f3f4;
	border-radius: 3px;
	padding: 0 5px;
	height: fit-content;
	white-space: nowrap;
	grid-column: 2;
	grid-row: 1;
	align-self: center;
}

.ptcmp-cookie-desc {
	font-size: 11px;
	color: #5f6368;
	grid-column: 1 / -1;
	grid-row: 2;
	line-height: 1.4;
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
	#ptcmp-banner,
	.ptcmp-btn,
	.ptcmp-toggle-switch,
	.ptcmp-toggle-switch::after,
	#ptcmp-toast {
		transition: none !important;
	}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 600px) {
	.ptcmp-layout-bar .ptcmp-view-main {
		flex-direction: column;
		align-items: stretch;
		padding: 16px;
	}

	.ptcmp-layout-bar .ptcmp-banner-actions {
		flex-wrap: wrap;
	}

	.ptcmp-btn {
		flex: 1;
		min-width: 120px;
	}

	.ptcmp-view-preferences {
		padding: 16px;
	}

	.ptcmp-prefs-actions {
		flex-direction: column;
	}

	.ptcmp-prefs-actions .ptcmp-btn {
		width: 100%;
	}

	#ptcmp-manage-btn span {
		display: none;
	}
}

/* ============================================================
   HIGH CONTRAST (WCAG AAA)
   ============================================================ */
@media (forced-colors: active) {
	.ptcmp-btn-primary {
		background: ButtonText;
		color: ButtonFace;
		border-color: ButtonText;
	}

	.ptcmp-toggle-input:checked + .ptcmp-toggle-switch {
		background: Highlight;
	}

	.ptcmp-toggle-switch {
		border: 1px solid ButtonText;
	}
}

/* ============================================================
   PRINT – hide banner
   ============================================================ */
@media print {
	#ptcmp-banner,
	#ptcmp-manage-btn,
	#ptcmp-toast {
		display: none !important;
	}
}
