/*! RweOnlineGallerySnippetConfig v1.1.6 | (c) 2023 Mark Heggan | MIT License | https://github.com/markheggan/rwe-online-gallery-snippet-config */
/**
 * @imports Main Styles
 */
/*-------------------------*\
    TRUNK STYLE VARIABLES  
\*-------------------------*/
/*-- Typography --*/
/*-- Color --*/
/*-- Interface --*/
/**
 * @section Normalize.css
 */
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
	line-height: 1.15;
	/* 1 */
	-webkit-text-size-adjust: 100%;
	/* 2 */
}

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
	margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
	display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
	font-size: 2em;
	margin: 0.67em 0;
}

/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
	box-sizing: content-box;
	/* 1 */
	height: 0;
	/* 1 */
	overflow: visible;
	/* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
	font-family: monospace, monospace;
	/* 1 */
	font-size: 1em;
	/* 2 */
}

/* Text-level semantics
   ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
	background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
	border-bottom: none;
	/* 1 */
	text-decoration: underline;
	/* 2 */
	text-decoration: underline dotted;
	/* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
	font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
	font-family: monospace, monospace;
	/* 1 */
	font-size: 1em;
	/* 2 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
	font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
	border-style: none;
}

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
	font-family: inherit;
	/* 1 */
	font-size: 100%;
	/* 1 */
	line-height: 1.15;
	/* 1 */
	margin: 0;
	/* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
	/* 1 */
	overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
	/* 1 */
	text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type=button],
[type=reset],
[type=submit] {
	-webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
	border-style: none;
	padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
	outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
	padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
	box-sizing: border-box;
	/* 1 */
	color: inherit;
	/* 2 */
	display: table;
	/* 1 */
	max-width: 100%;
	/* 1 */
	padding: 0;
	/* 3 */
	white-space: normal;
	/* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
	vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
	overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type=checkbox],
[type=radio] {
	box-sizing: border-box;
	/* 1 */
	padding: 0;
	/* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
	height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type=search] {
	-webkit-appearance: textfield;
	/* 1 */
	outline-offset: -2px;
	/* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
	-webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
	-webkit-appearance: button;
	/* 1 */
	font: inherit;
	/* 2 */
}

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
	display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
	display: list-item;
}

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
	display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
	display: none;
}

/**
 * @section Setup Styles
 */
/*-- Setup --*/
html,
body,
div,
span,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
code,
img,
small,
strong,
b,
u,
i,
ol,
ul,
li,
fieldset,
form,
label,
table,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
figure,
figcaption,
footer,
header,
nav,
section,
video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}

article,
aside,
figcaption,
figure,
footer,
header,
menu,
nav,
section {
	display: block;
}

html,
body {
	height: 100%;
}

a img {
	border: none;
}

blockquote {
	quotes: none;
}

blockquote:before,
blockquote:after {
	content: "";
	content: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

img {
	font-style: italic;
}

label,
input,
textarea,
button,
select,
option {
	cursor: pointer;
}

.text-input:active, .text-input:focus,
textarea:active,
textarea:focus {
	cursor: text;
	outline: none;
}

/*-- Box Layout Model --*/
html {
	box-sizing: border-box;
}

*, *:before, *:after {
	box-sizing: inherit;
}

/*-- Clearfix --*/
.cf:after {
	content: "";
	display: table;
	clear: both;
}

/*-- Defaults --*/
html,
input,
textarea,
button {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
}

body {
	font-family: "Roboto", "Franklin Gothic Medium", Tahoma, sans-serif;
	font-style: normal;
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.6;
	font-display: optional;
	color: #252627;
}

a {
	color: #B07AC0;
	font-weight: 700;
	text-decoration: underline;
	transition: color 0.25s ease;
}
a:hover, a:focus {
	color: #9b57b0;
	text-decoration: none;
}

/*-- Typography --*/
strong,
b {
	font-weight: 700;
}

em,
i {
	font-style: italic;
}

h1,
h2,
h3,
h4,
h5,
h6,
.heading-1,
.heading-2,
.config-panel .panel-section_title,
.heading-3,
.config-section_title,
.heading-4,
.heading-5,
.heading-6 {
	padding-top: 0.75rem;
	font-style: normal;
	font-weight: 700;
	line-height: 1.36;
}

h1,
.heading-1 {
	font-size: 2.25rem;
	margin-bottom: 1.25rem;
	letter-spacing: -0.02rem;
}

h2,
.heading-2 {
	font-size: 1.72rem;
	margin-bottom: 1.125rem;
	letter-spacing: -0.02rem;
}

h3,
.config-panel .panel-section_title,
.heading-3 {
	font-size: 1.48rem;
	margin-bottom: 1rem;
	letter-spacing: -0.02rem;
}

h4,
.config-section_title,
.heading-4 {
	font-size: 1.32rem;
	margin-bottom: 1rem;
	letter-spacing: -0.01rem;
}

h5,
.heading-5 {
	font-size: 1.2rem;
	margin-bottom: 0.88rem;
	letter-spacing: -0.01rem;
}

h6,
.heading-6 {
	font-size: 1.08rem;
	margin-bottom: 0.75rem;
	letter-spacing: -0.01rem;
}

.--highlighted-heading span {
	position: relative;
	left: 0.25em;
	padding-left: 0;
	display: inline;
	line-height: 2.2;
	color: #252627;
	padding: 0.25em;
}
.--highlighted-heading.--green span {
	background: #B8EBE2;
	box-shadow: 0.25em 0 0 #B8EBE2, -0.25em 0 0 #B8EBE2, 0.25em 3px 0 #252627, -0.25em 3px 0 #252627;
}
.--highlighted-heading.--purple span {
	background: #DFC9E4;
	box-shadow: 0.25em 0 0 #DFC9E4, -0.25em 0 0 #DFC9E4, 0.25em 3px 0 #252627, -0.25em 3px 0 #252627;
}
.--highlighted-heading.--blue span {
	background: #C7E7F4;
	box-shadow: 0.25em 0 0 #C7E7F4, -0.25em 0 0 #C7E7F4, 0.25em 3px 0 #252627, -0.25em 3px 0 #252627;
}
.--highlighted-heading.--pink span {
	background: #EFD8DA;
	box-shadow: 0.25em 0 0 #EFD8DA, -0.25em 0 0 #EFD8DA, 0.25em 3px 0 #252627, -0.25em 3px 0 #252627;
}
.--highlighted-heading.--orange span {
	background: #F5DEC9;
	box-shadow: 0.25em 0 0 #F5DEC9, -0.25em 0 0 #F5DEC9, 0.25em 3px 0 #252627, -0.25em 3px 0 #252627;
}

p {
	margin-bottom: 1.25rem;
}

hr {
	margin: 2.5rem 0;
	border: 0;
	height: 2px;
	background-color: #F1F5F7;
}

.small,
small {
	font-size: 0.86rem;
	line-height: 1.7;
}

ul {
	list-style: disc outside;
}

ol {
	list-style: decimal outside;
}

ol,
ul {
	margin: 0 0 1.25rem 2.25rem;
}

ul ul,
ul ol,
ol ol,
ol ul {
	margin: 1rem 0 1rem 1rem;
}

li {
	margin-bottom: 0.625rem;
}

::-moz-selection {
	background-color: #CFA9D9;
	color: #FFFFFF;
}

::selection {
	background-color: #CFA9D9;
	color: #FFFFFF;
}

pre {
	font-family: "Roboto Mono", monospace;
	font-size: 1.12rem;
	font-weight: 500;
	white-space: pre-wrap;
}

/**
 * @section Icon Styles
 */
.icon {
	display: inline-block;
	width: 22px;
	height: 22px;
	background-position: top left;
	background-repeat: no-repeat;
}
.icon.ext-link-icon {
	background-image: url("../svg/external-link.svg");
}

/**
 * @section Animation Styles
 */
@keyframes wiggle {
	0% {
		transform: rotate(0deg);
	}
	4% {
		transform: rotate(-2deg);
	}
	8% {
		transform: rotate(2deg);
	}
	12% {
		transform: rotate(0deg);
	}
	100% {
		transform: rotate(0deg);
	}
}
/**
 * @section Base Styles
 */
html {
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
	font-size: 14px;
}

body {
	font-size: 1rem;
	margin: 0 auto;
	width: 100vw;
	height: 100vh;
	color: #2E2F30;
}

img,
svg {
	max-width: 100%;
	vertical-align: bottom;
}

img[width],
img[height],
svg[width],
svg[height] {
	max-width: 100%;
	height: auto;
}

/**
 * @section Button Styles
 */
/*-- Defaults --*/
.btn {
	display: inline-block;
	vertical-align: middle;
	white-space: nowrap;
	cursor: pointer;
	border: none;
	margin: 0;
	padding-top: 0;
	padding-bottom: 0;
	font-family: "Roboto", "Franklin Gothic Medium", Tahoma, sans-serif;
	font-style: normal;
	font-weight: 700;
	line-height: 2.5;
	padding-right: 1em;
	padding-left: 1em;
	text-align: center;
	text-decoration: none !important;
	border: 2px solid transparent;
	border-radius: 4px;
	transition: all 0.5s ease;
	/*-- Button Sizing --*/
	/*-- Button Basic Color --*/
	/*-- Bordered Buttons --*/
	/*-- Shadow Buttons --*/
}
.btn,
.btn:hover,
.btn:active,
.btn:focus {
	color: #252627;
}
.btn,
.btn:hover {
	text-decoration: none;
}
.btn:active,
.btn:focus {
	outline: none;
}
.btn.--sml {
	font-size: 0.88rem;
	line-height: 2.34;
	padding-left: 0.75em;
	padding-right: 0.75em;
}
.btn.--lrg {
	font-size: 1.08rem;
	line-height: 2.66;
	padding-left: 1em;
	padding-right: 1em;
}
.btn.--dark {
	background-color: #252627;
	border-color: #252627;
}
.btn.--dark,
.btn.--dark:hover,
.btn.--dark:active,
.btn.--dark:focus {
	color: #FFFFFF;
}
.btn.--dark:hover,
.btn.--dark:focus {
	background-color: #404243;
	border-color: #404243;
}
.btn.--purple {
	background-color: #C29CCC;
	border-color: #C29CCC;
}
.btn.--purple:hover,
.btn.--purple:focus {
	background-color: #caa9d3;
	border-color: #caa9d3;
}
.btn.--lightpurple {
	background-color: #CFA9D9;
	border-color: #CFA9D9;
}
.btn.--lightpurple:hover,
.btn.--lightpurple:focus {
	background-color: #c79bd3;
	border-color: #c79bd3;
}
.btn.--blue {
	background-color: #A5D6E9;
	border-color: #A5D6E9;
}
.btn.--blue:hover,
.btn.--blue:focus {
	background-color: #b5dded;
	border-color: #b5dded;
}
.btn.--lightblue {
	background-color: #B2DCEC;
	border-color: #B2DCEC;
}
.btn.--lightblue:hover,
.btn.--lightblue:focus {
	background-color: #a2d5e8;
	border-color: #a2d5e8;
}
.btn.--green {
	background-color: #86CABD;
	border-color: #86CABD;
}
.btn.--green:hover,
.btn.--green:focus {
	background-color: #94d0c5;
	border-color: #94d0c5;
}
.btn.--lightgreen {
	background-color: #9AD8CC;
	border-color: #9AD8CC;
}
.btn.--lightgreen:hover,
.btn.--lightgreen:focus {
	background-color: #8bd2c5;
	border-color: #8bd2c5;
}
.btn.--orange {
	background-color: #EAC8A8;
	border-color: #EAC8A8;
}
.btn.--orange:hover,
.btn.--orange:focus {
	background-color: #eed2b8;
	border-color: #eed2b8;
}
.btn.--lightorange {
	background-color: #ECD0B6;
	border-color: #ECD0B6;
}
.btn.--lightorange:hover,
.btn.--lightorange:focus {
	background-color: #e8c6a6;
	border-color: #e8c6a6;
}
.btn.--pink {
	background-color: #E2C0C2;
	border-color: #E2C0C2;
}
.btn.--pink:hover,
.btn.--pink:focus {
	background-color: #e8ced0;
	border-color: #e8ced0;
}
.btn.--lightpink {
	background-color: #E5CACB;
	border-color: #E5CACB;
}
.btn.--lightpink:hover,
.btn.--lightpink:focus {
	background-color: #debcbe;
	border-color: #debcbe;
}
.btn.--bordered {
	background-color: rgba(0, 0, 0, 0);
	border-color: #252627;
}
.btn.--bordered:hover,
.btn.--bordered:focus {
	background-color: rgba(0, 0, 0, 0.06);
}
.btn.--bordered-purple {
	background-color: #C29CCC;
	border-color: #252627;
}
.btn.--bordered-purple:hover,
.btn.--bordered-purple:focus {
	background-color: #ba8fc5;
}
.btn.--bordered-green {
	background-color: #86CABD;
	border-color: #252627;
}
.btn.--bordered-green:hover,
.btn.--bordered-green:focus {
	background-color: #78c4b5;
}
.btn.--bordered-blue {
	background-color: #A5D6E9;
	border-color: #252627;
}
.btn.--bordered-blue:hover,
.btn.--bordered-blue:focus {
	background-color: #95cfe5;
}
.btn.--bordered-pink {
	background-color: #E2C0C2;
	border-color: #252627;
}
.btn.--bordered-pink:hover,
.btn.--bordered-pink:focus {
	background-color: #dcb2b4;
}
.btn.--bordered-orange {
	background-color: #EAC8A8;
	border-color: #252627;
}
.btn.--bordered-orange:hover,
.btn.--bordered-orange:focus {
	background-color: #e6be98;
}
.btn.--bordered-lightpurple {
	background-color: #DFC9E4;
	border-color: #252627;
}
.btn.--bordered-lightpurple:hover,
.btn.--bordered-lightpurple:focus {
	background-color: #d7bbdd;
}
.btn.--bordered-lightgreen {
	background-color: #B8EBE2;
	border-color: #252627;
}
.btn.--bordered-lightgreen:hover,
.btn.--bordered-lightgreen:focus {
	background-color: #a8e7db;
}
.btn.--bordered-lightblue {
	background-color: #C7E7F4;
	border-color: #252627;
}
.btn.--bordered-lightblue:hover,
.btn.--bordered-lightblue:focus {
	background-color: #b6e0f1;
}
.btn.--bordered-lightpink {
	background-color: #EFD8DA;
	border-color: #252627;
}
.btn.--bordered-lightpink:hover,
.btn.--bordered-lightpink:focus {
	background-color: #e9cacc;
}
.btn.--bordered-lightorange {
	background-color: #F5DEC9;
	border-color: #252627;
}
.btn.--bordered-lightorange:hover,
.btn.--bordered-lightorange:focus {
	background-color: #f2d3b8;
}
.btn.--shadow-purple,
.btn.--shadow-green,
.section-config .btn.config-panel,
.btn.--shadow-blue,
.btn.--shadow-pink,
.btn.--shadow-orange {
	background-color: #252627;
	border-color: #252627;
}
.btn.--shadow-purple,
.btn.--shadow-purple:hover,
.btn.--shadow-purple:active,
.btn.--shadow-purple:focus,
.btn.--shadow-green,
.btn.--shadow-green:hover,
.btn.--shadow-green:active,
.btn.--shadow-green:focus,
.section-config .btn.config-panel,
.btn.--shadow-blue,
.btn.--shadow-blue:hover,
.btn.--shadow-blue:active,
.btn.--shadow-blue:focus,
.btn.--shadow-pink,
.btn.--shadow-pink:hover,
.btn.--shadow-pink:active,
.btn.--shadow-pink:focus,
.btn.--shadow-orange,
.btn.--shadow-orange:hover,
.btn.--shadow-orange:active,
.btn.--shadow-orange:focus {
	color: #FFFFFF;
}
.btn.--shadow-purple:hover,
.btn.--shadow-purple:focus,
.btn.--shadow-green:hover,
.btn.--shadow-green:focus,
.section-config .btn.config-panel:hover,
.section-config .btn.config-panel:focus,
.btn.--shadow-blue:hover,
.btn.--shadow-blue:focus,
.btn.--shadow-pink:hover,
.btn.--shadow-pink:focus,
.btn.--shadow-orange:hover,
.btn.--shadow-orange:focus {
	background-color: #2E2F30;
	border-color: #2E2F30;
}
.section-config.step-4 .btn.config-panel,
.btn.--shadow-purple {
	box-shadow: 4px 4px #C29CCC;
}
.section-config.step-4 .btn.config-panel:hover,
.section-config.step-4 .btn.config-panel:focus,
.btn.--shadow-purple:hover,
.btn.--shadow-purple:focus {
	box-shadow: 4px 4px #B07AC0;
}
.section-config.step-5 .btn.config-panel,
.btn.--shadow-green {
	box-shadow: 4px 4px #86CABD;
}
.section-config.step-5 .btn.config-panel:hover,
.section-config.step-5 .btn.config-panel:focus,
.btn.--shadow-green:hover,
.btn.--shadow-green:focus {
	box-shadow: 4px 4px #5BAF9B;
}
.section-config .btn.config-panel,
.btn.--shadow-blue {
	box-shadow: 4px 4px #A5D6E9;
}
.section-config .btn.config-panel:hover,
.section-config .btn.config-panel:focus,
.btn.--shadow-blue:hover,
.btn.--shadow-blue:focus {
	box-shadow: 4px 4px #6BBFDF;
}
.section-config.step-3 .btn.config-panel,
.btn.--shadow-pink {
	box-shadow: 4px 4px #E2C0C2;
}
.section-config.step-3 .btn.config-panel:hover,
.section-config.step-3 .btn.config-panel:focus,
.btn.--shadow-pink:hover,
.btn.--shadow-pink:focus {
	box-shadow: 4px 4px #D99B9E;
}
.section-config.step-2 .btn.config-panel,
.btn.--shadow-orange {
	box-shadow: 4px 4px #EAC8A8;
}
.section-config.step-2 .btn.config-panel:hover,
.section-config.step-2 .btn.config-panel:focus,
.btn.--shadow-orange:hover,
.btn.--shadow-orange:focus {
	box-shadow: 4px 4px #E5B180;
}

/*-- Multiple Buttons --*/
.btn-group .btn {
	width: 100%;
	margin-bottom: 1.25rem;
}
.btn-group .btn:last-child {
	margin-bottom: 0;
}

/**
 * @section Box Panel Styles
 */
/*-- Default --*/
.config-panel, .intro_panel,
.box-panel {
	padding: 2rem;
	background-color: #FFFFFF;
	border: 2px solid #252627;
	border-radius: 4px;
}
.--bg-lightblue.config-panel, .--bg-lightblue.intro_panel,
.box-panel.--bg-lightblue {
	box-shadow: inset 2px 2px #FFFFFF, 4px 4px #C7E7F4;
	background-color: #C7E7F4;
}
.--bg-lightgreen.config-panel, .--bg-lightgreen.intro_panel,
.box-panel.--bg-lightgreen {
	box-shadow: inset 2px 2px #FFFFFF, 4px 4px #B8EBE2;
	background-color: #B8EBE2;
}
.--bg-lightpurple.config-panel, .--bg-lightpurple.intro_panel,
.box-panel.--bg-lightpurple {
	box-shadow: inset 2px 2px #FFFFFF, 4px 4px #DFC9E4;
	background-color: #DFC9E4;
}
.intro_panel, .--bg-lightorange.config-panel,
.box-panel.--bg-lightorange {
	box-shadow: inset 2px 2px #FFFFFF, 4px 4px #F5DEC9;
	background-color: #F5DEC9;
}
.--bg-lightpink.config-panel, .--bg-lightpink.intro_panel,
.box-panel.--bg-lightpink {
	box-shadow: inset 2px 2px #FFFFFF, 4px 4px #EFD8DA;
	background-color: #EFD8DA;
}
.section-config .config-panel, .--shadow-blue.config-panel, .--shadow-blue.intro_panel,
.box-panel.--shadow-blue {
	box-shadow: 4px 4px #C7E7F4;
}
.section-config.step-5 .config-panel, .--shadow-green.config-panel, .--shadow-green.intro_panel,
.box-panel.--shadow-green {
	box-shadow: 4px 4px #B8EBE2;
}
.section-config.step-4 .config-panel, .--shadow-purple.config-panel, .--shadow-purple.intro_panel,
.box-panel.--shadow-purple {
	box-shadow: 4px 4px #DFC9E4;
}
.section-config.step-2 .config-panel, .--shadow-orange.config-panel, .--shadow-orange.intro_panel,
.box-panel.--shadow-orange {
	box-shadow: 4px 4px #F5DEC9;
}
.section-config.step-3 .config-panel, .--shadow-pink.config-panel, .--shadow-pink.intro_panel,
.box-panel.--shadow-pink {
	box-shadow: 4px 4px #EFD8DA;
}

/**
 * @section Form Styles
 */
/*-- Form Components --*/
form,
.form {
	text-align: left;
}

::placeholder {
	font-style: italic;
	color: #B8BBBC;
}

fieldset,
.form-fieldset {
	margin: 0 0 1.5rem;
}
fieldset .form-block:last-child,
.form-fieldset .form-block:last-child {
	margin-bottom: 0.75rem;
}

legend,
.form-legend {
	margin-top: 0;
	margin-bottom: 0.25rem;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.5;
}

.form-fieldset-desc {
	margin-bottom: 1.5rem;
	font-size: 0.86rem;
	color: #404243;
}

.form-block {
	margin-bottom: 1.25rem;
}
.form-block.--block-indent-1 {
	padding-left: 2rem;
}
.form-block.--block-indent-2 {
	padding-left: 4rem;
}

.btn-block {
	display: flex;
	flex-direction: column;
	padding: 1rem 0 0;
}
.btn-block .btn {
	width: 100%;
	font-size: 1.12rem;
	line-height: 3;
	margin-bottom: 1rem;
}
.btn-block .btn:last-child {
	margin-bottom: 0;
}

.input-checkbox {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
}
.input-checkbox input[type=checkbox] {
	margin-right: 0.75rem;
}
.input-checkbox label,
.input-checkbox .label {
	margin-top: 8px;
}

.input-color {
	margin-bottom: 0.75rem;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: flex-start;
}
.input-color .clr-field {
	margin-right: 1rem;
	width: 130px;
}
.input-color .clr-field button {
	width: 22px;
	height: 22px;
	left: 5px;
	right: auto;
	border-radius: 8px;
}
.input-color .clr-field input {
	padding-left: 36px;
}
.input-color label,
.input-color .label {
	font-weight: 400;
	font-style: italic;
}

.form-radio-block {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
}
.form-radio-block input[type=radio] {
	width: 20px;
}
.form-radio-block label.label {
	width: auto;
	margin: 8px 30px 8px 8px;
}

.form-block-nav {
	display: flex;
	flex-direction: column;
	margin-bottom: 0;
	text-align: center;
}

.form-error {
	margin: 0.5rem 0 0 0;
	font-size: 0.86rem;
	font-style: italic;
	color: #D15B5B;
}

.form-success {
	text-align: center;
}
.form-success p {
	margin-bottom: 1rem;
}

.form-extra-help {
	visibility: hidden;
	display: block;
	margin: 0;
	padding: 0;
	max-height: 0;
	font-size: 0.86rem;
	font-style: italic;
	color: #FFFFFF;
	transition: all 0.15s ease-out;
}
.input-text:active + .form-extra-help, .input-text:focus + .form-extra-help {
	visibility: visible;
	padding-top: 0.5rem;
	max-height: 100px;
	color: #404243;
	transition: all 0.25s ease-in;
}

/*-- Labels --*/
label,
.label {
	display: block;
	margin-bottom: 0.5rem;
	font-weight: 500;
}

.label-large {
	font-size: 1.12rem;
	display: block;
	margin-bottom: 0.65rem;
	font-weight: 500;
}

.label-error {
	color: #D15B5B;
}

/*-- Inputs / Textareas --*/
input[type=text],
input [type=number],
input[type=email],
input[type=password],
input[type=tel],
input[type=url],
.input-text,
textarea,
.input-textarea {
	padding: 0.5rem;
	width: 100%;
	color: #252627;
	background-color: #FFFFFF;
	border: 2px solid #cdcfd0;
	border-radius: 4px;
	box-shadow: 0;
	-webkit-appearance: none;
}
input[type=text]:focus,
input [type=number]:focus,
input[type=email]:focus,
input[type=password]:focus,
input[type=tel]:focus,
input[type=url]:focus,
.input-text:focus,
textarea:focus,
.input-textarea:focus {
	background-color: #FFFFFF;
	border: 2px solid #C29CCC !important;
	outline: none;
	box-shadow: 0 0 0 0.25rem #F1F5F7;
}

textarea,
.input-textarea {
	min-height: 160px;
}

input[type=hidden] {
	display: none;
}

/*-- SearchInputs --*/
input[type=search],
.input-search {
	box-sizing: border-box;
}

/*-- Button Inputs --*/
input[type=button]:disabled,
.input-btn:disabled,
input[type=submit]:disabled,
.input-submit:disabled,
input[type=reset]:disabled,
.input-reset:disabled {
	opacity: 0.75;
}

/**
 * @section Form Custom Field Styles
 */
/*-- Form Custom Field Components --*/
.form-fields-custom__header .form-msg {
	margin-bottom: 0.75rem;
	font-size: 0.76rem;
	font-style: italic;
}
.form-fields-custom__header .btn {
	width: 100%;
	margin-bottom: 1rem;
}
.form-fields-custom__main .custom-field {
	margin-bottom: 0.75rem;
	display: grid;
	grid-template-columns: 46px auto 34px;
	gap: 5px;
	align-items: flex-start;
}
.form-fields-custom__main .custom-field .label {
	font-size: 0.76rem;
}
.form-fields-custom__main .custom-field .input-checkbox {
	flex-direction: column;
}
.form-fields-custom__main .custom-field .input-checkbox input[type=checkbox] {
	margin: 0.75rem 0 0 0;
}
.form-fields-custom__main .custom-field .input-checkbox label,
.form-fields-custom__main .custom-field .input-checkbox .label {
	margin-top: 0;
}
.form-fields-custom__main .custom-field .form-block {
	margin-bottom: 0;
}
.form-fields-custom__main .custom-field .form-block .label {
	text-align: center;
}
.form-fields-custom__main .custom-field .btn {
	margin-top: 1.75rem;
}

/**
 * @section App Section Styles
 */
.main,
section[class^=section-] {
	width: 100%;
	min-width: 1024px;
	height: 100%;
}

section[class^=section] {
	overflow-y: auto;
}

.section-intro,
.section-config,
.section-result {
	display: none;
}

.section-intro {
	padding: 4.5rem 2rem;
}

.section-config {
	background-position: center;
	transition: 0.3s background-color;
	background-image: url("../svg/patt-dots.svg");
	background-color: #DFC9E4;
	background-size: 2%;
}
.section-config.step-1 {
	background-image: url("../svg/patt-dots.svg");
	background-color: #DFC9E4;
	background-size: 2%;
}
.section-config.step-2 {
	background-image: url("../svg/patt-wave-horz.svg");
	background-color: #B8EBE2;
	background-size: 2.2%;
}
.section-config.step-3 {
	background-image: url("../svg/patt-line-vert.svg");
	background-color: #C7E7F4;
	background-size: 1.5%;
}
.section-config.step-4 {
	background-image: url("../svg/patt-wave-vert.svg");
	background-color: #F5DEC9;
	background-size: 1.75%;
}
.section-config.step-5 {
	background-image: url("../svg/patt-dots.svg");
	background-color: #EFD8DA;
	background-size: 2%;
}
.section-result {
	padding: 4.5rem 2rem;
	background-image: url("../svg/patt-dots.svg");
	background-size: 2%;
}

/**
 * @section Section Intro Styles
 */
.intro {
	margin: 0 auto;
	max-width: 720px;
}
.intro_header {
	display: flex;
	flex-direction: row;
	align-items: center;
}
.intro_header_text {
	margin-right: -5rem;
}
.intro_img {
	margin: 0 auto 2.5rem;
	width: 100%;
	max-width: 420px;
}
.intro_title {
	padding-top: 0;
	font-size: 3rem;
	margin-bottom: 0.25rem;
}
.intro_subtitle {
	text-align: center;
	font-size: 1.18rem;
	font-style: italic;
}
.intro_panel {
	max-width: 680px;
	margin: 0 auto 1.75rem;
	padding: 2.5rem;
	font-size: 1.22rem;
	font-style: italic;
	text-align: center;
}
.intro_panel p {
	margin-bottom: 0;
}
.intro_text {
	margin: 0 auto;
	max-width: 560px;
	text-align: center;
}
.intro #formStart .form-block-platform {
	margin: 1.5rem 0 0.5rem;
	text-align: center;
}
.intro #formStart .form-block-platform span.label {
	margin-bottom: 0;
	font-size: 1.12rem;
	font-style: italic;
}
.intro #formStart .form-block-platform .form-radio-block {
	justify-content: center;
}
.intro #formStart .btn {
	font-size: 1.5rem;
	line-height: 2.66;
	padding-left: 1.6em;
	padding-right: 1.6em;
}

/**
 * @section App Configuration Panel Styles
 */
.config-panel {
	transition: 0.3s all;
	position: fixed;
	top: 3rem;
	left: 3rem;
	width: 340px;
	height: auto;
	min-height: 280px;
	max-height: calc(100vh - 6rem);
	overflow-y: auto;
}
.config-panel #blockShopifyPage,
.config-panel #blockWishlistFeatures,
.config-panel #blockWishlistStyles,
.config-panel #blockWishlistQuickAddIcon,
.config-panel #blockStylesWishlistQuickAddIcon,
.config-panel #blockWishlistFormText,
.config-panel #blockWishlistSubmittedText,
.config-panel #blockWishlistFormCustomFields,
.config-panel #blockSearchBtn,
.config-panel #blockWishlistQuickAddIconStyle,
.config-panel #blockAddMoreBtn,
.config-panel #blockViewWishlistBtn,
.config-panel #blockSubmitWishlistBtn,
.config-panel #blockAddRemoveWishlistBtn,
.config-panel #blockSubmitWishlistFormBtn,
.config-panel #blockListingDisplayPricePosition {
	display: none;
}
.config-panel #configPlatform {
	display: inline-block;
	font-size: 0.82rem;
	padding: 0.2rem 0.5rem;
	margin-bottom: 1rem;
	font-weight: 700;
	background-color: #E5CACB;
	border-radius: 2px;
}
.config-panel .panel-section_title {
	padding-top: 0;
}
@media only screen and (min-width: 1024px) {
	.config-panel {
		width: 440px;
	}
}

/**
 * @section App Configuration Information Styles
 */
.config-info {
	margin-left: calc(340px + 3rem);
	padding: 3rem 4rem;
}
.config-info .info-section {
	max-width: 680px;
	padding: 2rem;
	margin: 0 auto;
	background-color: #FFFFFF;
	border-radius: 3px;
}
@media only screen and (min-width: 1024px) {
	.config-info {
		margin-left: calc(440px + 3rem);
	}
}

.config-section {
	margin-bottom: 1.5rem;
	padding: 2rem 1.5rem 2rem;
	text-align: center;
	background-color: #FFFFFF;
	border: 2px solid #FFFFFF;
	border-radius: 3px;
}
.config-section:last-child {
	margin-bottom: 0.25rem;
}
.config-section.active {
	background-color: #EEFEFB;
	border: 2px solid #76C0B2;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
	transition: all 0.5s ease;
}
.config-section_title {
	padding-top: 0;
}
.config-section_media {
	width: 100%;
	max-width: 520px;
	margin-bottom: 1rem;
	border: 1px solid #EDF1F4;
	border-radius: 3px;
}
.config-section p:last-child {
	margin-bottom: 0;
}

/**
 * @section Section Result Styles
 */
.result {
	margin: 0 auto;
	max-width: 680px;
}
.result_title {
	text-align: center;
	padding-top: 0;
	margin-bottom: 2rem;
	font-size: 2.5rem;
}
.result_text {
	text-align: center;
	margin-bottom: 2rem;
}
.result_text p:first-child {
	font-size: 1.12rem;
	font-style: italic;
}
.result_text p:last-child {
	margin-bottom: 0;
}
.result_form {
	margin: 0 auto;
	width: 380px;
}
.result_form .form-block {
	display: flex;
	align-items: center;
}
.result_form .label {
	text-align: right;
	margin-right: 10px;
	min-width: 125px;
}
.result_output-panel {
	padding: 0.5rem;
	background-color: #2E2F30;
	color: #F1F5F7;
	border: 2px solid #E3BC98;
	border-radius: 4px;
	box-shadow: 0 10px 25px rgba(0, 0, 0, 0.25);
}
.result_output-pre {
	padding: 3rem 5rem;
}
.result_controls {
	padding-top: 0.5rem;
	display: flex;
	flex-direction: row-reverse;
	justify-content: space-between;
}
.result_output-copied-msg {
	display: none;
	font-family: "Roboto Mono", monospace;
	font-weight: 500;
	color: #FFFFFF;
	background-color: rgba(0, 0, 0, 0.3);
}
.result #btnOutputCopy {
	animation: wiggle 3s infinite;
}
.result .guide-link {
	margin-top: 2.5rem;
}
.result .guide-link .btn {
	display: block;
	width: 100%;
	line-height: 3.5;
}
.result .guide-link .btn .icon {
	position: relative;
	top: 4px;
	margin-left: 8px;
}