html,
body {
     margin: 0;
     padding: 0;
     width: 100%;
     min-height: 100vh;
     overflow-x: hidden;
     scroll-behavior: smooth;
     font-family: "Ubuntu", serif;
     font-optical-sizing: auto;
     font-size: 20px;
     font-weight: 400;
     font-style: normal;
     line-height: 2;
     background-color: white;
     color: black;
     position: relative;
}

* {
     -webkit-box-sizing: border-box;
     box-sizing: border-box;
}

a {
     text-decoration: none;
     color: inherit;
}

h1 {
     font-size: 4.5vw;
     font-weight: 400;
}

h2 {
     font-size: 2.5vw;
     font-weight: 400;
}

h3 {
     font-size: 1.5vw;
     font-weight: 400;
}

h4 {
     font-size: 2.5vw;
     font-weight: 500;
     color: white;
}

h5 {
     font-size: 1.25vw;
     font-weight: 600;
     margin-bottom: 1vh;
}

h5:first-child {
     margin-top: 0;
}

.header {
     width: 100%;
     height: 6vh;
     background-color: #d9d9d9;
     padding: 0 10vw;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -webkit-box-pack: end;
     -ms-flex-pack: end;
     justify-content: flex-end;
     gap: 5vw;
     position: fixed;
     top: 0;
     z-index: 500;
     font-size: 0.85rem;
     font-weight: 500;
}

.header span > span {
     color: red;
}

.header a:hover {
     color: red;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

.menu {
     width: 100%;
     height: 10vh;
     background-color: #e8e8e8;
     padding: 0 10vw;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -webkit-box-pack: justify;
     -ms-flex-pack: justify;
     justify-content: space-between;
     position: fixed;
     top: 6vh;
     z-index: 500;
}

.menu > button {
     border: none;
     outline: none;
     background-color: transparent;
     padding: 0;
     margin: 0;
     cursor: pointer;
}

.menu > button:hover {
     -webkit-filter: brightness(130%);
     filter: brightness(130%);
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

.menu span {
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -webkit-box-pack: end;
     -ms-flex-pack: end;
     justify-content: flex-end;
     gap: 5vw;
}

.menu span > button {
     border: none;
     outline: none;
     background-color: transparent;
     padding: 0;
     margin: 0;
     font-family: "Ubuntu", serif;
     font-optical-sizing: auto;
     font-size: 24px;
     font-weight: 500;
     font-style: normal;
     color: black;
     cursor: pointer;
}

.menu span > button:hover {
     color: red;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

.menu img {
     height: 6vh;
}

.scrollable {
     width: 100%;
     overflow-y: auto;
     position: absolute;
     top: 16vh;
     bottom: 0;
}

.cover {
     width: 100%;
     height: 25vh;
     position: relative;
}

.cover img {
     width: 100%;
     height: 100%;
     -o-object-fit: cover;
     object-fit: cover;
     -o-object-position: top;
     object-position: top;
     padding: 0;
     margin: 0;
     -webkit-filter: brightness(40%);
     filter: brightness(40%);
     position: relative;
}

.cover span {
     width: 100%;
     height: 25vh;
     z-index: 20;
     position: absolute;
     top: 0;
     left: 0;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -webkit-box-pack: center;
     -ms-flex-pack: center;
     justify-content: center;
}

.content {
     width: 100%;
     padding: 5vh 10vw;
     background-color: white;
}

.vignette {
     width: 100%;
     height: 84vh;
     position: relative;
}

.vignette img {
     width: 100%;
     height: 100%;
     -o-object-fit: cover;
     object-fit: cover;
     -o-object-position: top;
     object-position: top;
     padding: 0;
     margin: 0;
     -webkit-filter: brightness(40%);
     filter: brightness(40%);
}

.vignette span {
     width: 100%;
     position: absolute;
     top: 5vh;
     left: 0;
     color: white;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-orient: vertical;
     -webkit-box-direction: normal;
     -ms-flex-direction: column;
     flex-direction: column;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     line-height: 1.1;
     text-align: center;
     z-index: 20;
}

.gapping {
     width: 100%;
     height: 10px;
     background-color: white;
}

.firm {
     width: 100%;
}

.offer {
     width: 100%;
}

.offer .section_offer {
     width: 100%;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: start;
     -ms-flex-align: start;
     align-items: flex-start;
     -webkit-box-pack: justify;
     -ms-flex-pack: justify;
     justify-content: space-between;
     margin-bottom: 5vh;
}

.offer .section_offer:last-child {
     margin-bottom: 0;
}

.offer .section_offer .image {
     width: 20vw;
     height: 20vw;
}

.offer .section_offer .image img {
     width: 100%;
     height: 100%;
     -o-object-fit: cover;
     object-fit: cover;
     padding: 0;
     margin: 0;
}

.offer .section_offer .text {
     width: 50vw;
}

.offer .section_offer .text ul {
     margin-top: 0;
     padding-top: 0;
}

.catalogue {
     width: 100%;
}

.cat_head {
     width: 100%;
     padding: 5vh 10vw;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -webkit-box-pack: center;
     -ms-flex-pack: center;
     justify-content: center;
}

.catalogue .login {
     width: 50%;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -webkit-box-pack: start;
     -ms-flex-pack: start;
     justify-content: flex-start;
}

.login input[type=password] {
     width: 8vw;
     font-family: "Ubuntu", serif;
     font-size: 1.25rem;
     font-weight: 500;
     color: black;
     background-color: transparent;
     padding: 0.5vh 0;
     border: 0;
     outline: 0;
     border-bottom: 1px solid black;
}

.login button[type="submit"] {
     border: none;
     outline: none;
     background-color: transparent;
     padding: 0;
     margin: 0;
     font-size: 1.25rem;
     cursor: pointer;
}

.login button[type="submit"]:hover {
     color: maroon;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

.catalogue .search {
     width: 50%;
}

.search form {
     width: 100%;
     background-color: transparent;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -webkit-box-pack: end;
     -ms-flex-pack: end;
     justify-content: flex-end;
}

.search input[type=text] {
     width: 30vw;
     font-family: "Ubuntu", serif;
     font-size: 1.25rem;
     font-weight: 500;
     color: black;
     background-color: transparent;
     padding: 0.5vh 0;
     border: 0;
     outline: 0;
     border-bottom: 1px solid black;
}

.search button {
     float: right;
     font-size: 1.25rem;
     color: #1f1f1f;
     background-color: transparent;
     border: none;
     cursor: pointer;
     margin-bottom: 0.5vh;
}

.search button:hover {
     color: maroon;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

.catalogue .content {
     width: 80vw;
     margin: 0 10vw;
     padding: 5vh 0;
     display: grid;
     grid-template-columns: repeat(5, 14vw);
     -webkit-box-pack: justify;
     -ms-flex-pack: justify;
     justify-content: space-between;
     gap: 2.5vw;
}

.catalogue .content .image_box {
     width: 14vw;
     height: 14vw;
     position: relative;
     border: 2px solid #c3c3c3;
}

.catalogue .content .image_box:hover {
     -webkit-transform: scale(1.05);
     transform: scale(1.05);
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

.catalogue .content .image_box button {
     width: 100%;
     height: 100%;
     -o-object-fit: cover;
     object-fit: cover;
     padding: 0;
     margin: 0;
     border: 0;
     cursor: pointer;
}

.catalogue .content .image_box img {
     width: 100%;
     height: 100%;
     -o-object-fit: cover;
     object-fit: cover;
     pointer-events: none;
}

.catalogue .content .image_box > span {
     position: absolute;
     left: 0;
     bottom: 0.5vw;
     z-index: 100;
     font-family: "Ubuntu", serif;
     font-size: 1rem;
     font-weight: 600;
     line-height: 1.1;
     color: black;
     padding: 1vh 0.5vw;
     background: rgba(255, 255, 255, 0.85);
}

.contact {
     width: 100%;
     background-color: turquoise;
}

.contact .content {
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: start;
     -ms-flex-align: start;
     align-items: flex-start;
     -webkit-box-pack: justify;
     -ms-flex-pack: justify;
     justify-content: space-between;
}

.contact .content span {
     width: 45%;
}

.contact .content h3 {
     font-weight: 500;
     color: red;
}

.contact .content a {
     font-weight: 500;
}

.contact .content a:hover {
     color: red;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

.footer {
     width: 100%;
     background-color: darkred;
     color: red;
     padding: 2vh 10vw;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -webkit-box-pack: justify;
     -ms-flex-pack: justify;
     justify-content: space-between;
}

.footer button {
     border: none;
     outline: none;
     background-color: transparent;
     color: red;
     font-family: "Ubuntu", serif;
     font-optical-sizing: auto;
     font-size: 20px;
     font-weight: 400;
     font-style: normal;
     cursor: pointer;
}

.footer button:hover {
     color: white;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

/* ============================ */

.wrapper_gallery {
     width: 90vw;
     height: 100vh;
     margin: 0 auto;
     -webkit-box-sizing: border-box;
     box-sizing: border-box;
}

.wrapper_gallery header {
     width: 100%;
     padding: 1vh 0;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -webkit-box-pack: justify;
     -ms-flex-pack: justify;
     justify-content: space-between;
     font-size: 1.5rem;
     font-weight: 500;
}

.wrapper_gallery header span {
     line-height: 1.1;
     padding: 0 20px;
}

.screen {
     width: 90vw;
     margin: 0 auto;
     height: 67vh;
     position: relative;
}

.prev {
     position: absolute;
     top: 50%;
     -webkit-transform: translateY(-50%);
     transform: translateY(-50%);
     left: 0.5vw;
     color: black;
     cursor: pointer;
     font-size: 3vw;
     font-weight: 700;
     z-index: 20;
}

.next {
     position: absolute;
     top: 50%;
     -webkit-transform: translateY(-50%);
     transform: translateY(-50%);
     right: 0.5vw;
     color: black;
     cursor: pointer;
     font-size: 3vw;
     font-weight: 700;
     z-index: 20;
}

.prev:hover,
.next:hover {
     color: maroon;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

.slide {
     width: 100%;
     height: 67vh;
     text-align: center;
}

.slide img {
     max-width: 100%;
     max-height: 100%;
     min-width: 100%;
     min-height: 100%;
     -o-object-fit: contain;
     object-fit: contain;
}

.subtitle {
     width: 100%;
     height: 8vh;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -webkit-box-pack: center;
     -ms-flex-pack: center;
     justify-content: center;
     font-family: "Ubuntu", serif;
     font-size: 2rem;
     font-weight: 500;
     line-height: 1.1;
     color: black;
}

.over_ribbon,
.ribbon {
     width: 90vw;
     margin: 0 auto;
     height: 13vh;
     overflow-x: auto;
     overflow-y: hidden;
     white-space: nowrap;
     position: relative;
     scroll-behavior: smooth;
     -ms-overflow-style: none;
     scrollbar-width: none;
}

.over_ribbon::-webkit-scrollbar,
.ribbon::-webkit-scrollbar {
     -webkit-appearance: none;
}

.left {
     position: absolute;
     left: 0.5vw;
     top: 5vh;
     z-index: 20;
     background-color: transparent;
     color: black;
     border: none;
     cursor: pointer;
     font-size: 1.5vw;
     font-weight: 900;
}

.right {
     position: absolute;
     right: 0.5vw;
     top: 5vh;
     z-index: 20;
     background-color: transparent;
     color: black;
     border: none;
     cursor: pointer;
     font-size: 1.5vw;
     font-weight: 900;
}

.left:hover,
.right:hover {
     color: maroon;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

.box {
     width: 13vh;
     height: 13vh;
     margin-right: 1vw;
     display: inline-block;
}

.box img {
     width: 100%;
     height: 100%;
     -o-object-fit: cover;
     object-fit: cover;
     opacity: 0.75;
     cursor: pointer;
}

.box img:hover {
     opacity: 1;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}






.envelope {
     width: 25vw;
     margin: 5vh auto;
     border: 1px solid #5c0000;
     padding: 25px;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-orient: vertical;
     -webkit-box-direction: normal;
     -ms-flex-direction: column;
     flex-direction: column;
     -webkit-box-pack: center;
     -ms-flex-pack: center;
     justify-content: center;
     text-align: center;
     position: relative;
}

.envelope h1 {
     padding-bottom: 25px;
     color: #7e0000;
     font-size: 1.5rem;
     font-weight: 600;
     line-height: 1.1;
}

.envelope p {
     padding: 0;
     margin: 0;
     line-height: 1.1;
}

.envelope .thumb {
     width: 10vw;
     height: 10vw;
     margin: 2vh auto;
     position: relative;
     overflow: hidden;
}

.envelope .thumb img {
     width: 100%;
     height: 100%;
     -o-object-fit: cover;
     object-fit: cover;
}

.envelope button[type="submit"] {
     width: 90%;
     height: 5vh;
     margin-top: 4vh;
     background-color: limegreen;
     border: none;
     outline: none;
     font-family: "Ubuntu", serif;
     font-size: 16px;
     font-weight: 600;
     text-transform: uppercase;
     color: black;
     cursor: pointer;
}

.envelope button[type="submit"]:hover {
     background-color: lime;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

.envelope label {
     width: 100%;
}

.envelope input[type="text"] {
     width: 100%;
     margin-bottom: 3vh;
     font-family: "Ubuntu", serif;
     font-size: 18px;
     font-weight: 400;
     padding: 10px 5px;
}

.envelope input[type="file"] {
     width: 100%;
     font-family: "Ubuntu", serif;
     border: 1px solid white;
     font-size: 18px;
     font-weight: 400;
     padding: 10px 5px;
}

.envelope input[type="password"] {
     width: 100%;
     margin-bottom: 3vh;
     font-family: "Ubuntu", serif;
     font-size: 18px;
     font-weight: 400;
     padding: 10px 5px;
}

.envelope select {
     width: 100%;
     margin-bottom: 3vh;
     font-family: "Ubuntu", serif;
     font-size: 18px;
     font-weight: 400;
     padding: 10px 5px;
}

input.editOption {
     display: none;
     width: 100%;
     margin-bottom: 3vh;
     font-family: "Ubuntu", serif;
     font-size: 18px;
     font-weight: 400;
     padding: 10px 5px;
}

button.exit {
     border: none;
     outline: none;
     background-color: transparent;
     font-size: 2.5rem;
     color: darkgreen;
     position: absolute;
     top: 18px;
     right: -3vw;
     cursor: pointer;
}

button.exit:hover {
     color: limegreen;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

.form_logging {
     width: 100%;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-orient: vertical;
     -webkit-box-direction: normal;
     -ms-flex-direction: column;
     flex-direction: column;
     text-align: center;
     -webkit-box-pack: center;
     -ms-flex-pack: center;
     justify-content: center;
     position: relative;
}

.form_logging .toggle-password {
     position: absolute;
     right: 10px;
     top: 36px;
     cursor: pointer;
     color: maroon;
     font-size: 26px;
}

.form_logging .toggle-password:hover {
     color: red;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

button#logout {
     border: none;
     outline: none;
     padding: 0;
     margin: 0;
     font-size: 2vw;
     color: black;
     background-color: transparent;
     cursor: pointer;
}

button#logout:hover {
     color: limegreen;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

.container {
     width: 90vw;
     margin: 3vh 5vw;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-orient: vertical;
     -webkit-box-direction: normal;
     -ms-flex-direction: column;
     flex-direction: column;
}

.panel_header {
     width: 100%;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -webkit-box-pack: justify;
     -ms-flex-pack: justify;
     justify-content: space-between;
}

button.price_pass {
     border: none;
     outline: none;
     background-color: transparent;
     padding: 0;
     margin: 0;
     font-size: 1.75rem;
     color: black;
     cursor: pointer;
     position: relative;
}

button.price_pass:hover {
     color: limegreen;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

button.price_pass::after {
     content: attr(data-title);
     position: absolute;
     top: 80%;
     left: 90%;
     -webkit-transform: translateX(-50%);
     transform: translateX(-50%);
     background-color: dimgrey;
     color: white;
     padding: 0.25vw 0.5vw;
     font-size: 12px;
     font-weight: 500;
     white-space: wrap;
     display: none;
     z-index: 9999;
     white-space: nowrap;
}

button.price_pass:hover::after {
     display: block;
}

.title {
     text-align: center;
}

.title h1 {
     font-size: 1.75rem;
     font-weight: 500;
}

.catalogues {
     width: 100%;
     padding: 2vh 0;
     width: 90vw;
     overflow: auto;
     -ms-overflow-style: none;
     scrollbar-width: none;
     overflow: -moz-scrollbars-none;
     position: relative;
     display: grid;
     grid-template-columns: repeat(4, 21.5vw [col-start]);
     justify-items: stretch;
     -webkit-column-gap: 1.33vw;
     column-gap: 1.33vw;
     padding: 0;
}

.section {
     width: 21.5vw;
     height: 4vw;
     margin-bottom: 1.42vw;
     text-align: center;
     position: relative;
}

.sec_deactivate {
     position: absolute;
     top: 50%;
     -webkit-transform: translate(0, -50%);
     transform: translate(0, -50%);
     left: 8px;
}

.sec_deactivate button {
     padding: 4px;
     margin: 4px;
     border: none;
     outline: none;
     font-size: 1.5rem;
     color: white;
     background-color: transparent;
     cursor: pointer;
     position: relative;
}

.sec_deactivate button:hover {
     color: limegreen;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

button#sec_deactivate::after {
     content: attr(data-title);
     position: absolute;
     top: 80%;
     left: 90%;
     -webkit-transform: translateX(-50%);
     transform: translateX(-50%);
     background-color: dimgrey;
     color: white;
     padding: 0.25vw 0.5vw;
     font-size: 12px;
     font-weight: 500;
     white-space: wrap;
     display: none;
     z-index: 9999;
}

button#sec_deactivate:hover::after {
     display: block;
}

.sec_select {
     width: 100%;
     height: 100%;
}

.sec_select button {
     width: 100%;
     height: 100%;
     border: none;
     outline: none;
     padding: 0 15%;
     margin: 0;
     font-family: "Ubuntu", serif;
     font-size: 0.9rem;
     font-weight: 500;
     letter-spacing: 1px;
     word-spacing: 3px;
     color: white;
     cursor: pointer;
}

.sec_name {
     position: absolute;
     top: 50%;
     -webkit-transform: translate(0, -50%);
     transform: translate(0, -50%);
     right: 8px;
}

.sec_name button {
     padding: 4px;
     margin: 4px;
     border: none;
     outline: none;
     font-size: 1.5rem;
     color: white;
     background-color: transparent;
     cursor: pointer;
}

.sec_name button:hover {
     color: limegreen;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

button#sec_name::after {
     content: attr(data-title);
     position: absolute;
     top: 80%;
     left: 30%;
     -webkit-transform: translateX(-50%);
     transform: translateX(-50%);
     background-color: dimgrey;
     color: white;
     padding: 0.25vw 0.5vw;
     font-size: 12px;
     font-weight: 500;
     white-space: wrap;
     display: none;
     z-index: 9999;
}

button#sec_name:hover::after {
     display: block;
}

.section_plus {
     width: 21.5vw;
     height: 4vw;
     border: 2px solid black;
     margin-bottom: 1.42vw;
     position: relative;
}

.section_plus button {
     width: 100%;
     height: 100%;
     background-color: transparent;
     border: none;
     outline: none;
     font-family: "Ubuntu", serif;
     font-size: 40px;
     color: white;
     cursor: pointer;
}

.section_plus button:hover {
     color: limegreen;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

.box_plus {
     width: 12vw;
     height: 28.1vw;
     border: 1px solid black;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -webkit-box-pack: center;
     -ms-flex-pack: center;
     justify-content: center;
     position: relative;
}

.box_plus button {
     padding: 0;
     margin: 0;
     border: none;
     outline: none;
     color: black;
     background-color: transparent;
     font-size: 3rem;
     cursor: pointer;
}

.box_plus button:hover {
     color: limegreen;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

.box_plus button::after {
     content: attr(data-title);
     position: absolute;
     top: 35%;
     left: 50%;
     -webkit-transform: translateX(-50%);
     transform: translateX(-50%);
     background-color: dimgrey;
     color: white;
     padding: 0.25vw 0.5vw;
     font-size: 12px;
     font-weight: 500;
     white-space: wrap;
     display: none;
     z-index: 9999;
}

.box_plus button:hover::after {
     display: block;
}

.items {
     width: 90vw;
     overflow: auto;
     -ms-overflow-style: none;
     scrollbar-width: none;
     overflow: -moz-scrollbars-none;
     position: relative;
     display: grid;
     grid-template-columns: repeat(7, 12vw [col-start]);
     justify-items: stretch;
     gap: 1vw;
     padding: 0 0 2vh 0;
}

.box_active {
     width: 12vw;
     height: 28.1vw;
     border: 1px solid black;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-orient: vertical;
     -webkit-box-direction: normal;
     -ms-flex-direction: column;
     flex-direction: column;
     -webkit-box-sizing: border-box;
     box-sizing: border-box;
}

.box_active button {
     border: none;
     outline: none;
     background-color: transparent;
     padding: 0;
     margin: 0;
     font-size: 1.5vw;
     color: dimgray;
     cursor: pointer;
}

.box_active button:hover {
     color: lime;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

.panel_line {
     width: 12vw;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: start;
     -ms-flex-align: start;
     align-items: flex-start;
     -webkit-box-pack: justify;
     -ms-flex-pack: justify;
     justify-content: space-between;
}

.code {
     width: 9vw;
     height: 2.7vw;
     padding: 0 0.5vw;
     font-size: 1.25vw;
     font-weight: 600;
     color: red;
}

.code_icon {
     width: 3vw;
     padding: 0.5vw;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: start;
     -ms-flex-align: start;
     align-items: flex-start;
     -webkit-box-pack: end;
     -ms-flex-pack: end;
     justify-content: flex-end;
     position: relative;
}

.code_form button::after {
     content: attr(data-title);
     position: absolute;
     top: 10%;
     left: -80%;
     -webkit-transform: translateX(-50%);
     transform: translateX(-50%);
     background-color: dimgrey;
     color: white;
     padding: 0.25vw 0.5vw;
     font-size: 12px;
     font-weight: 500;
     white-space: wrap;
     display: none;
     z-index: 9999;
}

.code_form button:hover::after {
     display: block;
}

.price {
     width: 9vw;
     height: 2.7vw;
     padding: 0 0.5vw;
     font-size: 1.25vw;
     font-weight: 600;
     color: blue;
}

.price_icon {
     width: 3vw;
     padding: 0.5vw;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: start;
     -ms-flex-align: start;
     align-items: flex-start;
     -webkit-box-pack: end;
     -ms-flex-pack: end;
     justify-content: flex-end;
     position: relative;
}

.price_form button::after {
     content: attr(data-title);
     position: absolute;
     top: 10%;
     left: -80%;
     -webkit-transform: translateX(-50%);
     transform: translateX(-50%);
     background-color: dimgrey;
     color: white;
     padding: 0.25vw 0.5vw;
     font-size: 12px;
     font-weight: 500;
     white-space: wrap;
     display: none;
     z-index: 9999;
}

.price_form button:hover::after {
     display: block;
}

input.price-input {
     width: 100%;
     font-family: "Ubuntu", serif;
     font-size: 1.25vw;
     font-weight: 600;
     padding: 5px;
     border: 1px solid #aaaaaa;
}

.name {
     width: 9vw;
     height: 4vw;
     font-size: 0.8vw;
     font-weight: 600;
     line-height: 1.1;
     padding: 0.5vw;
}

.name_icon {
     width: 3vw;
     padding: 0.5vw;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: start;
     -ms-flex-align: start;
     align-items: flex-start;
     -webkit-box-pack: end;
     -ms-flex-pack: end;
     justify-content: flex-end;
     position: relative;
}

.name_form button::after {
     content: attr(data-title);
     position: absolute;
     top: 10%;
     left: -80%;
     -webkit-transform: translateX(-50%);
     transform: translateX(-50%);
     background-color: dimgrey;
     color: white;
     padding: 0.25vw 0.5vw;
     font-size: 12px;
     font-weight: 500;
     white-space: wrap;
     display: none;
     z-index: 9999;
}

.name_form button:hover::after {
     display: block;
}

.keys {
     width: 9vw;
     height: 4vw;
     font-size: 0.6vw;
     font-weight: 400;
     line-height: 1.1;
     padding: 0.5vw;
}

.keys_icon {
     width: 3vw;
     padding: 0.5vw;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: start;
     -ms-flex-align: start;
     align-items: flex-start;
     -webkit-box-pack: end;
     -ms-flex-pack: end;
     justify-content: flex-end;
     position: relative;
}

.keys_form button::after {
     content: attr(data-title);
     position: absolute;
     top: 10%;
     left: -80%;
     -webkit-transform: translateX(-50%);
     transform: translateX(-50%);
     background-color: dimgrey;
     color: white;
     padding: 0.25vw 0.5vw;
     font-size: 12px;
     font-weight: 500;
     white-space: wrap;
     display: none;
     z-index: 9999;
}

.keys_form button:hover::after {
     display: block;
}

.group {
     width: 9vw;
     height: 2.7vw;
     font-size: 0.75vw;
     font-weight: 400;
     padding: 0 0.5vw;
}

.group_icon {
     width: 3vw;
     padding: 0.5vw;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: start;
     -ms-flex-align: start;
     align-items: flex-start;
     -webkit-box-pack: end;
     -ms-flex-pack: end;
     justify-content: flex-end;
     position: relative;
}

.group_form button::after {
     content: attr(data-title);
     position: absolute;
     top: 10%;
     left: -80%;
     -webkit-transform: translateX(-50%);
     transform: translateX(-50%);
     background-color: dimgrey;
     color: white;
     padding: 0.25vw 0.5vw;
     font-size: 12px;
     font-weight: 500;
     white-space: wrap;
     display: none;
     z-index: 9999;
}

.group_form button:hover::after {
     display: block;
}

.image {
     width: 9vw;
     height: 9vw;
     padding: 0;
}

.image img {
     width: 100%;
     height: 100%;
     padding: 0;
     margin: 0;
     border: none;
     outline: none;
     -o-object-fit: cover;
     object-fit: cover;
}

.image_icon {
     width: 3vw;
     height: 9vw;
     padding-right: 0.5vw;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-orient: vertical;
     -webkit-box-direction: normal;
     -ms-flex-direction: column;
     flex-direction: column;
     -webkit-box-align: end;
     -ms-flex-align: end;
     align-items: flex-end;
     -webkit-box-pack: justify;
     -ms-flex-pack: justify;
     justify-content: space-between;
     position: relative;
}

.cover_form button::after {
     content: attr(data-title);
     position: absolute;
     top: 0%;
     left: -80%;
     -webkit-transform: translateX(-50%);
     transform: translateX(-50%);
     background-color: dimgrey;
     color: white;
     padding: 0.25vw 0.5vw;
     font-size: 12px;
     font-weight: 500;
     white-space: wrap;
     display: none;
     z-index: 9999;
}

.cover_form button:hover::after {
     display: block;
}

.photo_form button::after {
     content: attr(data-title);
     position: absolute;
     top: 75%;
     left: -80%;
     -webkit-transform: translateX(-50%);
     transform: translateX(-50%);
     background-color: dimgrey;
     color: white;
     padding: 0.25vw 0.5vw;
     font-size: 12px;
     font-weight: 500;
     white-space: wrap;
     display: none;
     z-index: 9999;
}

.photo_form button:hover::after {
     display: block;
}

.base_icon {
     width: 12vw;
     height: 3vw;
     padding: 0.5vw;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -webkit-box-pack: justify;
     -ms-flex-pack: justify;
     justify-content: space-between;
     position: relative;
}

.remove_form button::after {
     content: attr(data-title);
     position: absolute;
     top: -25%;
     left: 20%;
     -webkit-transform: translateX(-50%);
     transform: translateX(-50%);
     background-color: dimgrey;
     color: white;
     padding: 0.25vw 0.5vw;
     font-size: 12px;
     font-weight: 500;
     white-space: wrap;
     display: none;
     z-index: 9999;
}

.remove_form button:hover::after {
     display: block;
}

.deactivate_form button::after {
     content: attr(data-title);
     position: absolute;
     top: -80%;
     left: 50%;
     -webkit-transform: translateX(-50%);
     transform: translateX(-50%);
     background-color: dimgrey;
     color: white;
     padding: 0.25vw 0.5vw;
     font-size: 12px;
     font-weight: 500;
     white-space: wrap;
     display: none;
     z-index: 9999;
}

.deactivate_form button:hover::after {
     display: block;
}

.change_form button::after {
     content: attr(data-title);
     position: absolute;
     top: -120%;
     left: 80%;
     -webkit-transform: translateX(-50%);
     transform: translateX(-50%);
     background-color: dimgrey;
     color: white;
     padding: 0.25vw 0.5vw;
     font-size: 12px;
     font-weight: 500;
     white-space: wrap;
     display: none;
     z-index: 9999;
}

.change_form button:hover::after {
     display: block;
}

.box_inactive {
     width: 12vw;
     height: 28.1vw;
     border: 1px solid black;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-orient: vertical;
     -webkit-box-direction: normal;
     -ms-flex-direction: column;
     flex-direction: column;
     -webkit-box-sizing: border-box;
     box-sizing: border-box;
     color: darkgray;
     background-color: gray;
}

.box_inactive button {
     border: none;
     outline: none;
     background-color: transparent;
     padding: 0;
     margin: 0;
     font-size: 1.5vw;
     color: white;
     cursor: pointer;
}

.box_inactive button:hover {
     color: lime;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

.box_inactive .code {
     color: #8b4949;
}

.box_inactive .image img {
     opacity: 0.15;
}

.thumbnail {
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-pack: center;
     -ms-flex-pack: center;
     justify-content: center;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     width: 250px;
     height: 250px;
     margin: 0 auto;
     margin-bottom: 2vh;
}

.thumbnail img {
     width: 100%;
     height: 100%;
     -o-object-fit: cover;
     object-fit: cover;
}







.cap {
     width: 100%;
     height: 6vh;
     padding: 0 10vw;
     position: fixed;
     top: 0;
     z-index: 10;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -webkit-box-pack: end;
     -ms-flex-pack: end;
     justify-content: flex-end;
     background-color: #d9d9d9;
}

.cap a:hover {
     color: red;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

.contacts {
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -webkit-box-pack: end;
     -ms-flex-pack: end;
     justify-content: flex-end;
     gap: 5vw;
}

.contacts span {
     font-weight: 600;
     color: red;
}

.head {
     width: 100%;
     height: 8vh;
     position: fixed;
     top: 6vh;
     left: 0;
     z-index: 10;
     padding: 0 10vw;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -webkit-box-pack: justify;
     -ms-flex-pack: justify;
     justify-content: space-between;
     background-color: #e8e8e8;
}

.head .logo img {
     height: 6vh;
}

.head .menu {
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -webkit-box-pack: end;
     -ms-flex-pack: end;
     justify-content: flex-end;
     gap: 5vw;
}

.head button {
     border: none;
     outline: none;
     padding: 0;
     margin: 0;
     background-color: transparent;
     font-family: "Ubuntu", serif;
     font-optical-sizing: auto;
     font-size: 24px;
     font-weight: 500;
     font-style: normal;
     color: black;
     cursor: pointer;
}

.head button:hover {
     color: red;
     -webkit-transition: 0.3s all;
     transition: 0.3s all;
}

.scrollable-container {
     width: 100%;
     position: absolute;
     top: 14vh;
     left: 0;
     right: 0;
     bottom: 0;
     overflow-y: auto;
}

.vignette_cookies {
     width: 100%;
     height: 25vh;
     position: relative;
}

.vignette_cookies img {
     width: 100%;
     height: 100%;
     -o-object-fit: cover;
     object-fit: cover;
     -o-object-position: top;
     object-position: top;
     padding: 0;
     margin: 0;
     -webkit-filter: brightness(40%);
     filter: brightness(40%);
}

.vignette_cookies span {
     width: 100%;
     position: absolute;
     top: 5vh;
     left: 0;
     color: white;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-orient: vertical;
     -webkit-box-direction: normal;
     -ms-flex-direction: column;
     flex-direction: column;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     line-height: 1.1;
     text-align: center;
     z-index: 20;
}

.shoe {
     width: 100%;
     background-color: #d9d9d9;
     padding: 2vh 10vw;
     display: -webkit-box;
     display: -ms-flexbox;
     display: flex;
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -ms-flex-pack: distribute;
     justify-content: space-around;
     font-size: 0.8vw;
     font-weight: 600;
     color: white;
}








@media only screen and (max-width: 1200px) {

     .omit,
     .offer .section .image,
     .offer ul,
     .offer .section h5 span {
          display: none;
     }

     .menu {
          height: 16vh;
          top: 0;
          -webkit-box-orient: vertical;
          -webkit-box-direction: normal;
          -ms-flex-direction: column;
          flex-direction: column;
          -webkit-box-pack: center;
          -ms-flex-pack: center;
          justify-content: center;
     }

     .menu img {
          margin: 2vh 0;
     }

     .vignette h1 {
          font-size: 10vw;
          font-weight: 400;
     }

     .vignette h2 {
          font-size: 7.5vw;
          font-weight: 400;
     }

     .vignette h3 {
          font-size: 4vw;
          font-weight: 400;
          line-height: 1.1;
     }

     .cover h4 {
          font-size: 8vw;
     }

     .offer h5 {
          font-size: 1rem;
          font-weight: 500;
          margin: 0;
     }

     .offer .section {
          margin-bottom: 0;
     }

     .offer .section .text {
          width: 100vw;
     }

     .catalogue .content {
          width: 80vw;
          margin: 0 10vw;
          padding: 5vh 0;
          display: grid;
          grid-template-columns: repeat(2, 38.5vw);
          -webkit-box-pack: justify;
          -ms-flex-pack: justify;
          justify-content: space-between;
          gap: 3vw;
     }

     .catalogue .content .image_box {
          width: 38.5vw;
          height: 38.5vw;
          position: relative;
          border: 2px solid #c3c3c3;
     }

     .catalogue .content .image_box > span {
          font-size: 4vw;
          line-height: 1;
     }

     .contact .content {
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -webkit-box-orient: vertical;
          -webkit-box-direction: normal;
          -ms-flex-direction: column;
          flex-direction: column;
     }

     .contact .content span {
          width: 100%;
     }

     .contact .content h3 {
          font-size: 1.25rem;
     }

     .contact .content p {
          font-size: 0.85rem;
          line-height: 1.1;
     }

     .wrapper_gallery header {
          font-size: 1rem;
          font-weight: 500;
     }

     .search input[type=text] {
          font-size: 1rem;
          font-weight: 500;
     }

     .search button {
          font-size: 1rem;
     }

     .prev,
     .next,
     .left,
     .right {
          font-size: 2rem;
     }

     .subtitle {
          font-size: 1rem;
          font-weight: 500;
     }
}
