/* Color Scheme - Modulair aanpasbaar */
:root {
	/* Basis kleuren */
	--bg-primary: #F5F7F6; /* Subtiel grijs-groen background */
	--card-bg: #FFFFFF; /* Witte cards/panels */
	--text-primary: #1F3A3D; /* Donker teal-grijs voor tekst */
	--border-primary: #D4DCD9; /* Subtiel grijs-groen voor borders */
	--accent-primary: #2A7A7F; /* Gedempte teal - primaire accent */
	--accent-secondary: #C17F4A; /* Warm brons voor highlights */
	
	/* Display card kleuren */
	--card-bg-new: #FFFFFF; /* Witte cards */
	--card-border-new: #2A7A7F; /* Primaire accent */
	--card-text-new: #1F3A3D; /* Donker teal-grijs */
	--card-bg-old: #FFFFFF; /* Witte cards */
	--card-border-old: #D4DCD9; /* Subtiel grijs-groen */
	--card-text-old: #1F3A3D; /* Donker teal-grijs, faded */
	--card-opacity-old: 0.6; /* Fade effect */
	
	/* Mythic decision result colors */
	--mythic-yes-bg: #4CAF50; /* Groen voor Yes */
	--mythic-yes-and-bg: #2E7D32; /* Donkerder, meer verzadigd groen voor Yes, and... */
	--mythic-no-bg: #FFB74D; /* Warning kleur voor No */
	--mythic-no-and-bg: #E57373; /* Error kleur voor No, and... */
	--mythic-text-color: #FFFFFF; /* Witte tekst voor gekleurde achtergronden */
	
	/* Message notification colors - aangepast naar nieuw schema */
	--message-bg-success: #FFFFFF; /* Witte background */
	--message-border-success: #2A7A7F; /* Primaire accent */
	--message-text-success: #1F3A3D; /* Donker teal-grijs */
	--message-bg-info: #FFFFFF; /* Witte background */
	--message-border-info: #2A7A7F; /* Primaire accent */
	--message-text-info: #1F3A3D; /* Donker teal-grijs */
	--message-bg-warning: #FFFFFF; /* Witte background */
	--message-border-warning: #C17F4A; /* Secundaire accent */
	--message-text-warning: #1F3A3D; /* Donker teal-grijs */
	--message-bg-error: #FFFFFF; /* Witte background */
	--message-border-error: #C17F4A; /* Secundaire accent */
	--message-text-error: #1F3A3D; /* Donker teal-grijs */
	
	/* Layout variabelen - Modulair aanpasbaar */
	--display-width: 650px; /* Fixed ergonomische leesbreedte (50-75 karakters) */
	--display-max-width: 650px;
	--controls-width: 95%;
	--controls-max-width: 1200px;
	--subgroups-per-row: 2; /* Aantal subgroepen per regel */
	--subgroup-gap: 15px; /* Ruimte tussen subgroepen (zowel horizontaal als verticaal) */
	--subgroup-padding-horizontal: 10px; /* Horizontale padding in subgroepen */
	--subgroup-padding-vertical: 12px; /* Verticale padding in subgroepen */
	--group-margin: 15px; /* Margin tussen groepen */
}

/* Body background */
body {
	background-color: var(--bg-primary);
	color: var(--text-primary);
}

/* Group centering */
.group {
	width: 100%;
	display: flex;
	justify-content: center;
	margin: var(--group-margin) 0;
}

.display-group {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	width: 100%;
	margin: 0;
	padding: 10px;
	box-sizing: border-box;
	background-color: var(--bg-primary);
	z-index: 100;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.controls-group {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--subgroup-gap);
	align-items: stretch;
	text-align: center;
	width: var(--controls-width);
	max-width: var(--controls-max-width);
	margin: 0 auto;
	margin-top: 340px; /* 300px display height + 20px padding top + 20px spacing */
	padding: var(--subgroup-gap);
	box-sizing: border-box;
}

/* Layout adjustments for collapsed/expanded states */
.control-subgroup.expanded-solo {
	grid-column: 1 / -1;
	justify-self: center;
	max-width: 50%;
}

.control-subgroup.collapsed-below {
	grid-column: 1 / -1;
	justify-self: center;
	max-width: 50%;
}

.control-subgroup {
	width: 100%;
	padding: var(--subgroup-padding-vertical) var(--subgroup-padding-horizontal);
	border: 1px solid var(--border-primary);
	border-radius: 8px;
	background-color: var(--card-bg);
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
	display: flex;
	flex-direction: column;
	height: 100%;
	box-sizing: border-box;
}

.subgroup-header {
	margin: 0 0 10px 0;
	padding: 0;
	font-size: 15px;
	font-weight: bold;
	color: var(--text-primary);
	text-align: center;
	display: flex;
	justify-content: space-between;
	align-items: center;
	cursor: pointer;
}

.subgroup-title {
	flex: 1;
}

.toggle-button {
	background: none;
	border: 1px solid var(--border-primary);
	border-radius: 4px;
	width: 24px;
	height: 24px;
	font-size: 18px;
	line-height: 1;
	padding: 0;
	cursor: pointer;
	color: var(--text-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background-color 0.2s ease, border-color 0.2s ease;
	flex-shrink: 0;
}

.toggle-button:hover {
	background-color: var(--accent-primary);
	border-color: var(--accent-primary);
	color: #FFFFFF;
}

.control-subgroup.collapsed .subgroup-content {
	display: none;
}

.control-subgroup.collapsed {
	height: auto;
	min-height: auto;
}

.subgroup-content {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	flex: 1;
	justify-content: center;
}

.button-row {
	display: flex;
	justify-content: center;
	gap: 10px;
	flex-wrap: wrap;
	width: 100%;
}

.button-row button {
	flex: 0 0 calc(33.333% - 10px);
	min-width: 150px;
	max-width: 200px;
}

.control-row {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
	width: 100%;
}

.control-row label {
	display: flex;
	align-items: center;
	gap: 5px;
	color: var(--text-primary);
}

/* Button styling */
button {
	background-color: var(--card-bg);
	border: 1px solid var(--border-primary);
	color: var(--text-primary);
	padding: 8px 16px;
	border-radius: 4px;
	cursor: pointer;
	font-size: 14px;
	transition: background-color 0.2s ease, border-color 0.2s ease;
}

button:hover {
	background-color: var(--accent-primary);
	border-color: var(--accent-primary);
	color: #FFFFFF;
}

button:active {
	background-color: var(--accent-secondary);
	border-color: var(--accent-secondary);
}

/* Input styling */
input[type="text"],
input[type="range"],
select {
	color: var(--text-primary);
	border: 1px solid var(--border-primary);
	background-color: var(--card-bg);
}

input[type="text"],
select {
	padding: 4px 8px;
	border-radius: 4px;
}

input[type="text"]:focus,
select:focus {
	outline: none;
	border-color: var(--accent-primary);
}

span {
	color: var(--text-primary);
}


#display {
	width: var(--display-width);
	max-width: var(--display-max-width);
	height: 300px;
	max-height: 30vh;
	border: 1px solid var(--border-primary);
	padding: 10px;
	overflow-y: auto;
	background-color: var(--card-bg);
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
	font-family: Arial, sans-serif;
	display: flex;
	flex-direction: column-reverse;
	margin: 0 auto;
}

/* Mobile portrait mode responsive layout */
@media screen and (max-width: 768px) and (orientation: portrait) {
	.display-group {
		padding: 8px;
	}
	
	#display {
		width: 100%;
		max-width: 100%;
		height: 33.33vh;
		max-height: 33.33vh;
		margin: 0;
	}
	
	.controls-group {
		margin-top: calc(33.33vh + 20px);
		display: flex;
		flex-direction: column;
		grid-template-columns: 1fr;
		width: 100%;
		max-width: 100%;
		padding: 10px;
		gap: 10px;
	}
	
	/* Small mobile screens */
	@media screen and (max-height: 600px) {
		#display {
			height: 30vh;
			max-height: 30vh;
		}
		
		.controls-group {
			margin-top: calc(30vh + 20px);
		}
	}
	
	.control-subgroup {
		width: 100%;
		max-width: 100%;
		min-width: 0;
	}
	
	.control-subgroup.expanded-solo,
	.control-subgroup.collapsed-below {
		max-width: 100%;
		grid-column: 1;
	}
	
	.button-row {
		flex-wrap: wrap;
	}
	
	.button-row button {
		flex: 1 1 calc(50% - 5px);
		min-width: 100px;
		max-width: none;
		font-size: 12px;
		padding: 6px 12px;
	}
	
	.control-row {
		flex-direction: column;
		align-items: stretch;
		gap: 8px;
	}
	
	.control-row label {
		flex-direction: column;
		align-items: flex-start;
		gap: 5px;
		width: 100%;
	}
	
	.control-row label input[type="range"] {
		width: 100%;
	}
	
	.subgroup-header {
		font-size: 13px;
	}
	
	.subgroup-content {
		gap: 6px;
	}
	
	button {
		font-size: 12px;
		padding: 6px 12px;
	}
	
	input[type="text"],
	select {
		width: 100%;
		font-size: 14px;
		box-sizing: border-box;
	}
	
	.footer {
		margin-top: 20px;
		padding: 15px 0;
		flex-shrink: 0;
	}
}

.display-card {
	margin-top: 10px;
	margin-bottom: 0;
	padding: 12px;
	border-radius: 8px;
	word-wrap: break-word;
	transition: opacity 0.3s ease;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	font-weight: bold;
}

.display-card.new {
	background-color: var(--card-bg-new);
	border: 2px solid var(--card-border-new);
	color: var(--card-text-new);
}

.display-card.old {
	background-color: var(--card-bg-old);
	border: 1px solid var(--card-border-old);
	color: var(--card-text-old);
	opacity: var(--card-opacity-old);
}

/* Glyph images in display cards */
.display-card .display-glyph {
	max-width: 80px;
	max-height: 80px;
	object-fit: contain;
	border: none;
	outline: none;
}

/* Message notification */
.message-notification {
	position: fixed;
	bottom: 20px;
	left: 50%;
	transform: translateX(-50%);
	padding: 12px 24px;
	border-radius: 8px;
	border: 2px solid;
	font-family: Arial, sans-serif;
	font-size: 14px;
	font-weight: 500;
	cursor: pointer;
	opacity: 0;
	display: none;
	transition: opacity 0.3s ease, transform 0.3s ease;
	z-index: 1000;
	min-width: 200px;
	text-align: center;
	box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.message-notification.show {
	opacity: 1;
	display: block;
	transform: translateX(-50%) translateY(0);
}

.message-notification.fade-out {
	opacity: 0;
	transform: translateX(-50%) translateY(20px);
}

.message-notification.success {
	background-color: var(--message-bg-success);
	border-color: var(--message-border-success);
	color: var(--message-text-success);
}

.message-notification.info {
	background-color: var(--message-bg-info);
	border-color: var(--message-border-info);
	color: var(--message-text-info);
}

.message-notification.warning {
	background-color: var(--message-bg-warning);
	border-color: var(--message-border-warning);
	color: var(--message-text-warning);
}

.message-notification.error {
	background-color: var(--message-bg-error);
	border-color: var(--message-border-error);
	color: var(--message-text-error);
}

/* Footer */
.footer {
	width: 100%;
	margin-top: 30px;
	padding: 20px 0;
	text-align: center;
}

.footer-content {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
}

.footer-line {
	font-size: 12px;
	color: var(--text-primary);
}

.footer-line a {
	color: var(--accent-primary);
	text-decoration: none;
}

.footer-line a:hover {
	text-decoration: underline;
}

