/*
** Theme Variables
*/
:root {
    --green: #016D39;
    --lgreen: #6AB637;
    --dgreen: #90C643;
    --blue: #016D39;
    --red: #dc3232;
    --white: #ffffff;
    --black: #000000;
    --lgray: rgba(32, 25, 21, 0.58);
    --lime: #E7FED6;
    --sky: #DEF1FB;
    --neon: #C0F24E;

    --primary:  var(--black);
    --primary-a: var(--lgray);

    --secondary:  var(--green);
    --secondary-a:  #00592e;

    --tertiary:  var(--lgreen);
    --tertiary-a:  #539726;

    --blue:  #0B94C6;
    --blue-a: #054860;

    --body: var(--black);

    --link: var(--primary);
    --link-a: var(--primary-a);

    --formfieldbg: var(--white);
    --formfieldplaceholder: #D6D6D6;
    --formtextcolor: var(--body);
    --formfieldborder: #D6D6D6;

    --siteradius: 16px;
    --siteradius24: 24px;

    scroll-behavior: smooth;
}

:target {
    scroll-margin-top: 120px
}

/*
** Fonts
*/

@font-face {
    font-family: 'jakarta';
    src: url('../fonts/PlusJakartaSans-Regular.woff2') format('woff2'),
        url('../fonts/PlusJakartaSans-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'jakarta-md';
    src: url('../fonts/PlusJakartaSans-Medium.woff2') format('woff2'),
        url('../fonts/PlusJakartaSans-Medium.woff') format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'jakarta-sb';
    src: url('../fonts/PlusJakartaSans-SemiBold.woff2') format('woff2'),
        url('../fonts/PlusJakartaSans-SemiBold.woff') format('woff');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'jakarta-bd';
    src: url('../fonts/PlusJakartaSans-Bold.woff2') format('woff2'),
        url('../fonts/PlusJakartaSans-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

/*
@font-face {
    font-family: 'jakarta-eb';
    src: url('../fonts/PlusJakartaSans-ExtraBold.woff2') format('woff2'),
        url('../fonts/PlusJakartaSans-ExtraBold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}
*/


/*
** Font Icons
*/
@font-face {
  font-family: 'gpc';
  src:  url('../fonts/icons/gpc.ttf?xgcgcr') format('truetype'),
    url('../fonts/icons/gpc.woff?xgcgcr') format('woff');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

[class^="icon-"], [class*=" icon-"] {
  font-family: 'gpc';
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-youtube:before {
    content: "\e907";
}
.icon-yt:before {
    content: "\e908";
}
.icon-insta:before {
    content: "\e903";
}
.icon-linkedin:before {
    content: "\e905";
}
.icon-fb:before {
    content: "\e906";
}
.icon-arrow:before {
    content: "\e901";
}
.icon-pause:before {
    content: "\e902";
}
.icon-play:before {
    content: "\e900";
}
.icon-angle-down:before {
    content: "\e904";
}



/*
** Custom Reset
*/
*,:after,:before { -webkit-box-sizing: border-box; box-sizing: border-box }
img { max-width: 100%; height: auto; vertical-align: top; }
a, span, i, label { display: inline-block; }
a { color: var(--link); text-decoration: none; transition: 0.3s ease-in-out; }
a:hover { color: var(--link-a); }
a:focus { outline: none; }
strong, b { font-family: 'jakarta-bd', sans-serif; }

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

p:last-child,
ul:last-child,
li:last-child {
  margin-bottom: 0;
}

button,
button:focus {
  border: 0;
  outline: 0;
  box-shadow: none;
  cursor: pointer;
  transition: all 0.3s ease-in-out;
}

input:focus {
    outline: none;
    box-shadow: none;
}

ul, ol { padding-left: 20px; }

li { margin-bottom: 10px; }

video { vertical-align: top; }


/*
** Globals
*/
/*Typo*/
body {
    font-family: 'jakarta', sans-serif;
    font-size: 16px;
    line-height: 24px;
    min-height: 120vh;
    margin: 0;
    color: var(--body);
}

h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 {
    font-family: 'jakarta-sb', serif;
    font-style: normal;
    font-weight: normal;
    margin-top: 0;
    color: var(--body);
}

h1, .h1 { --fsize: 48px; font-size: var(--fsize); line-height: calc(var(--fsize) + 12px); margin-bottom: 20px; }
h2, .h2 { --fsize: 40px; font-size: var(--fsize); line-height: calc(var(--fsize) + 10px); margin-bottom: 16px; }
h3, .h3 { --fsize: 32px; font-size: var(--fsize); line-height: calc(var(--fsize) + 8px); margin-bottom: 16px; }
h4, .h4 { --fsize: 24px; font-size: var(--fsize); line-height: calc(var(--fsize) + 8px); margin-bottom: 16px; }
h5, .h5 { --fsize: 20px; font-size: var(--fsize); line-height: calc(var(--fsize) + 8px); margin-bottom: 12px; }
h6, .h6 { --fsize: 18px; font-size: var(--fsize); line-height: calc(var(--fsize) + 8px); margin-bottom: 10px; }

p { margin-top: 0; }

img {
    -webkit-user-drag: none;
    -webkit-user-select: none;
    user-select: none;
}

/* Form Fields */
form {
    --fieldsize: 50px;
    --fieldpadds: 0px 16px;
    --fieldtop: 15px;
    --fieldfsize: 14px;
}

input[type="text"],
input[type="search"],
input[type="email"],
input[type="password"],
input[type="num"],
input[type="tel"],
input[type="url"],
select,
textarea {
    font-family: 'jakarta', sans-serif;
    font-size: var(--fieldfsize);
    line-height: calc(var(--fieldsize) - 2px);
    width: 100%;
    height: var(--fieldsize);
    padding: var(--fieldpadds);
    border-radius: var(--siteradius);
    background-color: var(--formfieldbg);
    border: 1px solid var(--formfieldborder);
    outline: 0 !important;
    vertical-align: top;
    color: var(--formtextcolor);
}

input::placeholder,
textarea::placeholder {
    color: var(--formfieldplaceholder);
}

textarea {
    padding-top: var(--fieldtop);
    line-height: 26px;
    height: 150px;
    resize: none;
}

select {
    width: 100%;
    padding-right: 42px;
    background-image: url('../images/angle-down.svg');
    background-size: 10px;
    background-position: right 20px center;
    background-repeat: no-repeat;
    -webkit-appearance: none;
    appearance: none;
}


/*Background Utilities*/
.bg--bgrad { color: var(--white); background: linear-gradient(126.47deg, #0B94C6 2.5%, #054860 97.5%); }
.bg--ggrad { color: var(--white); background: linear-gradient(131.38deg, #00904B 6.03%, #01381E 99.19%); }
.bg--lime { background-color: var(--lime); }
.bg--dgreen { background-color: var(--dgreen); }
.bg--sky { background-color: var(--sky); }

/*Text Utilities*/
.text-rg { font-family: 'jakarta', sans-serif; }
.text-md { font-family: 'jakarta-md', sans-serif; }
.text-sb { font-family: 'jakarta-sb', sans-serif; }
.text-bd { font-family: 'jakarta-bd', sans-serif; }
/* .text-eb { font-family: 'jakarta-eb', sans-serif; } */

.text--primary { color: var(--primary); }
.text--secondary { color: var(--secondary); }
.text--body { color: var(--body); }
.text--white { color: var(--white); }
.text--black { color: var(--black); }
.text--copy { color: var(--lgray); }

.text-upercase { text-transform: uppercase; }

.font-32 { --fsize: 32px; font-size: var(--fsize); line-height: calc(var(--fsize) + 8px); }
.font-28 { --fsize: 28px; font-size: var(--fsize); line-height: calc(var(--fsize) + 8px); }
.font-24 { --fsize: 24px; font-size: var(--fsize); line-height: calc(var(--fsize) + 8px); }
.font-22 { --fsize: 22px; font-size: var(--fsize); line-height: calc(var(--fsize) + 10px);}
.font-20 { --fsize: 20px; font-size: var(--fsize); line-height: calc(var(--fsize) + 10px); }
.font-18 { --fsize: 18px; font-size: var(--fsize); line-height: calc(var(--fsize) + 10px); }
.font-16 { --fsize: 16px; font-size: var(--fsize); line-height: calc(var(--fsize) + 10px); }
.font-14 { --fsize: 14px; font-size: var(--fsize); line-height: calc(var(--fsize) + 10px); }

/*Image*/
.siteimg, .siteimg img { border-radius: var(--siteradius); }
img.fitimg, .fitimg img { width: 100%; height: 100%; object-fit: cover; object-position: center; }

/*
** Buttons
*/
.bttn {
    --btnsize: 50px;
    position: relative;
    font-family: 'jakarta-sb', sans-serif;
    font-size: 16px;
    line-height: calc(var(--btnsize) - 2px);
    min-width: 124px;
    height: var(--btnsize);
    padding: 0 16px;
    text-align: center;
    border: 1px solid transparent;
    border-radius: 0;
    cursor: pointer;
    overflow: hidden;
    transition: all 0.3s ease-in-out;
}

.bttn::before {
    content: "";
    position: absolute;
    top: 0;
    left: -85%;
    width: 50%;
    height: 100%;
    background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.3) 100%);
}

.bttn-hauto {
    height: auto;
    padding-top: 11px;
    padding-bottom: 11px;
    line-height: 22px;
}

.bttn:hover::before {
    animation: shine .75s;
}

@keyframes shine {
  100% { left: 125%; }
}

.bttn-primary {
    color: var(--white);
    background-color: var(--black);
}

.bttn-primary:hover {
    color: var(--white);
    background-color: var(--black);
}

.bttn-secondary {
    color: var(--white);
    background-color: var(--secondary);
}

.bttn-secondary:hover {
    color: var(--white);
    background-color: var(--secondary-a);
}

.bttn-primary-alt {
    color: var(--black);
    border: 1px solid var(--black);
    background-color: transparent;
}

.bttn-primary-alt:hover {
    color: var(--white);
    background-color: var(--black);
}

.bttn-white {
    color: #0C83D5;
    border: 1px solid var(--white);
    background-color: var(--white);
}

.bttn-white:hover {
    color: var(--white);
    background-color: transparent;
}

.bttn-tertiary {
    color: var(--white);
    background-color: var(--tertiary);
}

.bttn-tertiary:hover {
    color: var(--white);
    background-color: var(--tertiary-a);
}

.bttn-primary-alt::before, .bttn-white::before { display: none; }


/*Other Utilities*/
.list-unstyled, .list-unstyled ul, .list-unstyled ol, header ul, footer ul { padding: 0; margin: 0; list-style: none; }
.transition { transition: 0.3s ease-in-out; }
.siteradius { border-radius: var(--siteradius); }

/*
** Bootstrap Extends & Overrides
*/
.container, .container-fluid, .row>* { padding-left: 20px; padding-right: 20px; }
.row { margin-left: -20px; margin-right: -20px; }

.gx-0.row>* { padding-left: 0; padding-right: 0; }
.gx-0.row { margin-left: 0; margin-right: 0; }

.row-20 { margin-left: -10px; margin-right: -10px; }
.row-20>* { padding-left: 10px; padding-right: 10px; }

.gap-30 { gap: 30px; }
.rgap-30 { row-gap: 30px; }

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

.overflow-hidden { overflow: hidden; }

/*
** WP Overrides
*/
.screen-reader-text { position: absolute; visibility: hidden; opacity: 0; }

/*
** Slick Slider
*/
.slick-initialized { z-index: 0; position: relative; }
.slide .slick-slide, .slide { display: none; float: left; height: 100%; min-height: 1px; }
.slick-initialized .slick-list { position: relative; overflow: hidden; }
.slick-initialized .slick-slide { display: inline-block; width: auto; vertical-align: top; }
.slick-initialized .slick-slide:focus { outline: none; }
.slick-dots { display: flex; align-items: center; justify-content: center; list-style: none; padding: 0; }
.slick-dots li { margin: 0; }
.slick-dots li + li { margin: 0; margin-left: 10px; }
.slick-dots li button {
    display: block;
    font-size: 0px;
    width: 10px;
    max-width: 10px;
    height: 10px;
    padding:0;
    border: 0px solid transparent;
    border-radius: 10px;
    background-color: var(--formfieldplaceholder);
    opacity: 1;
    overflow: hidden;
    transition: all 0.3s ease-in-out;
}
.slick-dots li.slick-active button { background-color: var(--blue); }


/*
** Header
*/
.site-header {
    font-family: 'jakarta-md', sans-serif;
    position: fixed;
    left: 0;
    top: 24px;
    width: 100%;
    transition: all 0.3s ease;
    z-index: 15;
}

.header-wrap {
    padding: 10px 24px;
    background-color: rgba(255, 255, 255, 0.4);
    background-color: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(12px);
    transition: all 0.3s ease;
}

.site-header.siteheader-sticky .header-wrap {
    box-shadow: 0px 0px 7px 0px rgba(0, 0, 0, 0.1);    
}

.custom-logo {
    width: auto;
    height: 40.47px;
    transition: 0.2s ease;
}

.site-header .row {
    align-items: center;
}

.colheadright {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    column-gap: 30px;
}

.headernav {
    display: inline-flex;
    align-items: center;
    column-gap: 20px;
}

.headernav li { margin-bottom: 0; }

.headernav a {
    padding: 8px 5px;
    color: var(--body);
}

/*
.headernav a:hover,
.headernav .current-menu-ancestor>a,
.headernav .current-menu-parent>a,
.headernav .current-menu-item>a {
    color: var(--primary);
}
*/

.sub-menu { display: none; }

.colheadright .bttn { --btnsize: 40px; }

.headctas { display: inline-flex; }

/*Site Menu Toggle*/
.site-menutoggle {
    display: flex;
    flex-wrap: wrap;
    align-content: center;
    align-items: center;
    width: 33px;
    height: 33px;
    position: relative;
    margin-bottom: 0;
}

.site-menutoggle span {
    display: block;
    width: 33px;
    height: 5px;
    height: 3px;
    margin-bottom: 5px;
    position: relative;
    background: linear-gradient(180deg, var(--primary) 0%, var(--primary) 100%);
    border-radius: 6px;
    transform-origin: 5px 5px;
    transition: transform 0.5s cubic-bezier(0.77, 0.2, 0.05, 1.0), background 0.5s cubic-bezier(0.77, 0.2, 0.05, 1.0), opacity 0.55s ease;
    z-index: 1;
}

.site-menutoggle span:last-child {
    margin-bottom: 0;
}

.site-menutoggle span:nth-last-child(2) {
    transform-origin: 0% 100%;
}

.site-menutoggle input:checked~span {
    margin: 0;
    opacity: 1;
    transform: rotate(45deg) translate(-8px, -12px);
}

.site-menutoggle input:checked~span:nth-last-child(2) {
    transform: rotate(-45deg) translate(1px, 20px);
    transform: rotate(-45deg) translate(-1px, 12px);
}

.site-menutoggle input:checked~span:nth-last-child(3) {
    opacity: 0;
    transform: rotate(0deg) scale(0.2, 0.2);
    transition: 0s;
}

/*Common Section*/
section.section { --padds: 50px; padding-top: var(--padds); padding-bottom: var(--padds); }
.section-head { margin-bottom: 40px; }
.section-head p + .bttn { margin-top: 10px; }
.page-off { padding-top: 128px; }
.hero { padding-bottom: 50px; }

/*Video*/
.vidwrap {
    position: relative;
}

.vidposter {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}

.vidposter img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.play-btn {
    --size: 56.66px;
    position: absolute;
    top: 50%;
    left: 50%;
    width: var(--size);
    height: var(--size);
    font-size: 24px;
    line-height: 1;
    padding: 3px 0px 0 5px;
    border: none;
    color: var(--white);
    border-radius: 100%;
    background-color: #C0F24E;
    box-shadow: 0px 0px 0 7.6px rgba(61, 173, 255, 0.5);
    transform: translate(-50%, -50%);
    cursor: pointer;
    z-index: 1;
}

.play-btn:hover,
.play-btn:focus {
    box-shadow: 0px 0px 0 5px rgba(61, 173, 255, 0.5);
}

.play-btn[data-play="play"] { padding: 3px 0px 0 3px; opacity: 0; }
.play-btn[data-play="pause"] .icon-pause { display: none; }
.play-btn[data-play="play"] .icon-play { display: none; }
.play-btn[data-play="play"] .icon-pause { display: block; }
.vidwrap:hover .play-btn { opacity: 1; }


/*FAQs*/
.faqbox {
    padding: 0 30px;
    padding-top: 100px;
    border-top-left-radius: var(--siteradius);
    border-top-right-radius: var(--siteradius);
}

.faqlist {
    display: grid;
    gap: 20px;
    max-width: 1010px;
    padding-top: 20px;
    margin: 0 auto;
}

.faqitem {
    padding: 24px 25px;
    border: 1px solid rgba(13, 0, 121, 0.1);
    border-radius: var(--siteradius);
    background-color: var(--white);
}

.faqhead {
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
}

.faqhead h3 {
    font-size: 22px;
    line-height: 30px;
}

.faqbody {
    display: none;
    padding: 10px 0 0;
}

.faqbttn {
    font-size: 20px;
    line-height: 30px;
    font-weight: bold;
    transform: rotate(0deg);
    transition: all .3s ease-in-out;
}

.faqopen .faqbttn { transform: rotate(180deg); color: var(--primary); }

/*Site Form*/
.sform { padding-top: 10px; }

.sform .row { row-gap: 20px; }

.sform label {
    display: block;
    font-family: 'poppins-sb', sans-serif;
    font-size: 16px;
    line-height: 22px;
    margin-bottom: 10px;
    color: var(--black);
}

.iti, .wpcf7-form-control-wrap { display: block; }

.wpcf7-not-valid-tip {
    font-size: 12px;
    line-height: 1.3;
    padding: 6px 5px 3px;
    margin-top: -4px;
    color: #a60000;
    /* background: #a60000; */
    border-radius: 0px 0px 10px 10px;
}

.wpcf7 form .wpcf7-response-output {
    font-size: 14px;
    line-height: 1.4em;
    padding: 8px 10px;
    margin: 20px 0 0 0;
    border: 0;
    border-radius: 5px;
    background: #fff;
}

.wpcf7 form.sent .wpcf7-response-output {
    background: var(--green);
    color: #fff;
}

.wpcf7 form.invalid .wpcf7-response-output {
    background: #a60000;
    color: #ffffff;
}

.wpcf7-spinner {
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    transform: translateX(110px) translateY(-15px);
}

/*Footer Edit*/
.post-edit-link,
.wp-logout {
    position: fixed;
    left: 0;
    bottom: 28px;
    font-size: 16px;
    line-height: 16px;
    padding: 6px 12px;
    min-width: 70px;
    text-align: center;
    color: var(--white) !important;
    background-color: var(--primary);
    z-index: 9000;
}

/*
** Homepage
*/
.hero-home {
    background: linear-gradient(180deg, #F0C074 0%, #F1C98E 32.66%, #EBBD6C 66.33%, #DAB370 100%);
}

.hero-col-lt {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.hero-cont {
    width: 492px;
    max-width: 100%;
}

.hero-cont strong { display: inline; }

.hero-cta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 16px;
}

.home-hero-vid {
    aspect-ratio: 1 / 1;
    width: 100%;
    max-width: 540px;
    border: 1px solid  var(--dgreen);
    border-radius: var(--siteradius24);
    overflow: hidden;
}

.home-hero-vid video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

/*GPC Icons*/
.gpcics {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    padding: 16px 0;
    gap: 80px;
    background: radial-gradient(79.14% 250.12% at 73.75% 60.49%, #00331B 0%, #009950 100%);
}

.gpcics-l {
    display: flex;
    gap: 80px;
}

.gpcics-i {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    flex: auto;
}

/*Benefits*/
.benelist {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
}

.benei {
    --calcSize: calc(33.33% - 10.66px);
    flex: 1 0 var(--calcSize);
    max-width: var(--calcSize);
    aspect-ratio: 384 / 356;
    perspective: 3000px;
}

.benei-halves {
    --calcSize: calc(50% - 8px);
    flex: 1 0 var(--calcSize);
    max-width: var(--calcSize);
    aspect-ratio: 592 / 356;
}

.benec {
    position: relative;
    width: 100%;
    height: 100%;
    transition: transform 0.4s, box-shadow 0.3s;
    transform-style: preserve-3d;
    border-radius: 20px;
}

.benei:hover .benec {
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4);
    transform: rotateY(180deg);
    transition: transform 0.8s cubic-bezier(0.4, 0.2, 0.2, 1), box-shadow 0.3s;
}

.benef, .beneb {
    position: absolute;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 100%;
    height: 100%;
    padding: 18px;
    border-radius: 20px;
    overflow: hidden;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

.benef {
    color: var(--white);
    background: #333;
    border: 2px solid #E6FFD2;
}

.benef h3 {
    position: relative;
    z-index: 1;
}

.beneb {
    justify-content: flex-start;
    color: #333;
    color: var(--white);
    border: 1px solid #E6FFD2;
    background-color: var(--white);
    transform: rotateY(180deg);
}

.benei-t { margin-bottom: 0; }

.beneb-t { position: relative; line-height: 1.3; color: var(--white); border-bottom: 1px solid var(--formfieldborder); z-index: 1; }
.beneb p, .beneb ul { position: relative;  z-index: 1; }
.beneb ul { margin-top: 0; }

.benei-img { position: absolute; top: 0; left: 0; }

.benei-1 .benef,
.benei-3 .benef,
.benei-4 .benef {
    background: linear-gradient(131.38deg, #00904B 6.03%, #01381E 99.19%);
}

.benei-2 .benef,
.benei-5 .benef {
    background: linear-gradient(132.24deg, #0B92C3 2.41%, #074F69 97.59%);
}


.benei-1 .benei-t { width: 70%; }
/*
.benei-1-1 { position: absolute; bottom: -35px; left: -30px; }
.benei-1-2 { position: absolute; top: -27px; right: -25px; }
*/

.benei-2 .benef, .benei-5 .benef { justify-content: flex-end; }
.benei-2 .benei-t { width: 66.32%; }
/*
.benei-2-1 { position: absolute; top: -52px; left: -11px; width: calc(100% + 36px); max-width: unset; }
*/

.benei-3 .benei-t { width: 52%; width: 100%; }
/*
.benei-3-1 { position: absolute; top: 0; right: 0; width: auto; min-height: 100%; max-width: unset; }
*/

.benei-4 .benei-t { width: 60%; }
/*
.benei-4-1 { position: absolute; bottom: 0; left: 0; width: auto; max-width: unset; }
*/

.benei-5 .benei-t { width: 46%; }
/*
.benei-5-1 { position: absolute; bottom: -30px; left: 0; width: auto; max-width: unset; }
*/

.beneb::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(180deg,  rgba(0, 0, 0, 0.76),  rgba(0, 0, 0, 0));
    background-color: var(--black);
    opacity: 0.65;
}

.beneb .benei-img {
    z-index: -1;
}

/*Pet Food Needs*/
.petfn-l {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}

.petfn-i {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    gap: 24px;
    padding: 24px;
    aspect-ratio: 588 / 422;
    border-radius: var(--siteradius24);
    transition: 0.3s ease;
    overflow: hidden;
}

.petfn-i:hover {
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4);
}

.petfn-i p {
    width: 278px;
    max-width: 100%;
}

.petfn-i a {
    display: inline-flex;
    align-items: center;
    align-self: flex-start;
    gap: 12px;
    margin-top: auto;
    color: var(--white);
    z-index: 2;
}

.petfn-i i {
    margin-top: 2px;
    transition: 0.3s ease;
}

/*
.petfn-i a:hover i {
    transform: translateX(5px);
}
*/

.petfn-i img {
    position: absolute;
    bottom: 0;
    right: 0;
    max-height: 100%;
    width: auto;
    padding-top: 14px;
}

.petfn-i h3,
.petfn-i p,
.petfn-i a {
    position: relative;
    z-index: 1;
}

.petfn-i video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0;
    transition: 0.3s ease;
    user-select: none;
    z-index: 1;
}

.petfn-i:hover video {
    opacity: 1;
}

.petfn-i:hover a {
    background: var(--primary);
    display: inline-flex;
    padding: 9px 8px;
    width: auto;
}

/*Trust Video*/
.trust-vid { border: 4px solid #0A7CA5; }
.trust-vid video { width: 100%; height: auto; }


/*
** Footer CTA
*/
.foocta { position: relative; background: linear-gradient(128.91deg, #0B92C3 5.34%, #05465D 94.66%); }
.foocta .container { padding-top: 50px; padding-bottom: 50px; }
.foocta-bg { position: absolute; right: 0; bottom: 0; }
.foocta p { margin-bottom: 30px; }


/*
** Footer
*/
.site-footer { padding-bottom: 16px; }

.foo-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    padding: 24px 0 16px;
    margin-bottom: 15px;
    border-bottom: 2px solid rgba(0,0,0,0.2);
}

.foo-nav,
.social-nav {
    display: flex;
    align-items: center;
    gap: 48px;
}

.site-footer li { margin: 0; }

.site-footer a:hover { color: var(--green); }

.social-nav { gap: 10px; }

/*Journey*/
.jour {
    position: relative;
    padding: 25px 0 58px;
    background: url(../images/journey-bg-top.webp), url(../images/journey-bg-btm.webp), linear-gradient(112.8deg, #018647 3.72%, #002011 96.28%);
    background-repeat: no-repeat;
    background-size: 192px, auto, auto;
    background-position: top -119px left 56%, bottom -79px left 54%, left top;
    background-position: top -38px left 46.5vw, bottom -79px left 42.6vw, left top;
}

.jour::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-image: url('../images/journey-line-xl.svg');
    background-position: top 50% center;
    background-repeat: no-repeat;
    background-size: 1925px auto;
    z-index: 0;
}

.jour .section-head {
    position: absolute;
    width: 322px;
    max-width: 100%;
    top: 56px;
}

.jour h2 { margin-bottom: 30px; }

.jour h3 {
    line-height: 30px;
    color: var(--white);
    margin-bottom: 8px;
}

.jourl {
    display: flex;
    flex-direction: column;
}

.jourli {
    position: relative;
    width: 340px;
    max-width: 100%;
}

.jourli span {
    position: absolute;
    top: 50%;
    left: 0;
    font-size: 195px;
    line-height: 0;
    color: rgba(255, 255, 255, 0.2);
    transform: translateX(-50%);
}

.jourl-2 span { transform: translate(-41%, -6px); }

.jourl-1 {
    width: 279px;
    margin-left: 30px;
    order: 1;
}

.jourl-2 {
    margin-left: 24%;
    order:-1;
}

.jourl-3 {
    margin: 35px 0 18px 66.66%;
}

.jourl-4 {
    margin: 0 -25px 38px auto;
    order:-2;
}

/*
** About Us
*/
.termval-l {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 76px;
}

.termval-t {
    margin-bottom: 4px;
    background: linear-gradient(108.73deg, #0C8BB8 24.68%, #038449 75.32%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-fill-color: transparent;
}

.teaml {
    /*
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    */
    display: grid;
    gap: 20px 16px;
    width: 1022px;
    max-width: 100%;
}

.teami {
    /*
    --flexw: calc(33.33% - 10.66px);
    flex: 1 0 var(--flexw);
    max-width: var(--flexw);
    */
    margin: 0 9.125px;
}

.teami img {
    aspect-ratio: 329 / 374;
    object-fit: cover;
    object-position: center;
    border-radius: var(--siteradius24);
}

.oteam {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 24px;
}

.oteami {
    --flexw: calc(20% - 20px);
    flex: 1 0 var(--flexw);
    max-width: var(--flexw);
}

.oteami-img {
    aspect-ratio: 220 / 250;
    border-radius: var(--siteradius24);
    background-color: #BBE4FC;
    overflow: hidden;
}

.oteami:nth-child(even) .oteami-img {
    background-color: #F1FFDC;
}

.oteam-role {
    color: rgba(32, 25, 21, 0.6);
}

.teamy {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 30px;
    padding: 16px 24px;
    margin-top: 40px;
    border-radius: var(--siteradius);
    background: linear-gradient(90.5deg, #BBE4FC 0.1%, #F1FFDC 99.9%);
}

.teamy-i {
    width: 275px;
    --flexw: calc(33.33% - 20px);
    flex: 1 0 var(--flexw);
    max-width: var(--flexw);
}

.teamy-t { color: #208AE6; }

.teamy p { width: 206px; max-width: 100%; }

.resbbl {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.resbbi {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
    min-height: 330px;
    padding: 24px;
    gap: 16px;
    border-radius: 24px;
    border: 1px solid #63BBEB;
    background: linear-gradient(180deg, #EAF8FF 0%, #F3FFED 100%);
}

.awal {
    /*
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    */
}

.awal .slick-track { padding: 2px 0; }

.awai {
    position: relative;
    aspect-ratio: 1 / 1;
    margin: 0 8px;
    border-radius: var(--siteradius);
    perspective: 3000px;
}

.slick-initialized .awai { display: inline-flex; }

.awai-c {
    position: relative;
    width: 100%;
    height: 100%;
    padding: 24px;
    transform-style: preserve-3d;
    border-radius: var(--siteradius);
    transition: transform 0.4s;
}

.awai:hover .awai-c {
    transform: rotateY(180deg);
    transition: transform 0.8s cubic-bezier(0.4, 0.2, 0.2, 1);
}

.awai-f,
.awai-b {
    position: absolute;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    padding: 20px;
    border: 1px solid #63BBEB;
    border-radius: var(--siteradius);
    background-color: var(--white);
    overflow: hidden;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

.awai-f {
    transition: transform 0.4s;
    transform-style: preserve-3d;
}

.awai-b { transform: rotateY(180deg); }

.awal .slick-dots { margin-top: 30px; }

.sushl {
    /* display: flex; */
    /* justify-content: center; */
    /* flex-wrap: wrap; */
    /* gap: 50px 35px; */
}

.sushi {
    /*
    --flexw: calc(14.28% - 30px);
    flex: 1 0 var(--flexw);
    max-width: var(--flexw);
    */
    margin: 0 10px;
}

.sushi-t {
    background: linear-gradient(108.73deg, #0C8BB8 24.68%, #038449 75.32%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-fill-color: transparent;
}

.sushi-d {
    width: 140px;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
}

.sussec .slick-dots { margin-top: 30px; }

.footpb { background: linear-gradient(117.98deg, #0C8CE9 15.31%, #095F7F 84.69%); }
.footpg { background: linear-gradient(112.8deg, #018647 3.72%, #002011 96.28%); }

.footp-cont {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.footp .section-head {
    width: 544px;
    max-width: 100%;
}

.footp ul a {
    display: block;
    color: var(--white);
}

.footpcus ul a {
    color: var(--black);
}

.footp-cta {
    margin-top: auto;
}

.footmap {
    position: relative;
    width: 100%;
    max-width: 600px;
    aspect-ratio: 1 / 1;
    margin-left: auto;
    margin-right: auto;
    border-radius: var(--siteradius24);
    overflow: hidden;
}

.footmap video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

#footp-vid { pointer-events: none; user-select: none; }

.footp-cont p { font-size: 20px; line-height: 28px; }

.footp-cont ul { font-size: 18px; line-height: 26px; }

.footp-cont li { margin-bottom: 24px; }

/*
** Contact Us
*/
.ccards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}

.ccard {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    gap: 16px;
    min-height: 265px;
    padding: 24px;
    border: 1px solid #63BBEB;
}

.ccard a { align-self: flex-start; }

.procl {
    position: relative;
    --imgsize: 140px;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 32px;
    width: 1132px;
    max-width: 100%;
}

.procl::before {
    content: "";
    position: absolute;
    left: 12.5%;
    top: calc(var(--imgsize) / 2);
    width: 75%;
    height: 3px;
    background: linear-gradient(90deg, #014324 0%, #014324 50%, transparent 51%, transparent);
    background-size: 20px;
    z-index: 0;
}

.proci {position: relative;}

.proci-img {
    width: var(--imgsize);
    height: var(--imgsize);
    margin: 0 auto 20px;
    background: #D9D9D9;
    border-radius: var(--imgsize);
}

/*
** Product Page
*/
.hero-prod {
    position: relative;
    display: flex;
    align-items: center;
    min-height: 715px;
    background-size: cover;
    background-position: center right;
    background-repeat: no-repeat;
}

.hero-prod::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(101.73deg, #016536 2.96%, rgba(1, 140, 74, 0) 97.04%);
    opacity: 0;
}

.hero-prod-wrap {
    width: 607px;
    max-width: 100%;
}

.hero-prod .container {
    position: relative;
    z-index: 1;
}