@charset "UTF-8";
/*!
Theme Name: mpplast
Theme URI: olo
Author: oj
Author URI: 
Description: Description
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: mpplast


*/
body {
  font-family: "Sofia Sans", sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.lblue {
  background-color: #bcd7f2;
}

.dblue {
  background-color: #2b7f63;
}

.lgreen {
  background-color: #b3c7b7;
}

.c-teal {
  background-color: #d1f2ed;
}

.c-gray {
  background-color: rgba(216, 202, 236, 0.61);
}

.c-vio {
  background-color: rgba(216, 202, 236, 0.61);
  -webkit-box-shadow: 3px 3px 20px 2px rgba(0, 0, 0, 0.18);
          box-shadow: 3px 3px 20px 2px rgba(0, 0, 0, 0.18);
}

.teal {
  color: #65c3b5;
}

/* 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;
  background-color: #50b72d;
}

/**
 * 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 {
  -webkit-box-sizing: content-box;
          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 */
  -webkit-text-decoration: underline dotted;
          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 {
  -webkit-box-sizing: border-box;
          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"] {
  -webkit-box-sizing: border-box;
          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;
}

.mobile-header-trego {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr auto;
      grid-template-columns: 1fr auto;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 90px;
  background: #fff;
  -webkit-box-shadow: 0 2px 10px rgba(0, 0, 0, 0.07);
          box-shadow: 0 2px 10px rgba(0, 0, 0, 0.07);
  padding: 0 1.5rem;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  -webkit-transition: -webkit-transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  transition: -webkit-transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), -webkit-transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  /* Hamburger to X animation */
}

.mobile-header-trego.hide-on-scroll {
  -webkit-transform: translateY(-100%);
          transform: translateY(-100%);
}

.mobile-header-trego.show-on-scroll {
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

.mobile-header-trego .logo {
  font-size: 1.5rem;
  font-weight: bold;
  color: #2c3e50;
  text-decoration: none;
}

.mobile-header-trego .menu-toggle {
  display: none;
}

.mobile-header-trego .menu-icon {
  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;
  width: 36px;
  height: 36px;
  cursor: pointer;
  z-index: 201;
  gap: 7px;
  -webkit-transition: 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  transition: 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

.mobile-header-trego .menu-icon span {
  display: block;
  height: 3px;
  width: 100%;
  background: #2c3e50;
  border-radius: 2px;
  -webkit-transition: 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  transition: 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

.mobile-header-trego .menu-toggle:checked + .menu-icon span:nth-child(1) {
  -webkit-transform: translateY(10px) rotate(45deg);
          transform: translateY(10px) rotate(45deg);
}

.mobile-header-trego .menu-toggle:checked + .menu-icon span:nth-child(2) {
  opacity: 0;
}

.mobile-header-trego .menu-toggle:checked + .menu-icon span:nth-child(3) {
  -webkit-transform: translateY(-10px) rotate(-45deg);
          transform: translateY(-10px) rotate(-45deg);
}

.mobile-header-trego .menu {
  position: fixed;
  top: 90px;
  left: 0;
  width: 100%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background: #D6F4F7;
  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: start;
      -ms-flex-align: start;
          align-items: flex-start;
  opacity: 0;
  pointer-events: none;
  -webkit-transform: translateY(-20px);
          transform: translateY(-20px);
  -webkit-transition: opacity 0.35s cubic-bezier(0.4, 0, 0.2, 1), -webkit-transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  transition: opacity 0.35s cubic-bezier(0.4, 0, 0.2, 1), -webkit-transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  transition: opacity 0.35s cubic-bezier(0.4, 0, 0.2, 1), transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  transition: opacity 0.35s cubic-bezier(0.4, 0, 0.2, 1), transform 0.35s cubic-bezier(0.4, 0, 0.2, 1), -webkit-transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 200;
  padding: 0 1.5rem 0 1.5rem;
}

.mobile-header-trego .menu ul {
  list-style: none;
  padding: 0;
  margin: 0;
  width: 100%;
}

.mobile-header-trego .menu li {
  margin: 1.5rem 0;
}

.mobile-header-trego .menu li.divider-class {
  width: 100%;
  height: 1px;
  background: #2b7f63;
}

.mobile-header-trego .menu a {
  color: #2b7f63;
  text-decoration: none;
  font-size: 1.125rem;
  font-weight: 500;
  -webkit-transition: color 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  transition: color 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

.mobile-header-trego .menu a:hover {
  color: #3498db;
}

.mobile-header-trego .menu-toggle:checked ~ .menu {
  opacity: 1;
  pointer-events: auto;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

body {
  font-family: "Sofia Sans", sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.lblue {
  background-color: #bcd7f2;
}

.dblue {
  background-color: #2b7f63;
}

.lgreen {
  background-color: #b3c7b7;
}

.c-teal {
  background-color: #d1f2ed;
}

.c-gray {
  background-color: rgba(216, 202, 236, 0.61);
}

.c-vio {
  background-color: rgba(216, 202, 236, 0.61);
  -webkit-box-shadow: 3px 3px 20px 2px rgba(0, 0, 0, 0.18);
          box-shadow: 3px 3px 20px 2px rgba(0, 0, 0, 0.18);
}

.teal {
  color: #65c3b5;
}

/* ===========================================================
   Trego – SCSS Version
   =========================================================== */
.mobile-header-trego {
  display: none;
  visibility: hidden;
}

.hero_text_header-mobile {
  display: none;
  visibility: hidden;
}

*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  overflow-x: hidden !important;
  overscroll-behavior-x: none;
  overscroll-behavior-y: auto;
}

body {
  margin: 0;
  font-size: 1rem;
  color: #212529;
  line-height: 1.6;
  background-color: #fff;
  overflow-x: hidden !important;
  overscroll-behavior-x: none;
  overscroll-behavior-y: auto;
}

img,
iframe {
  max-width: 100%;
  display: block;
}

ul,
ol {
  list-style: none;
  margin: 0;
  padding: 0;
}

button,
summary {
  cursor: pointer;
}

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

.grid {
  display: -ms-grid;
  display: grid;
  gap: 1rem;
}

.grid--gap-sm {
  gap: 0.5rem;
}

.grid--gap-lg {
  gap: 2rem;
}

.grid--place-center {
  place-items: center;
}

.grid--auto-flow-col {
  grid-auto-flow: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.grid--2-col {
  -ms-grid-columns: (minmax(300px, 1fr))[auto-fit];
      grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

.grid--4-col {
  -ms-grid-columns: (minmax(200px, 1fr))[auto-fit];
      grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.grid--6-col {
  -ms-grid-columns: (minmax(140px, 1fr))[auto-fit];
      grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}

.full {
  grid-column: 1 / -1;
}

.app-navigation {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: auto 1fr auto;
      grid-template-columns: auto 1fr auto;
  gap: 1rem;
      grid-template-areas: "logo menu contact";
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.app-navigation .menu-menu-container {
  -ms-grid-row: 1;
  -ms-grid-column: 2;
  grid-area: menu;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
}

.app-navigation a.logo {
  width: 150px;
  height: auto;
}

.app-navigation a.logo img {
  width: 100%;
  height: auto;
}

.app-navigation .socmenu {
  -ms-grid-row: 1;
  -ms-grid-column: 3;
  grid-area: contact;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.app-navigation .main {
  -ms-grid-row: 1;
  -ms-grid-column: 2;
  grid-area: menu;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.app-navigation .main li {
  margin-left: 2rem;
  margin-right: 2rem;
}

.app-navigation .main li a {
  font-size: 1.2rem;
  font-weight: 500;
  color: #2b7f63;
}

.app-navigation .main li a:hover {
  color: #39A883;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}

.app-navigation .socmenu {
  -ms-grid-row: 1;
  -ms-grid-column: 3;
  grid-area: contact;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.app-navigation .socmenu li.divider {
  color: #212529;
  margin-left: 0.5rem !important;
  margin-right: 0.5rem !important;
}

.app-navigation .socmenu li {
  margin-left: 1rem;
  margin-right: 1rem;
}

.app-navigation .socmenu li a {
  font-size: 1.2rem;
  font-weight: 500;
  color: #2b7f63;
}

.app-navigation .socmenu li a:hover {
  color: #39A883;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}

.section-title {
  padding-top: 4rem;
  padding-bottom: 1rem;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
  gap: 0.5rem;
}

.section-title h2 {
  font-size: 2.2rem;
  line-height: 3rem;
  margin: 0;
  text-align: left;
  color: #2b7f63;
  font-weight: 700;
}

.section-title h3 {
  font-size: 1.125rem;
  margin: 0;
  text-align: left;
  color: #212529;
}

.dark h2 {
  color: #E98F3A;
}

.dark h3 {
  color: #f8f9fa;
}

.button {
  background: #39A883;
  color: #fff;
  border: 2px solid #39A883;
  font-weight: 600;
  padding: 0.875em 1.75em 0.75em 1.75em;
  line-height: 1.2;
  font-size: 1.2rem;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  vertical-align: middle;
  text-decoration: none;
  cursor: pointer;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  border-radius: 0;
}

.button:hover, .button:focus-visible {
  background: #2f8a6b;
  border-color: #2f8a6b;
  -webkit-box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
          box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
  color: #fff;
}

.button:active {
  -webkit-transform: translateY(0);
          transform: translateY(0);
  -webkit-box-shadow: 0 2px 4px rgba(57, 168, 131, 0.3);
          box-shadow: 0 2px 4px rgba(57, 168, 131, 0.3);
}

.button i {
  margin-right: 0.5rem;
}

.button--secondary {
  background: #fff;
  color: #39A883;
  border: 2px solid #39A883;
}

.button--secondary:hover, .button--secondary:focus-visible {
  background: rgba(255, 255, 255, 0.95);
  border-color: #339574;
  color: #339574;
}

.button--ghost {
  background: transparent;
  color: #2b7f63;
  border-color: transparent;
  -webkit-box-shadow: none;
          box-shadow: none;
}

.button--ghost:hover, .button--ghost:focus-visible {
  background: rgba(57, 168, 131, 0.1);
  border-color: #39A883;
  color: #39A883;
}

.price-tag {
  font-size: 1.75rem;
  font-weight: 700;
  color: #2b7f63;
  width: 12rem;
  height: 12rem;
  background-color: #E98F3A;
  border-radius: 50%;
  text-align: center;
  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;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  z-index: 2;
  -webkit-transform: rotate(-10deg);
          transform: rotate(-10deg);
  font-size: 2.2rem;
}

.price-tag .small-text {
  font-size: 1.2rem;
  line-height: 1.4rem;
}

.price-tag .price-tag-price {
  font-size: 4rem;
  line-height: 4rem;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

section {
  padding-top: 4rem;
  padding-bottom: 4rem;
}

/* ----- typography ----- */
h2 {
  font-size: 1.75rem;
  font-weight: 700;
  color: #2b7f63;
  line-height: 2.2rem;
}

/* ----- Header ----- */
.site-header {
  background-color: #fff;
  -webkit-box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
          box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  padding: 15px 0;
  position: relative;
}

.header-container {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 20px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: auto 1fr auto;
      grid-template-columns: auto 1fr auto;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  grid-gap: 20px;
}

.site-branding {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.site-branding .logo {
  max-width: 131px;
  height: auto;
}

/* Navigation styles */
.main-navigation {
  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;
}

.main-navigation ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
}

.main-navigation li {
  position: relative;
  margin: 0 15px;
}

.main-navigation a {
  display: block;
  text-decoration: none;
  color: #3D3FA4;
  font-weight: 500;
  font-size: 16px;
  padding: 10px 0;
  -webkit-transition: color 0.3s;
  transition: color 0.3s;
}

.main-navigation a:hover {
  color: #2CC8D6;
}

/* Contact info styles */
.contact-info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}

.contact-info a {
  color: #3D3FA4;
  text-decoration: none;
  margin-left: 20px;
  font-weight: 500;
  -webkit-transition: color 0.3s;
  transition: color 0.3s;
}

.contact-info a:hover {
  color: #2CC8D6;
}

.contact-info .phone {
  font-weight: 700;
  color: #3D3FA4;
}

.contact-info .email {
  display: inline-block;
}

.social-icons {
  margin-left: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.social-icons a {
  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;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background-color: #3D3FA4;
  color: #fff;
  margin-left: 10px;
  -webkit-transition: background-color 0.3s;
  transition: background-color 0.3s;
}

.social-icons a:hover {
  background-color: #2CC8D6;
  color: #fff;
}

/* Mobile menu (SlickNav) customization */
.slicknav_menu {
  display: none;
  background: transparent;
  padding: 0;
}

.slicknav_btn {
  background-color: #3D3FA4;
  margin: 0;
}

.slicknav_nav {
  background-color: #fff;
  -webkit-box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
          box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  border-radius: 4px;
}

.slicknav_nav a {
  color: #3D3FA4;
}

.slicknav_nav a:hover {
  background-color: #f8f8f8;
  color: #2CC8D6;
  border-radius: 0;
}

.slicknav_nav .slicknav_row:hover {
  background-color: #f8f8f8;
  color: #2CC8D6;
  border-radius: 0;
}

.slicknav_menu .slicknav_icon-bar {
  background-color: #fff;
}

/* Media queries for responsive layout */
@media screen and (max-width: 992px) {
  .header-container {
    -ms-grid-columns: auto auto;
        grid-template-columns: auto auto;
  }
  .main-navigation {
    grid-column: 1 / -1;
    -ms-grid-row: 2;
    grid-row: 2;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}

@media screen and (max-width: 768px) {
  .header-container {
    -ms-grid-columns: 1fr auto;
        grid-template-columns: 1fr auto;
  }
  .main-navigation {
    -ms-grid-column: 1;
    grid-column: 1;
    -ms-grid-row: 1;
    grid-row: 1;
  }
  /* Hide desktop menu and show mobile menu */
  .main-navigation ul.nav-menu {
    display: none;
  }
  .slicknav_menu {
    display: block;
  }
  .contact-info {
    -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;
  }
  .contact-info a {
    margin: 5px 0;
    margin-left: 0;
  }
  .social-icons {
    margin-left: 0;
    margin-top: 10px;
  }
}

.inpad {
  max-width: 1440px;
  width: 100%;
  margin: 0 auto;
  padding: 0 1rem;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.green {
  color: #2b7f63;
}

/* ----- Hero ----- */
.hero-section {
  padding: 0.5rem 2rem;
  background: #E1E1E1;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
  width: 100%;
  background-image: url("https://www.mpplast.sk/wp-content/uploads/2026/02/hero-image-mpplast.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  min-height: 85vh;
  position: relative;
}

.hero-section::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 20%;
  background: -webkit-gradient(linear, left bottom, left top, from(#39A883), to(transparent));
  background: linear-gradient(to top, #39A883 0%, transparent 100%);
  pointer-events: none;
  z-index: 1;
}

.hero-section .hero_salamander-logo {
  position: absolute;
  top: 2rem;
  right: 2rem;
  z-index: 10;
}

.hero-section .hero_salamander-logo img {
  max-width: 200px;
  height: auto;
}

.hero-section h1 {
  margin: 0;
  font-size: clamp(2rem, 4vw, 2.8rem);
  line-height: 1.2;
  color: #242424;
  margin-bottom: 1rem;
  font-weight: 900;
}

.hero-section .hero_content {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
  gap: 2rem;
  width: 100%;
  height: auto;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 1rem;
}

.hero-section .hero_text {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
  gap: 0em;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
  max-width: 650px;
  padding-top: 8em;
}

.hero-section .hero_text h3 {
  margin: 0;
  font-size: clamp(1.1rem, 2vw, 1.3rem);
  line-height: 1.6;
  color: #242424;
  font-weight: 600;
}

.hero-section .hero_buttons {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1rem;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-top: 1rem;
}

/* ----- Features ----- */
.features-section {
  font-weight: 500;
  display: -ms-grid;
  display: grid;
  gap: 1rem;
  background-color: #39A883;
  padding-top: 4rem;
  padding-bottom: 4rem;
}

.features-section .hero__features {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (1fr)[4];
      grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  padding: 0;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
}

@media (max-width: 992px) {
  .features-section .hero__features {
    -ms-grid-columns: (1fr)[2];
        grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .features-section .hero__features {
    -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
  }
}

.features-section .hero__features div {
  padding: 0;
  display: -ms-grid;
  display: grid;
  -ms-grid-rows: auto 1fr;
      grid-template-rows: auto 1fr;
  gap: 0;
  text-align: left;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
  position: relative;
}

.features-section .hero__features div h4 {
  margin: 0;
  font-size: 1.75rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.3;
  margin-bottom: 1rem;
}

.features-section .hero__features div p {
  margin: 0;
  font-size: 1rem;
  color: #fff;
  line-height: 1.6;
}

/* ----- Container info ----- */
.container-info {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #D6F4F7;
}

.container-info .container-info_content {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 3fr 2fr;
      grid-template-columns: 3fr 2fr;
  gap: 4rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.container-info .container-info_content .container-info_content_image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
      grid-template-areas: "size-image";
  display: -ms-grid;
  display: grid;
}

.container-info .container-info_content .container-info_content_image img {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  grid-area: size-image;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.container-info .container-info_content .container-info_content_image .price-tag {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  grid-area: size-image;
}

.container-info .dimension-table {
  border-collapse: collapse;
  width: 100%;
  border-radius: 0.75rem;
  overflow: hidden;
}

.container-info .dimension-table th, .container-info .dimension-table td {
  padding: 0.5rem 0.5rem;
  border-bottom: 1px solid #868e96;
  text-align: left;
  line-height: 1.6;
}

.container-info .dimension-table td:last-child {
  font-weight: 600;
  color: #212529;
}

.container-info .dimension-table tr:last-child td {
  border-bottom: none;
}

/* ----- Fits list ----- */
.fits {
  background: #f8f9fa;
  background-color: #111169;
}

.fits .fits_content {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
  gap: 1rem;
}

.fits .fits_content h2 {
  color: #E98F3A;
  -ms-flex-item-align: start;
      -ms-grid-row-align: start;
      align-self: start;
  -ms-grid-column-align: start;
      justify-self: start;
}

.fits .fits_items {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (minmax(140px, 1fr))[auto-fit];
      grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 0;
  display: grid;
  gap: 1rem;
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.fits .fits_items h4 {
  margin: 0;
  font-size: 1.75rem;
  font-weight: 700;
  color: #f8f9fa;
  line-height: 2.6rem;
}

.fits .fits_items p {
  margin: 0;
  font-size: 1rem;
  color: #f8f9fa;
  line-height: 1.4rem;
}

.fits .fits_items div {
  display: -ms-grid;
  display: grid;
  grid-gap: 1rem;
}

/* ----- Storage conditions ----- */
.salamader {
  background-color: #fbf9f6;
  padding-top: 4rem;
  padding-bottom: 4rem;
}

.salamader h2 {
  font-weight: 900;
  font-size: 2.5rem;
  color: #242424;
  line-height: 1.2;
}

.salamader .salamader_content {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 6fr 4fr;
      grid-template-columns: 6fr 4fr;
  gap: 0;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.salamader .salamader_text {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
  gap: 0;
}

.salamader .salamader_text p {
  margin-bottom: 1rem;
}

.salamader .salamader_text .button {
  -ms-grid-column-align: start;
      justify-self: start;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-top: 1rem;
}

.salamader_content {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 2fr 3fr;
      grid-template-columns: 2fr 3fr;
  gap: 4rem;
}

/* ----- Process ----- */
.process-section {
  background: #242424;
  padding-top: 4rem;
  padding-bottom: 4rem;
}

.process-section img.process_item_icon {
  width: 12rem;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}

.process-section .section-title {
  text-align: center;
  margin-bottom: 1rem;
}

.process-section .section-title h2 {
  color: #fff;
}

.process-section .section-title h3 {
  color: #E1E1E1;
}

.process-section .process_content {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (1fr)[4];
      grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  position: relative;
  padding-bottom: 2rem;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
}

.process-section .process_item {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
  gap: 0;
  text-align: left;
  position: relative;
  z-index: 1;
  padding-top: 0.5rem;
}

.process-section .process_item_number {
  font-family: "Borel", cursive;
  font-size: 2.5rem;
  font-weight: 700;
  color: #39A883;
  line-height: 1;
  margin-bottom: 1rem;
  background-color: #242424;
  display: inline-block;
  padding: 0.25rem 0.25rem;
  z-index: 2;
  text-align: left;
}

.process-section .process_item_content {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: auto 1fr;
      grid-template-columns: auto 1fr;
  -ms-grid-rows: auto 1fr;
      grid-template-rows: auto 1fr;
  gap: 0.5rem;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
  justify-items: start;
}

.process-section .process_item_content h4 {
  margin: 0;
  font-size: 1.75rem;
  font-weight: 700;
  color: #fff;
  line-height: 2rem;
  margin-bottom: 0.5rem;
  background-color: #242424;
  display: inline-block;
  padding: 0.25rem 0.25rem;
}

.process-section .process_item_content p {
  margin: 0;
  font-size: 1rem;
  color: #fff;
  line-height: 1.6rem;
  padding: 0.25rem 0.25rem;
  -ms-grid-column: 2;
  -ms-grid-column-span: 2;
  grid-column: 2 / span 2;
}

@media (max-width: 992px) {
  .process-section .process_content {
    -ms-grid-columns: (1fr)[2];
        grid-template-columns: repeat(2, 1fr);
    gap: 4rem;
    padding-top: 2rem;
  }
  .process-section .process_content::before {
    display: none;
  }
}

@media (max-width: 768px) {
  .process-section .process_content {
    -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
    gap: 2rem;
    padding-top: 2rem;
  }
}

/* ----- Area map ----- */
.area-map {
  padding: 4rem 0;
  text-align: center;
  background: #f8f9fa img;
  background-margin-inline: auto;
  background-max-width: 950px;
}

/* ----- Pricing ----- */
.pricing {
  background-color: #D6F4F7;
}

.pricing .pricing_table_header {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 2fr 8fr;
      grid-template-columns: 2fr 8fr;
  gap: 1rem;
  border-bottom: 1px solid #212529;
      grid-template-areas: "head header";
}

.pricing .pricing_table_header h3 {
  -ms-grid-row: 1;
  -ms-grid-column: 2;
  grid-area: header;
  font-size: 1.75rem;
  font-weight: 700;
  color: #212529;
      justify-self: center;
}

.pricing .pricing_table_row {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 2fr 8fr;
      grid-template-columns: 2fr 8fr;
  gap: 1rem;
  border-bottom: 1px solid #212529;
      grid-template-areas: "head header";
}

.pricing .pricing_table_row .price_value {
  grid-area: price;
  font-size: clamp(2.55rem, calc(2.55rem + 2vw), 4rem);
  font-weight: 700;
  color: #212529;
  -ms-grid-column-align: center;
      justify-self: center;
  border-right: 1px solid #212529;
  border-left: 1px solid #212529;
  width: 100%;
  text-align: center;
  margin-top: 1rem;
  margin-bottom: 1rem;
}

.pricing .pricing_table_footer {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 2fr 8fr;
      grid-template-columns: 2fr 8fr;
  gap: 1rem;
      grid-template-areas: "head header";
}

.pricing .pricing_table_footer .pricing_table_footer_text {
  font-size: 1rem;
  font-weight: 700;
  color: #212529;
  -ms-grid-column-align: center;
      justify-self: center;
  -ms-grid-row: 1;
  -ms-grid-column: 2;
  grid-area: header;
}

/* ----- Realizations ----- */
.realizations-section {
  padding: 4rem 0;
  background-color: #fbf9f6;
}

.realizations-section .realizations_content {
  padding: 4rem 0;
}

.realizations-section .realizations_placeholder {
  font-size: 1.75rem;
  color: #868e96;
  font-weight: 600;
  text-align: center;
}

.realizations-section .realizations_grid {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (minmax(230px, 1fr))[auto-fill];
      grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: 1rem;
  padding-top: 2rem;
}

@media (max-width: 992px) {
  .realizations-section .realizations_grid {
    -ms-grid-columns: (minmax(250px, 1fr))[auto-fill];
        grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 2rem;
  }
}

@media (max-width: 768px) {
  .realizations-section .realizations_grid {
    -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
    gap: 2rem;
  }
}

.realizations-section .realization_item {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
  -ms-grid-rows: auto auto;
      grid-template-rows: auto auto;
  gap: 0;
  background: #fff;
  overflow: hidden;
  -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
          box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: start;
  -ms-flex-line-pack: start;
      align-content: start;
  border-bottom: 1px solid #39A883;
}

.realizations-section .realization_item:hover {
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
          box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
}

.realizations-section .realization_image {
  width: 100%;
  overflow: hidden;
  position: relative;
  aspect-ratio: 1 / 1;
  background: #f8f9fa;
}

.realizations-section .realization_image a {
  display: block;
  width: 100%;
  height: 100%;
}

.realizations-section .realization_image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}

.realizations-section .realization_image:hover img {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}

.realizations-section .realization_content {
  padding: 0.5em 2rem 1rem 2rem;
  -ms-grid-rows: auto 1fr;
      grid-template-rows: auto 1fr;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
  gap: 1rem;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: start;
}

.realizations-section .realization_title {
  -ms-grid-column-align: start;
      justify-self: start;
  margin: 0;
  font-size: 1.25rem;
  font-weight: 700;
  color: #2b7f63;
  line-height: 1.3;
}

.realizations-section .realization_title a {
  color: inherit;
  text-decoration: none;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}

.realizations-section .realization_title a:hover {
  color: #39A883;
}

.realizations-section .realization_taxonomies {
  display: -ms-grid;
  display: grid;
  font-size: 0.7rem !important;
  -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
  gap: 0.25rem;
  font-size: 1rem;
}

.realizations-section .realization_taxonomy {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.25rem;
  color: #212529;
  line-height: 1.5;
}

.realizations-section .realization_taxonomy strong {
  font-weight: 600;
  color: #2b7f63;
  margin-right: 0.25rem;
}

.realizations-section .realization_taxonomy:not(:last-child)::after {
  content: '';
}

/* ----- Single Realization ----- */
.realization-single-section {
  padding: 4rem 0;
  background-color: #fff;
}

.breadcrumbs {
  margin-bottom: 2rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid #E1E1E1;
}

.breadcrumbs__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0;
  list-style: none;
  margin: 0;
  padding: 0;
}

.breadcrumbs__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 1rem;
  line-height: 1.5;
}

.breadcrumbs__item--home {
  font-weight: 500;
}

.breadcrumbs__item--current {
  font-size: 1.2rem;
  font-weight: 700;
  color: #65c3b5;
}

.breadcrumbs__link {
  color: #212529;
  text-decoration: none;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}

.breadcrumbs__link:hover {
  color: #39A883;
  text-decoration: underline;
}

.breadcrumbs__current {
  color: #65c3b5;
  font-weight: 700;
}

.breadcrumbs__separator {
  color: #868e96;
  font-size: 1rem;
  padding: 0 0.25rem;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

.breadcrumbs--realizacie {
  margin-bottom: 4rem;
}

.realization-single {
  max-width: 1440px;
  margin: 0 auto;
}

.realization-single__header {
  margin-bottom: 4rem;
}

.realization-single__back {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
  color: #2b7f63;
  text-decoration: none;
  font-weight: 500;
  margin-bottom: 2rem;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}

.realization-single__back:hover {
  color: #39A883;
}

.realization-single__back i {
  font-size: 0.9rem;
}

.realization-single__title {
  font-size: 2.2rem;
  font-weight: 700;
  color: #2b7f63;
  line-height: 1.2;
  margin: 0 0 2rem 0;
}

.realization-single__taxonomies {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0.5rem;
}

.realization-single__taxonomy {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.25rem;
  color: #212529;
  line-height: 1.6;
  font-size: 1rem;
}

.realization-single__taxonomy strong {
  font-weight: 600;
  color: #2b7f63;
  margin-right: 0.25rem;
}

.realization-single__taxonomy a {
  color: #39A883;
  text-decoration: none;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}

.realization-single__taxonomy a:hover {
  color: #2b7f63;
  text-decoration: underline;
}

.realization-single__image {
  width: 100%;
  margin-bottom: 4rem;
  border-radius: 0.75rem;
  overflow: hidden;
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
          box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.realization-single__image img {
  width: 100%;
  height: auto;
  display: block;
}

.realization-single__content {
  margin-bottom: 1rem;
  font-size: 1rem;
  line-height: 1.8;
  color: #212529;
}

.realization-single__content h2, .realization-single__content h3, .realization-single__content h4 {
  color: #2b7f63;
  margin-top: 4rem;
  margin-bottom: 1rem;
}

.realization-single__content p {
  margin-bottom: 1rem;
}

.realization-single__content ul, .realization-single__content ol {
  margin-bottom: 1rem;
  padding-left: 2rem;
}

.realization-single__gallery {
  margin-bottom: 4rem;
  padding-top: 4rem;
}

.realization-single__gallery-title {
  font-size: 1.75rem;
  font-weight: 700;
  color: #2b7f63;
  margin-bottom: 2rem;
}

.realization-single__gallery-grid {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (minmax(288px, 1fr))[auto-fit];
      grid-template-columns: repeat(auto-fit, minmax(288px, 1fr));
  grid-auto-rows: 288px;
  gap: 0;
  width: 100%;
  grid-auto-flow: row dense;
}

@media (max-width: 768px) {
  .realization-single__gallery-grid {
    -ms-grid-columns: (minmax(120px, 1fr))[auto-fit];
        grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    grid-auto-rows: 120px;
    gap: 0.25rem;
  }
}

.realization-single__gallery-item {
  position: relative;
  overflow: hidden;
  aspect-ratio: 1 / 1;
  background: #f8f9fa;
  width: 100%;
  height: 100%;
}

.realization-single__gallery-item--span-2x2 {
  grid-column: span 2;
  grid-row: span 2;
  aspect-ratio: 1 / 1;
  width: 100%;
  height: 100%;
}

@media (max-width: 768px) {
  .realization-single__gallery-item--span-2x2 {
    grid-column: span 1;
    grid-row: span 1;
  }
}

.realization-single__gallery-item img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
  display: block;
}

.realization-single__gallery-link {
  display: block;
  width: 100%;
  height: 100%;
  position: relative;
}

.realization-single__gallery-link:hover img {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}

.realization-single__gallery-icon {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  width: 15px;
  height: 15px;
  color: rgba(255, 255, 255, 0.8);
  font-size: 15px;
  line-height: 1;
  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;
  background: rgba(0, 0, 0, 0.3);
  border-radius: 50%;
  padding: 4px;
  z-index: 10;
  pointer-events: none;
  -webkit-transition: opacity 0.3s ease, background 0.3s ease;
  transition: opacity 0.3s ease, background 0.3s ease;
}

.realization-single__gallery-link:hover .realization-single__gallery-icon {
  opacity: 1;
  background: rgba(0, 0, 0, 0.5);
}

.realization-single__navigation {
  margin-top: 4rem;
  padding-top: 4rem;
  border-top: 1px solid #E1E1E1;
}

.realization-single__nav {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1fr;
      grid-template-columns: 1fr 1fr;
  gap: 2rem;
}

@media (max-width: 768px) {
  .realization-single__nav {
    -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
  }
}

.realization-single__nav-item--prev {
  text-align: left;
}

.realization-single__nav-item--next {
  text-align: right;
}

@media (max-width: 768px) {
  .realization-single__nav-item--next {
    text-align: left;
  }
}

.realization-single__nav-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1rem;
  padding: 1rem;
  background: #f8f9fa;
  text-decoration: none;
  color: #212529;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.realization-single__nav-link:hover {
  background: #39A883;
  color: #fff;
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
          box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.realization-single__nav-link i {
  font-size: 1.2rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.realization-single__nav-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.25rem;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}

.realization-single__nav-label {
  font-size: 1rem;
  font-weight: 500;
  opacity: 0.8;
}

.realization-single__nav-title {
  font-size: 1.2rem;
  font-weight: 600;
  color: inherit;
}

.realization-single__nav-image {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 80px;
  height: 80px;
  overflow: hidden;
}

.realization-single__nav-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}

.realization-single__nav-item--next .realization-single__nav-link {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}

.realization-single__nav-item--next .realization-single__nav-link .realization-single__nav-content {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}

.realization-single__nav-item--next .realization-single__nav-link .realization-single__nav-image {
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
  margin-left: auto;
}

.realization-single__nav-item--next .realization-single__nav-link i {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
  margin-left: 1rem;
  margin-right: 1rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

@media (max-width: 768px) {
  .realization-single__nav-item--next .realization-single__nav-link .realization-single__nav-content {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  .realization-single__nav-item--next .realization-single__nav-link .realization-single__nav-image {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    margin-left: 0;
  }
  .realization-single__nav-item--next .realization-single__nav-link i {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
    margin-left: auto;
    margin-right: 0;
  }
}

/* ----- FAQ ----- */
.faq {
  padding: 4rem 0;
  background-color: #fff;
}

.faq .section-title h2 {
  color: #242424;
}

.faq .section-title h3 {
  color: #242424;
}

.faq__grid {
  display: -ms-grid;
  display: grid;
  gap: 1rem;
  width: 100%;
  margin: 0 auto;
  padding-top: 4rem;
  padding-bottom: 4rem;
}

.faq__item {
  background: #fff;
  border-radius: 0.75rem;
  overflow: hidden;
  -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
          box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.faq__item[open] {
  margin-bottom: 1rem;
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
          box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.faq__item[open] .faq__question::after {
  content: '\f077';
  /* Font Awesome chevron-up */
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.faq__question {
  position: relative;
  padding: 1rem 2rem;
  cursor: pointer;
  font-weight: 600;
  color: #2b7f63;
  list-style: none;
  -webkit-transition: background-color 0.2s ease;
  transition: background-color 0.2s ease;
}

.faq__question:hover {
  background-color: #f8f9fa;
}

.faq__question::after {
  content: '\f078';
  /* Font Awesome chevron-down */
  font-family: 'FontAwesome';
  position: absolute;
  right: 2rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}

.faq__answer {
  padding: 0 2rem 1rem;
  color: #212529;
  background-color: #fff;
}

.faq__answer p:first-child {
  margin-top: 0;
}

.faq__answer p:last-child {
  margin-bottom: 0;
}

.faq details > summary::-webkit-details-marker {
  display: none;
}

/* ----- Location ----- */
.location {
  padding: 4rem 0;
  background: #fff;
}

.location .map-wrapper {
  max-width: 100%;
  margin-inline: auto;
  border-radius: 0.75rem;
  overflow: hidden;
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
          box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

/* ----- References ----- */
.references {
  padding: 4rem 2rem;
  background: #f8f9fa;
  text-align: center;
}

/* ----- Referencie ----- */
.referencie {
  background: #f8f9fa;
  padding-top: 4rem;
  padding-bottom: 4rem;
}

.referencie .section-title {
  margin-bottom: 1rem;
}

.referencie .section-title h2 {
  color: #212529;
  text-align: left;
}

.referencie__carousel-wrapper {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1rem;
}

.referencie__carousel {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  overflow: hidden;
  position: relative;
}

.referencie__track {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2rem;
  -webkit-transition: -webkit-transform 0.5s ease;
  transition: -webkit-transform 0.5s ease;
  transition: transform 0.5s ease;
  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
  will-change: transform;
}

.referencie__item {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 calc(33.333% - 1.33rem);
          flex: 0 0 calc(33.333% - 1.33rem);
  min-width: 0;
  background: #fff;
  border-radius: 0.75rem;
  padding: 4rem;
  -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
          box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: relative;
  gap: 1rem;
}

@media (max-width: 992px) {
  .referencie__item {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 calc(50% - 1rem);
            flex: 0 0 calc(50% - 1rem);
  }
}

@media (max-width: 768px) {
  .referencie__item {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 100%;
            flex: 0 0 100%;
  }
}

.referencie__quote-mark {
  position: absolute;
  top: 1rem;
  right: 2rem;
  font-size: 4rem;
  line-height: 1;
  color: #E1E1E1;
  font-family: Georgia, serif;
  font-weight: 700;
  opacity: 0.5;
  z-index: 0;
}

.referencie__stars {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2px;
  margin-bottom: 0.5rem;
  position: relative;
  z-index: 1;
}

.referencie__stars .fa-star {
  color: #FF8C00;
  font-size: 1.1rem;
}

.referencie__text {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  position: relative;
  z-index: 1;
}

.referencie__text p {
  color: #212529;
  font-size: 1rem;
  line-height: 1.6;
  margin: 0;
}

.referencie__customer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1rem;
  margin-top: auto;
  position: relative;
  z-index: 1;
}

.referencie__image {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.referencie__image img.referencie__avatar {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}

.referencie__name p {
  font-weight: 700;
  font-size: 1rem;
  color: #39A883;
  margin: 0;
}

.referencie__nav {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 1px solid #E1E1E1;
  background: #fff;
  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;
  cursor: pointer;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  z-index: 2;
}

.referencie__nav i {
  color: #212529;
  font-size: 1.2rem;
}

.referencie__nav:hover {
  background: #39A883;
  border-color: #39A883;
}

.referencie__nav:hover i {
  color: #fff;
}

.referencie__nav:active {
  -webkit-transform: scale(0.95);
          transform: scale(0.95);
}

.referencie__nav--prev {
  -webkit-box-ordinal-group: 0;
      -ms-flex-order: -1;
          order: -1;
}

.referencie__nav--next {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}

@media (max-width: 768px) {
  .referencie__nav {
    width: 40px;
    height: 40px;
  }
  .referencie__nav i {
    font-size: 1rem;
  }
  .referencie__item {
    padding: 2rem;
  }
}

/* ----- Footer ----- */
/* ----- Contact Form ----- */
.contact-form {
  padding: 4rem 2rem;
  background-color: #f8f9fa;
  width: 100%;
}

.contact-form__grid {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1rem;
  margin: 0 auto;
  padding-top: 4rem;
  padding-bottom: 4rem;
}

.contact-form .form-group {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  margin-bottom: 0.5rem;
  /* Hide the native select */
  /* Custom select styling */
}

.contact-form .form-group label {
  font-weight: 500;
  color: #212529;
  margin-bottom: 0.25rem;
  font-size: 0.9rem;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}

.contact-form .form-group input,
.contact-form .form-group select,
.contact-form .form-group textarea {
  padding: 1rem;
  border: 1px solid #E1E1E1;
  border-radius: 2px;
  font-family: "Roboto", sans-serif;
  font-size: 1rem;
  width: 100%;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  background-color: white;
}

.contact-form .form-group input:hover,
.contact-form .form-group select:hover,
.contact-form .form-group textarea:hover {
  border-color: #c8c8c8;
}

.contact-form .form-group input:focus,
.contact-form .form-group select:focus,
.contact-form .form-group textarea:focus {
  outline: none;
  border-color: #2b7f63;
  -webkit-box-shadow: 0 0 0 3px rgba(43, 127, 99, 0.1);
          box-shadow: 0 0 0 3px rgba(43, 127, 99, 0.1);
}

.contact-form .form-group input.error,
.contact-form .form-group select.error,
.contact-form .form-group textarea.error {
  border-color: #e74c3c;
  background-color: rgba(231, 76, 60, 0.02);
}

.contact-form .form-group .error-message {
  color: #e74c3c;
  font-size: 0.8rem;
  margin-top: 0.25rem;
  display: none;
}

.contact-form .form-group .error-message.visible {
  display: block;
}

.contact-form .form-group select#container {
  display: none;
}

.contact-form .form-group .custom-select-wrapper {
  position: relative;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  width: 100%;
}

.contact-form .form-group .custom-select {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  border: 1px solid #E1E1E1;
  border-radius: 2px;
  background-color: white;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.contact-form .form-group .custom-select:hover {
  border-color: #c8c8c8;
}

.contact-form .form-group .custom-select.open {
  border-color: #2b7f63;
  -webkit-box-shadow: 0 0 0 3px rgba(43, 127, 99, 0.1);
          box-shadow: 0 0 0 3px rgba(43, 127, 99, 0.1);
}

.contact-form .form-group .custom-select.open .custom-select__trigger {
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}

.contact-form .form-group .custom-select.open .custom-options {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
  margin-top: 0;
}

.contact-form .form-group .custom-select.open .arrow {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

.contact-form .form-group .custom-select__trigger {
  position: relative;
  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;
  padding: 1rem;
  font-size: 1rem;
  color: #212529;
  height: 54px;
  cursor: pointer;
  border-radius: 2px;
}

.contact-form .form-group .custom-select__trigger .arrow {
  position: relative;
  width: 12px;
  height: 12px;
  display: inline-block;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.contact-form .form-group .custom-select__trigger .arrow::before, .contact-form .form-group .custom-select__trigger .arrow::after {
  content: "";
  position: absolute;
  bottom: 0;
  width: 0.15rem;
  height: 0.6rem;
  background-color: #212529;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.contact-form .form-group .custom-select__trigger .arrow::before {
  left: 0;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}

.contact-form .form-group .custom-select__trigger .arrow::after {
  right: 0;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

.contact-form .form-group .custom-options {
  position: absolute;
  display: block;
  top: 100%;
  left: 0;
  right: 0;
  background: white;
  border: 1px solid #E1E1E1;
  border-top: 0;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  margin-top: -8px;
  z-index: 10;
  max-height: 240px;
  overflow-y: auto;
  border-bottom-left-radius: 0.75rem;
  border-bottom-right-radius: 0.75rem;
}

.contact-form .form-group .custom-option {
  position: relative;
  display: block;
  padding: 0.5rem 1rem;
  font-size: 1rem;
  color: #212529;
  cursor: pointer;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.contact-form .form-group .custom-option:hover {
  background-color: rgba(43, 127, 99, 0.06);
}

.contact-form .form-group .custom-option.selected {
  background-color: rgba(43, 127, 99, 0.1);
  color: #2b7f63;
}

.contact-form .form-group .custom-option.disabled {
  color: #868e96;
  background-color: #f8f9fa;
  cursor: not-allowed;
}

.contact-form .form-group .custom-option.disabled:hover {
  background-color: #f8f9fa;
}

.contact-form .form-group .custom-option i.fa {
  margin-right: 8px;
}

.contact-form .form-group .custom-option i.status-available {
  color: #2ecc71;
}

.contact-form .form-group .custom-option i.status-unavailable {
  color: #e74c3c;
}

/* Style for custom select dropdown */
.status-icon {
  display: inline-block;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  margin-right: 8px;
  vertical-align: middle;
}

.status-available {
  color: #2ecc71;
}

.status-unavailable {
  color: #e74c3c;
}

@-webkit-keyframes ripple {
  0% {
    -webkit-transform: scale(0, 0);
            transform: scale(0, 0);
    opacity: 0.5;
  }
  20% {
    -webkit-transform: scale(25, 25);
            transform: scale(25, 25);
    opacity: 0.5;
  }
  100% {
    opacity: 0;
    -webkit-transform: scale(40, 40);
            transform: scale(40, 40);
  }
}

@keyframes ripple {
  0% {
    -webkit-transform: scale(0, 0);
            transform: scale(0, 0);
    opacity: 0.5;
  }
  20% {
    -webkit-transform: scale(25, 25);
            transform: scale(25, 25);
    opacity: 0.5;
  }
  100% {
    opacity: 0;
    -webkit-transform: scale(40, 40);
            transform: scale(40, 40);
  }
}

@-webkit-keyframes ripple-effect {
  100% {
    -webkit-transform: scale(2.5);
            transform: scale(2.5);
    opacity: 0;
  }
}

@keyframes ripple-effect {
  100% {
    -webkit-transform: scale(2.5);
            transform: scale(2.5);
    opacity: 0;
  }
}

/* Form validation styles */
.form-validation-message {
  padding: 1rem;
  margin-bottom: 2rem;
  border-radius: 2px;
  font-weight: 500;
  display: none;
}

.form-validation-message.success {
  display: block;
  background-color: rgba(46, 204, 113, 0.1);
  color: #2ecc71;
  border: 1px solid rgba(46, 204, 113, 0.2);
}

.form-validation-message.error {
  display: block;
  background-color: rgba(231, 76, 60, 0.1);
  color: #e74c3c;
  border: 1px solid rgba(231, 76, 60, 0.2);
}

/* Mobile responsiveness */
@media (max-width: 768px) {
  .contact-form {
    padding: 1rem;
  }
  .contact-form__grid {
    padding: 2rem;
  }
  .contact-form .button {
    width: 100%;
    -ms-flex-item-align: center;
        -ms-grid-row-align: center;
        align-self: center;
  }
}

.pswp-gallery {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (minmax(140px, 1fr))[auto-fit];
      grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 0px;
}

.interactive-map-container {
  display: -ms-grid;
  display: grid;
      grid-template-areas: "legend map";
  -ms-grid-columns: 1fr 4fr;
      grid-template-columns: 1fr 4fr;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
}

.interactive-map-container .map-legend {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  grid-area: legend;
}

.interactive-map-container .svg-map-wrapper {
  -ms-grid-row: 1;
  -ms-grid-column: 2;
  grid-area: map;
}

.svg-map-wrapper svg {
  max-width: 100%;
  height: auto;
}

.storage-tooltip {
  background: rgba(0, 0, 0, 0.8);
  color: white;
  padding: 5px 10px;
  border-radius: 3px;
  pointer-events: none;
  z-index: 1000;
}

/* Legend styles */
.map-legend {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
  margin-top: 20px;
}

.legend-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 1rem;
}

.legend-circle {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  margin-right: 8px;
}

.legend-red {
  background-color: #e74c3c;
}

.legend-green {
  background-color: #2ecc71;
}

.legend-grey {
  background-color: #CCCCCC;
}

.legend-text {
  font-size: 14px;
}

.gallery {
  background-color: #D6F4F7;
}

.site-footer {
  padding-top: 4rem;
  padding-bottom: 4rem;
  background-color: #242424;
  color: #fff;
  text-align: left;
  font-size: 1rem;
}

.site-footer .footer-logo {
  width: 8rem;
  height: auto;
  margin-bottom: 1rem;
  margin-top: 1.3em;
}

.site-footer p {
  margin: 0;
  margin-bottom: 0.5rem;
  line-height: 1.6;
}

.site-footer .footer-content {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (1fr)[5];
      grid-template-columns: repeat(5, 1fr);
  gap: 4rem;
  margin-bottom: 4rem;
}

@media (max-width: 992px) {
  .site-footer .footer-content {
    -ms-grid-columns: (1fr)[2];
        grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .site-footer .footer-content {
    -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
  }
}

.site-footer .footer-column h3 {
  font-size: 1.2rem;
  font-weight: 700;
  margin-bottom: 1rem;
  color: #fff;
}

.site-footer .footer-column ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.site-footer .footer-column ul li {
  margin-bottom: 0.5rem;
}

.site-footer .footer-column ul li a {
  color: #fff;
  text-decoration: none;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}

.site-footer .footer-column ul li a:hover {
  color: #39A883;
}

.site-footer .contact-info-footer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.5rem;
  color: #fff;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  text-align: left;
}

.site-footer .contact-info-footer .phone {
  font-size: 1.3rem;
  font-weight: 700;
  color: #39A883;
}

.site-footer .contact-info-footer i {
  color: #39A883;
  display: inline;
  margin-right: 0.5rem;
}

.site-footer .contact-info-footer .email {
  font-size: 1.3rem;
  font-weight: 700;
  color: #39A883;
}

.site-footer .contact-info-footer .social-icons {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1rem;
  margin-top: 0.5rem;
}

.site-footer .contact-info-footer .social-icons a {
  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;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.1);
  color: #fff;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.site-footer .contact-info-footer .social-icons a:hover {
  background-color: #39A883;
  color: #fff;
}

.site-footer .footer-contact p {
  margin-bottom: 0.5rem;
}

.site-footer .footer-contact .phone, .site-footer .footer-contact .email {
  color: #fff;
  text-decoration: none;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}

.site-footer .footer-contact .phone:hover, .site-footer .footer-contact .email:hover {
  color: #39A883;
}

.site-footer .footer-locations {
  list-style: none;
  padding: 0;
  margin: 0;
}

.site-footer .footer-locations li {
  margin-bottom: 0.5rem;
  color: #fff;
}

.site-footer .site-info {
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  padding-top: 1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1rem;
}

.site-footer .site-info .copyright {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.25rem;
}

.site-footer .site-info .copyright p {
  margin: 0;
  color: #fff;
  font-size: 1rem;
}

.site-footer .site-info .copyright .footer-credit {
  font-size: 0.9rem;
  opacity: 0.8;
}

@media (min-width: 60em) {
  .hero__content {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  .hero__image {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
}

.reviews {
  padding: 60px 20px;
}

.reviews__carousel-wrapper {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1rem;
  max-width: 1440px;
  margin: 0 auto;
}

.reviews__carousel {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  overflow: hidden;
  position: relative;
  padding: 1rem 2rem;
}

.reviews__track {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 4rem;
  -webkit-transition: -webkit-transform 0.3s ease-in-out;
  transition: -webkit-transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
  will-change: transform;
}

.reviews__nav {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 2px solid #E1E1E1;
  background: #fff;
  color: #fbf9f6;
  cursor: pointer;
  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;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.reviews__nav i {
  font-size: 1.2rem;
}

.reviews__nav:hover {
  border-color: #fbf9f6;
  background: #f8f9fa;
}

.reviews__nav:hover i {
  color: #212529;
}

.reviews__nav:active {
  -webkit-transform: scale(0.95);
          transform: scale(0.95);
}

@media (max-width: 768px) {
  .reviews__nav {
    width: 40px;
    height: 40px;
  }
  .reviews__nav i {
    font-size: 1rem;
  }
}

.review {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 calc(33.333% - 1.33rem);
          flex: 0 0 calc(33.333% - 1.33rem);
  -ms-flex-negative: 0;
      flex-shrink: 0;
  min-width: 0;
  max-width: 520px;
}

@media (max-width: 992px) {
  .review {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 calc(50% - 1rem);
            flex: 0 0 calc(50% - 1rem);
  }
}

@media (max-width: 768px) {
  .review {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 100%;
            flex: 0 0 100%;
  }
}

.bubble {
  position: relative;
  background: #ffffff;
  border-radius: 16px;
  padding: 22px 26px 24px;
  color: #222;
  min-height: 200px;
  -webkit-filter: drop-shadow(0 6px 12px rgba(0, 0, 0, 0.12)) drop-shadow(0 6px 12px rgba(0, 0, 0, 0.08));
          filter: drop-shadow(0 6px 12px rgba(0, 0, 0, 0.12)) drop-shadow(0 6px 12px rgba(0, 0, 0, 0.08));
}

.bubble p {
  margin: 0;
  line-height: 1.55;
  font-size: 16px;
}

.bubble .stars {
  color: #FFD700 !important;
  font-size: 14px;
  letter-spacing: 2px;
  margin-left: 0.5rem;
  display: inline-block;
}

.bubble .quote {
  position: absolute;
  top: 16px;
  right: 18px;
  font-size: 42px;
  line-height: 1;
  opacity: .15;
  pointer-events: none;
}

.bubble::after {
  content: "";
  position: absolute;
  left: 64px;
  bottom: -10px;
  width: 20px;
  height: 20px;
  background: #ffffff;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  border-radius: 4px;
}

.author {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 12px;
  margin-top: 14px;
  padding-left: 44px;
}

.author .avatar {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  -o-object-fit: cover;
     object-fit: cover;
}

.author .meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0.25rem;
}

.author .meta strong {
  font-size: 14px;
  display: inline-block;
}

.author .meta span {
  font-size: 13px;
  color: #666;
}

.author .meta .stars {
  color: #FFD700 !important;
  display: inline-block;
  margin-left: 0.25rem;
}

/* Responsive */
@media (max-width: 480px) {
  .bubble {
    padding: 18px 20px;
  }
  .bubble::after {
    left: 42px;
  }
  .author {
    padding-left: 30px;
  }
}

body {
  font-family: "Sofia Sans", sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.lblue {
  background-color: #bcd7f2;
}

.dblue {
  background-color: #2b7f63;
}

.lgreen {
  background-color: #b3c7b7;
}

.c-teal {
  background-color: #d1f2ed;
}

.c-gray {
  background-color: rgba(216, 202, 236, 0.61);
}

.c-vio {
  background-color: rgba(216, 202, 236, 0.61);
  -webkit-box-shadow: 3px 3px 20px 2px rgba(0, 0, 0, 0.18);
          box-shadow: 3px 3px 20px 2px rgba(0, 0, 0, 0.18);
}

.teal {
  color: #65c3b5;
}

@media (max-width: 1200px) {
  html {
    font-size: 87.5%;
  }
  .button {
    -ms-grid-column-align: center;
        justify-self: center;
  }
  .hero_text_header-desktop {
    display: none;
    visibility: hidden;
  }
  .hero_text_header-mobile {
    display: inline-block;
    visibility: visible;
  }
  .app-navigation {
    display: none;
    visibility: hidden;
  }
  .mobile-header-trego {
    display: -ms-grid;
    display: grid;
    visibility: visible;
  }
  main {
    margin-top: 90px;
  }
  .hero-section .hero_content {
    -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
        grid-template-areas: "hero-image" "hero-headline";
  }
  .hero-section .hero_content .price-tag {
    margin-right: 1rem;
    margin-top: 0.5rem;
    width: 9rem;
    height: 9rem;
  }
  .hero-section .hero_content .button {
    -ms-flex-item-align: center;
        -ms-grid-row-align: center;
        align-self: center;
  }
  .hero-section .hero_text {
    -ms-grid-column-align: center;
        justify-self: center;
    text-align: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .container-info .container-info_content {
    -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
  }
  .storage-conditions .storage-conditions_content {
    -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
  }
  .interactive-map-container {
    -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
    grid-template-columns: 1fr;
        grid-template-areas: "legend" "map";
  }
  .contact-form__grid {
    padding: 0;
  }
  .hero-section {
    padding-top: 4rem;
    padding-bottom: 4rem;
    padding-left: 0.25rem;
    padding-right: 0.25rem;
  }
  .features-section .hero__features div:not(:last-child)::after {
    content: none;
    position: absolute;
    right: 0;
    top: 10%;
    height: 80%;
    width: 0px;
    background-color: #5BD2DD;
  }
  .container-info .container-info_content .container-info_content_image .price-tag {
    width: 10rem;
    height: 10rem;
  }
  .container-info .container-info_content {
    gap: 0.5rem;
  }
  .fits .fits_items {
    gap: 2rem;
  }
}

@media (max-width: 600px) {
  html {
    font-size: 75%;
  }
}
/*# sourceMappingURL=style.css.map */