@charset "utf-8";

/* Site colours */
:root {
	--feature: #8D99AE;
    --feature2: #D90429;
	--text: #222;
	--links: #B50000;
    --links--hover: #D90429;
	--error: #dd0000;		
    --button-bg: #D90429;
    --button-text: #fff;
    --header-bg: #111;
	--header-text: #fff;
    --footer-bg: #111;
	--footer-text: #888;
	--borders-input: #ddd;
}

html {font-family: 'Poppins', arial, verdana, sans-serif; font-size: 15px; color: var(--text); box-sizing: border-box; -webkit-tap-highlight-color: #fff; min-height: 100%; background-color: #fff; scroll-behavior: smooth;}
button, textarea, select, input[type='text'], input[type='password'] {font-family: 'Poppins', arial, verdana, sans-serif; font-size: 1em;}
textarea, select, input[type='text'], input[type='password'] {border: 1px solid var(--borders-input); outline: none; box-sizing: border-box; background: #fff; padding: 8px 10px; }
select:focus, input[type='text']:focus, input[type='password']:focus, textarea:focus {outline: 5px solid rgba(0,0,0,0.08);}
button {cursor:pointer;}
hr {border: none; margin: 30px 0; padding: 0; height: 1px; background: #ddd;}

body {position:relative; display: flex; flex-direction: column; margin: 0; padding: 0; min-height: 100vh; }
body > header {flex-grow: 0; flex-shrink: 0;}
body > .main {flex-grow: 1; flex-shrink: 0;}
body > footer {flex-grow: 0; flex-shrink: 0;}

.alignL {text-align: left;}
.alignC {text-align: center;}
.alignR {text-align: right;}

.waiting {}
body > .waiting {position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(255,255,255,0.4); }
.waiting:before {content: ""; position: absolute; top: 50%; left: 50%; width: 40px; height: 40px; margin-top: -20px; margin-left: -20px; box-sizing: border-box; border: 8px solid #fff; border-radius: 50%;}
.waiting:after {content: ""; position: absolute; top: 50%; left: 50%; width: 36px; height: 36px; margin-top: -18px; margin-left: -18px; box-sizing: border-box; border: 4px solid var(--feature); border-top-color: transparent; border-radius: 50%; animation: spin 1.5s infinite linear}

a {text-decoration: none; color: var(--links)}
a:hover {text-decoration: none; color: var(--links--hover)}
p {display: block; margin-top: 1em; margin-bottom: 1em;}
small {font-size: 0.8em; line-height: 1.4}
select option:disabled {color: #b8b8b8;}

.hidden {display:none;}
.any--sticky {position: sticky;  top: 0; overflow-y: auto; }
.empty {text-align:center; margin: 1em 0; } 
.empty:before {content: ""; display: block; padding-top: 1px; margin-bottom: 40px; }
.empty:after {content: ""; display: block; padding-bottom: 1px; margin-top: 40px; }
.error-message {color: var(--error);}
.discount {color:var(--discount); }

/* Universal padding // UNIP */
.unip:before {content: ""; position: relative; display:block; margin-bottom: 30px; padding-top: 1px; }
.unip:after {content: ""; position: relative; display:block; margin-top: 30px; padding-bottom: 1px; }
.unip--l:before {margin-bottom: 60px;}
.unip--l:after {margin-top: 60px;}
.unip--s:before {margin-bottom: 15px;}
.unip--s:after {margin-top: 15px;}

/* Headings */
h1, h2, h3, h4, h5 {line-height: 1;}
h1, .title-xlarge {display: block; font-size: 1.6em; margin: 2rem 0 1rem 0; font-weight: 600;}
h2, .title-large {display: block; font-size: 1.4em; margin: 2rem 0 1rem 0; font-weight: 600;}
h3, .title-medium {display: block; font-size: 1.2em; margin: 20px 0 1rem 0; font-weight: 600;}
h4, h5, h6, .title-small {display: block; font-size: 1.1em; margin: 20px 0 1rem 0; font-weight: 600;}
table {border: 1px solid #ccc; border-collapse: collapse; }
table td {border-top: 1px solid #ccc; }

.cta {}
.cta a {display: block; background-color: var(--button-bg); padding: 5px 20px; border: 2px solid var(--button-bg); border-radius: 4px; color: var(--button-text); transition: all ease-in 0.1s; text-align: center; text-decoration: none; }
.cta a:hover {color: var(--button-bg); background-color: var(--button-text); }

.button-container {display: flex; position: relative; margin: 20px 0; align-content: center; justify-content: space-between; gap: 20px; }
.button-container button {position: relative; box-sizing: border-box; display: inline-block; background-color: var(--button-bg); padding: 10px 50px; border: 2px solid var(--button-bg); border-radius: 4px; color: var(--button-text); font-weight: 400; text-align:center; transition: all ease-in 0.1s;}
.button-container button:hover {position: relative; background-color: #fff; color: var(--button-bg)}
.button-container a {position: relative;  box-sizing: border-box; display: inline-block; background-color: var(--button-bg); padding: 10px 50px; border: 2px solid var(--button-bg); border-radius: 4px; color: #fff; font-weight: 400; text-align:center; transition: all ease-in 0.1s;}
.button-container a:hover {background: var(--button-text); color: var(--button-bg); border: 2px solid var(--button-bg);}
.button-container button.inactive {color:#eee; background: #ccc; border-color: #ccc; pointer-events: none;}
.button-container a.inactive {color:#eee; background: #ccc; border-color: #ccc; pointer-events: none;}
.button-container button.dimmed {color:#fff; background: #ccc; border-color: #ccc; }
.button-container a.dimmed {color:#fff; background: #ccc; border-color: #ccc; }

@media screen and (max-width: 900px) { 
    .button-container button {display: block; width: 100%;}
    .button-container a {display: block; width: 100%;}
}
@media screen and (max-width: 900px) { 
	.button-container {flex-direction: column; gap: 10px; }
}

/* Body Containers + Columns */
.main {position: relative; text-align: center;}
.container {position:relative; margin-left: auto; margin-right: auto; max-width: 1000px; padding-left: 30px; padding-right: 30px; box-sizing: border-box; }
.container .container {padding-left: 0; padding-right: 0;}
.content-image {margin: 30px auto; width: 100%; max-width: 1300px; }
.content-image img {width: 100%; border-radius: 10px; }
.content-text {margin: 30px auto; max-width: 750px; padding: 0 30px; box-sizing: border-box;}
.container .content-text {padding: 0; }
.content-button {margin: 30px auto; max-width: 1300px; padding: 0 30px; box-sizing: border-box;}
.content-button a {display: block; margin: 0 auto; padding: 10px; color: var(--button-text); background: var(--button-bg); font-weight: 700; font-size: 1.1; border-radius: 20px; width: 100%; max-width: 300px; text-align: center; }
.cookies-table {border:1px solid #ccc; border-collapse: collapse; width: 100%; ma-wiidth: 1300px; margin: 20px auto;}
.cookies-table thead td {font-weight: 700;}
.cookies-table td {padding: 5px 10px; border: 1px solid #ccc; text-align: left;}
@media screen and (max-width: 600px) {
	.container {padding-left: 15px; padding-right: 15px; } 
	.content-text {padding-left: 15px; padding-right: 15px; } 
}
.button-small {display:inline-block; padding: 3px 8px; margin: 1px; font-size: 0.8em; color: var(--button-text); background: var(--button-bg); border: 1px solid var(--button-bg); border-radius: 8px; cursor:pointer; transition: all ease-in 0.1s; }
.button-small:hover {color: var(--button-bg); background-color: var(--button-text); }

/* Headers */

header {background: rgb(14,15,13); background: linear-gradient(108deg, rgba(14,15,13,1) 0%, rgba(22,25,18,1) 100%);}
header .header-links {display: flex; gap: 20px; justify-content: flex-end; }
header .header-links a {display: block; padding: 6px; color: #fff;}
header .header-main {display: flex; align-items: center; justify-content: space-between; background: url("../_IMG/dots.svg") no-repeat; background-position: right; background-size: auto 60%;}
header .hi {font-size: 15px; color: #fff;}
header h1 {font-size: 55px; font-weight: 700; color: #fff; margin: 0;}
header h2 {font-size: 55px; font-weight: 700; color: #707965; margin: 0;}
header .button {margin: 20px 0;}
header .button a {display: inline-block; padding: 10px 20px; border: 1px solid #fff; color: #fff;} 
header .header-main img {display: block; width: 340px; height: 320px; object-fit: contain; object-position: bottom; }
@media screen and (max-width: 900px) {
	header h1 {font-size: 40px; }
	header h2 {font-size: 40px; }
	header .header-main img {width: 290px; }
}
@media screen and (max-width: 750px) {
	header .header-links a span {display: none;}
	header .header-main {display: block; margin-top: 20px;  } 
	header .header-main img {display: block; height: 150px; width: 100%; object-position: right;} 
}

.post-group-container {position: relative; display: grid; grid-template-columns: 1fr; gap: 40px; margin: 40px auto; text-align: left; }
.post-group {position: relative; display: grid; grid-template-columns: 2fr 3fr; gap: 10px 20px; overflow: hidden; }
.post-group .post-group__image {position: relative; width: 100%; height: 0; padding-bottom: 65%; border-radius: 5px; overflow: hidden; background: url(../_IMG/trans.gif) #ddd; border: 1px solid #ccc;cursor: pointer}
.post-group .post-group__image img {position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: contain;}
.post-group .post-group__image i {position: absolute; left: 0; top: 50%; width: 100%; line-height: 0; text-align: center; font-size: 50px; color: #ccc; }
.post-group .post-group__tag { position: absolute; display:flex; flex-direction: column; justify-content: flex-end; box-sizing: border-box; top: -40px; right: -40px; width: 80px; height: 80px; text-align: center; transform:rotate(45deg); padding: 2px; background: var(--feature2); color: #fff; }
.post-group .post-group__text {display: flex; flex-direction: column; gap: 10px; justify-content: space-between; }
.post-group .post-group__text .post-group__title {display: flex; gap: 10px; align-items: center; justify-content: space-between; margin-bottom: 4px; color: inherit; }
.post-group .post-group__text .post-group__title span {font-weight: 600; font-size: 1.2em; }
.post-group .post-group__text .post-group__title a {display: flex; align-items: center; gap: 5px; font-size: 0.8em; color: inherit;}
.post-group .post-group__text .post-group__title a i {font-size: 18px; color: var(--links);}
.post-group .post-group__text p {margin-bottom: 0;}
.post-group .post-group__images {display: grid; grid-template-columns: repeat(7, 1fr); gap: 5px;}
.post-group .post-group__images img {display: block; width: 100%; height: auto; border-radius: 5px;  cursor: pointer; border: 1px solid #ccc;}
.post-group .post-group__images :nth-child(n+8) {display: none;}


.post-group .modalContent{display:none;}
@media screen and (max-width: 1000px) { 
	.post-group {grid-template-columns: 1fr; }
	.post-group .post-group__images {grid-template-columns: repeat(5, 1fr);}
	.post-group .post-group__images :nth-child(n+8) {display: block;}
}

.socials {margin: 1em 0; text-align:center;display: flex; gap: 10px; align-items: center; justify-content: center; }
.socials a {font-size: 20px; padding: 22px 0; width: 44px; border: 1px solid rgba(255,255,255,0.5); color: #fff;  border-radius: 50%; line-height: 0; opacity: 0.4; transition: opacity 0.2s;  }
.socials a:hover {opacity: 1; }

.cookie-container {position: fixed; z-index:10; top: 0; left: 0; width:100%; height: 100%; overflow: hidden; pointer-events: none; transition: all 300ms linear; }
.cookie-container.active { backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); background: rgba(0,0,0,0.4); pointer-events: all;} 
.cookie-container > div {position: absolute; bottom: 0; left: 0; height: 0; width: 100%; overflow: hidden; background: #111; color: #fff;}
.cookie-container a {color: inherit; text-decoration: underline;}	
.cookie-container > div >  div {position: absolute; top: 0; left: 0; width: 100%;}
.cookie-container .cookie-container__inner {display:flex; width: 100%; color: #fff; gap: 60px; align-items: center; }
.cookie-container .cookie-container__inner > div {flex-grow: 1;}
.cookie-container .cookie-container__inner > div.buttons {flex-grow: 0; text-align: right; padding: 20px 0; display: flex; flex-direction: column; gap: 10px; }
.cookie-container .cookie-container__inner > div.buttons a {display: inline-block; width: auto; border: 1px solid #fff; color: #fff; text-decoration: none; padding: 6px 10px; transition: all 0.3s; white-space:nowrap }
.cookie-container .cookie-container__inner > div.buttons a:hover {background: #fff; color: var(--feature);}
.cookie-container > div.open {height: auto; }
.cookie-container > div.open > div {position: relative; }
@media screen and (max-width: 900px) { 
	.cookie-container .cookie-container__inner {display:block; }
	.cookie-container .cookie-container__inner > div.buttons {padding-top: 0; align-items: center; justify-content: flex-start; flex-direction: row; text-align: left; }
}
.cookie-options {max-width: 700px; margin: 20px auto; padding: 0 30px; text-align: left  }
#modal .cookie-options {margin: 0; padding: 0;  }
#modal .content-text { padding: 0;  }
.cookie-options hr {margin: 20px 0;}
.cookie-options p {margin: 0 0 1em 0;}
.cookie-options .checkbox {margin: 3px 0;}
.cookie-options .checkbox label {display: flex; position: relative; align-items: center; justify-content: left; cursor: pointer;}
.cookie-options .checkbox label input[type=checkbox] {position: absolute; opacity: 0; pointer-events: none; }
.cookie-options .checkbox label i {position: relative; display: block; margin-right: 10px; width: 26px; height: 26px; border: 1px solid var(--borders-input); outline: none }
.cookie-options .checkbox.checked label i {border-color: #111; background: #111;}
.cookie-options .checkbox.checked label i:after {content: ""; position: absolute; top: 50%; left: 50%; margin-left: -7px; margin-top: -5px; width: 14px; height: 7px; box-sizing: border-box; border-bottom: 3px solid #fff; border-left: 3px solid #fff; transform: rotate(-45deg);}
.cookie-options .checkbox-always {margin: 3px 0;}
.cookie-options .checkbox-always label {display: flex; position: relative; align-items: center; justify-content: left; }
.cookie-options .checkbox-always label i {position: relative; display: block; margin-right: 10px; width: 26px; height: 26px; border: 1px solid #ccc; background: #ccc;}
.cookie-options .checkbox-always label i:after {content: ""; position: absolute; top: 50%; left: 50%; margin-left: -7px; margin-top: -5px; width: 14px; height: 7px; box-sizing: border-box; border-bottom: 3px solid #fff; border-left: 3px solid #fff; transform: rotate(-45deg);}

/* Forms */
.main > form {margin: 30px auto; max-width: 850px; padding: 0 30px; box-sizing: border-box;}
.form {margin: 30px auto; max-width: 1300px; padding: 0 0px; box-sizing: border-box;}
.form .field {position: relative; margin: 20px 0;}
.form label {display: block; margin: 5px 0; }
.form.floating-labels textarea,.form.floating-labels select, .form.floating-labels input[type='text'], .form.floating-labels input[type='password'] {padding: 12px 10px 4px 10px; }
.form.floating-labels label {position: absolute; left: 1px; top: 1px; z-index: 1; pointer-events: none; padding: 8px 0 0 10px; transition: all 0.2s; margin: 0; }
.form.floating-labels .field.fl-active label {font-size:9px; padding-top: 2px; opacity: 0.6; }
.form .error-message {color: var(--error); display:none; margin-top: 5px; }
.form .error-message.active {display:block; }
.form input[type=text], .form input[type=password], textarea, select {width: 100%; }

.form .select-container select {-webkit-appearance: none; -moz-appearance: none; }
.form .select-container select::-ms-expand { display: none; }
.form .select-container {position: relative; }
.form .select-container:after {content: ""; position: absolute; right: 10px; top: 50%; margin-top: -7px; width: 8px; height: 8px; border-right: 1px solid #555; border-bottom: 1px solid #555; transform: rotate(45deg); box-sizing: border-box; pointer-events: none; z-index: 1; }

.form .checkbox {margin: 3px 0;}
.form .checkbox label {display: flex; position: relative; align-items: center; justify-content: left; cursor: pointer;}
.form .checkbox label input[type=checkbox] {position: absolute; opacity: 0; pointer-events: none; }
.form .checkbox label i {position: relative; display: block; margin-right: 10px; width: 22px; height: 22px; border: 1px solid var(--borders-input); }
.form .checkbox.focused label i {outline: 4px solid rgba(0,0,0,0.08);}
.form .checkbox.checked label i:after {content: ""; position: absolute; top: 50%; left: 50%; margin-left: -7px; margin-top: -5px; width: 14px; height: 7px; box-sizing: border-box; border-bottom: 3px solid var(--text); border-left: 3px solid var(--text); transform: rotate(-45deg);}

.form .radio {margin: 3px 0;}
.form .radio label {display: flex; align-items: center; justify-content: left; cursor:pointer;}
.form .radio label input[type=radio] {position: absolute; opacity: 0;  pointer-events: none;}
.form .radio label i {position: relative; display: block; margin-right: 10px; width: 20px; height: 20px; border: 1px solid #bbb;; border-radius: 50%; }
.form .radio.focused label i {outline: 4px solid rgba(0,0,0,0.08);}
.form .radio.checked label i:after {content: ""; position: absolute; left: 5px; top: 5px; right: 5px; bottom: 5px; background: var(--text); border-radius: 50%; }

.form .date-container {display: flex; width: 100%; margin: 0 -2px; }
.form .date-container .select-container {width: 100%; padding: 2px; }

.form .searchList-container {position: relative; }
.form .searchList-container .searchList-display {position: relative; outline: none; line-height: 1.1;  }
.form .searchList-container .searchList-display > div {position: relative; box-sizing: border-box; border: 1px solid #ccc; background: #fff; color: #333; outline: none; padding: 8px 10px;; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; cursor: pointer}
.form .searchList-container .searchList-opener {display:none;}
.form .searchList-container.active .searchList-display > div {border-bottom-left-radius: 0; border-bottom-right-radius: 0; border-bottom: 1px solid #ccc;}
.form .searchList-container.active .searchList-cover {position: fixed; width: 100%; height: 100%; top: 0; left: 0; z-index: 6; background: rgba(0,0,0,0.1); }
.form .searchList-container.active .searchList-opener {z-index: 8; border: 1px solid #ccc; border-top: none; } 
.form .searchList-container.active .searchList-opener {display: block; position: absolute; top: 100%; left: 0; width: 100%; background: #fff; font-size: 14px; overflow: hidden; }
.form .searchList-container.active .searchList-opener .searchList-search {padding: 10px; position: relative;  }
.form .searchList-container.active .searchList-opener .searchList-search input[type=text] { border: 1px solid #aaa; padding: 5px 10px; font-size: 15px; background: #fff;   }
.form .searchList-container.active .searchList-opener .searchList-search i {position: absolute; top: 50%; right: 20px; line-height: 0; pointer-events: none; color:#333; }
.form .searchList-container.active .searchList-opener .searchList-result {position: relative; max-height: 220px; overflow: auto; }
.form .searchList-container.active .searchList-opener .searchList-result ul { margin: 0; padding: 0; list-style: none; text-align: left; }
.form .searchList-container.active .searchList-opener .searchList-result ul li { border-top: 1px solid #ccc;}
.form .searchList-container.active .searchList-opener .searchList-result ul li a {display: block; position: relative; padding: 8px 15px 5px 15px; text-decoration: none; color: #333;  }
.form .searchList-container.active .searchList-opener .searchList-result ul li a i {position: absolute; top: 50%; right: 10px; line-height: 0; }
.form .searchList-container.active .searchList-opener .searchList-result ul li a:hover {background: var(--button-bg); color: var(--button-text);}
.form .searchList-container.active .searchList-opener .searchList-result ul li a::after {content: ""; position: absolute; box-sizing: border-box;  right: 10px; top: 50%; margin-top: -3px; width: 6px; height: 6px; border-top: 1px solid #333; border-right: 1px solid #333; transform: rotate(45deg);}
.form .searchList-container.active .searchList-opener .searchList-result ul li a:hover::after {border-color: var(--button-text);}
.form .searchList-container.active .searchList-opener .searchList-result ul li.active a {background: #1e3664; color: #fff;}
.form .searchList-container.active .searchList-opener .searchList-result ul li a b {display: block; }
.form .searchList-container.active .searchList-opener .searchList-result.waiting ul {opacity: 0.5;}
.form .searchList-container.active .searchList-opener .searchList-result.waiting:after {content: ""; position: absolute; top: 50%; left: 50%; width: 26px; height: 26px; margin-top: -13px; margin-left: -13px; border: 5px solid #fff; border-right: 5px solid rgba(255,255,255,0.5); border-radius: 50%; box-sizing: border-box; animation: spin 1.5s linear infinite;  }
.form .searchList-container.active .searchList-opener .searchList-result .empty {padding: 20px 0; color: #333; font-size: 0.8em; text-align: center;}

.form .qty-container {display:flex; align-items: center; justify-content:flex-start; }
.form .qty-container span {position: relative; display: block; box-sizing: border-box; width: 36px; height: 36px; background: var(--button-bg); cursor: pointer; border-radius: 4px; transition: ease-in-out all 0.2s; border: 2px solid var(--button-bg);   }
.form .qty-container span.inactive {background: #eee; pointer-events: none; border: 2px solid #ddd; }
.form .qty-container span.minus:before {content: ""; position: absolute; top: 50%; left: 50%; width: 16px; height: 2px; margin-top: -1px; margin-left: -8px; background: var(--button-text);}
.form .qty-container span.minus.inactive:before {background: #ccc;}
.form .qty-container span.plus:before {content: ""; position: absolute; top: 50%; left: 50%; width: 16px; height: 2px; margin-top: -1px; margin-left: -8px; background: var(--button-text);}
.form .qty-container span.plus:after {content: ""; position: absolute; top: 50%; left: 50%; width: 2px; height: 16px; margin-top: -8px; margin-left: -1px; background: var(--button-text);}
.form .qty-container input {width: 60px; margin: 0 5px; text-align:center;}
.form .qty-container span:hover {background: #fff; }
.form .qty-container span:hover.plus:before { background: var(--feature);}
.form .qty-container span:hover.plus:after { background: var(--feature);}
.form .qty-container span:hover.minus:before { background: var(--feature);}
.form .qty-container span:hover.minus:after { background: var(--feature);}

.form .upload-container .uploader-inner { position: relative; padding: 0 0 0 111px; min-height: 101px; }
.form .upload-container .thumb {position: absolute; display: flex; overflow: hidden; align-items: center; justify-content: center; left: 0; top: 0; width: 101px; height: 101px;cursor: pointer; box-sizing: border-box; background-color: #eee; border: 1px solid #ccc; }
.form .upload-container .thumb img {max-height: 100px; max-width: 100px; }
.form .upload-container .thumb i {position: absolute; top: 50%; left: 0; width: 100%; line-height: 0; color: #ccc; text-align: center; font-size: 30px;}
.form .upload-container .thumb a {display: none;}
.form .upload-container .thumb .progress {position: absolute; z-index: 1; left: 0;bottom: 0;width: 100%; border-top: 1px solid #ccc; height: 6px; background: #fff; box-sizing: border-box;}
.form .upload-container .thumb .progress div {position: absolute; left: 0; top: 0;height: 100%; background: red;}
.form .upload-container .thumb.active i {display: none;}
.form .upload-container .thumb.active a {position: absolute; display: block; top: 0; right: 0; width: 20px; padding: 10px 0; color: #fff; background: rgba(0, 0, 0, 0.4); }
.form .upload-container .thumb.active a:after {content: ""; position: absolute; background: #fff; width: 16px; height: 2px; top: 50%; left: 50%; margin-top: -1px; margin-left: -8px; transform: rotate(-45deg); border-radius: 2px; }
.form .upload-container .thumb.active a:before { content: ""; position: absolute; background: #fff; width: 16px; height: 2px; top: 50%; left: 50%; margin-top: -1px; margin-left: -8px; transform: rotate(45deg); border-radius: 2px; }
.form .upload-container .thumb.active a:hover {background: red;}
.form .upload-container .thumb:before {content: ""; position: absolute; top: 50px; left: -30px; right: -30px; height: 1px; background: #ccc; transform: rotate(45deg); }
.form .upload-container .thumb:after {content: ""; position: absolute; top: 50px; left: -30px; right: -30px; height: 1px; background: #ccc; transform: rotate(-45deg); }
.form .upload-container .thumb.active:before {display:none;}
.form .upload-container .thumb.active:after {display:none;}
.form .upload-container .details {font-size: 0.7em;} 
.form .upload-container .button {margin-bottom: 5px; }
.form .upload-container .button a {display:inline-block; padding: 10px 20px; background: var(--button-bg); color: var(--button-text); border:none; outline: none;  border-radius: 4px; }

.form .success-message {display:none;}

form.loading .form {pointer-events: none;}
form.loading .form  .field {opacity: 0.5; }
form.loading .form .button-container button {color: transparent;}
form.loading .form .button-container button {color: transparent;}
form.loading .form .button-container button:before {border-color: transparent;}
form.loading .form .button-container button:after {content: ""; position: absolute; border: 3px solid var(--button-text); border-top-color: transparent; width: 16px; height: 16px; left: 50%; top: 50%; margin-left: -8px; margin-top: -8px; border-radius: 50%; box-sizing: border-box; animation: spin 1.5s infinite linear; }

/* Footer */
footer {position: relative; width: 100%; background: var(--footer-bg); font-size: 13px; color: var(--footer-text); }
footer .content-text {margin: 1em auto; }

/* Modals */
#modal { position: fixed; display:flex; align-items: center; justify-content: center; width: 100%; height: 100%; left: 0; top: 0; background: rgba(0, 0, 0, 0.45); z-index: 200; cursor: pointer; backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);; }
#modal.hidden {display:none;}
#modal .inner {position: relative; width: 100%; max-width: 700px; max-height: 100%; cursor: default; padding: 20px; box-sizing: border-box; }
#modal .inner #content { position: relative; max-height: 95vh; max-height: calc(100vh - 60px); background: #fff; padding: 0 30px; text-align: left; border-radius: 5px; overflow: auto; -ms-overflow-style: none;  /* IE and Edge */ scrollbar-width: none;  /* Firefox */ }
#modal .inner #content::-webkit-scrollbar {display: none;}
#modal .inner #content:before { content: ""; display: block; margin-bottom: 30px; padding-top: 1px; }
#modal .inner #content:after { content: ""; display: block; margin-top: 30px; padding-bottom: 1px; }
#modal .inner #content h1, #modal .inner #content h2, #modal .inner #content h3 {margin-top: 20px; } 
#modal.no-padding .inner #content {padding: 0;}
#modal.no-padding .inner #content:before {display: none; }
#modal.no-padding .inner #content:after {display: none; }
#modal .inner .closeButton { position: absolute; top: 5px; right: 5px;}
@media screen and (max-width: 600px) { 
	#modal .inner #content { padding: 0 20px; }
	#modal .inner #content:before {margin-bottom: 20px; }
	#modal .inner #content:after {margin-top: 20px; }
}
#supersize { position: fixed; width: 100%; height: 100%; left: 0; top: 0; overflow: auto; background: rgba(0, 0, 0, 0.45); z-index: 200; backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); }
#supersize .inner {position: absolute; top: 40px; left: 40px; right: 40px; bottom: 40px; box-sizing: border-box; }
#supersize .inner .content {position: absolute; width: 100%; height: 100%; background: url(../_IMG/trans.gif) #ddd;  overflow: hidden;;}
#supersize .inner .closeButton { position: absolute; top: -15px; right: -15px; }	
#supersize .inner .ssprev {position: absolute; top: 50%; left: -1px; width: 30px; height: 60px; border-top-right-radius: 30px; border-bottom-right-radius: 30px; margin-top: -30px; background: #fff; border: 1px solid #ccc; box-shadow: 0 3px 10px rgba(0,0,0,0.2); z-index: 1; }
#supersize .inner .ssprev::after {content: ""; position: absolute; top: 50%; left: 8px; width: 12px; height: 12px; border: solid #333; border-width: 0 0 2px 2px; box-sizing: border-box; margin-top: -6px; transform: rotate(45deg);}
#supersize .inner .ssprev:hover::after {border-color: var(--button-bg);}
#supersize .inner .ssnext {position: absolute; top: 50%; right: -1px; width: 30px; height: 60px; border-top-left-radius: 30px; border-bottom-left-radius: 30px; margin-top: -30px; background: #fff; border: 1px solid #ccc; box-shadow: 0 3px 10px rgba(0,0,0,0.2); z-index: 1; }
#supersize .inner .ssnext::after {content: ""; position: absolute; top: 50%; right: 8px; width: 12px; height: 12px; border: solid #333; border-width: 0 2px 2px 0; box-sizing: border-box; margin-top: -6px; transform: rotate(-45deg);}
#supersize .inner .ssnext:hover::after {border-color: var(--button-bg);}
#supersize .inner .ssbuttons {position: absolute; display: flex; justify-content: center; bottom: 15px; left: 0; width: 100%; z-index: 1; pointer-events: none; }
#supersize .inner .ssbuttons .ssbuttons-inner {display: flex; justify-content: center; padding: 3px; background: #fff; border-radius: 8px; box-shadow: 0 3px 10px rgba(0,0,0,0.2); border: 1px solid #ccc; }

#supersize .inner .ssbuttons .ssbuttons-inner a {display: block; padding: 6px; transition: all 0.3s; pointer-events: all;}
#supersize .inner .ssbuttons .ssbuttons-inner a::after {content: ""; display: block; width: 8px; height: 8px; background: #333; border: 1px solid #333; border-radius: 3px; transition: all 0.3s; box-shadow: 0 3px 10px rgba(0,0,0,0.2); }
#supersize .inner .ssbuttons .ssbuttons-inner a.active {pointer-events: none;}
#supersize .inner .ssbuttons .ssbuttons-inner a.active::after { background: #fff;}
#supersize .inner .ssbuttons .ssbuttons-inner a:hover::after { background: var(--button-bg); border-color: var(--button-bg);}
#supersize .zoom-control {position:absolute; right: 15px; bottom: 15px; border-radius: 8px; box-shadow: 0 3px 10px rgba(0,0,0,0.2); z-index: 1; border: 1px solid #ccc;}
#supersize .zoom-control a {position: relative; width: 30px; height: 30px; display: block; background: #fff; }
#supersize .zoom-control a:first-child {border-top-right-radius: 8px; border-top-left-radius: 8px; }
#supersize .zoom-control a:last-child {border-bottom-right-radius: 8px; border-bottom-left-radius: 8px; border-top: 1px solid #ccc;;}
#supersize .zoom-control a::before {content: ""; position: absolute; width: 14px; height: 2px; left: 50%; top: 50%; margin-left: -7px; margin-top: -1px; background-color: #333}
#supersize .zoom-control a:first-child::after {content: ""; position: absolute; width: 2px; height: 14px; left: 50%; top: 50%; margin-left: -1px; margin-top: -7px; background-color: #333}
#supersize .zoom-control a:hover {background: var(--button-text);}
#supersize .zoom-control a:hover::before {background: var(--button-bg);}
#supersize .zoom-control a:hover::after {background: var(--button-bg);}
#supersize .zoom-control a.disabled {pointer-events: none;}
#supersize .zoom-control a.disabled:before {opacity: 0.25;}
#supersize .zoom-control a.disabled:after {opacity: 0.25;}
#supersize .pan-control {position:absolute; right: 70px; bottom: 15px; border-radius: 100%; box-shadow: 0 3px 10px rgba(0,0,0,0.2); border: 1px solid #ccc; height: 70px; width: 70px; background-color: #fff; display: none; z-index: 1;}
#supersize .pan-control a {position: absolute; display: block; left: 50%; top: 50%; margin-left: -13px; margin-top: -35px; width: 26px; height: 26px; transform-origin: 13px 35px}
#supersize .pan-control a::after {content: ""; position: absolute; top: 50%; left: 50%; margin-left: -6px; margin-top: -3px; width: 12px; height: 12px; display: block; border-style: solid; border-color: #333; border-width: 2px 2px 0 0; box-sizing: border-box; transform: rotate(-45deg)}
#supersize .pan-control a:nth-child(1) {transform: rotate(0);  }
#supersize .pan-control a:nth-child(2) {transform: rotate(90deg);}
#supersize .pan-control a:nth-child(3) {transform: rotate(180deg);}
#supersize .pan-control a:nth-child(4) {transform: rotate(270deg);}
#supersize .pan-control a.disabled {pointer-events:none; opacity: 0.25;}
@media screen and (max-width: 600px) { 
	#supersize .inner {top: 20px; left: 20px; right: 20px; bottom: 20px; }
	#supersize .inner .ssbuttons {display: none;}
}

.closeButton {width: 30px; height: 30px; background: var(--button-bg); border-radius: 50%;  transition: all 0.2s; border: 2px solid var(--button-bg) }
.closeButton:before { content: ""; position: absolute; background: var(--button-text); width: 16px; height: 2px; top: 50%; left: 50%; margin-top: -1px; margin-left: -8px; transform: rotate(45deg); border-radius: 2px; }
.closeButton:after { content: ""; position: absolute; background: var(--button-text); width: 16px; height: 2px; top: 50%; left: 50%; margin-top: -1px; margin-left: -8px; transform: rotate(-45deg); border-radius: 2px; }
.closeButton:hover {background-color: var(--button-text); }
.closeButton:hover:before {background: var(--button-bg);}
.closeButton:hover:after {background: var(--button-bg);}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

