/** ============================================
    RESET
============================================ **/
/* http://meyerweb.com/eric/tools/css/reset/
   v2.0-modified | 20110126
   License: none (public domain)
*/

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
	padding: 0;
	border: 0;
	font: inherit;
	vertical-align: baseline;
}

/* make sure to set some focus styles for accessibility */
:focus {
    outline: 0 !important;
}


/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

body {
	line-height: 1;
}

ol, ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration,
input[type=search]::-webkit-search-results-button,
input[type=search]::-webkit-search-results-decoration {
    -webkit-appearance: none;
    -moz-appearance: none;
}

input[type=search] {
    -webkit-appearance: none;
    -moz-appearance: none;
    -webkit-box-sizing: content-box;
    -moz-box-sizing: content-box;
    box-sizing: content-box;
}

textarea {
    overflow: auto;
    vertical-align: top;
    resize: vertical;
}

/**
 * Correct `inline-block` display not defined in IE 6/7/8/9 and Firefox 3.
 */

audio,
canvas,
video {
    display: inline-block;
    *display: inline;
    *zoom: 1;
    /* max-width: 100%; */
}

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */

audio:not([controls]) {
    display: none;
    height: 0;
}

/**
 * Address styling not present in IE 7/8/9, Firefox 3, and Safari 4.
 * Known issue: no IE 6 support.
 */

[hidden] {
    display: none;
}

/**
 * 1. Correct text resizing oddly in IE 6/7 when body `font-size` is set using
 *    `em` units.
 * 2. Prevent iOS text size adjust after orientation change, without disabling
 *    user zoom.
 */

html {}

/**
 * Address `outline` inconsistency between Chrome and other browsers.
 */

a:focus {
    outline: thin dotted;
}

/**
 * Improve readability when focused and also mouse hovered in all browsers.
 */

a:active,
a:hover {
    outline: 0;
}

/**
 * 1. Remove border when inside `a` element in IE 6/7/8/9 and Firefox 3.
 * 2. Improve image quality when scaled in IE 7.
 */

img {
    border: 0; /* 1 */
    -ms-interpolation-mode: bicubic; /* 2 */
}

/**
 * Address margin not present in IE 6/7/8/9, Safari 5, and Opera 11.
 */

figure {
    margin: 0;
}

/**
 * Correct margin displayed oddly in IE 6/7.
 */

form {
    margin: 0;
}

/**
 * Define consistent border, margin, and padding.
 */

fieldset {
    border: 1px solid #c0c0c0;
    margin: 0 2px;
    padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct color not being inherited in IE 6/7/8/9.
 * 2. Correct text not wrapping in Firefox 3.
 * 3. Correct alignment displayed oddly in IE 6/7.
 */

legend {
    border: 0; /* 1 */
    padding: 0;
    white-space: normal; /* 2 */
    *margin-left: -7px; /* 3 */
}

/**
 * 1. Correct font size not being inherited in all browsers.
 * 2. Address margins set differently in IE 6/7, Firefox 3+, Safari 5,
 *    and Chrome.
 * 3. Improve appearance and consistency in all browsers.
 */

button,
input,
select,
textarea {
    margin: 0; /* 2 */
    vertical-align: baseline; /* 3 */
    *vertical-align: middle; /* 3 */
}

/**
 * Address Firefox 3+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */

button,
input {
    line-height: normal;
}

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Chrome, Safari 5+, and IE 6+.
 * Correct `select` style inheritance in Firefox 4+ and Opera.
 */

button,
select {
    text-transform: none;
}

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 * 4. Remove inner spacing in IE 7 without affecting normal text inputs.
 *    Known issue: inner spacing remains in IE 6.
 */

button,
html input[type="button"], /* 1 */
input[type="reset"],
input[type="submit"] {
    -webkit-appearance: button; /* 2 */
    cursor: pointer; /* 3 */
    *overflow: visible;  /* 4 */
}

/**
 * Re-set default cursor for disabled elements.
 */

button[disabled],
html input[disabled] {
    cursor: default;
}

/**
 * 1. Address box sizing set to content-box in IE 8/9.
 * 2. Remove excess padding in IE 8/9.
 * 3. Remove excess padding in IE 7.
 *    Known issue: excess padding remains in IE 6.
 */

input[type="checkbox"],
input[type="radio"] {
    box-sizing: border-box; /* 1 */
    padding: 0; /* 2 */
    *height: 13px; /* 3 */
    *width: 13px; /* 3 */
}

/**
 * 1. Address `appearance` set to `searchfield` in Safari 5 and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari 5 and Chrome
 *    (include `-moz` to future-proof).
 */

input[type="search"] {
    -webkit-appearance: textfield; /* 1 */
    -moz-box-sizing: content-box;
    -webkit-box-sizing: content-box; /* 2 */
    box-sizing: content-box;
}

/**
 * Remove inner padding and search cancel button in Safari 5 and Chrome
 * on OS X.
 */

input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none;
}

/**
 * Remove inner padding and border in Firefox 3+.
 */

button::-moz-focus-inner,
input::-moz-focus-inner {
    border: 0;
    padding: 0;
}

/**
 * 1. Remove default vertical scrollbar in IE 6/7/8/9.
 * 2. Improve readability and alignment in all browsers.
 */

textarea {
    overflow: auto; /* 1 */
    vertical-align: top; /* 2 */
}

/**
 * Remove most spacing between table cells.
 */

table {
    border-collapse: collapse;
    border-spacing: 0;
}

html,
button,
input,
select,
textarea {
    color: #222;
}


::-moz-selection {
    background: #b3d4fc;
    text-shadow: none;
}

::selection {
    background: #b3d4fc;
    text-shadow: none;
}

img {
    vertical-align: middle;
}

fieldset {
    border: 0;
    margin: 0;
    padding: 0;
}

textarea {
    resize: vertical;
}

.chromeframe {
    margin: 0.2em 0;
    background: #ccc;
    color: #000;
    padding: 0.2em 0;
}

section {
    position: relative;
}

/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */
html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{}article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary{display:block}audio,canvas,progress,video{display:inline-block;vertical-align:baseline}audio:not([controls]){display:none;height:0}[hidden],template{display:none}a{background-color:transparent}a:active,a:hover{outline:0}abbr[title]{border-bottom:1px dotted}b,strong{font-weight:400}dfn{font-style:italic}h1{margin:0.67em 0}mark{background:#ff0;color:#000}small{font-size: 60%;}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sup{top:-0.5em}sub{bottom:-0.25em}img{border:0}svg:not(:root){overflow:hidden}figure{margin:1em 40px}hr{box-sizing:content-box;height:0}pre{overflow:auto}code,kbd,pre,samp{font-family:monospace, monospace;font-size:1em}button,input,optgroup,select,textarea{color:inherit;font:inherit;margin:0}button{overflow:visible}button,select{text-transform:none}button,html input[type="button"],input[type="reset"],input[type="submit"]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}input{line-height:normal}input[type="checkbox"],input[type="radio"]{box-sizing:border-box;padding:0}input[type="number"]::-webkit-inner-spin-button,input[type="number"]::-webkit-outer-spin-button{height:auto}input[type="search"]{-webkit-appearance:textfield;box-sizing:content-box}input[type="search"]::-webkit-search-cancel-button,input[type="search"]::-webkit-search-decoration{-webkit-appearance:none}fieldset{border:1px solid #c0c0c0;margin:0 2px;padding:0.35em 0.625em 0.75em}legend{border:0;padding:0}textarea{overflow:auto}optgroup{font-weight:bold}table{border-collapse:collapse;border-spacing:0}td,th{padding:0}


/*! HTML5 Boilerplate v5.2.0 | MIT License | https://html5boilerplate.com/ */

/*
* What follows is the result of much research on cross-browser styling.
* Credit left inline and big thanks to Nicolas Gallagher, Jonathan Neal,
* Kroc Camen, and the H5BP dev community and team.
*/

/* ==========================================================================
    Base styles: opinionated defaults
    ========================================================================== */
/*
    Amarillo: #FACC2E
    Rojo: #F75940
    Azul: #334252
    Azul hover: #364857
    Azul claro: #3DC7BE
*/

::-moz-selection { background: #b3d4fc; text-shadow: none; }
::selection {}

hr { display: block; height: 1px; border: 0; border-top: 1px solid #ccc; margin: 1em 0; padding: 0; }
audio, canvas, iframe, img, svg, video { vertical-align: middle; }
fieldset { border: 0; margin: 0; padding: 0; }
textarea { resize: vertical; }
.clearfix { display: block;clear: both; }
.clearfix:after { content: " ";display: block;clear: both; }

/** ============================================
    FONTS
============================================ **/

@font-face {
    font-family: 'Druk Web';
    src: url('../fonts/Druk-Bold-Web.woff2') format('woff2'),
         url('../fonts/Druk-Bold-Web.woff') format('woff');
    font-weight: 700;
    font-style: normal;
    font-stretch: normal;
}

@import url("https://fast.fonts.net/lt/1.css?apiType=css&c=6c3dbe4a-3a31-430a-84a6-1222fac060c5&fontids=1296152");
@font-face{
    font-family: "De Vinne W03 Text";
    src: url("../fonts/07de4eda-cb1c-4c7b-b6fa-0f2d15017911.woff2") format("woff2"),
         url("../fonts/34d3dd57-dd25-4c4f-aa5d-3bd669744ecc.woff") format("woff");
    font-weight: 400;
    font-style: normal;
    font-stretch: normal;
}

/** ============================================
    GENERICS
============================================ **/
/* h2::selection, h3::selection, p::selection {background: #FACC2E;}
h6::selection {background: #FACC2E;}
h2::-moz-selection, h3::-moz-selection, p::-moz-selection {background: #FACC2E; }
h6::-moz-selection {background: #FACC2E; }
a.btn::selection {background: none;}
a.btn::-moz-selection {background: none; }
::-webkit-input-placeholder { color: #FACC2E;}
::-moz-placeholder { color: #FACC2E;}
:-ms-input-placeholder { color: #FACC2E;}
:-moz-placeholder { color: #FACC2E;} */

/* MARGIN */
.m-auto { margin: auto; }

.m-0 { margin: 0px; }

.mt--35 { margin-top: -35px; }
.mt--1 { margin-top: -10px; }
.mt-0 { margin-top: 0px; }
.mt-1 { margin-top: 10px; }
.mt-2 { margin-top: 20px; }
.mt-3 { margin-top: 30px; }
.mt-4 { margin-top: 40px; }
.mt-5 { margin-top: 50px; }
.mt-6 { margin-top: 60px; }
.mt-7 { margin-top: 70px; }
.mt-8 { margin-top: 80px; }
.mt-9 { margin-top: 90px; }
.mt-10 { margin-top: 100px; }
.-mt-60 { margin-top: -60px; }

.mb-03 { margin-bottom: 3px; }
.mb-05 { margin-bottom: 5px; }
.mb-1 { margin-bottom: 10px; }
.mb-2 { margin-bottom: 20px; }
.mb-3 { margin-bottom: 30px; }
.mb-35 { margin-bottom: 35px; }
.mb-4 { margin-bottom: 40px; }
.mb-5 { margin-bottom: 50px; }
.mb-55 { margin-bottom: 55px; }
.mb-6 { margin-bottom: 60px; }
.mb-7 { margin-bottom: 70px; }
.mb-8 { margin-bottom: 80px; }
.mb-9 { margin-bottom: 90px; }
.mb-10 { margin-bottom: 100px; }

.mr-05 { margin-right: 05px; }
.mr-1 { margin-right: 10px; }
.mr-15 { margin-right: 15px; }
.mr-2 { margin-right: 20px; }
.mr-3 { margin-right: 30px; }
.mr-4 { margin-right: 40px; }
.mr-5 { margin-right: 50px; }
.mr-6 { margin-right: 60px; }
.mr-7 { margin-right: 70px; }
.mr-8 { margin-right: 80px; }
.mr-9 { margin-right: 90px; }
.mr-10 { margin-right: 100px; }

.ml-0 { margin-left: 0px !important; }
.ml-1 { margin-left: 10px; }
.ml-2 { margin-left: 20px; }
.ml-3 { margin-left: 30px; }
.ml-4 { margin-left: 40px; }
.ml-5 { margin-left: 50px; }
.ml-6 { margin-left: 60px; }
.ml-7 { margin-left: 70px; }
.ml-8 { margin-left: 80px; }
.ml-9 { margin-left: 90px; }
.ml-10 { margin-left: 100px; }

.mtb-1 { margin-top: 10px;margin-bottom: 10px; }
.mtb-2 { margin-top: 20px;margin-bottom: 20px; }
.mtb-3 { margin-top: 30px;margin-bottom: 30px; }
.mtb-4 { margin-top: 40px;margin-bottom: 40px; }
.mtb-5 { margin-top: 50px;margin-bottom: 50px; }
.mtb-6 { margin-top: 60px;margin-bottom: 60px; }
.mtb-7 { margin-top: 70px;margin-bottom: 70px; }
.mtb-8 { margin-top: 80px;margin-bottom: 80px; }
.mtb-9 { margin-top: 90px;margin-bottom: 90px; }
.mtb-10 { margin-top: 100px;margin-bottom: 100px; }

.mlr-1 { margin-left: 10px;margin-right: 10px; }
.mlr-2 { margin-left: 20px;margin-right: 20px; }
.mlr-3 { margin-left: 30px;margin-right: 30px; }
.mlr-4 { margin-left: 40px;margin-right: 40px; }
.mlr-5 { margin-left: 50px;margin-right: 50px; }
.mlr-6 { margin-left: 60px;margin-right: 60px; }
.mlr-7 { margin-left: 70px;margin-right: 70px; }
.mlr-8 { margin-left: 80px;margin-right: 80px; }
.mlr-9 { margin-left: 90px;margin-right: 90px; }
.mlr-10 { margin-left: 100px;margin-right: 100px; }

/* PADDING */
.p-2 { padding: 20px; }
.p-5 { padding: 50px; }
.py-1 { padding: 10px 0; }
.py-5 { padding: 50px 0; }
.px-05 { padding: 0 5px; }
.px-2 { padding: 0 20px; }

.pt-1 { padding-top: 10px; }
.pt-2 { padding-top: 20px; }
.pt-3 { padding-top: 30px; }
.pt-4 { padding-top: 40px; }
.pt-5 { padding-top: 50px; }
.pt-55 { padding-top: 55px; }
.pt-6 { padding-top: 60px; }
.pt-7 { padding-top: 70px; }
.pt-8 { padding-top: 80px; }
.pt-9 { padding-top: 90px; }
.pt-10 { padding-top: 100px; }
.pt-11 { padding-top: 110px; }
.pt-12 { padding-top: 120px; }
.pt-13 { padding-top: 130px; }
.pt-14 { padding-top: 140px; }
.pt-15 { padding-top: 150px; }

.pb-1 { padding-bottom: 10px; }
.pb-2 { padding-bottom: 20px; }
.pb-3 { padding-bottom: 30px; }
.pb-4 { padding-bottom: 40px; }
.pb-5 { padding-bottom: 50px; }
.pb-6 { padding-bottom: 60px; }
.pb-7 { padding-bottom: 70px; }
.pb-8 { padding-bottom: 80px; }
.pb-9 { padding-bottom: 90px; }
.pb-10 { padding-bottom: 100px; }
.pb-11 { padding-bottom: 110px; }
.pb-12 { padding-bottom: 120px; }
.pb-13 { padding-bottom: 130px; }
.pb-14 { padding-bottom: 140px; }
.pb-15 { padding-bottom: 150px; }

.pr-1 { padding-right: 10px; }
.pr-2 { padding-right: 20px; }
.pr-3 { padding-right: 30px; }
.pr-4 { padding-right: 40px; }
.pr-5 { padding-right: 50px; }
.pr-6 { padding-right: 60px; }
.pr-7 { padding-right: 70px; }
.pr-8 { padding-right: 80px; }
.pr-9 { padding-right: 90px; }
.pr-10 { padding-right: 100px; }

.pl-1 { padding-left: 10px; }
.pl-2 { padding-left: 20px; }
.pl-3 { padding-left: 30px; }
.pl-4 { padding-left: 40px; }
.pl-5 { padding-left: 50px; }
.pl-6 { padding-left: 60px; }
.pl-7 { padding-left: 70px; }
.pl-8 { padding-left: 80px; }
.pl-9 { padding-left: 90px; }
.pl-10 { padding-left: 100px; }

.ptb-1 { padding-top: 10px;padding-bottom: 10px; }
.ptb-2 { padding-top: 20px;padding-bottom: 20px; }
.ptb-3 { padding-top: 30px;padding-bottom: 30px; }
.ptb-4 { padding-top: 40px;padding-bottom: 40px; }
.ptb-5 { padding-top: 50px;padding-bottom: 50px; }
.ptb-6 { padding-top: 60px;padding-bottom: 60px; }
.ptb-7 { padding-top: 70px;padding-bottom: 70px; }
.ptb-8 { padding-top: 80px;padding-bottom: 80px; }
.ptb-9 { padding-top: 90px;padding-bottom: 90px; }
.ptb-10 { padding-top: 100px;padding-bottom: 100px; }

.plr-1 { padding-left: 10px;padding-right: 10px; }
.plr-2 { padding-left: 20px;padding-right: 20px; }
.plr-3 { padding-left: 30px;padding-right: 30px; }
.plr-4 { padding-left: 40px;padding-right: 40px; }
.plr-5 { padding-left: 50px;padding-right: 50px; }
.plr-6 { padding-left: 60px;padding-right: 60px; }
.plr-7 { padding-left: 70px;padding-right: 70px; }
.plr-8 { padding-left: 80px;padding-right: 80px; }
.plr-9 { padding-left: 90px;padding-right: 90px; }
.plr-10 { padding-left: 100px;padding-right: 100px; }

.bg-meddd {
    background-color: #47AA9C;
}
.bg-meddd--hover:hover { background-color: #2a6a61; }

/* FONT FAMILY */
.ff-arial { font-family: Arial, Helvetica, sans-serif; }
.ff-drukweb { font-family: 'Druk Web', Arial, Helvetica, sans-serif; }
.ff-devinne { font-family: 'De Vinne W03 Text', sans-serif; }

/* FONT SIZE */

.fs-035 { font-size: 0.35em; }
.fs-1 { font-size: 1em; }
.fs-1-6 { font-size: 1.6em; }
.fs-1-65 { font-size: 1.65em; }
.fs-2-95 { font-size: 2.95em; }
.fs-3-6 { font-size: 3.6em; }
.fs-4-75 { font-size: 4.75em; }

/* LINE HEIGHT */
.lh-1 { line-height: 1.0em; }
.lh-20px { line-height: 20px; }


/* TEXT TRANSFORM */
.tt-upper { text-transform: uppercase; }

/* TEXT DECORATION */
.td-none { text-decoration: none; }

/* LETTER SPACING */
.ls-02 { letter-spacing: 0.2px; }
.ls-2-5 { letter-spacing: 2.5px; }

/* FONT WEIGHT */
.fw-300 { font-weight: 300; }
.fw-400 { font-weight: 400; }
.fw-b { font-weight: bold; }

/* TEXT ALIGN */
.text-left { text-align: left; }
.text-right { text-align: right; }
.text-center { text-align: center; }

/* BG COLOR */
.bg-white { background-color: #ffffff; }
.bg-green { background-color: #46aa9c; }

/* TEXT COLOR */
.text-white { color: #ffffff; }
.text-green { color: #46aa9c; }
.text-green--hover:hover { color: #46aa9c; }
.text-darkgreen { color: #2a6a61; }
.text-black { color: #000000; }
.text-nav { color: #000000; }

.text-white--hover:hover { color: #46aa9c !important; }
/* a.text-black:hover { color: #ffffff; } */
a.text-nav:hover { color: #46aa9c; }

.phone-link:hover a { color: #ffffff; }
.phone-link:hover svg { fill: #ffffff; }

/* SIZES */

.w-16 { width: 16px; }
.w-32 { width: 32px; }
.w-full { width: 100%; }
.w-1\/5 {
    width: 20%;
}
.w-2\/5 {
    width: 40%;
}
.w-3\/5 {
    width: 60%;
}

.w-200 { width: 200px; }
.w-250 { width: 250px; }
.w-115 { width: 115px; }
.h-16 { height: 16px; }
.h-32 { height: 32px; }
.h-full { height: 100%; }

/* DISPLAYS */
.block { display: block; }

.no-underline {
    -webkit-text-decoration-line: none;
    text-decoration-line: none;
}

.text-lg {
    font-size: 1.125rem;
    line-height: 1.75rem;
}

/* INPUTS */
input[type="text"],
input[type="tel"],
input[type="email"],
textarea {
    width: 100%;
    height: 38px;
    padding: 5px 10px;
    border: none;
    box-sizing: border-box;
    color: #ffffff;
}
textarea { height: 150px; }

.p-r {position: relative;} 
.zi-999 {z-index: 999;}

/* OVERFLOWS */
.o-h { overflow: hidden; }

/* Chrome, Firefox, Opera, Safari 10.1+ */
::placeholder { 
    color: #f1f1f1;
    opacity: 1; /* Firefox */
}
  
/* Internet Explorer 10-11 */
:-ms-input-placeholder { color: #f1f1f1; }
  
/* Microsoft Edge */
::-ms-input-placeholder { color: #f1f1f1; }



.btn {
    width: 100%;
    border: none;
    border-radius: 5px;
    color: #46aa9c;
    font-weight: bold;
    padding: 15px;
    text-align: center;
}
.btn--white {
    background-color: #ffffff;
}
.btn--white:hover {
    background-color: #46aa9c;
    color: #ffffff;
}


.clean__wrapper {
    width: 1280px;
    height: 100%;
    margin: auto;
}
.short-wrapper {
    position: relative;
    width: 720px;
    height: 100%;
    padding-right: 15px;
    padding-left: 15px;
    margin-right: auto;
    margin-left: auto;
}
.wrapper {
    position: relative;
    width: 1280px;
    height: 100%;
    padding-right: 15px;
    padding-left: 15px;
    margin-right: auto;
    margin-left: auto;
}

.social {
    top: -2px;
    display: inline-block;
    position: relative;
}

.alert {
    margin-top: 50px;
}
    .alert--success {
        color: #8bc34a;
    }
    .alert--error {
        color: #f44336;
    }
button:disabled,
button:disabled:hover {
    background-color: #cfcfcf;
    color: #9e9e9e;
}
.text-white {
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity));
}

.text-lg {
    font-size: 1.125rem;
    line-height: 1.75rem;
}

.block {
    display: block;
}

.rounded {
    border-radius: 0.25rem;
}

.overflow-hidden {
    overflow: hidden;
}

.w-48 {
    width: 12rem;
}

.h-12 {
    height: 3rem;
}

.relative {
    position: relative;
}

.flex {
    display: flex;
    height: 100%;
}

.flex-wrap {
    flex-wrap: wrap;
}

.justify-center {
    justify-content: center;
}
.justify-end {
    justify-content: flex-end;
}
.justify-between {
    justify-content: space-between;
}

.items-center {
    align-items: center;
}


    .flex--no-height { height: initial; }
    .flex--clean {
        margin-left: 0;
        margin-right: 0;
    }
    .f-wrap {
        flex-wrap: wrap;
    }

    .aitem--start { align-items: flex-start; }
    .aitem--center { align-items: center; }
    .aitem--end { align-items: flex-end; }

    .jc-between { justify-content: space-between; }
    .jc--start { justify-content: flex-start; }
    .jc--center{ justify-content: center; }
    .jc--end{ justify-content: flex-end; }

    .aself--end {
        align-self: flex-end;
    }
    .fflow--rr {
        flex-flow: row-reverse;
    }

    .fdirection--column {
        flex-direction: column;
    }
    .item { 
        position: relative;
        min-height: 1px;
        /* padding-right: 15px;
        padding-left: 15px; */
    }
    .item--25 {
        flex: 25%;
        max-width: 25%;
    }
    .item--33 {
        flex: 33.3333%;
        max-width: 33.3333%;
    }
    .item--50 {
        flex: 50%;
        max-width: 50%;
    }
        .item--50m {
            flex: 50%;
            max-width: calc(50% - 10px);
        }
    .item--75 {
        flex: 75%;
        max-width: 75%;
    }
    .item--100 {
        flex: 100%;
        max-width: 100%;
    }
    .item--iframe iframe {
        width: 100%;
    }

sup {
    top: -28px;
    display: inline-block;
}

section {
    min-height: 590px;
}

header {
    height: 500px;
    overflow: hidden;
    position: relative;
    background-color: #d8d8d8;
}
    .header__bg,
    .section__bg,
    .block__bg {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        overflow: hidden;
    }
        .header__bg img {
            position: absolute;
            top: -9999px;
            right: -9999px;
            bottom: -9999px;
            left: -10029px;
            margin: auto;
            height: 100%;
        }

    .nav__bar { 
        position: relative; 
        top: 0;
        left: 0;
        width: 100%;
        height: 60px;
        z-index: 9999;
    }

        .nav__bar nav { }
            .nav__bar nav a { 
                font-family: 'De Vinne W03 Text', sans-serif; 
                font-size: 1em; 
                font-weight: bold;
                color: #000;
                text-decoration: none;
            }

    .header__content {}
        .header__logo {
            top: 30px;
            width: 370px;
            height: 240px;
        }

.section__bg img {
    position: absolute;
    top: -9845px;
    right: -9999px;
    bottom: -9999px;
    left: -9999px;
    margin: auto;
    width: 120%;
}

.cover {
    height: 545px;
    overflow: hidden;
}
.tech {
    height: 680px;
    background-color: #daeeeb;
    overflow: hidden;
}
    .tech .column { 
        position: relative; 
        width: calc(33.3333% - 20px);
        height: 380px;
    }
        .tech .column .column__content {
            position: relative;
            box-sizing: border-box;
            padding: 35px;
            height: 185px;
        }

.signal {
    /* height: 745px; */
    overflow: hidden;
}
    .signal .column { 
        position: relative; 
        width: calc(33.3333% - 20px);
        height: 425px;
        overflow: hidden;
    }
        .signal .column .column__content {
            position: relative;
            box-sizing: border-box;
            padding: 15px 26px;
            height: 76px;
        }
    .catalog:hover h3 {
        color: #46aa9c;
    }

    .catalog__conent {
        max-width: calc(24% - 3.5px) !important;
        height: 356px;
        position: relative;
    }
        .catalog__conent .block__text {
            padding: 20px;
            box-sizing: border-box;
        }
        .catalog__conent:hover h3 {
            color: #46aa9c;
        }

    .slide__catalog { display: none; }

.others {
    height: 745px;
    background-color: #daeeeb;
    overflow: hidden;
}
    .others .column { 
        position: relative; 
        width: calc(33.3333% - 20px);
        height: 425px;
    }
        .others .column .column__content {
            position: relative;
            box-sizing: border-box;
            padding: 15px 26px;
            height: 163px;
            line-height: 40px;
        }
            .others .column .column__content--small {
                height: 130px;
            }

.contact {
    /* height: 935px; */
    background-color: #000000;
    overflow: hidden;
}
    .contact .column { 
        position: relative; 
        width: calc(50% - 20px);
    }
        .contact .column .column__content {
            width: 100%;
        }

.block__bg img {
    position: absolute;
    top: -9999px;
    right: -9999px;
    bottom: -9999px;
    left: -9999px;
    margin: auto;
    width: 100%;
}


footer {
    height: 330px;
}
    footer .disclaimer {
        background-color: #46aa9c;
    }

    footer .h-footer {
        /* height: calc(330px - 50px); */
    }


.top{
    background-color: transparent;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    transition: all 0.5s ease;
}
        
.no-top{
    background-color: #FFFFFF;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    transition: all 0.5s ease;
}

.menu-mobile,
.header__bg--t,
.header__bg--m,
.section__bg--m {display: none;}


.carousel {
	width: 100%;
	margin: 0 auto;
}

.carousel-cell {
	width: 100%;
	height: auto;
}

.carousel-cell-img {
	width: 100%;
	height: auto;
}

.flickity-viewport {
    width: 100%;
	height: 100%;
    padding-top:56.25%;
}
.flickity-slider{
    margin-top:-56.25%;
}

/*Styling only, you can change this */
.carousel-container{
    display:flex;
    margin:0 auto;
    width:200px; 
}

.carrusel{ 
    height: 425px;
}

.text-white {
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity));
}

.text-lg {
    font-size: 1.125rem;
    line-height: 1.75rem;
}

.text-center {
    text-align: center;
}

.py-2 {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

.px-4 {
    padding-left: 1rem;
    padding-right: 1rem;
}

.rounded { border-radius: 0.25rem; }
.overflow-hidden { overflow: hidden; }
.inline-block { display: inline-block; }
.relative { position: relative; }

.modal {
    display: none;
    position: fixed;
    top: 0px;
    left: 0px;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    overflow: hidden;
    z-index: 9999;
}
    .modal__block {
        position: absolute;
        top: -9999px;
        right: -9999px;
        bottom: -9999px;
        left: -9999px;
        margin: auto;
        width: 75%;
        height: 75%;
        background-color: #ffffff;
    }
        .modal__block .modal__header {}
            .modal__header .modal__close {
                text-align: right;
                padding: 20px 30px;
            }
                .modal__header a {
                    display: inline-block;
                    width: 30px;
                    height: 30px;
                }
                    .modal__header a svg {
                        width: 30px;
                        height: 30px;
                    }

        .modal__block .modal__content {
            position: relative;
            padding: 10px 30px;
            height: calc(100% - 130px);
            overflow-y: scroll;
            box-sizing: border-box;
        }
        .modal__block .modal__footer {
            height: 50px;
        }


strong { font-weight: bold; }

::-webkit-scrollbar-track {
    -webkit-box-shadow: inset 0 0 2px rgba(0,0,0,0.3);
    background-color: #F5F5F5;
}

::-webkit-scrollbar {
    width: 2px;
    background-color: #F5F5F5;
}

::-webkit-scrollbar-thumb { background-color: #d6d6d6; }

/* ==========================================================================
      $MEDIA-QUERIES
========================================================================== */
   
/* FULL HD PORTRAIT
----------------------------------------------- */
@media only screen and (min-height: 1080px) and (orientation: portrait) {}

/* FULL HD LANDSCAPE
----------------------------------------------- */
@media only screen and (min-width: 1900px) and (orientation: landscape) {}
@media only screen and (min-width: 1280px) and (max-width: 1299px) {}

/* > 1180PX
----------------------------------------------- */
@media only screen and (min-width: 2100px) {}
@media only screen and (min-width: 1820px) {}
@media only screen and (min-width: 1280px) {



}

/* TABLET LAYOUT
----------------------------------------------- */
@media only screen and (min-width: 768px) and (max-width: 1279px) and (orientation: landscape)  {
    .tech .column {
        width: calc(33.3333% - 20px) !important;
        height: 322px !important;
    }
}

@media only screen and (max-width: 1279px) {
    
    .mr-0--t { margin-right: 0px; }
    .mr-2--t { margin-right: 20px; }
    
    .mb-5--t { margin-bottom: 50px; }

    .pt-8--t { padding-top: 80px; }
    .pb-8--t { padding-bottom: 80px; }

    
    .fs-1--t { font-size: 1em; }
    .fs-1-8--t { font-size: 1.8em; }
    .fs-1-45--t { font-size: 1.45em; }
    .lh-24--t { line-height: 24px; }
    
    .w-200--t { width: 200px; }

    .wrapper { width: initial; }
    
    .jc--center--t { justify-content: center; }

    .item--85--t { flex: 85%; max-width: 85%; }
    .item--15--t { flex: 15%; max-width: 15%; }

    .header__bg--m { display: none; }

    .header__logo {
        top: 30px;
        width: 280px;
    }

    .header__bg img {
        position: absolute;
        top: -9999px;
        right: -9999px;
        bottom: -9999px;
        left: -9999px;
        margin: auto;
        height: 100%;
    }
    

    .tech { height: initial; }
        .tech .column {
            position: relative;
            width: 222px;
            height: 235px;
        }
            .tech .column .column__content {
                position: relative;
                box-sizing: border-box;
                padding: 15px;
                height: 115px;
            }

    .signal { height: initial; }
        .signal .column {
            position: relative;
            width: 222px;
            height: 285px;
            overflow: hidden;
        }
            .signal .column .column__content {
                position: relative;
                box-sizing: border-box;
                padding: 15px 26px;
                height: 56px;
            }

            .catalog__conent {
                max-width: calc(24% - 8px) !important;
                height: 217px;
                position: relative;
            }



    .others {
        height: initial;
    }
    .others .column {
        position: relative;
        width: 222px;
        height: 290px;
        overflow: hidden;
    }
        .others .column .column__content {
            position: relative;
            box-sizing: border-box;
            padding: 15px 26px;
            height: 105px;
            line-height: 40px;
        }
        .others .column .column__content--small {
            height: 82px;
        }

    .contact { height: initial; }
        .contact .column {
            width: 100%;
            height: initial;
        }

    footer,
    footer .h-footer { height: initial; }
        footer .item--33 {
            /* flex: 100%;
            max-width: 100%; */
        }

    .modal__block {
        width: 95%;
        height: 85%;
    }

}

/* MOBILE LAYOUT (PORTRAIT)
----------------------------------------------- */
@media only screen and (max-width: 1024px) {

    .mr-0--m { margin-right: 0px; }
    .mr-3--m { margin-right: 30px; }

    .mb-1--m { margin-bottom: 10px; }
    .mb-2--m { margin-bottom: 20px; }
    .mb-3--m { margin-bottom: 30px; }
    .mb-5--m { margin-bottom: 50px; }

    .pt-2--m { padding-top: 20px; }
    .pt-8--m { padding-top: 80px; }
    
    .pb-2--m { padding-bottom: 20px; }
    .pb-8--m { padding-bottom: 80px; }

    .w-100p--m { width: 100%; }

    .text-center--m { text-align: center; }

    .jc-unset--m { justify-content: unset; }
    .jc--center--m {
        justify-content: center;
    }

    .wrapper {
        width: initial;
    }

    .header__bg,
    .header__bg--t { display: none; }

    .header__bg--m { 
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        overflow: hidden;
    }
    .header__bg--m img {
        position: absolute;
        top: -9999px;
        right: -9999px;
        bottom: -9999px;
        left: -10340px;
        margin: auto;
        height: 100%;
    }

    .header__bg--m img.dist {
        position: absolute;
        top: initial;
        right: 30px;
        bottom: 30px;
        left: initial;
        width: 168px;
        height: auto;
    }

    .header__logo {
        width: 250px;
    }


    /* .nav__bar nav {
        position: fixed;
        top: 0;
        right: 0;
        display: block;
        background-color: #FFFFFF;
        font-size: 1.6em;
        width: 100%;
        padding: 120px 20px 0px;
        box-sizing: border-box;
    }
    .nav__bar nav.open{
        right: 0;
        -webkit-transition: all 0.5s ease;
        -moz-transition: all 0.5s ease;
        -o-transition: all 0.5s ease;
        -ms-transition: all 0.5s ease;
        transition: all 0.5s ease;
    }
            
    .nav__bar nav.no-open{
        right: -780px;
        -webkit-transition: all 0.5s ease;
        -moz-transition: all 0.5s ease;
        -o-transition: all 0.5s ease;
        -ms-transition: all 0.5s ease;
        transition: all 0.5s ease;
    }
    .nav__bar nav div {
        flex: none;
        width: 100%;
        max-width: 100%;
        text-align: right;
    }
    .nav__bar nav div a {
        display: block;
    } */
    
    /* .menu-mobile {
        position: relative;
        height: 100%;
        z-index: 9999;
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
        .logo__mobile { 
            opacity: 1;
            -webkit-transition: all 0.5s ease;
            -moz-transition: all 0.5s ease;
            -o-transition: all 0.5s ease;
            -ms-transition: all 0.5s ease;
            transition: all 0.5s ease;
            width: 70px; 
        }
            .logo__mobile--hidden { 
                opacity: 0;
                -webkit-transition: all 0.5s ease;
                -moz-transition: all 0.5s ease;
                -o-transition: all 0.5s ease;
                -ms-transition: all 0.5s ease;
                transition: all 0.5s ease;
            }

        .menu {
            background-color: transparent;
            border: none;
            cursor: pointer;
            display: flex;
            padding: 0;
            width: 50px;
            height: 100%;
            margin-right: -10px;
        }
            .menu svg { height: 100%; }
                .line {
                    fill: none;
                    stroke: black;
                    stroke-width: 6;
                    transition: stroke-dasharray 600ms cubic-bezier(0.4, 0, 0.2, 1),
                    stroke-dashoffset 600ms cubic-bezier(0.4, 0, 0.2, 1);
                }
                .line1 {
                    stroke-dasharray: 60 207;
                    stroke-width: 6;
                }
                .line2 {
                    stroke-dasharray: 60 60;
                    stroke-width: 6;
                }
                .line3 {
                    stroke-dasharray: 60 207;
                    stroke-width: 6;
                }
                .opened .line1 {
                    stroke-dasharray: 90 207;
                    stroke-dashoffset: -134;
                    stroke-width: 6;
                }
                .opened .line2 {
                    stroke-dasharray: 1 60;
                    stroke-dashoffset: -30;
                    stroke-width: 6;
                }
                .opened .line3 {
                    stroke-dasharray: 90 207;
                    stroke-dashoffset: -134;
                    stroke-width: 6;
                } */
        
    .cover { height: initial; }
    .section__bg {display: none;}
    .section__bg--m {display: block;}

    .tech { height: initial; }
        .tech .column { width: 100%; }
   
    .signal { height: initial; }
        .signal .column {
            width: 100%;
        }

        .catalog__conent {
            flex: 100%;
            width: 100%;
            max-width: 100% !important;
            height: 406px;
            position: relative;
            margin: 0;
        }

        .slider_mobile,
        .slider { height: 425px; }

    .others { height: initial; }
        .others .column {
            width: 100%;
        }

    .contact { height: initial; }
        .contact .column {
            width: 100%;
        }
            .contact .form__group {
                width: 100%;
                max-width: 100%;
                flex: 100%;
                margin-right: 0;
            }

    footer,
    footer .h-footer { height: initial; }
        footer .item--33 {
            flex: 100%;
            max-width: 100%;
        }
        footer .disclaimer { height: initial; }
        .disclaimer .item--50 {
            flex: 100%;
            max-width: 100%;
        }

    .modal__block {
        width: 100%;
        height: 100%;
    }

}
   
/* WIDE MOBILE LAYOUT (LANDSCAPE)
----------------------------------------------- */
@media only screen and (min-width: 480px) and (max-width: 767px) and (orientation: landscape) {
    .header__bg--m img {
        left: -10120px;
    }

    .cover {
        height: 415px;
    }
    .section__bg {
        display: block;
    }
    .section__bg--m {
        display: none;
    }
    .section__bg img {
        top: -9705px;
    }
}

/* WIDE MOBILE LAYOUT
----------------------------------------------- */
@media only screen and (max-width: 705px) {

    .w-1\/5 {
        width: 0%;
    }

    .fs-4-75 {
        font-size: 4em;
    }

    .justify-between { justify-content: unset;}

    .justify-center--m {
        justify-content: center;
    }

    .polices a {
        display: block;
        margin-bottom: 10px;
    }

    .polices span {
        display: none;
    }

}

/* MOBILE LAYOUT PORTRAIT LIMITS
----------------------------------------------- */
@media only screen and (max-width: 479px) {}

/* FULL LAYOUT
----------------------------------------------- */
@media only screen and (min-width: 2260px) {}







