*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0
}

html,
body {
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
    background: #FAF7F1 !important
}

a {
    color: inherit;
}

#page,
#wrapper,
#main,
#content,
#primary,
.site,
.site-inner,
.site-content,
.content-area,
.entry-content,
.entry,
.post,
.page,
main,
article,
.wp-site-blocks,
.is-layout-constrained,
.is-layout-flow,
.wp-block-post-content,
.wp-block-group,
.wp-block-html,
.alignfull,
.container,
.container-fluid,
div[class*="container"],
div[class*="wrapper"] {
    max-width: 100% !important;
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    left: 0 !important;
    right: 0 !important
}

@font-face {
    font-family: 'Jura';
    src: url('fonts/Jura-Light.woff2') format('woff2');
    font-weight: 300;
}

@font-face {
    font-family: 'Jura';
    src: url('fonts/Jura-Regular.woff2') format('woff2');
    font-weight: 400;
}

@font-face {
    font-family: 'Jura';
    src: url('fonts/Jura-Medium.woff2') format('woff2');
    font-weight: 500;
}

@font-face {
    font-family: 'Work Sans';
    src: url('fonts/WorkSans-Light.woff2') format('woff2');
    font-weight: 300;
}

@font-face {
    font-family: 'Work Sans';
    src: url('fonts/WorkSans-Regular.woff2') format('woff2');
    font-weight: 400;
}

@font-face {
    font-family: 'Work Sans';
    src: url('fonts/WorkSans-Medium.woff2') format('woff2');
    font-weight: 500;
}

@font-face {
    font-family: 'Work Sans';
    src: url('fonts/WorkSans-SemiBold.woff2') format('woff2');
    font-weight: 600;
}

@font-face {
    font-family: 'Playfair Display';
    src: url('fonts/PlayfairDisplay-Italic.woff2') format('woff2');
    font-weight: 400;
    font-style: italic;
}

#pg {
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw !important;
    margin-right: -50vw !important;
    width: 100vw;
    max-width: 100vw;
    padding: 0
}

html {
    scroll-behavior: smooth
}

:root {
    --cream: #FAF7F1;
    --cream-d: #F0EBE1;
    --navy: #0A1432;
    --navy-m: #141E40;
    --gold: #C6A24B;
    --gold-d: #AF8C38;
    --chalk: #F5F2EA;
    --mist: #A09880;
    --smoke: #6B6558;
    --rule: rgba(10, 20, 50, 0.09);
    --ease: cubic-bezier(0.16, 1, 0.3, 1);
    --fd: 'Jura', sans-serif;
    --fb: 'Work Sans', sans-serif;
    --fa: 'Playfair Display', serif;
    /* font sizes */
    --micro: 11px;
    --smallest: 12px;
    --small: 13px;
}

body {
    background: var(--cream);
    color: var(--navy);
    font-family: var(--fb);
    overflow-x: hidden;
    cursor: default;
}

body::before {
    content: '';
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 9990;
    opacity: .03;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")
}

.cur {
    position: fixed;
    width: 7px;
    height: 7px;
    background: var(--navy);
    border-radius: 50%;
    pointer-events: none;
    z-index: 9995;
    transform: translate(-50%, -50%);
    transition: width .3s, height .3s, background .3s;
    mix-blend-mode: multiply
}

.crng {
    position: fixed;
    width: 34px;
    height: 34px;
    border: 1px solid rgba(10, 20, 50, 0.18);
    border-radius: 50%;
    pointer-events: none;
    z-index: 9994;
    transform: translate(-50%, -50%);
    transition: width .4s var(--ease), height .4s var(--ease), border-color .3s
}

.cur.h {
    width: 4px;
    height: 4px;
    background: var(--gold)
}

.crng.h {
    width: 52px;
    height: 52px;
    border-color: var(--gold)
}

#pre {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: var(--navy);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 30px
}

.pdoor {
    width: 64px;
    aspect-ratio: 1/1.618;
    border: 1px solid rgba(245, 242, 234, 0.15);
    position: relative;
    overflow: hidden;
}

.pdoor::after {
    display: inline;
}

/* The Flame Container */
.pflame {
    position: absolute;
    bottom: -5px;
    width: 100%;
    height: 95%;
    background: radial-gradient(ellipse at bottom,
            #fff 0%, gold 15%, #ff4500 40%, #800000 75%, transparent 100%);
    filter: url(#fire);
    opacity: 0.95;
    transform-origin: bottom;
    animation: roar 0.1s infinite alternate;
}

.pflame::before {
    content: '';
    position: absolute;
    inset: 0;
    background: inherit;
    filter: blur(15px);
    opacity: 0.6;
}

/* The 'Roar' animation: Subtle scaling and shifting to simulate heat haze */
@keyframes roar {
    0% {
        transform: scaleY(1) scaleX(1);
        filter: url(#fire) brightness(1);
    }

    100% {
        transform: scaleY(1.1) scaleX(1.05);
        filter: url(#fire) brightness(1.2);
    }
}

/* The actual door leaf that shuts */
.pshut {
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: var(--navy);
    z-index: 2;
    /* Added a slight inner shadow to the door edge for depth */
    box-shadow: -10px 0 20px rgba(0, 0, 0, 0.5);
}

.pshut::after {
    content: '';
    position: absolute;
    right: 11px;
    top: calc(100%/1.618 - 1px);
    width: 16px;
    height: 1.5px;
    background: var(--gold);
    z-index: 3;
}

/* Animation to shut the door over the flames */
@keyframes shutDoor {
    0% {
        left: -100%;
    }

    70% {
        left: -100%;
    }

    /* Wait a bit while flames flicker */
    100% {
        left: 0%;
    }

    /* Shut the door */
}

/* Optional: Make the flames "roaring" slightly */
.pflame::after {
    content: '';
    position: absolute;
    inset: 0;
    background: inherit;
    filter: blur(5px);
    animation: flicker 0.15s infinite alternate;
}

@keyframes flicker {
    from {
        opacity: 0.7;
    }

    to {
        opacity: 1;
    }
}

.pname {
    font-family: var(--fd);
    font-size: var(--smallest);
    font-weight: 300;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: rgba(245, 242, 234, 0.3)
}

.ppct {
    font-family: var(--fd);
    font-size: var(--smallest);
    font-weight: 300;
    letter-spacing: .1em;
    color: var(--gold)
}

#pg {
    opacity: 0
}

.tb {
    background: var(--navy);
    padding: 10px 0;
    overflow: hidden
}

.tbi {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 64px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-family: var(--fd);
    font-size: var(--smallest);
    font-weight: 300;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: rgba(245, 242, 234, 0.45)
}

.tbc {
    display: flex;
    gap: 0
}

.tbc span {
    padding: 0 24px;
    border-right: 1px solid rgba(198, 162, 75, 0.2)
}

.tbc span:first-child {
    padding-left: 0
}

.tbp {
    color: var(--gold);
    letter-spacing: .12em;
    font-weight: 400;
    text-decoration: none
}

nav {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(250, 247, 241, 0.94);
    border-bottom: 1px solid var(--rule);
    backdrop-filter: blur(14px);
    transition: box-shadow .3s
}

.ni {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 64px;
    height: 88px;
    display: flex;
    justify-content: space-between;
    align-items: center
}

.logo {
    display: flex;
    align-items: center;
    gap: 18px;
    text-decoration: none
}

.ld {
    width: 36px;
    height: 48px;
    border: 1.5px solid var(--navy);
    position: relative;
    flex-shrink: 0
}

.ld::before {
    content: '';
    position: absolute;
    right: 7px;
    top: calc(100%/1.618 - 1px);
    width: 11px;
    height: 1.5px;
    background: var(--gold)
}

.ld::after {
    content: '';
    position: absolute;
    bottom: -11px;
    left: -7px;
    right: -7px;
    height: 1.5px;
    background: var(--gold-d);
    opacity: .5
}

.lsep {
    width: 1px;
    height: 32px;
    background: rgba(10, 20, 50, 0.1)
}

.ll1 {
    font-family: var(--fd);
    font-weight: 300;
    font-size: 17px;
    letter-spacing: .07em;
    color: var(--navy);
    text-transform: uppercase;
    display: block
}

.ll2 {
    font-family: var(--fd);
    font-weight: 800;
    font-size: 18px;
    letter-spacing: .05em;
    color: var(--gold);
    display: block;
    margin-top: 2px
}

.nl {
    display: flex;
    gap: 40px;
    align-items: center
}

.nl a {
    font-family: var(--fd);
    font-size: 12px;
    font-weight: 300;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--navy);
    text-decoration: none;
    opacity: .65;
    position: relative;
    transition: opacity .2s
}

.nl a::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 0;
    height: 1px;
    background: var(--gold);
    transition: width .4s var(--ease)
}

.nl a:hover {
    opacity: 1
}

.nl a:hover::after {
    width: 100%
}

.ncta {
    opacity: 1 !important;
    border: 1px solid var(--navy) !important;
    padding: 12px 24px !important;
    font-size: var(--small) !important;
    transition: background .25s, color .25s !important
}

.ncta::after {
    display: none !important
}

.ncta:hover {
    background: var(--navy) !important;
    color: var(--chalk) !important
}

.hero {
    min-height: 92vh;
    background: var(--cream);
    display: grid;
    grid-template-columns: 56% 44%;
    position: relative;
    overflow: hidden
}

.hero::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 44%;
    background: var(--navy);
    clip-path: polygon(8% 0, 100% 0, 100% 100%, 0% 100%)
}

.hl {
    padding: 110px 64px 80px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
    z-index: 2
}

.hey {
    font-family: var(--fd);
    font-size: var(--small);
    font-weight: 300;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--gold);
    margin-bottom: 28px;
    display: flex;
    align-items: center;
    gap: 12px
}

.hey::before {
    content: '';
    width: 32px;
    height: 1px;
    background: var(--gold)
}

.hh1 {
    font-family: var(--fd);
    font-weight: 300;
    font-size: clamp(44px, 5.2vw, 76px);
    line-height: 1.04;
    letter-spacing: -.01em;
    color: var(--navy)
}

.hh1 em {
    font-style: italic;
    font-family: var(--fa);
    color: var(--gold);
    font-weight: 400;
    font-size: .88em
}

.hsub {
    font-family: var(--fb);
    font-size: 15px;
    font-weight: 300;
    line-height: 1.8;
    color: var(--smoke);
    max-width: 420px;
    margin: 28px 0 44px
}

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

.bp {
    background: var(--navy);
    color: var(--chalk);
    font-family: var(--fd);
    font-size: var(--small);
    font-weight: 400;
    letter-spacing: .16em;
    text-transform: uppercase;
    padding: 16px 36px;
    border: none;
    text-decoration: none;
    display: inline-block;
    position: relative;
    overflow: hidden;
    transition: color .4s
}

.bp::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--gold);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .5s var(--ease)
}

.bp span {
    position: relative;
    z-index: 1
}

.bp:hover::before {
    transform: scaleX(1)
}

.bp:hover {
    color: var(--navy)
}

.hr {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 2;
    padding: 80px 48px
}

.hdm {
    width: 190px;
    aspect-ratio: 1/1.618;
    border: 1px solid rgba(245, 242, 234, 0.12);
    position: relative
}

.hdm::before {
    content: '';
    position: absolute;
    right: 22px;
    top: calc(100%/1.618 - 1px);
    width: 28px;
    height: 2px;
    background: var(--gold)
}

.hdm::after {
    content: '';
    position: absolute;
    bottom: -14px;
    left: -10px;
    right: -10px;
    height: 2px;
    background: rgba(198, 162, 75, 0.3)
}

.hst {
    position: absolute;
    right: 40px;
    display: flex;
    flex-direction: column;
    gap: 30px
}

.stn {
    font-family: var(--fd);
    font-weight: 300;
    font-size: 40px;
    color: var(--gold);
    letter-spacing: -.02em;
    line-height: 1;
    text-align: right
}

.stl {
    font-family: var(--fb);
    font-size: var(--smallest);
    font-weight: 300;
    letter-spacing: .13em;
    text-transform: uppercase;
    color: rgba(245, 242, 234, 0.35);
    margin-top: 4px;
    text-align: right
}

.trust {
    background: var(--navy);
    padding: 18px 0;
    border-top: 1px solid rgba(198, 162, 75, 0.1)
}

.trustin {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 64px;
    display: flex;
    justify-content: space-around;
    align-items: center;
    flex-wrap: wrap;
    gap: 14px
}

.ti {
    font-family: var(--fd);
    font-size: var(--smallest);
    font-weight: 300;
    letter-spacing: .17em;
    text-transform: uppercase;
    color: rgba(245, 242, 234, 0.38);
    display: flex;
    align-items: center;
    gap: 8px
}

.ti::before {
    content: '';
    width: 4px;
    height: 4px;
    background: var(--gold);
    border-radius: 50%;
    flex-shrink: 0
}

.si {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 64px
}

.sh {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 72px;
    align-items: end;
    margin-bottom: 72px;
    padding-bottom: 48px;
    border-bottom: 1px solid var(--rule)
}

.sey {
    font-family: var(--fd);
    font-size: var(--smallest);
    font-weight: 300;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--gold);
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 10px
}

.sey::before {
    content: '';
    width: 24px;
    height: 1px;
    background: var(--gold)
}

.stitle {
    font-family: var(--fd);
    font-weight: 300;
    font-size: clamp(30px, 3.2vw, 48px);
    letter-spacing: -.01em;
    line-height: 1.08;
    color: var(--navy)
}

.stitle em {
    font-style: italic;
    font-family: var(--fa);
    color: var(--gold);
    font-size: .9em
}

.sint {
    font-family: var(--fb);
    font-size: 15px;
    font-weight: 300;
    line-height: 1.8;
    color: var(--smoke);
    align-self: end
}

.svc {
    padding: 120px 0;
    background: var(--cream)
}

.sg {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2px;
    background: rgba(10, 20, 50, 0.08)
}

.sc {
    background: var(--cream);
    padding: 48px 36px 52px;
    position: relative;
    overflow: hidden;
    transition: background .35s var(--ease)
}

.sc::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--gold);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .4s var(--ease)
}

.sc:hover {
    background: var(--navy)
}

.sc:hover::after {
    transform: scaleX(1)
}

.scn {
    font-family: var(--fd);
    font-size: var(--smallest);
    font-weight: 300;
    letter-spacing: .2em;
    color: var(--gold);
    margin-bottom: 32px;
    display: flex;
    align-items: center;
    gap: 8px
}

.scn::before {
    content: '';
    width: 16px;
    height: 1px;
    background: var(--gold);
    opacity: .4
}

.sct {
    font-family: var(--fd);
    font-size: 22px;
    font-weight: 300;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--navy);
    margin-bottom: 14px;
    line-height: 1;
    transition: color .35s
}

.sc:hover .sct {
    color: var(--chalk)
}

.scd {
    font-family: var(--fb);
    font-size: var(--small);
    font-weight: 300;
    line-height: 1.75;
    color: var(--smoke);
    transition: color .35s
}

.sc:hover .scd {
    color: rgba(245, 242, 234, 0.52)
}

.sg2 {
    position: absolute;
    bottom: -14px;
    right: -6px;
    width: 42px;
    aspect-ratio: 1/1.618;
    border: 1px solid rgba(10, 20, 50, 0.05);
    transition: border-color .35s, transform .4s var(--ease)
}

.sc:hover .sg2 {
    border-color: rgba(198, 162, 75, 0.14);
    transform: translate(-5px, -5px)
}

.about {
    background: var(--navy);
    padding: 120px 0;
    position: relative;
    overflow: hidden
}

.abd {
    position: absolute;
    right: -60px;
    top: 50%;
    transform: translateY(-50%);
    width: 300px;
    aspect-ratio: 1/1.618;
    border: 1px solid rgba(245, 242, 234, 0.04)
}

.abd::before {
    content: '';
    position: absolute;
    right: 34px;
    top: calc(100%/1.618 - 1px);
    width: 56px;
    height: 1px;
    background: rgba(198, 162, 75, 0.06)
}

.ag {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: start
}

.about .sey {
    color: var(--gold)
}

.about .stitle {
    color: var(--chalk)
}

.abb {
    font-family: var(--fb);
    font-size: 15px;
    font-weight: 300;
    line-height: 1.8;
    color: rgba(245, 242, 234, 0.5);
    margin: 24px 0 40px
}

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

.ap {
    display: flex;
    gap: 18px;
    align-items: flex-start;
    padding: 22px 0;
    border-top: 1px solid rgba(245, 242, 234, 0.06)
}

.ap:last-child {
    border-bottom: 1px solid rgba(245, 242, 234, 0.06)
}

.api {
    width: 34px;
    height: 34px;
    flex-shrink: 0;
    background: rgba(198, 162, 75, 0.1);
    display: flex;
    align-items: center;
    justify-content: center
}

.apt {
    font-family: var(--fd);
    font-size: var(--small);
    font-weight: 400;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--chalk);
    margin-bottom: 5px
}

.app {
    font-family: var(--fb);
    font-size: var(--small);
    font-weight: 300;
    color: rgba(245, 242, 234, 0.42);
    line-height: 1.65
}

.asts {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: 2px;
    background: rgba(245, 242, 234, 0.04)
}

.ast {
    background: var(--navy-m);
    padding: 40px 32px
}

.astn {
    font-family: var(--fd);
    font-weight: 300;
    font-size: 44px;
    color: var(--gold);
    letter-spacing: -.02em;
    line-height: 1;
    margin-bottom: 8px
}

.astl {
    font-family: var(--fb);
    font-size: var(--smallest);
    font-weight: 300;
    letter-spacing: .13em;
    text-transform: uppercase;
    color: rgba(245, 242, 234, 0.3)
}

.proc {
    padding: 120px 0;
    background: var(--cream-d)
}

.proc .sh {
    grid-template-columns: 1fr;
    border: none;
    padding-bottom: 0;
    margin-bottom: 0
}

.ps {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    margin-top: 80px;
    position: relative
}

.ps::before {
    content: '';
    position: absolute;
    top: 23px;
    left: 8%;
    width: 84%;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(198, 162, 75, 0.25) 20%, rgba(198, 162, 75, 0.25) 80%, transparent)
}

.pst {
    padding: 0 32px;
    text-align: center
}

.psd {
    width: 46px;
    height: 46px;
    border: 1px solid var(--gold);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 26px;
    background: var(--cream-d);
    position: relative;
    z-index: 2;
    font-family: var(--fd);
    font-size: 14px;
    font-weight: 300;
    color: var(--gold)
}

.pstit {
    font-family: var(--fd);
    font-size: var(--small);
    font-weight: 300;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--navy);
    margin-bottom: 12px
}

.psdesc {
    font-family: var(--fb);
    font-size: var(--small);
    font-weight: 300;
    line-height: 1.7;
    color: var(--smoke)
}

.certs {
    background: var(--navy);
    padding: 52px 0;
    border-top: 1px solid rgba(198, 162, 75, 0.1)
}

.ci {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 64px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    flex-wrap: wrap
}

.cl {
    font-family: var(--fd);
    font-size: var(--smallest);
    font-weight: 300;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: rgba(245, 242, 234, 0.22);
    white-space: nowrap
}

.csep {
    height: 36px;
    width: 1px;
    background: rgba(245, 242, 234, 0.08);
    flex-shrink: 0
}

.cbs {
    display: flex;
    gap: 20px;
    flex-wrap: wrap
}

.cb {
    font-family: var(--fd);
    font-size: var(--smallest);
    font-weight: 300;
    letter-spacing: .13em;
    text-transform: uppercase;
    color: var(--gold);
    padding: 8px 14px;
    border: 1px solid rgba(198, 162, 75, 0.2);
    transition: border-color .25s
}

.cb:hover {
    border-color: rgba(198, 162, 75, 0.5)
}

.contact {
    padding: 120px 0;
    background: var(--cream)
}

.cg {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: start
}

.cbody {
    font-family: var(--fb);
    font-size: 15px;
    font-weight: 300;
    line-height: 1.8;
    color: var(--smoke);
    margin: 24px 0 40px
}

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

.cm {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 22px 0;
    border-bottom: 1px solid var(--rule)
}

.cm:first-child {
    border-top: 1px solid var(--rule)
}

.cml {
    font-family: var(--fd);
    font-size: var(--micro);
    font-weight: 300;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--mist);
    width: 68px;
    flex-shrink: 0
}

.cmv {
    font-family: var(--fd);
    font-size: 18px;
    font-weight: 300;
    letter-spacing: .03em;
    color: var(--navy)
}

.cmv a {
    color: inherit;
    text-decoration: none;
    transition: color .2s
}

.cmv a:hover {
    color: var(--gold)
}

.cf {
    background: var(--navy);
    padding: 52px;
    color: var(--chalk);
}

.ftit {
    font-family: var(--fd);
    font-size: 17px;
    font-weight: 300;
    letter-spacing: .08em;
    text-transform: uppercase;
    margin-bottom: 6px;
}

.fsub {
    font-family: var(--fb);
    font-size: var(--small);
    font-weight: 300;
    margin-bottom: 34px;
    line-height: 1.6;
}

.fr {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-bottom: 0
}

.fg {
    margin-bottom: 16px
}

.fg label {
    display: block;
    font-family: var(--fd);
    font-size: var(--micro);
    font-weight: 300;
    letter-spacing: .2em;
    text-transform: uppercase;
    margin-bottom: 10px;
}

.fg input,
.fg select,
.fg textarea {
    width: 100%;
    background: transparent;
    border: none;
    border-bottom: 1px solid rgba(245, 242, 234, 0.12);
    padding: 12px 0;
    font-family: var(--fb);
    font-size: 14px;
    font-weight: 300;
    color: var(--chalk);
    outline: none;
    border-radius: 0;
    -webkit-appearance: none;
    transition: border-color .2s
}

.fg input:focus,
.fg select:focus,
.fg textarea:focus {
    border-bottom-color: var(--gold)
}

.fg input::placeholder,
.fg textarea::placeholder {
    font-weight: lighter;
}

.fg select {
    cursor: default;
}

.fg select option {
    background: var(--navy-m);
}

.fg textarea {
    resize: none;
    height: 76px
}

.bsub {
    width: 100%;
    background: var(--gold);
    color: var(--navy);
    font-family: var(--fd);
    font-size: var(--small);
    font-weight: 400;
    letter-spacing: .2em;
    text-transform: uppercase;
    padding: 18px;
    border: none;
    cursor: auto;
    margin-top: 12px;
    position: relative;
    overflow: hidden;
    transition: color .4s
}

.bsub::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--navy);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .5s var(--ease)
}

.bsub span {
    position: relative;
    z-index: 1
}

.bsub:hover::before {
    transform: scaleX(1)
}

.bsub:hover span {
    color: var(--gold)
}

footer {
    background: #0C1020;
    padding: 64px 0 32px;
    border-top: 1px solid rgba(198, 162, 75, 0.07)
}

.fg2 {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 64px;
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 56px;
    margin-bottom: 48px;
    color: var(--mist);
}

.fl1 {
    font-family: var(--fd);
    font-size: 17px;
    font-weight: 300;
    letter-spacing: .07em;
    text-transform: uppercase;
    color: var(--chalk);
    display: block
}

.fl2 {
    font-family: var(--fd);
    font-size: 14px;
    font-weight: 300;
    color: var(--gold);
    display: block;
    margin-top: 2px
}

.fa2 {
    font-family: var(--fb);
    font-size: var(--small);
    font-weight: 300;
    line-height: 1.75;
    margin-top: 16px
}

.fc h4 {
    font-family: var(--fd);
    font-size: var(--micro);
    font-weight: 400;
    letter-spacing: .2em;
    text-transform: uppercase;
    margin-bottom: 20px
}

.fc ul {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 10px
}

.fc ul li a {
    font-family: var(--fb);
    font-size: var(--small);
    font-weight: 300;
    text-decoration: none;
    transition: color .2s
}

.fc ul li a:hover {
    color: var(--gold)
}

.fb2 {
    max-width: 1400px;
    margin: 0 auto;
    padding: 22px 64px 0;
    border-top: 1px solid rgba(245, 242, 234, 0.04);
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px
}

.fb2 p {
    font-family: var(--fd);
    font-size: var(--small);
    font-weight: 300;
    letter-spacing: .1em;
    color: var(--mist);
}

@media (max-width:1024px) {
    .si {
        padding: 0 40px
    }

    .ni {
        padding: 0 40px;
        height: 80px
    }

    .tbi {
        padding: 0 40px
    }

    .sh {
        grid-template-columns: 1fr;
        gap: 40px
    }

    .hero {
        grid-template-columns: 1fr;
        min-height: auto;
        display: flex;
        flex-direction: column
    }

    .hero::before {
        position: relative;
        width: 100%;
        height: 400px;
        clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%)
    }

    .hl {
        padding: 72px 40px 52px
    }

    .hr {
        padding: 40px;
        display: flex;
        flex-wrap: wrap
    }

    .hst {
        position: relative;
        right: auto;
        flex-direction: row;
        gap: 28px;
        flex-wrap: wrap;
        margin-top: 28px
    }

    .hdm {
        width: 110px
    }

    .sg {
        grid-template-columns: repeat(2, 1fr)
    }

    .ag {
        grid-template-columns: 1fr;
        gap: 52px
    }

    .asts {
        grid-template-columns: repeat(2, 1fr)
    }

    .ps {
        grid-template-columns: repeat(2, 1fr);
        gap: 48px 24px
    }

    .ps::before {
        display: none
    }

    .cg {
        grid-template-columns: 1fr;
        gap: 52px
    }

    .fg2 {
        grid-template-columns: 1fr 1fr;
        gap: 40px
    }

    .trustin {
        padding: 0 40px
    }

    .ci {
        padding: 0 40px
    }

    .fb2 {
        padding: 16px 40px 0
    }
}

@media (max-width:640px) {
    body {
        cursor: auto
    }

    .cur,
    .crng {
        display: none
    }

    .tb {
        display: none
    }

    .ni {
        padding: 0 20px;
        height: 68px
    }

    .ll1 {
        font-size: 14px
    }

    .ll2 {
        font-size: 12px
    }

    .ld {
        width: 28px;
        height: 38px
    }

    .nl a:not(.ncta) {
        display: none
    }

    .ncta {
        padding: 10px 18px !important;
        font-size: var(--smallest) !important
    }

    .hero {
        grid-template-columns: 1fr;
        min-height: auto;
        display: flex;
        flex-direction: column
    }

    .hero::before {
        display: none
    }

    .hl {
        padding: 80px 20px 48px
    }

    .hr {
        display: none
    }

    .hh1 {
        font-size: clamp(34px, 9vw, 50px)
    }

    .hsub {
        font-size: 14px;
        max-width: 100%
    }

    .hact {
        flex-direction: column;
        align-items: stretch
    }

    .bp,
    .bo {
        width: 100%;
        text-align: center;
        display: block;
        padding: 16px 20px
    }

    .si {
        padding: 0 20px
    }

    .sh {
        gap: 24px;
        margin-bottom: 40px;
        padding-bottom: 28px
    }

    .stitle {
        font-size: clamp(24px, 7vw, 36px)
    }

    .svc {
        padding: 64px 0
    }

    .sg {
        grid-template-columns: 1fr
    }

    .sc {
        padding: 32px 22px 36px
    }

    .about {
        padding: 64px 0
    }

    .ag {
        gap: 36px
    }

    .asts {
        grid-template-columns: 1fr 1fr
    }

    .astn {
        font-size: 34px
    }

    .ast {
        padding: 28px 20px
    }

    .proc {
        padding: 64px 0
    }

    .ps {
        grid-template-columns: 1fr;
        gap: 36px
    }

    .pst {
        padding: 0
    }

    .certs {
        padding: 32px 0
    }

    .ci {
        flex-direction: column;
        align-items: flex-start;
        gap: 18px;
        padding: 0 20px
    }

    .csep {
        display: none
    }

    .cbs {
        gap: 10px
    }

    .cb {
        font-size: var(--micro);
        padding: 7px 12px
    }

    .contact {
        padding: 64px 0
    }

    .cg {
        gap: 36px
    }

    .cf {
        padding: 24px 20px
    }

    .fr {
        grid-template-columns: 1fr
    }

    .fg2 {
        grid-template-columns: 1fr;
        gap: 36px
    }

    .fb2 {
        flex-direction: column;
        gap: 6px;
        padding: 16px 20px 0
    }

    .trustin {
        padding: 12px 20px;
        gap: 8px
    }

    .ti {
        font-size: var(--micro);
        letter-spacing: .12em
    }
}