.reviewView {
	display: flex;
	flex-direction: column;
	height: 100vh;
	width: 100vw;
}

.reviewView-backLink {
	align-items: center;
	color: rgb(var(--secondary-alt));
	cursor: pointer;
	display: flex;
}

.reviewView-header {
	align-items: center;
	background-color: rgb(var(--secondary-contrast));
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
	color: rgb(var(--secondary-alt));
	display: flex;
	justify-content: space-between;
	padding: 2px;
	position: relative;
	z-index: 2;
}

.reviewView-headerCenter {
	align-items: center;
	display: flex;
	flex: 1;
	font-weight: 600;
	gap: var(--basic-spacing);
	justify-content: flex-start;
	margin-left: var(--basic-spacing);
	min-width: 0;
}

.reviewView-reviewName {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.reviewView-reviewSelect {
	max-width: fit-content;
	min-width: 300px;
}

.reviewView-addFeedbackBtn {
	align-items: center;
	background-color: rgb(var(--primary));
	border: none;
	border-radius: 5px;
	color: rgb(var(--primary-contrast));
	cursor: pointer;
	display: flex;
	font-size: 14px;
	gap: calc(var(--basic-spacing) / 2);
	margin-left: var(--basic-spacing);
	padding: 6px 16px;
	transition: opacity 0.2s ease-in-out;
	white-space: nowrap;
}

.reviewView-addFeedbackBtn:hover {
	opacity: 0.85;
}

.reviewView-completeBtn {
	align-items: center;
	background-color: #4caf50;
	border: none;
	border-radius: 5px;
	color: #fff;
	cursor: pointer;
	display: flex;
	font-size: 14px;
	gap: calc(var(--basic-spacing) / 2);
	margin-left: var(--basic-spacing);
	padding: 6px 16px;
	transition: opacity 0.2s ease-in-out;
	white-space: nowrap;
}

.reviewView-completeBtn:hover {
	opacity: 0.85;
}

.reviewView-completeBtn:disabled {
	cursor: not-allowed;
	opacity: 0.5;
}

.reviewView-completeBtnSidebar {
	display: none;
}

.reviewView-completedMessage {
	align-items: center;
	color: rgb(var(--secondary-alt));
	display: flex;
	font-size: 14px;
	gap: calc(var(--basic-spacing) / 2);
	margin-left: var(--basic-spacing);
	white-space: nowrap;
}

.reviewView-completedMessageSidebar {
	display: none;
}

.reviewView-mobileFab {
	display: none;
}

.reviewView-logo {
	cursor: pointer;
	height: 40px;
}

.reviewView-breakpoints {
	align-items: center;
	display: flex;
	gap: 2px;
}

.reviewView-headerRight {
	align-items: center;
	display: flex;
	flex: 1;
	justify-content: flex-end;
	padding-right: 5px;
}

.reviewView-breakpointBtn {
	align-items: center;
	background: transparent;
	border: none;
	border-radius: 4px;
	color: rgb(var(--secondary-alt));
	cursor: pointer;
	display: flex;
	justify-content: center;
	opacity: 0.5;
	padding: 4px 8px;
	transition: opacity 0.2s ease-in-out, background-color 0.2s ease-in-out;
}

.reviewView-breakpointBtn:hover {
	background-color: rgba(0, 0, 0, 0.08);
	opacity: 0.8;
}

.reviewView-breakpointBtnActive {
	align-items: center;
	background-color: rgba(0, 0, 0, 0.1);
	border: none;
	border-radius: 4px;
	color: rgb(var(--secondary-alt));
	cursor: pointer;
	display: flex;
	justify-content: center;
	opacity: 1;
	padding: 4px 8px;
}

.reviewView-content {
	display: flex;
	flex: 1;
	flex-direction: row;
	min-height: 0;
}

.reviewView-iframe {
	align-items: center;
	background-color: rgb(var(--paper));
	display: flex;
	flex: 1;
	justify-content: center;
	overflow: auto;
	padding: 40px;
}

.reviewView-iframeContainer {
	align-items: center;
	background-color: #fff;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
	display: flex;
	justify-content: center;
	transition: width 0.3s ease-in-out, height 0.3s ease-in-out;
}

.reviewView-iframePlaceholder {
	align-items: center;
	color: rgb(var(--neutral));
	display: flex;
	flex-direction: column;
	gap: var(--basic-spacing);
}

.reviewView-sidebar {
	box-shadow: -2px 0 8px rgba(0, 0, 0, 0.15);
	min-width: 0;
	overflow: hidden;
	position: relative;
	transition: width 0.3s ease-in-out;
	z-index: 1;
}

.reviewView-sidebarInner {
	background-color: #f7f8fa;
	display: flex;
	flex-direction: column;
	height: 100%;
}

.reviewView-sidebarCollapsed {
}

.reviewView-sidebarResizing {
	transition: none;
}

.reviewView-sidebarResizeHandle {
	cursor: col-resize;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 5px;
	z-index: 10;
}

.reviewView-sidebarResizeHandle:hover {
	background-color: rgb(var(--primary));
	opacity: 0.3;
}

.reviewView-sidebarBody {
	display: flex;
	flex: 1;
	flex-direction: row;
	min-height: 0;
}

.reviewView-sidebarContent {
	display: flex;
	flex: 1;
	flex-direction: column;
	min-width: 0;
	overflow: hidden;
	position: relative;
}

.reviewView-sidebarHeader {
	align-items: center;
	background-color: rgb(var(--primary));
	color: rgb(var(--primary-contrast));
	display: flex;
	padding: calc(var(--basic-spacing) / 2) var(--basic-spacing) calc(var(--basic-spacing) / 2) 0;
}

.reviewView-sidebarHeader h3 {
	margin: 0;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.reviewView-sidebarToggle {
	align-items: center;
	cursor: pointer;
	display: flex;
	font-size: 28px;
	justify-content: center;
	min-width: 48px;
	opacity: 0.8;
	transition: opacity 0.2s ease-in-out;
	width: 48px;
}

.reviewView-sidebarToggle:hover {
	opacity: 1;
}

.reviewView-commentsList {
	display: flex;
	flex: 1;
	flex-direction: column;
	gap: var(--basic-spacing);
	overflow-y: auto;
	padding: var(--basic-spacing);
}

.reviewView-messageRow {
	display: flex;
	flex-direction: row;
	gap: calc(var(--basic-spacing) / 2);
}

.reviewView-message {
	background-color: rgb(var(--primary-contrast));
	border-radius: 6px;
	box-shadow: 0 1px 4px rgba(0, 0, 0, 0.12);
	flex: 1;
	min-width: 0;
	padding: var(--basic-spacing);
	position: relative;
}

.reviewView-messageActions {
	display: none;
	position: absolute;
	right: 4px;
	top: 4px;
}

.reviewView-messageRow:hover .reviewView-messageActions {
	display: flex;
}

.reviewView-messageActionsBtn {
	align-items: center;
	background: white;
	border: none;
	border-radius: 4px;
	color: rgb(var(--neutral));
	cursor: pointer;
	display: flex;
	justify-content: center;
	padding: 2px;
}

.reviewView-messageActionsBtn:hover {
	background-color: white;
	color: rgb(var(--secondary-alt));
}

.reviewView-messageMenu {
	background-color: #fff;
	border-radius: 6px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
	min-width: 140px;
	position: absolute;
	right: 0;
	top: 100%;
	z-index: 10;
}

.reviewView-messageMenuItem {
	align-items: center;
	cursor: pointer;
	display: flex;
	font-size: 13px;
	gap: calc(var(--basic-spacing) / 2);
	padding: 8px 12px;
}

.reviewView-messageMenuItem:first-child {
	border-radius: 6px 6px 0 0;
}

.reviewView-messageMenuItem:last-child {
	border-radius: 0 0 6px 6px;
}

.reviewView-messageMenuItem:hover {
	background-color: rgba(0, 0, 0, 0.05);
}

.reviewView-messageMenuItem .material-icons {
	font-size: 18px;
}

.reviewView-messageEditArea {
	display: flex;
	flex-direction: column;
	gap: calc(var(--basic-spacing) / 2);
}

.reviewView-messageEditActions {
	display: flex;
	gap: calc(var(--basic-spacing) / 2);
	justify-content: flex-end;
}

.reviewView-confirmModal {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: var(--basic-spacing);
	max-width: 360px;
	padding: calc(var(--basic-spacing) * 2);
	text-align: center;
}

.reviewView-confirmModalActions {
	display: flex;
	gap: calc(var(--basic-spacing) / 2);
	justify-content: center;
}

.reviewView-messageIcon {
	align-items: center;
	background-color: rgb(var(--secondary-alt));
	border-radius: 45px;
	color: rgb(var(--secondary-contrast));
	display: flex;
	font-size: 14px;
	height: 32px;
	justify-content: center;
	min-width: 32px;
}

.reviewView-messageContent {
	display: flex;
	flex-direction: column;
	gap: calc(var(--basic-spacing) / 4);
	min-width: 0;
}

.reviewView-messageDate {
	color: #666;
	font-size: 12px;
}

.reviewView-messageName {
	font-weight: 600;
}

.reviewView-messageStatus {
	background-color: rgb(var(--secondary));
	border-radius: 3px;
	color: rgb(var(--secondary-contrast));
	display: inline-block;
	font-size: 11px;
	padding: 1px 6px;
	width: fit-content;
}

.reviewView-messageClosed {
	background-color: #deeedc;
}

.reviewView-messageAbandoned {
	background-color: #f0f0f0;
}

.reviewView-messageBadge {
	background-color: #deeedc;
	border-radius: 50%;
	bottom: 6px;
	color: #4caf50;
	font-size: 18px;
	position: absolute;
	right: 6px;
}

.reviewView-messageBadgeAbandoned {
	background-color: #f0f0f0;
	color: #9e9e9e;
}

.reviewView-messageText {
	font-size: 14px;
	line-height: 1.4;
	max-height: 150px;
	overflow-y: auto;
	word-break: break-word;
}

.reviewView-messageAttachments {
	display: flex;
	flex-wrap: wrap;
	gap: calc(var(--basic-spacing) / 4);
}

.reviewView-emptyMessage {
	align-items: center;
	color: rgb(var(--neutral));
	display: flex;
	justify-content: center;
	padding: calc(var(--basic-spacing) * 3);
}

.reviewView-addCommentBtn {
	align-items: center;
	display: flex;
	justify-content: center;
	padding: var(--basic-spacing);
}

.reviewView-formClose {
	align-items: center;
	background-color: rgb(var(--primary-contrast));
	border: 1px solid rgb(var(--primary));
	border-radius: 0 0 0 5px;
	color: rgb(var(--primary));
	cursor: pointer;
	display: flex;
	height: 32px;
	justify-content: center;
	position: absolute;
	right: 0;
	top: 0;
	width: 32px;
	z-index: 2;
}

.reviewView-formHeader {
	margin: 0;
	text-align: center;
}

.reviewView-formActions {
	align-items: center;
	display: flex;
	gap: calc(var(--basic-spacing) / 2);
	justify-content: flex-end;
}

.reviewView-closedMessage {
	border-top: 1px solid rgb(var(--neutral));
	color: rgb(var(--neutral));
	font-style: italic;
	padding: var(--basic-spacing);
	text-align: center;
}

.reviewView-formPanel {
	background-color: white;
	bottom: 0;
	box-shadow: 0 -4px 8px rgba(0, 0, 0, 0.15);
	left: 0;
	max-height: 100%;
	overflow-y: auto;
	position: absolute;
	right: 0;
	transition: transform 0.3s ease-in-out;
	z-index: 10;
}

.reviewView-formPanelOpen {
	transform: translateY(0);
}

.reviewView-formPanel:not(.reviewView-formPanelOpen) {
	transform: translateY(100%);
}

.reviewView-submitArea {
	display: flex;
	flex-direction: column;
	gap: calc(var(--basic-spacing) / 2);
	padding: calc(var(--basic-spacing));
	position: relative;
}

.reviewView-screenshotBtn {
	align-items: center;
	background-color: rgb(var(--secondary-alt));
	border: none;
	border-radius: 5px;
	color: rgb(var(--secondary-contrast));
	cursor: pointer;
	display: inline-flex;
	font-size: 0;
	justify-content: center;
	line-height: 1;
	padding: 6px;
}

.reviewView-screenshotBtn .material-icons {
	font-size: 24px;
	height: 24px;
	width: 24px;
}

.reviewView-screenshotBtn:hover {
	opacity: 0.85;
}

.reviewView-submitActions {
	align-items: center;
	display: flex;
	gap: calc(var(--basic-spacing) / 2);
	justify-content: space-between;
	margin-top: calc(var(--basic-spacing) * 4)
}

.reviewView-annotateBtn {
	align-items: center;
	background-color: rgb(var(--secondary-alt));
	border: none;
	border-radius: 5px;
	color: rgb(var(--secondary-contrast));
	cursor: pointer;
	display: inline-flex;
	font-size: 0;
	justify-content: center;
	line-height: 1;
	padding: 6px;
}

.reviewView-annotateBtn .material-icons {
	font-size: 24px;
	height: 24px;
	width: 24px;
}

.reviewView-annotateBtn:hover {
	opacity: 0.85;
}

.reviewView-annotationModal .modal-inner {
	margin: 2vh auto;
	max-height: 90vh;
	max-width: 90vw;
	width: fit-content;
}

.reviewView-previewModal .modal-inner {
	margin: 2vh auto;
	max-height: 96vh;
	max-width: 96vw;
	overflow: hidden;
	width: fit-content;
}

.reviewView-previewModal .attachmentThumbnail-card {
	overflow: hidden;
}

.reviewView-previewModal .attachmentThumbnail-image {
	max-height: calc(96vh - 120px);
	max-width: calc(96vw - 40px);
}

.reviewView-captureOverlay {
	cursor: crosshair;
	height: 100vh;
	left: 0;
	position: fixed;
	top: 0;
	width: 100vw;
	z-index: 10000;
}

.reviewView-captureImage {
	height: 100%;
	left: 0;
	object-fit: cover;
	pointer-events: none;
	position: absolute;
	top: 0;
	width: 100%;
}

.reviewView-captureInstructions {
	background-color: rgba(0, 0, 0, 0.7);
	border-radius: 6px;
	color: #fff;
	font-size: 14px;
	left: 50%;
	padding: 8px 16px;
	pointer-events: none;
	position: absolute;
	top: 20px;
	transform: translateX(-50%);
	z-index: 10001;
}

.reviewView-captureSelection {
	border: 2px dashed #fff;
	box-shadow: 0 0 0 9999px rgba(0, 0, 0, 0.4);
	position: fixed;
	z-index: 10001;
}

.reviewView-welcomeMessage {
	color: rgb(var(--secondary-alt));
	font-size: 14px;
	margin: 0 0 var(--basic-spacing) 0;
	text-align: center;
}

.reviewView-welcomeError {
	color: #d32f2f;
	font-size: 14px;
	margin: 0;
	white-space: pre-line;
}

/* Mobile layout */
@media (max-width: 768px) {
	.reviewView-header {
		background-color: transparent;
		box-shadow: none;
		padding: 0;
		position: absolute;
		z-index: 100;
	}

	.reviewView-header > *:not(.reviewView-headerRight) {
		display: none;
	}

	.reviewView-content {
		height: 100vh;
	}

	.reviewView-iframe {
		background-color: #fff;
		padding: 0;
	}

	.reviewView-iframeContainer {
		box-shadow: none;
		height: 100% !important;
		width: 100% !important;
	}

	.reviewView-sidebar {
		height: 100dvh;
		position: fixed;
		right: 0;
		top: 0;
		width: 100vw !important;
		z-index: 200;
	}

	.reviewView-sidebarCollapsed {
		width: 0 !important;
	}

	.reviewView-sidebarInner {
		min-width: 100vw !important;
		width: 100vw !important;
	}

	.reviewView-sidebarResizeHandle {
		display: none;
	}

	.reviewView-headerRight {
		display: none;
	}

	.reviewView-completeBtnSidebar {
		display: flex;
		margin-left: auto;
	}

	.reviewView-completedMessageSidebar {
		display: flex;
		color: rgb(var(--primary-contrast));
		margin-left: auto;
	}

	.reviewView-mobileFab {
		align-items: center;
		background-color: rgb(var(--primary));
		border: none;
		border-radius: 50%;
		bottom: 20px;
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
		color: rgb(var(--primary-contrast));
		cursor: pointer;
		display: flex;
		font-size: 0;
		height: 56px;
		justify-content: center;
		position: fixed;
		right: 20px;
		width: 56px;
		z-index: 300;
	}

	.reviewView-mobileFab .material-icons {
		font-size: 28px;
	}
}
