@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@700;800;900&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap");

/* Local framework utilities used by the public templates. */
.container-fluid{
    width:100%;
}

.d-none{
    display:none !important;
}

.d-flex{
    display:flex !important;
}

.flex-wrap{
    flex-wrap:wrap !important;
}

@media(min-width:1200px){
    .d-xl-flex{
        display:flex !important;
    }

    .d-xl-none{
        display:none !important;
    }
}

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

html{
    width:100%;
    max-width:100%;
    overflow-x:hidden;
}

:root{
    --accent-rgb:255,0,127;
    --black:#050609;
    --black2:#08090d;
    --white:#ffffff;
    --copy-color:rgba(255,255,255,.66);
    --caption-color:rgba(255,255,255,.52);
    --copy-size:17px;
    --copy-size-mobile:16px;
    --copy-line-height:1.78;
    --copy-line-height-mobile:1.72;
    --display-heading-font:'Montserrat',sans-serif;
    --display-heading-weight:900;
    --display-heading-transform:uppercase;
    --display-heading-letter-spacing:-.082em;
    --display-heading-line-height:.86;
    --glass-bg:rgba(18,20,24,.54);
    --glass-blur:blur(5px) saturate(120%);
    --glass-border:rgba(255,255,255,.045);
    --section-divider:color-mix(in srgb, rgb(var(--accent-rgb)) 38%, transparent);
    --section-divider-glow:none;
    --glass-shadow:inset 0 1px 0 rgba(255,255,255,.04), 0 10px 40px rgba(0,0,0,.22);
    --control-bg:
        linear-gradient(180deg,rgba(255,255,255,.18),rgba(255,255,255,.075)),
        linear-gradient(135deg,color-mix(in srgb, rgb(var(--accent-rgb)) 34%, rgba(255,255,255,.08)),rgba(255,255,255,.035));
    --control-bg-strong:
        linear-gradient(180deg,rgba(255,255,255,.22),rgba(255,255,255,.10)),
        linear-gradient(135deg,color-mix(in srgb, rgb(var(--accent-rgb)) 42%, rgba(255,255,255,.10)),rgba(255,255,255,.05));
    --control-shadow:
        inset 0 -2px 0 rgba(var(--accent-rgb),.78),
        inset 0 1px 0 rgba(255,255,255,.22),
        inset 0 -1px 0 rgba(255,255,255,.055),
        0 10px 30px rgba(0,0,0,.16);
    --control-hover-shadow:
        inset 0 2px 0 rgba(var(--accent-rgb),.78),
        0 18px 45px rgba(0,0,0,.28),
        0 0 38px color-mix(in srgb, rgb(var(--accent-rgb)) 22%, transparent);
    --accent-text-glow:0 0 38px rgba(var(--accent-rgb),.44);
    --shine-accent:
        linear-gradient(
            115deg,
            transparent 0%,
            transparent 24%,
            rgba(255,255,255,.06) 38%,
            rgba(255,255,255,.62) 50%,
            rgba(255,255,255,.08) 62%,
            transparent 76%,
            transparent 100%
        );
    --control-shine:
        linear-gradient(
            115deg,
            transparent 0%,
            transparent 30%,
            rgba(255,255,255,.18) 42%,
            rgba(255,255,255,.96) 50%,
            rgba(255,255,255,.34) 58%,
            rgba(255,255,255,.10) 66%,
            transparent 78%,
            transparent 100%
        );
    --motion-ease:cubic-bezier(.22,1,.36,1);
    --motion-fast:.35s ease;
    --menu-slide-speed:.7s;
    --shine-speed:1.75s;
    --shine-duration:var(--shine-speed);
    --corner-cut:22px;
    --small-corner-cut:13px;
    --icon-corner-cut:14px;
    --ui-height:48px;
    --ui-font-size:11px;
    --ui-letter-spacing:.16em;
    --ui-padding-x:24px;
    --ui-left-pad:42px;
    --ui-dot-size:7px;
    --hero-title-max-size:145px;
    --hero-media-height:88vh;
    --hero-media-min-height:560px;
    --hero-media-bleed:-9vw;
}

body{
    background:var(--black);
    color:white;
    overflow-x:hidden;
    width:100%;
    max-width:100%;
    font-family:'Plus Jakarta Sans',sans-serif;
}

h1,h2,h3,h4,.logo,.nav-links a{
    font-family:'Montserrat',sans-serif;
}

.bg-glow{
    position:fixed;
    inset:0;
    z-index:-1;
    overflow:hidden;
}


.site-bg-image{
    position:absolute;
    inset:0;
    background-image:
        linear-gradient(rgba(5,6,9,.64),rgba(5,6,9,.64)),
        url("https://www.theeventdjs.com/assets/images/darkbg9.jpg");
    background-size:cover;
    background-position:center center;
    background-repeat:no-repeat;
    filter:grayscale(100%) contrast(115%);
    opacity:.42;
    transform:scale(1.02);
}

.glow{
    position:absolute;
    z-index:2;
    border-radius:50%;
    filter:blur(130px);
}

.glow.one{
    width:700px;
    height:700px;
    background:rgb(var(--accent-rgb));
    opacity:.15;
    top:-250px;
    left:-220px;
    animation:glowOne 10s ease-in-out infinite;
}

.glow.two{
    width:850px;
    height:850px;
    background:rgb(var(--accent-rgb));
    opacity:.13;
    bottom:-340px;
    right:-270px;
    animation:glowTwo 12s ease-in-out infinite;
}

@keyframes glowOne{
    0%,100%{transform:scale(1);}
    50%{transform:scale(1.12);}
}

@keyframes glowTwo{
    0%,100%{transform:scale(1.06);}
    50%{transform:scale(.92);}
}

header{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    z-index:100;
    border-bottom:1px solid var(--section-divider);
    box-shadow:none;
    overflow:visible;
}

header::after{
    content:"";
    position:absolute;
    inset:-1px;
    background:var(--shine-accent);
    transform:translateX(-120%);
    pointer-events:none;
    animation:none;
}

header,
.mobile-menu,
.tag,
.card,
.split-copy,
.wide-caption,
.testimonial-card,
.luxury-form,
.elements-hero-panel,
.element-copy,
.element-panel,
.element-card,
.stat-card,
.gallery-item,
.element-dropdown details,
.process-step{
    background:var(--glass-bg);
    backdrop-filter:var(--glass-blur);
    -webkit-backdrop-filter:var(--glass-blur);
    box-shadow:var(--glass-shadow);
}

.card,
.tag,
.split-copy,
.wide-caption,
.testimonial-card,
.luxury-form,
.elements-hero-panel,
.element-copy,
.element-panel,
.element-card,
.stat-card,
.gallery-item,
.element-dropdown details,
.process-step{
    border:1px solid var(--glass-border);
}

.nav-links a,
.menu-toggle{
    background:var(--control-bg);
    backdrop-filter:var(--glass-blur);
    -webkit-backdrop-filter:var(--glass-blur);
    box-shadow:var(--control-shadow);
    transition:var(--motion-fast);
}

.nav-links a::after,
.menu-toggle::after{
    background:var(--shine-accent);
}

header::after,
.nav-links a::after,
.tag::after,
.gloss-panel::after,
.card::after,
.menu-toggle::after{
    left:-75% !important;
    right:auto !important;
    top:-1px !important;
    bottom:-1px !important;
    width:250% !important;
    transform:translateX(-70%);
}

.nav{
    position:relative;
    z-index:2;
    max-width:1500px;
    margin:auto;
    padding:28px 40px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:20px;
    animation:navReveal 1s var(--motion-ease) both;
}

.nav > div:first-child{
    min-width:0;
}



.logo{
    display:block;
    font-family:'Montserrat',sans-serif;
    font-size:32px;
    line-height:.80;
    letter-spacing:-.082em;
    white-space:nowrap;
    text-transform:uppercase;
    color:white;
    text-decoration:none;
}

.logo span{
    display:inline-block;
    margin:0;
    padding:0;
}





.logo .logo-light{
    display:inline-block;
    font-family:'Plus Jakarta Sans',sans-serif;
    font-weight:300;
    font-size:.88em;
    color:white;
    transform:translateY(-.5px);
}





.logo .logo-bold{
    display:inline-block;
    font-family:'Montserrat',sans-serif;
    font-weight:900;
    color:white;
    margin:0 .055em 0 .04em;
    transform:translateY(.5px);
}



.logo-sub{
    margin-top:6px;
    margin-bottom:0;
    max-width:100%;
    overflow:visible;
    text-overflow:clip;
    white-space:nowrap;
    overflow-wrap:normal;
    text-wrap:normal;
}

.nav-links{
    display:flex;
    gap:16px;
    align-items:center;
}

.nav-item{
    position:relative;
}

.nav-item::after{
    content:"";
    position:absolute;
    left:0;
    right:0;
    top:100%;
    height:18px;
}

.nav-links a{
    position:relative;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:var(--ui-height);
    padding:0 var(--ui-padding-x) 0 var(--ui-left-pad);
    text-decoration:none;
    color:white;
    font-size:var(--ui-font-size);
    line-height:1;
    letter-spacing:var(--ui-letter-spacing);
    text-transform:uppercase;
    font-weight:700;
    overflow:hidden;
    border:1px solid var(--glass-border);
}

.nav-links a::before{
    content:"";
    position:absolute;
    left:18px;
    top:50%;
    width:var(--ui-dot-size);
    height:var(--ui-dot-size);
    transform:translateY(-50%);
    background:rgb(var(--accent-rgb));
    box-shadow:none;
    transition:var(--motion-fast);
}

.nav-links a::after{
    content:"";
    position:absolute;
    inset:-1px;
    transform:translateX(-120%);
    pointer-events:none;
}

.dropdown-menu{
    position:absolute;
    top:calc(100% + 8px);
    left:0;
    z-index:40;
    min-width:235px;
    padding:10px;
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transform:translateY(12px);
    background:var(--glass-bg);
    backdrop-filter:var(--glass-blur);
    -webkit-backdrop-filter:var(--glass-blur);
    box-shadow:var(--glass-shadow);
    clip-path:polygon(
        0 0,
        100% 0,
        100% 100%,
        var(--corner-cut) 100%,
        0 calc(100% - var(--corner-cut))
    );
    transition:var(--motion-fast);
}

.has-dropdown:hover .dropdown-menu,
.has-dropdown:focus-within .dropdown-menu{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transform:translateY(0);
}

.mobile-menu-label{
    display:block;
    padding:22px 40px 10px;
    color:rgb(var(--accent-rgb));
    font-family:'Montserrat',sans-serif;
    font-size:10px;
    line-height:1;
    letter-spacing:.24em;
    font-weight:900;
    text-transform:uppercase;
    border-top:1px solid var(--section-divider);
}

.hero{
    min-height:100vh;
    padding-bottom:90px;
    display:grid;
    grid-template-columns:minmax(0,1.25fr) minmax(0,.95fr);
    align-items:center;
    padding-left:max(40px,calc((100vw - 1450px)/2));
    padding-top:120px;
    overflow:hidden;
}

.hero-copy{
    padding-right:60px;
}

.tag{
    position:relative;
    display:inline-flex;
    align-items:center;
    gap:12px;
    padding:14px 22px;
    margin-bottom:42px;
    overflow:hidden;
    text-transform:uppercase;
    letter-spacing:.26em;
    font-size:11px;
    color:white;
}

.tag::after,
.gloss-panel::after,
.card::after{
    content:"";
    position:absolute;
    inset:-1px;
    background:var(--shine-accent);
    transform:translateX(-120%);
    pointer-events:none;
}

.tag::after{
    animation:none;
}

.dot{
    width:8px;
    height:8px;
    background:rgb(var(--accent-rgb));
    box-shadow:none;
}

.hero h1{
    font-size:clamp(66px,8vw,145px);
    line-height:.80;
    margin-bottom:36px;
}

.hero h1 > span:not(.display-part),
.elements-hero h1 > span:not(.display-part){
    display:block;
    width:fit-content;
    max-width:100%;
    white-space:nowrap;
    text-wrap:balance;
}

.hero h1 > span:not(.display-part):not(.hero-title-accent),
.elements-hero h1 > span:not(.display-part):not(.hero-title-accent){
    color:white;
    text-shadow:none;
}

.hero h1 > span.hero-title-accent,
.hero h1 > span:not(.display-part):not(.hero-title-line),
.elements-hero h1 > span.hero-title-accent,
.elements-hero h1 > span:not(.display-part):not(.hero-title-line){
    color:rgb(var(--accent-rgb));
    text-shadow:var(--accent-text-glow);
}

.hero p:not(.kicker){
    max-width:660px;
    font-size:21px;
    line-height:1.85;
    color:white;
    margin-bottom:0;
}

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

.hero-copy > p + .buttons,
.elements-hero p + .buttons,
.element-copy p + .buttons,
.element-panel p + .buttons,
.final-cta p + .btn{
    margin-top:44px;
}

@keyframes buttonShine{
    from{transform:translateX(-70%);}
    to{transform:translateX(70%);}
}

.hero-image-wrap{
    position:relative;
    height:var(--hero-media-height);
    min-height:var(--hero-media-min-height);
    margin-left:0;
    margin-right:var(--hero-media-bleed);
}

.hero-main-gloss{
    border:none;
    background:transparent;
    box-shadow:none;
    -webkit-mask-image:linear-gradient(
        to right,
        transparent 0%,
        rgba(0,0,0,.18) 8%,
        rgba(0,0,0,.48) 18%,
        rgba(0,0,0,.78) 30%,
        black 44%
    );
    mask-image:linear-gradient(
        to right,
        transparent 0%,
        rgba(0,0,0,.18) 8%,
        rgba(0,0,0,.48) 18%,
        rgba(0,0,0,.78) 30%,
        black 44%
    );
}

.gloss-panel{
    position:absolute;
    inset:0;
    overflow:hidden;
    border-top:1px solid var(--glass-border);
    border-left:1px solid var(--glass-border);
    border-bottom:1px solid var(--glass-border);
    background:
        linear-gradient(180deg,rgba(255,255,255,.032),rgba(255,255,255,.008)),
        linear-gradient(135deg,color-mix(in srgb, rgb(var(--accent-rgb)) 6%, transparent),color-mix(in srgb, rgb(var(--accent-rgb)) 4%, transparent));
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.07),
        inset 0 -1px 0 rgba(255,255,255,.025),
        0 35px 90px rgba(0,0,0,.45);
}

.hero-main-gloss{
    border:none !important;
    background:transparent !important;
    box-shadow:none !important;
}

.gloss-panel:not(.hero-main-gloss):hover::after{
    animation:panelShine var(--shine-duration, var(--shine-speed)) ease forwards;
}

@keyframes panelShine{
    to{transform:translateX(70%);}
}

.hero-main-gloss::after{
    animation:none;
}

@keyframes heroImageShine{
    to{transform:translateX(70%);}
}


.hero-video{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    z-index:1;
    opacity:.92;
    filter:contrast(108%) brightness(.82);
}

.hero-image{
    width:100%;
    height:100%;
    object-fit:cover;
    opacity:1;
}

.hero-video,
.hero-image,
.hero-main-gloss .image-overlay{
    clip-path:none;
    -webkit-mask-image:none;
    mask-image:none;
}

.image-overlay{
    position:absolute;
    inset:0;
    background:
        linear-gradient(to top,rgba(0,0,0,.42),transparent 44%),
        linear-gradient(to right,rgba(0,0,0,.22),transparent 36%);
}

.hero-caption{
    position:absolute;
    bottom:60px;
    right:clamp(40px,7vw,120px);
    left:auto;
    z-index:5;
    text-align:right;
    max-width:min(520px,52vw);
}

.hero-caption h2{
    font-size:64px;
    max-width:100%;
}

.service-page-hero{
    min-height:100vh;
    padding-bottom:90px;
    grid-template-columns:minmax(0,1.25fr) minmax(0,.95fr);
}

.service-page-hero .hero-copy{
    position:relative;
    z-index:6;
    max-width:none;
}

.service-page-hero .hero-copy .hero-kicker{
    margin:0 0 20px;
}

.service-page-hero .hero-image-wrap{
    z-index:1;
    height:var(--hero-media-height);
    min-height:var(--hero-media-min-height);
    margin-left:0;
    margin-right:var(--hero-media-bleed);
}

.service-page-image-panel{
    border-left:none;
}

.service-page-hero .hero-video,
.service-page-hero .hero-image{
    filter:contrast(108%) brightness(.78);
}

.service-page-hero .image-overlay{
    background:
        linear-gradient(to top,rgba(0,0,0,.48),transparent 48%),
        linear-gradient(to right,rgba(5,6,9,.70),rgba(5,6,9,.32) 34%,transparent 66%);
}

.service-page-hero .hero-caption{
    right:clamp(40px,7vw,120px);
    left:auto;
}

.section{
    padding:140px max(40px,calc((100vw - 1450px)/2));
    border-top:1px solid var(--section-divider);
    box-shadow:var(--section-divider-glow);
}

.section-title{
    margin-bottom:72px;
}

.kicker,
.logo-sub,
.wide-caption p{
    color:rgb(var(--accent-rgb));
    font-size:12px;
    text-transform:uppercase;
    letter-spacing:.35em;
    margin-bottom:20px;
}

.hero-caption .kicker{
    margin-bottom:14px;
}

.section-title h3{
    max-width:920px;
    font-size:58px;
}

.display-part{
    color:white;
    text-shadow:none;
}

.section-title h3 > span:not(.display-part),
.display-part.display-part-accent,
.display-part-accent{
    color:rgb(var(--accent-rgb));
    text-shadow:var(--accent-text-glow);
}

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

.card{    position:relative;
    padding:45px;
    min-height:330px;
    overflow:hidden;
    transition:var(--motion-fast);
}

.card:hover{
    transform:translateX(0) scale(1.015);
    border-color:color-mix(in srgb, rgb(var(--accent-rgb)) 26%, transparent);
}

.card:hover::after{
    animation:panelShine var(--shine-duration, var(--shine-speed)) ease forwards;
}

.icon{
    width:64px;
    height:64px;
    background:linear-gradient(135deg,rgb(var(--accent-rgb)),color-mix(in srgb, rgb(var(--accent-rgb)) 65%, white));
    margin-bottom:34px;
    box-shadow:0 0 38px color-mix(in srgb, rgb(var(--accent-rgb)) 28%, transparent);
    clip-path:polygon(0 0,100% 0,100% 100%,22px 100%,0 calc(100% - 22px));
}

.card h4{
    font-size:29px;
    line-height:1.1;
    text-transform:uppercase;
    margin-bottom:20px;
}

.card p{
    font-size:16px;
    line-height:1.85;
    color:white;
}

.split{
    display:grid;
    grid-template-columns:1fr 1.18fr;
    align-items:center;
    gap:70px;
    padding-left:max(40px,calc((100vw - 1450px)/2));
    padding-top:140px;
    padding-bottom:140px;
    border-top:1px solid var(--section-divider);
    box-shadow:var(--section-divider-glow);
    overflow:hidden;
}

.split-copy{    padding:50px;
}

.split-copy h3{
    font-size:55px;
    margin-bottom:28px;
}

.split-copy p{
    color:white;
    font-size:18px;
    line-height:1.85;
    margin-bottom:34px;
}

.wide-image{
    position:relative;
    height:590px;
    margin-right:-11vw;
    overflow:hidden;
}

.wide-image img{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    opacity:1;
    -webkit-mask-image:linear-gradient(
        to right,
        transparent 0%,
        rgba(0,0,0,.18) 8%,
        rgba(0,0,0,.48) 18%,
        rgba(0,0,0,.78) 30%,
        black 44%
    );
    mask-image:linear-gradient(
        to right,
        transparent 0%,
        rgba(0,0,0,.18) 8%,
        rgba(0,0,0,.48) 18%,
        rgba(0,0,0,.78) 30%,
        black 44%
    );
}

.wide-image::before{
    content:"";
    position:absolute;
    inset:0;
    z-index:2;
    pointer-events:none;
    background:transparent;
}

.wide-caption{
    position:absolute;
    z-index:4;
    left:45px;
    bottom:45px;
    max-width:460px;
    padding:30px;
}

.wide-caption p{
    margin-bottom:14px;
}

.wide-caption h4{
    font-size:32px;
    line-height:1.08;
    text-transform:uppercase;
}

.reveal-left,
.reveal-right{
    opacity:0;
    transition:
        opacity 1s var(--motion-ease),
        transform 1s var(--motion-ease);
    will-change:opacity, transform;
}

.reveal-left{
    transform:translate3d(-95px,0,0);
}

.reveal-right{
    transform:translate3d(95px,0,0);
}

.reveal-left.active,
.reveal-right.active{
    opacity:1;
    transform:translate3d(0,0,0);
}

.no-js .reveal-left,
.no-js .reveal-right{
    opacity:1;
    transform:none;
}


.menu-toggle{
    display:none;
    position:relative;
    width:46px;
    height:38px;
    border:1px solid var(--glass-border);
    background:var(--control-bg-strong);
    cursor:pointer;
    overflow:hidden;
}

.menu-toggle::after{
    content:"";
    position:absolute;
    inset:-1px;
    transform:translateX(-120%);
    pointer-events:none;
}

.menu-toggle:hover::after{
    animation:buttonShine var(--shine-duration, var(--shine-speed)) ease forwards;
}

.menu-toggle span{
    position:absolute;
    left:50%;
    width:22px;
    height:2px;
    background:white;
    transform:translateX(-50%);
    transform-origin:center;
    transition:var(--motion-fast);
    z-index:2;
}

.menu-toggle span:nth-child(1){ top:11px; }
.menu-toggle span:nth-child(2){ top:18px; }
.menu-toggle span:nth-child(3){ top:25px; }

.menu-toggle.active span:nth-child(1){
    top:18px;
    transform:translateX(-50%) rotate(45deg);
}

.menu-toggle.active span:nth-child(2){
    opacity:0;
    transform:translateX(calc(-50% + 12px));
}

.menu-toggle.active span:nth-child(3){
    top:18px;
    transform:translateX(-50%) rotate(-45deg);
}

.mobile-menu{
    position:fixed;
    top:var(--header-height, 91px);
    left:0;
    right:0;
    max-height:calc(100vh - var(--header-height, 91px));
    z-index:90;
    display:none;
    flex-direction:column;
    padding-bottom:24px;
    border-bottom:1px solid var(--glass-border);
    overflow-y:auto;
    overscroll-behavior:contain;
    -webkit-overflow-scrolling:touch;
    transform:none;
    visibility:hidden;
    pointer-events:none;
    transition:none;
}

.mobile-menu.open{
    visibility:visible;
    pointer-events:auto;
}

@media(max-width:1100px){
    .mobile-menu{
        display:flex;
        transform:translateX(100%);
        transition:none;
    }

    .mobile-menu.open{
        transform:translateX(0);
    }

    .menu-ready .mobile-menu{
        transition:
            transform var(--menu-slide-speed) var(--motion-ease),
            visibility 0s linear var(--menu-slide-speed);
    }

    .menu-ready .mobile-menu.open{
        transition:
            transform var(--menu-slide-speed) var(--motion-ease),
            visibility 0s;
    }
}

.mobile-menu a{
    position:relative;
    padding:24px 40px;
    z-index:2;
    display:flex;
    align-items:center;
    min-height:58px;
    color:white;
    text-decoration:none;
    text-transform:uppercase;
    letter-spacing:var(--ui-letter-spacing);
    font-family:'Montserrat',sans-serif;
    font-size:var(--ui-font-size);
    line-height:1;
    font-weight:700;
    border-top:1px solid var(--glass-border);
    transition:var(--motion-fast);
}

.mobile-menu a::before{
    content:"";
    display:inline-block;
    width:8px;
    height:8px;
    margin-right:15px;
    background:rgb(var(--accent-rgb));
    box-shadow:none;
    transition:var(--motion-fast);
}

.mobile-menu a:hover::before{
    background:white;
    box-shadow:0 0 20px rgba(255,255,255,.9);
}




/* Unified clickable marker glow system */
.mobile-menu a::before{
    box-shadow:none;
}

.mobile-menu a:hover::before,
.mobile-menu a:focus-visible::before{
    background:white;
    box-shadow:0 0 20px rgba(255,255,255,.9);
}

.menu-toggle:hover span,
.menu-toggle:focus-visible span{
    box-shadow:0 0 12px rgba(255,255,255,.75);
}


/* Final typography + colour correction */

/* Cinematic compressed heading style across the site */
.hero h1,
.section-title h3,
.split-copy h3,
.hero-caption h2,
.final-cta h2,
.elements-hero h1,
.element-section-heading h2,
.card h4,
.wide-caption h4{
    font-family:var(--display-heading-font);
    font-weight:var(--display-heading-weight);
    text-transform:var(--display-heading-transform);
    letter-spacing:var(--display-heading-letter-spacing);
}

.section-title h3,
.split-copy h3,
.hero-caption h2,
.card h4,
.wide-caption h4{
    line-height:var(--display-heading-line-height);
}


/* Force all clickable hover/focus outlines to accent, never white */
.menu-toggle:hover,
.menu-toggle:focus-visible,
.mobile-menu a:hover,
.mobile-menu a:focus-visible{
    border-color:color-mix(in srgb, rgb(var(--accent-rgb)) 72%, rgba(255,255,255,.08)) !important;
    outline:1px solid color-mix(in srgb, rgb(var(--accent-rgb)) 52%, transparent) !important;
    outline-offset:0;
}

.menu-toggle:hover,
.menu-toggle:focus-visible{
    box-shadow:var(--control-shadow) !important;
}

@keyframes navReveal{
    from{opacity:0; transform:translateX(95px);}
    to{opacity:1; transform:translateX(0);}
}

/* 8 / Testimonials */
.testimonial-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:30px;
}

.testimonial-card{
    position:relative;
    padding:48px;
    min-height:310px;
    overflow:hidden;
}

.quote-mark{
    font-family:'Montserrat',sans-serif;
    font-size:110px;
    line-height:.7;
    color:rgb(var(--accent-rgb));
    opacity:1;
    text-shadow:var(--accent-text-glow);
    margin-bottom:20px;
}

.testimonial-card p{
    color:var(--copy-color);
    font-size:18px;
    line-height:1.85;
    margin-bottom:28px;
}

.testimonial-card strong{
    color:white;
    font-size:12px;
    text-transform:uppercase;
    letter-spacing:.25em;
}

/* 10 / Availability form */
.luxury-form{
    padding:46px;
}

.form-status{
    margin-bottom:22px;
    padding:18px 20px;
    color:white;
    background:rgba(255,255,255,.045);
    border:1px solid var(--glass-border);
    font-size:var(--copy-size);
    line-height:var(--copy-line-height);
}

.form-hp{
    position:absolute !important;
    left:-9999px !important;
    width:1px !important;
    height:1px !important;
    opacity:0 !important;
    pointer-events:none !important;
}

.form-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:20px;
    margin-bottom:20px;
}

.luxury-form input:not([type="checkbox"]):not([type="radio"]),
.luxury-form textarea,
.luxury-form select{
    width:100%;
    min-height:52px;
    padding:18px 20px;
    border:none !important;
    border-radius:0 !important;
    background:
        linear-gradient(180deg,rgba(255,255,255,.044),rgba(255,255,255,.024)),
        rgba(255,255,255,.028);
    color:white;
    font-family:'Plus Jakarta Sans',sans-serif;
    font-size:15px;
    font-weight:500;
    line-height:1.35;
    letter-spacing:0;
    outline:none !important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.045), inset 0 -1px 0 rgba(0,0,0,.18);
    clip-path:polygon(
        0 0,
        100% 0,
        100% 100%,
        var(--small-corner-cut) 100%,
        0 calc(100% - var(--small-corner-cut))
    );
    transition:var(--motion-fast);
}

.luxury-form input:not([type="checkbox"]):not([type="radio"]):focus,
.luxury-form textarea:focus,
.luxury-form select:focus{
    border:none !important;
    outline:none !important;
    background:
        linear-gradient(180deg,rgba(255,255,255,.065),rgba(255,255,255,.03)),
        rgba(255,255,255,.038);
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.06),
        inset 0 -2px 0 rgba(var(--accent-rgb),.72),
        0 0 34px color-mix(in srgb, rgb(var(--accent-rgb)) 16%, transparent);
}

.luxury-form textarea{
    min-height:160px;
    resize:vertical;
    margin-bottom:24px;
}

.luxury-form select{
    appearance:none;
    -webkit-appearance:none;
    cursor:pointer;
}

.luxury-form select option{
    color:#050609;
}

.luxury-form input::placeholder,
.luxury-form textarea::placeholder{
    color:rgba(255,255,255,.44);
}

/* 15 / Dramatic final CTA */
.final-cta{
    position:relative;
    padding:150px max(40px,calc((100vw - 1450px)/2));
    text-align:center;
    border-top:1px solid var(--section-divider);
    box-shadow:var(--section-divider-glow);
    overflow:hidden;
}

.final-cta::before{
    content:"";
    position:absolute;
    inset:0;
    background:radial-gradient(circle at center, color-mix(in srgb, rgb(var(--accent-rgb)) 14%, transparent), transparent 42%);
    pointer-events:none;
}

.final-cta-inner{
    position:relative;
    z-index:2;
}

.final-cta h2{
    max-width:1100px;
    margin:0 auto 28px;
    font-size:clamp(52px,8vw,132px);
    line-height:.80;
}

.final-cta p{
    color:var(--copy-color);
    font-size:20px;
    line-height:1.8;
    max-width:720px;
    margin:0 auto 34px;
}

.site-footer{
    padding:58px max(40px,calc((100vw - 1450px)/2)) 34px;
    border-top:1px solid var(--section-divider);
    box-shadow:var(--section-divider-glow);
}

.footer-inner{
    display:grid;
    grid-template-columns:minmax(260px, 1.05fr) minmax(420px, 1.45fr);
    align-items:flex-start;
    gap:70px;
    padding-bottom:42px;
}

.footer-brand p{
    margin-top:14px;
    color:var(--copy-color);
    font-size:var(--copy-size);
    line-height:var(--copy-line-height);
    max-width:520px;
}

.footer-links{
    display:grid;
    grid-template-columns:repeat(3,minmax(120px,1fr));
    gap:34px;
    justify-content:end;
}

.footer-link-group{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    gap:13px;
}

.footer-link-group h2{
    color:rgb(var(--accent-rgb));
    font-family:'Montserrat',sans-serif;
    font-size:12px;
    line-height:1;
    letter-spacing:.24em;
    font-weight:900;
    text-transform:uppercase;
    margin-bottom:8px;
    text-shadow:var(--accent-text-glow);
}

.footer-links a,
.footer-credit a{
    color:white;
    text-decoration:none;
    transition:var(--motion-fast);
}

.footer-links a{
    font-family:'Montserrat',sans-serif;
    font-size:var(--ui-font-size);
    line-height:1.2;
    letter-spacing:var(--ui-letter-spacing);
    font-weight:700;
    text-transform:uppercase;
}

.footer-links a:hover,
.footer-credit a:hover,
.footer-links a:focus-visible,
.footer-credit a:focus-visible{
    color:rgb(var(--accent-rgb));
    text-shadow:var(--accent-text-glow);
}

.footer-credit{
    padding-top:26px;
    border-top:none;
    box-shadow:none;
    color:var(--caption-color);
    font-size:12px;
    line-height:1.6;
    text-align:center;
}

.hero p:not(.kicker),
.card p,
.split-copy p,
.testimonial-card p,
.final-cta p,
.element-copy p,
.element-panel p,
.element-card p,
.gallery-item p,
.stat-card p{
    color:var(--copy-color);
    font-size:var(--copy-size);
    line-height:var(--copy-line-height);
}

.elements-hero{
    min-height:72vh;
    padding:calc(var(--header-height, 91px) + 100px) max(40px,calc((100vw - 1450px)/2)) 110px;
    display:grid;
    grid-template-columns:minmax(0,1fr) minmax(360px,.72fr);
    align-items:end;
    gap:70px;
    overflow:hidden;
}

.elements-hero p{
    max-width:760px;
    color:var(--copy-color);
    font-size:var(--copy-size);
    line-height:var(--copy-line-height);
}

.elements-hero-panel{
    padding:34px;
    overflow:hidden;
}

.elements-hero-panel img{
    width:100%;
    aspect-ratio:4 / 5;
    object-fit:cover;
    display:block;
    margin-bottom:24px;
}

.element-section{
    padding:125px max(40px,calc((100vw - 1450px)/2));
    border-top:1px solid var(--section-divider);
    box-shadow:var(--section-divider-glow);
}

.element-section.compact{
    padding-top:90px;
    padding-bottom:90px;
}

.element-section-heading{
    margin-bottom:54px;
}

.element-section-heading h2{
    max-width:900px;
    font-size:clamp(40px,5vw,72px);
    line-height:.88;
}

.element-split{
    display:grid;
    grid-template-columns:1fr 1.06fr;
    gap:64px;
    align-items:center;
}

.element-split.reverse{
    grid-template-columns:1.06fr 1fr;
}

.element-media{
    position:relative;
    min-height:520px;
    overflow:hidden;
}

.element-media img{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
}

.element-copy,
.element-panel{
    padding:46px;
}

.element-copy h3,
.element-panel h3,
.element-card h3,
.stat-card strong{
    font-family:'Montserrat',sans-serif;
    text-transform:uppercase;
    font-weight:900;
    letter-spacing:-.06em;
    line-height:.95;
}

.element-copy h3,
.element-panel h3{
    font-size:clamp(34px,4vw,56px);
    margin-bottom:24px;
}

.element-chip-row{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    margin-top:28px;
}

.element-chip{
    min-height:38px;
    display:inline-flex;
    align-items:center;
    padding:0 16px;
    font-family:'Montserrat',sans-serif;
    font-size:10px;
    letter-spacing:var(--ui-letter-spacing);
    text-transform:uppercase;
    color:white;
    background:var(--control-bg);
}

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

.element-card,
.stat-card{
    padding:34px;
    min-height:230px;
    overflow:hidden;
}

.element-card h3{
    font-size:30px;
    margin-bottom:18px;
}

.stat-card strong{
    display:block;
    color:rgb(var(--accent-rgb));
    font-size:54px;
    margin-bottom:14px;
    text-shadow:var(--accent-text-glow);
}

.gallery-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:18px;
}

.gallery-item{
    position:relative;
    min-height:340px;
    overflow:hidden;
}

.gallery-item.large{
    grid-column:span 2;
    min-height:460px;
}

.gallery-item img{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    filter:contrast(108%) brightness(.78);
    transition:transform .6s var(--motion-ease);
}

.gallery-item:hover img{
    transform:scale(1.055);
}

.gallery-item div{
    position:absolute;
    left:24px;
    right:24px;
    bottom:24px;
    z-index:2;
}

.gallery-item h3{
    font-family:'Montserrat',sans-serif;
    font-size:28px;
    line-height:.95;
    letter-spacing:-.06em;
    text-transform:uppercase;
    margin-bottom:10px;
}

.element-dropdown{
    display:grid;
    grid-template-columns:minmax(0,.8fr) minmax(0,1.2fr);
    gap:40px;
    align-items:start;
}

.element-dropdown details{
    margin-bottom:14px;
    padding:0 26px;
    overflow:hidden;
}

.element-dropdown summary{
    min-height:72px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
    cursor:pointer;
    color:white;
    font-family:'Montserrat',sans-serif;
    font-size:15px;
    letter-spacing:var(--ui-letter-spacing);
    text-transform:uppercase;
    list-style:none;
}

.element-dropdown summary::-webkit-details-marker{
    display:none;
}

.element-dropdown summary::after{
    content:"+";
    color:rgb(var(--accent-rgb));
    font-size:22px;
    line-height:1;
}

.element-dropdown details[open] summary::after{
    content:"-";
}

.element-dropdown details p{
    color:var(--copy-color);
    font-size:var(--copy-size);
    line-height:var(--copy-line-height);
    padding:0 0 26px;
}

.process-list{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:18px;
    counter-reset:process;
}

.process-step{
    position:relative;
    min-height:260px;
    padding:34px;
    counter-increment:process;
}

.process-step::before{
    content:counter(process, decimal-leading-zero);
    display:block;
    color:rgb(var(--accent-rgb));
    font-family:'Montserrat',sans-serif;
    font-size:42px;
    font-weight:900;
    margin-bottom:28px;
    text-shadow:var(--accent-text-glow);
}

.process-step h3{
    font-family:'Montserrat',sans-serif;
    font-size:25px;
    line-height:.98;
    letter-spacing:-.06em;
    text-transform:uppercase;
    margin-bottom:16px;
}

.process-step p{
    color:var(--copy-color);
    font-size:var(--copy-size);
    line-height:var(--copy-line-height);
}

.element-form-row{
    display:grid;
    grid-template-columns:1fr;
    gap:18px;
    margin-bottom:18px;
}

.element-panel select{
    width:100%;
    padding:18px 20px;
    border:none;
    background:rgba(255,255,255,.028);
    color:white;
    font-family:'Plus Jakarta Sans',sans-serif;
    font-size:15px;
    outline:none;
}

.element-panel select option{
    color:black;
}



@media(max-width:1100px){
    .hero{
        grid-template-columns:1fr;
        padding-top:calc(var(--header-height, 91px) + 58px);
        padding-right:40px;
    }

    .split{
        grid-template-columns:1fr;
        padding-right:40px;
    }

    .hero-copy{
        padding-right:0;
        padding-bottom:60px;
    }

    .buttons{
        margin-bottom:10px;
    }

    .hero-image-wrap,
    .wide-image{
        margin-right:-40px;
        height:70vh;
    }

    .service-page-hero{
        min-height:auto;
    }

    .service-page-hero .hero-copy{
        max-width:880px;
    }

    .service-page-hero .hero-image-wrap{
        margin-left:0;
        margin-right:-40px;
        min-height:420px;
        height:56vh;
    }

    .service-page-hero .hero-video,
    .service-page-hero .hero-image,
    .service-page-hero .image-overlay{
        -webkit-mask-image:none;
        mask-image:none;
    }

    .service-page-hero .hero-caption{
        right:40px;
        left:auto;
    }

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

    .nav-links{
        display:none;
    }

    .no-js .nav-links{
        display:flex;
        flex-wrap:wrap;
        justify-content:flex-end;
        gap:8px;
    }

    .menu-toggle{
        display:block;
    }

    .no-js .menu-toggle{
        display:none;
    }

    .hero-caption h2{
        font-size:44px;
    }

    .section-title h3,
    .split-copy h3{
        font-size:42px;
    }
}

@media(max-width:520px){
    .hero{
        padding-top:calc(var(--header-height, 110px) + 70px);
        padding-right:24px;
        padding-left:24px;
    }

    .split{
        padding-right:24px;
        padding-left:24px;
    }

    .hero-image-wrap,
    .wide-image{
        margin-right:-24px;
    }

    .service-page-hero .hero-image-wrap{
        margin-right:-24px;
        min-height:340px;
    }

    .service-page-hero .hero-caption{
        right:24px;
        left:auto;
        bottom:34px;
    }
}


@media(max-width:1100px){
    .glow.one{
        width:340px;
        height:340px;
        top:-180px;
        left:-220px;
        opacity:.18;
        filter:blur(160px);
    }

    .glow.two{
        width:340px;
        height:340px;
        bottom:-220px;
        right:-240px;
        opacity:.14;
        filter:blur(170px);
    }
}

@media(max-width:520px){
    .glow.one{
        width:280px;
        height:280px;
        top:-170px;
        left:-210px;
        opacity:.14;
        filter:blur(175px);
    }

    .glow.two{
        width:280px;
        height:280px;
        bottom:-210px;
        right:-230px;
        opacity:.11;
        filter:blur(180px);
    }
}


/* Bottom-left cut corner treatment - gradients untouched, outlines removed */
.nav-links a,
.tag,
.card,
.split-copy,
.wide-caption,
.testimonial-card,
.luxury-form,
.elements-hero-panel,
.element-copy,
.element-panel,
.element-card,
.stat-card,
.gallery-item,
.element-dropdown details,
.process-step,
.menu-toggle,
.gloss-panel,
.mobile-menu,
.mobile-menu a{
    clip-path:polygon(
        0 0,
        100% 0,
        100% 100%,
        var(--corner-cut) 100%,
        0 calc(100% - var(--corner-cut))
    );
    border:none !important;
    outline:none !important;
}

.nav-links a,
.tag,
.menu-toggle,
.mobile-menu a{
    clip-path:polygon(
        0 0,
        100% 0,
        100% 100%,
        var(--small-corner-cut) 100%,
        0 calc(100% - var(--small-corner-cut))
    );
}


.hero-main-gloss{
    clip-path:polygon(
        0 0,
        100% 0,
        100% 100%,
        var(--corner-cut) 100%,
        0 calc(100% - var(--corner-cut))
    );
    border:none !important;
    outline:none !important;
}

.luxury-form input:not([type="checkbox"]):not([type="radio"]),
.luxury-form textarea,
.luxury-form select,
.element-panel select,
.element-chip{
    clip-path:polygon(
        0 0,
        100% 0,
        100% 100%,
        var(--small-corner-cut) 100%,
        0 calc(100% - var(--small-corner-cut))
    );
    border:none !important;
    outline:none !important;
}

.nav-links a:hover,
.nav-links a:focus-visible,
.menu-toggle:hover,
.menu-toggle:focus-visible,
.mobile-menu a:hover,
.mobile-menu a:focus-visible,
.luxury-form input:not([type="checkbox"]):not([type="radio"]):focus,
.luxury-form textarea:focus,
.luxury-form select:focus{
    border:none !important;
    outline:none !important;
}


/* Final fix: cut every small square accent marker as well */
.icon,
.dot,
.nav-links a::before,
.mobile-menu a::before{
    clip-path:polygon(
        0 0,
        100% 0,
        100% 100%,
        30% 100%,
        0 70%
    ) !important;
    border:none !important;
    outline:none !important;
}

.icon{
    clip-path:polygon(
        0 0,
        100% 0,
        100% 100%,
        18px 100%,
        0 calc(100% - 18px)
    ) !important;
}







/* =========================================================
   BUTTON + NAV TYPOGRAPHY CONSISTENCY PASS
   ========================================================= */

@media(max-width:680px){
    .hero p:not(.kicker),
    .card p,
    .split-copy p,
    .testimonial-card p,
    .final-cta p,
    .element-copy p,
    .element-panel p,
    .element-card p,
    .gallery-item p,
    .stat-card p,
    .process-step p,
    .element-dropdown details p{
        font-size:var(--copy-size-mobile);
        line-height:var(--copy-line-height-mobile);
    }

    .testimonial-grid,
    .form-grid{
        grid-template-columns:1fr;
    }

    .testimonial-card,
    .luxury-form{
        padding:32px 24px;
    }

    .site-footer{
        padding:46px 24px 30px;
    }

    .footer-inner{
        grid-template-columns:1fr;
        gap:34px;
    }

    .footer-links{
        grid-template-columns:1fr;
        margin-top:30px;
        gap:28px;
    }

    .elements-hero,
    .element-split,
    .element-split.reverse,
    .element-dropdown{
        grid-template-columns:1fr;
    }

    .elements-hero{
        padding:calc(var(--header-height, 110px) + 70px) 24px 74px;
        gap:40px;
    }

    .elements-hero-panel,
    .element-copy,
    .element-panel,
    .element-card,
    .stat-card,
    .process-step{
        padding:30px 24px;
    }

    .element-section{
        padding:82px 24px;
    }

    .element-media{
        min-height:360px;
    }

    .element-card-grid,
    .stat-grid,
    .pricing-grid,
    .process-list,
    .element-form-row{
        grid-template-columns:1fr;
    }

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

    .gallery-item,
    .gallery-item.large{
        grid-column:auto;
        min-height:360px;
    }

}

/* Final shared button standard, matched to the navigation buttons */
.btn,
.button,
.nav-links a,
.portal-icon-button,
button:not(.menu-toggle),
input[type="submit"],
input[type="button"],
input[type="reset"]{
    appearance:none !important;
    -webkit-appearance:none !important;
    position:relative !important;
    isolation:isolate !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    min-height:var(--ui-height) !important;
    width:auto;
    padding:0 var(--ui-padding-x) 0 var(--ui-left-pad) !important;
    color:white !important;
    font-family:'Montserrat',sans-serif !important;
    font-size:var(--ui-font-size) !important;
    line-height:1 !important;
    letter-spacing:var(--ui-letter-spacing) !important;
    font-weight:700 !important;
    text-transform:uppercase !important;
    text-decoration:none !important;
    background:var(--control-bg) !important;
    border:none !important;
    outline:none !important;
    clip-path:polygon(
        0 0,
        100% 0,
        100% 100%,
        var(--small-corner-cut) 100%,
        0 calc(100% - var(--small-corner-cut))
    ) !important;
    backdrop-filter:var(--glass-blur) !important;
    -webkit-backdrop-filter:var(--glass-blur) !important;
    box-shadow:var(--control-shadow) !important;
    filter:none !important;
    -webkit-filter:none !important;
    transition:var(--motion-fast) !important;
    overflow:hidden !important;
    cursor:pointer !important;
}

.btn::before,
.button::before,
.nav-links a::before,
.portal-icon-button::before,
button:not(.menu-toggle)::before,
input[type="submit"]::before,
input[type="button"]::before,
input[type="reset"]::before{
    content:"" !important;
    position:absolute !important;
    left:18px !important;
    top:50% !important;
    z-index:2 !important;
    display:block !important;
    width:var(--ui-dot-size) !important;
    height:var(--ui-dot-size) !important;
    transform:translateY(-50%) !important;
    background:rgb(var(--accent-rgb)) !important;
    clip-path:polygon(
        0 0,
        100% 0,
        100% 100%,
        30% 100%,
        0 70%
    ) !important;
    border:none !important;
    outline:none !important;
    box-shadow:none !important;
    opacity:1 !important;
}

.btn::after,
.button::after,
.nav-links a::after,
.portal-icon-button::after,
button:not(.menu-toggle)::after,
input[type="submit"]::after,
input[type="button"]::after,
input[type="reset"]::after{
    content:"" !important;
    position:absolute !important;
    left:-75% !important;
    right:auto !important;
    top:-1px !important;
    bottom:-1px !important;
    z-index:1 !important;
    width:250% !important;
    background:var(--control-shine) !important;
    transform:translateX(-70%);
    pointer-events:none !important;
    opacity:1 !important;
    animation:none !important;
    will-change:transform;
}

.btn:hover,
.btn:focus-visible,
.button:hover,
.button:focus-visible,
.nav-links a:hover,
.nav-links a:focus-visible,
.portal-icon-button:hover,
.portal-icon-button:focus-visible,
button:not(.menu-toggle):hover,
button:not(.menu-toggle):focus-visible,
input[type="submit"]:hover,
input[type="submit"]:focus-visible,
input[type="button"]:hover,
input[type="button"]:focus-visible,
input[type="reset"]:hover,
input[type="reset"]:focus-visible{
    transform:translateY(-2px);
    border:none !important;
    outline:none !important;
    outline-offset:0 !important;
    box-shadow:var(--control-hover-shadow) !important;
    filter:none !important;
    -webkit-filter:none !important;
    text-shadow:none !important;
}

.btn:hover::after,
.btn:focus-visible::after,
.button:hover::after,
.button:focus-visible::after,
.nav-links a:hover::after,
.nav-links a:focus-visible::after,
.portal-icon-button:hover::after,
.portal-icon-button:focus-visible::after,
button:not(.menu-toggle):hover::after,
button:not(.menu-toggle):focus-visible::after,
input[type="submit"]:hover::after,
input[type="submit"]:focus-visible::after,
input[type="button"]:hover::after,
input[type="button"]:focus-visible::after,
input[type="reset"]:hover::after,
input[type="reset"]:focus-visible::after{
    animation:buttonShine var(--shine-duration, var(--shine-speed)) ease forwards !important;
}

.btn:hover::before,
.btn:focus-visible::before,
.button:hover::before,
.button:focus-visible::before,
.nav-links a:hover::before,
.nav-links a:focus-visible::before,
.portal-icon-button:hover::before,
.portal-icon-button:focus-visible::before,
button:not(.menu-toggle):hover::before,
button:not(.menu-toggle):focus-visible::before,
input[type="submit"]:hover::before,
input[type="submit"]:focus-visible::before,
input[type="button"]:hover::before,
input[type="button"]:focus-visible::before,
input[type="reset"]:hover::before,
input[type="reset"]:focus-visible::before{
    background:white !important;
    box-shadow:0 0 20px rgba(255,255,255,.9) !important;
}

.shine-auto-active::after{
    animation:buttonShine var(--shine-duration, var(--shine-speed)) ease forwards !important;
}

.nav-links .dropdown-menu a{
    display:flex !important;
    justify-content:flex-start !important;
    width:100% !important;
    min-height:44px !important;
    padding:0 16px 0 36px !important;
    background:transparent !important;
    clip-path:none !important;
    box-shadow:none !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
    color:white !important;
}

.nav-links .dropdown-menu a::before{
    left:14px !important;
    width:6px !important;
    height:6px !important;
}

.nav-links .dropdown-menu a::after{
    display:none !important;
}

.nav-links .dropdown-menu a:hover,
.nav-links .dropdown-menu a:focus-visible{
    transform:none !important;
    background:rgba(255,255,255,.06) !important;
    color:white !important;
    box-shadow:none !important;
}

.nav-links .dropdown-menu a:hover::before,
.nav-links .dropdown-menu a:focus-visible::before{
    background:white !important;
    box-shadow:0 0 20px rgba(255,255,255,.82) !important;
}

/* Match the compact mobile menu button to the shared button behaviour. */
.menu-toggle{
    background:var(--control-bg) !important;
    border:none !important;
    outline:none !important;
    box-shadow:var(--control-shadow) !important;
    flex:0 0 46px !important;
    transition:var(--motion-fast) !important;
}

.menu-toggle::after{
    content:"" !important;
    position:absolute !important;
    left:-75% !important;
    right:auto !important;
    top:-1px !important;
    bottom:-1px !important;
    z-index:1 !important;
    width:250% !important;
    background:var(--control-shine) !important;
    transform:translateX(-70%);
    pointer-events:none !important;
    opacity:1 !important;
    animation:none !important;
    will-change:transform;
}

.menu-toggle:hover,
.menu-toggle:focus-visible{
    transform:translateY(-2px);
    border:none !important;
    outline:none !important;
    outline-offset:0 !important;
    box-shadow:var(--control-hover-shadow) !important;
}

.menu-toggle:hover::after,
.menu-toggle:focus-visible::after{
    animation:buttonShine var(--shine-duration, var(--shine-speed)) ease forwards !important;
}

@media(max-width:680px){
    .btn{
        width:100%;
    }

    .nav{
        padding-right:24px;
        padding-left:24px;
    }
}

/* =========================================================
   BOOTSTRAP HYBRID FOUNDATION PASS
   Bootstrap supplies structure hooks; this layer keeps the
   bespoke Event DJs visual system in full control.
   ========================================================= */

:root{
    --container-max:1450px;
    --container-pad:clamp(24px,4vw,40px);
    --container-x:max(var(--container-pad), calc((100vw - var(--container-max)) / 2));
    --section-space:clamp(82px,9vw,140px);
    --section-space-compact:clamp(68px,7vw,96px);
    --heading-gap:clamp(36px,5vw,72px);
    --grid-gap:clamp(18px,2.2vw,30px);
    --grid-gap-small:clamp(14px,1.6vw,22px);
    --panel-pad:clamp(24px,3.2vw,50px);
    --panel-pad-small:clamp(22px,2.4vw,34px);
    --button-gap:clamp(12px,1.6vw,20px);
    --copy-size:clamp(16px,.35vw + 15px,17px);
    --copy-size-mobile:clamp(15px,1.2vw + 12px,16px);
    --ui-height:clamp(46px,2.6vw,48px);
    --ui-font-size:clamp(10px,.28vw + 9.5px,11px);
    --ui-padding-x:clamp(18px,1.7vw,24px);
    --ui-left-pad:clamp(36px,2.8vw,42px);
}

html,
body{
    min-width:0;
}

body{
    font-size:var(--copy-size);
    line-height:var(--copy-line-height);
}

body.menu-open{
    overflow:hidden;
    overscroll-behavior:none;
    touch-action:none;
}

body.menu-open .mobile-menu{
    touch-action:pan-y;
}

main,
section,
header,
footer,
div,
article,
form,
nav{
    min-width:0;
}

img,
video,
iframe,
svg{
    max-width:100%;
}

p,
li,
a,
button,
input,
textarea,
select,
h1,
h2,
h3,
h4{
    overflow-wrap:break-word;
}

.hero.row,
.split.row,
.elements-hero.row,
.element-split.row,
.cards.row,
.testimonial-grid.row,
.form-grid.row,
.element-card-grid.row,
.stat-grid.row,
.pricing-grid.row,
.gallery-grid.row,
.process-list.row,
.element-form-row.row,
.element-dropdown.row,
.footer-links.row{
    --bs-gutter-x:0;
    --bs-gutter-y:0;
    margin-left:0;
    margin-right:0;
}

.hero.row > *,
.split.row > *,
.elements-hero.row > *,
.element-split.row > *,
.cards.row > *,
.testimonial-grid.row > *,
.form-grid.row > *,
.element-card-grid.row > *,
.stat-grid.row > *,
.pricing-grid.row > *,
.gallery-grid.row > *,
.process-list.row > *,
.element-form-row.row > *,
.element-dropdown.row > *,
.footer-links.row > *{
    flex:initial;
    width:auto !important;
    max-width:100%;
    padding-left:0;
    padding-right:0;
    margin-top:0;
}

.nav{
    max-width:calc(var(--container-max) + (var(--container-pad) * 2));
    padding:clamp(22px,2.6vw,28px) var(--container-pad);
}

.site-brand{
    display:flex;
    flex-direction:column;
    justify-content:center;
    min-width:0;
    width:max-content;
    max-width:min(100%, 620px);
    transform:translateY(3px);
}

.logo{
    font-size:clamp(25px,1.2vw + 19px,32px);
    max-width:100%;
}

.logo-sub,
.kicker,
.wide-caption p{
    font-size:clamp(10px,.35vw + 9px,12px);
    line-height:1.35;
    letter-spacing:clamp(.18em,.7vw,.35em);
}

.section,
.element-section,
.split,
.final-cta,
.site-footer{
    padding-left:var(--container-x);
    padding-right:var(--container-x);
}

.section,
.split{
    padding-top:var(--section-space);
    padding-bottom:var(--section-space);
}

.element-section{
    padding-top:var(--section-space);
    padding-bottom:var(--section-space);
}

.element-section.compact{
    padding-top:var(--section-space-compact);
    padding-bottom:var(--section-space-compact);
}

.final-cta{
    padding-top:clamp(96px,10vw,150px);
    padding-bottom:clamp(96px,10vw,150px);
}

.section-title,
.element-section-heading{
    margin-bottom:var(--heading-gap);
}

.hero{
    padding-left:var(--container-x);
    padding-right:var(--container-x);
    padding-top:calc(var(--header-height, 91px) + clamp(36px,4vw,62px));
    padding-bottom:clamp(68px,8vw,90px);
    gap:0;
}

.hero-copy{
    padding-right:clamp(0px,4vw,60px);
}

.elements-hero{
    padding-left:var(--container-x);
    padding-right:var(--container-x);
    padding-top:calc(var(--header-height, 91px) + clamp(60px,7vw,100px));
    padding-bottom:clamp(74px,8vw,110px);
    gap:clamp(36px,5vw,70px);
}

.cards,
.testimonial-grid,
.form-grid,
.element-card-grid,
.stat-grid,
.pricing-grid,
.gallery-grid,
.process-list,
.element-form-row{
    gap:var(--grid-gap);
}

.element-chip-row,
.buttons{
    gap:var(--button-gap);
}

.element-split,
.element-dropdown{
    gap:clamp(34px,5vw,70px);
}

.card,
.split-copy,
.testimonial-card,
.luxury-form,
.elements-hero-panel,
.element-copy,
.element-panel,
.element-card,
.stat-card,
.process-step{
    padding:var(--panel-pad);
}

.wide-caption{
    padding:var(--panel-pad-small);
}

.hero h1{
    max-width:calc(100% - clamp(10px,1.4vw,18px));
    font-size:clamp(52px,8vw,var(--hero-title-max-size));
    line-height:.82;
    margin-bottom:clamp(18px,2.2vw,26px);
}

.service-page-hero .hero-copy h1{
    max-width:calc(100% - clamp(10px,1.4vw,18px));
}

.elements-hero h1{
    max-width:calc(100% - clamp(10px,1.4vw,18px));
    font-size:clamp(48px,7vw,128px);
    line-height:.84;
    margin-bottom:32px;
}

.section-title h3,
.split-copy h3,
.element-section-heading h2,
.element-copy h3,
.element-panel h3{
    font-size:clamp(36px,4.8vw,72px);
    line-height:.9;
}

.hero-caption h2{
    font-size:clamp(38px,4.4vw,64px);
}

.card h4,
.element-card h3,
.process-step h3,
.gallery-item h3{
    font-size:clamp(24px,2.1vw,30px);
    line-height:1;
}

.final-cta h2{
    font-size:clamp(48px,8vw,132px);
    line-height:.82;
}

.hero p:not(.kicker),
.elements-hero p,
.final-cta p{
    font-size:clamp(17px,.55vw + 15px,21px);
    line-height:1.78;
}

.btn,
.nav-links a{
    max-width:100%;
}

.btn{
    min-width:min(100%, 190px);
    white-space:normal;
    text-align:center;
}

.nav-links a{
    white-space:nowrap;
}

.dropdown-menu{
    display:block;
    margin:0;
    border:0;
    border-radius:0;
}

.mobile-menu{
    top:var(--header-height, 91px);
    height:calc(100vh - var(--header-height, 91px));
    height:calc(100dvh - var(--header-height, 91px));
    max-height:calc(100vh - var(--header-height, 91px));
    max-height:calc(100dvh - var(--header-height, 91px));
    padding-bottom:max(var(--container-pad), env(safe-area-inset-bottom));
    overflow-y:auto;
    overscroll-behavior:contain;
    -webkit-overflow-scrolling:touch;
}

.mobile-menu.open{
    transform:translateX(0) !important;
}

@media(max-width:1199.98px){
    .mobile-menu{
        display:flex;
        transform:translateX(100%);
        transition:none;
    }

    .mobile-menu.open{
        transform:translateX(0);
    }

    .menu-ready .mobile-menu{
        transition:
            transform var(--menu-slide-speed) var(--motion-ease),
            visibility 0s linear var(--menu-slide-speed);
    }

    .menu-ready .mobile-menu.open{
        transition:
            transform var(--menu-slide-speed) var(--motion-ease),
            visibility 0s;
    }

    .menu-toggle{
        display:block;
    }

    .elements-hero,
    .split,
    .element-split,
    .element-split.reverse,
    .element-dropdown{
        grid-template-columns:1fr;
    }

    .wide-image{
        margin-right:calc(var(--container-pad) * -1);
        margin-left:0;
        min-height:clamp(340px,56vh,560px);
        height:clamp(340px,62vh,680px);
    }
}

@media(max-width:900px){
    .footer-inner{
        grid-template-columns:1fr;
        gap:34px;
    }

    .footer-links{
        width:100%;
        grid-template-columns:repeat(3,minmax(0,1fr));
        justify-content:start;
    }
}

@media(max-width:680px){
    :root{
        --container-pad:24px;
        --section-space:82px;
        --section-space-compact:68px;
        --heading-gap:38px;
        --panel-pad:24px;
        --ui-letter-spacing:.12em;
        --ui-left-pad:34px;
        --ui-padding-x:16px;
    }

    .hero h1{
        font-size:clamp(46px,13vw,76px);
        line-height:.84;
    }

    .section-title h3,
    .split-copy h3,
    .element-section-heading h2,
    .element-copy h3,
    .element-panel h3{
        font-size:clamp(34px,11vw,48px);
    }

    .hero-caption{
        right:var(--container-pad);
        left:var(--container-pad);
        max-width:none;
    }

    .hero p:not(.kicker),
    .elements-hero p,
    .final-cta p,
    .card p,
    .split-copy p,
    .testimonial-card p,
    .element-copy p,
    .element-panel p,
    .element-card p,
    .gallery-item p,
    .stat-card p,
    .process-step p,
    .element-dropdown details p{
        font-size:var(--copy-size-mobile);
        line-height:var(--copy-line-height-mobile);
    }

    .mobile-menu a{
        padding-left:var(--container-pad);
        padding-right:var(--container-pad);
    }

    .logo-sub{
        white-space:nowrap;
        max-width:100%;
    }

    .btn{
        min-width:0;
        padding-right:var(--ui-left-pad) !important;
    }

    .reveal-left{
        transform:translate3d(clamp(-28px, -8vw, -16px),0,0);
    }

    .reveal-right{
        transform:translate3d(clamp(16px, 8vw, 28px),0,0);
    }
}

@media(min-width:681px){
    .reveal-left{
        transform:translate3d(clamp(-32px, -4vw, -18px),0,0);
    }

    .reveal-right{
        transform:translate3d(clamp(18px, 4vw, 32px),0,0);
    }
}

.js .reveal-left:not(.active){
    transform:translate3d(clamp(-95px, -8vw, -18px),0,0) !important;
}

.js .reveal-right:not(.active){
    transform:translate3d(clamp(18px, 8vw, 95px),0,0) !important;
}

.js .reveal-left.active,
.js .reveal-right.active{
    transform:translate3d(0,0,0) !important;
}

/* Media caption boxes: keep every image/video label readable without losing the cinematic blend. */
.hero-caption,
.wide-caption,
.gallery-item > div{
    background:
        linear-gradient(180deg,rgba(255,255,255,.065),rgba(255,255,255,.018)),
        color-mix(in srgb, var(--glass-bg) 88%, rgba(0,0,0,.82));
    border:1px solid color-mix(in srgb, rgb(var(--accent-rgb)) 28%, rgba(255,255,255,.14));
    box-shadow:
        0 18px 48px rgba(0,0,0,.46),
        inset 0 1px 0 rgba(255,255,255,.08);
    backdrop-filter:var(--glass-blur);
    -webkit-backdrop-filter:var(--glass-blur);
    clip-path:polygon(
        0 0,
        100% 0,
        100% 100%,
        var(--small-corner-cut) 100%,
        0 calc(100% - var(--small-corner-cut))
    );
}

.hero-caption,
.wide-caption{
    padding:var(--panel-pad-small) !important;
}

.gallery-item > div{
    padding:clamp(18px,2vw,26px);
}

.hero-caption{
    max-width:min(520px,calc(100% - (var(--container-pad) * 2)));
}

.wide-caption{
    max-width:min(460px,calc(100% - clamp(32px,6vw,90px))) !important;
}

.hero-caption .kicker,
.wide-caption p{
    margin-bottom:clamp(10px,1vw,14px);
}

.gallery-item p{
    margin-bottom:0;
}

@media(max-width:360px){
    :root{
        --container-pad:20px;
        --ui-font-size:9.5px;
        --ui-letter-spacing:.09em;
    }

    .hero h1{
        font-size:clamp(40px,13vw,52px);
        max-width:100%;
    }

    .service-page-hero .hero-copy h1,
    .service-page-hero h1{
        font-size:clamp(31px,10.2vw,42px);
        max-width:100%;
    }

    .logo{
        font-size:23px;
    }
}

/* =========================================================
   BESPOKE DESIGN RESTORE PASS
   Keeps Bootstrap structural only; final visual authority
   belongs to the original Event DJs component system.
   ========================================================= */

h1,
h2,
h3,
h4,
.logo,
.section-title h3,
.split-copy h3,
.element-section-heading h2,
.element-copy h3,
.element-panel h3,
.element-card h3,
.process-step h3,
.card h4,
.wide-caption h4,
.gallery-item h3{
    overflow-wrap:normal !important;
    word-break:normal !important;
    hyphens:manual !important;
}

.element-panel,
.element-copy,
.split-copy,
.card,
.element-card,
.stat-card,
.process-step,
.testimonial-card,
.luxury-form,
.elements-hero-panel{
    padding:var(--panel-pad) !important;
}

.wide-caption{
    padding:var(--panel-pad-small) !important;
}

.element-card h3,
.process-step h3,
.card h4,
.gallery-item h3{
    color:white !important;
    font-family:var(--display-heading-font) !important;
    font-weight:var(--display-heading-weight) !important;
    text-transform:var(--display-heading-transform) !important;
    letter-spacing:var(--display-heading-letter-spacing) !important;
}

.process-step h3{
    line-height:.98 !important;
}

.btn,
.nav-links a,
.menu-toggle,
.mobile-menu a,
.nav-links .dropdown-menu a{
    border-radius:0 !important;
    --bs-btn-border-radius:0;
}

.nav-links .dropdown-menu a{
    clip-path:polygon(
        0 0,
        100% 0,
        100% 100%,
        var(--small-corner-cut) 100%,
        0 calc(100% - var(--small-corner-cut))
    ) !important;
}

.nav-links .dropdown-menu a:hover,
.nav-links .dropdown-menu a:focus-visible{
    clip-path:polygon(
        0 0,
        100% 0,
        100% 100%,
        var(--small-corner-cut) 100%,
        0 calc(100% - var(--small-corner-cut))
    ) !important;
}

@media(min-width:1200px){
    .hero,
    .service-page-hero{
        padding-right:0 !important;
    }

    .hero-image-wrap,
    .service-page-hero .hero-image-wrap{
        margin-right:0 !important;
    }

    .split{
        padding-right:0 !important;
    }

    .split .wide-image{
        margin-right:0 !important;
    }
}

@media(max-width:680px){
    .nav{
        flex-wrap:nowrap;
        justify-content:space-between;
        align-items:center;
        gap:12px;
    }

    .site-brand,
    .nav > div:first-child{
        flex:0 1 calc(100% - 62px) !important;
        width:auto !important;
        max-width:calc(100% - 62px) !important;
        min-width:0 !important;
    }

    .menu-toggle{
        display:block !important;
        flex:0 0 46px !important;
        width:46px !important;
        min-width:46px !important;
        margin-left:auto !important;
        position:absolute !important;
        top:50% !important;
        right:var(--container-pad) !important;
        transform:translateY(-50%) !important;
    }
}

@media(min-width:1200px) and (max-width:1280px),
       (max-width:600px){
    .logo-sub{
        white-space:normal;
    }
}

/* Edge media: hard edge to centre, with fades capped at 25% of media width. */
@media(min-width:1200px){
    .hero-image-wrap,
    .service-page-hero .hero-image-wrap,
    .split .wide-image{
        width:50vw !important;
        max-width:50vw !important;
        justify-self:end;
        margin-right:0 !important;
    }

    .hero-main-gloss,
    .wide-image img{
        -webkit-mask-image:linear-gradient(
            to right,
            transparent 0%,
            black 33.333%
        ) !important;
        mask-image:linear-gradient(
            to right,
            transparent 0%,
            black 33.333%
        ) !important;
    }

    .hero-video{
        opacity:1 !important;
        filter:contrast(112%) brightness(.95);
    }

    .hero-image,
    .wide-image img{
        opacity:1 !important;
    }
}

/* Merged page element rules. */

/* Page Elements uses the homepage components as the visual reference.
   These rules are now global so element changes apply site-wide. */

.elements-hero-panel,
.element-copy,
.element-panel,
.element-card,
.stat-card,
.gallery-item,
.element-dropdown details,
.process-step{
    clip-path:polygon(
        0 0,
        100% 0,
        100% 100%,
        var(--corner-cut) 100%,
        0 calc(100% - var(--corner-cut))
    ) !important;
    overflow:hidden;
    border:none !important;
    outline:none !important;
}

.element-chip,
.element-panel select{
    clip-path:polygon(
        0 0,
        100% 0,
        100% 100%,
        var(--small-corner-cut) 100%,
        0 calc(100% - var(--small-corner-cut))
    ) !important;
}

.elements-hero-panel,
.element-card,
.stat-card,
.gallery-item,
.process-step,
.element-dropdown details{
    position:relative;
}

.elements-hero-panel::after,
.gallery-item::after,
.process-step::after,
.element-dropdown details::after{
    content:"";
    position:absolute;
    left:-75% !important;
    right:auto !important;
    top:-1px !important;
    bottom:-1px !important;
    width:250% !important;
    background:var(--shine-accent);
    transform:translateX(-70%);
    pointer-events:none;
}

.elements-hero-panel:hover::after,
.gallery-item:hover::after,
.process-step:hover::after,
.element-dropdown details:hover::after{
    animation:panelShine var(--shine-duration, var(--shine-speed)) ease forwards;
}

.elements-hero-panel img{
    clip-path:polygon(
        0 0,
        100% 0,
        100% 100%,
        var(--corner-cut) 100%,
        0 calc(100% - var(--corner-cut))
    );
}

.image-split-section{
    padding-left:0;
    padding-right:0;
    overflow:hidden;
}

.image-split-section .element-section-heading{
    padding-left:max(40px,calc((100vw - 1450px)/2));
    padding-right:max(40px,calc((100vw - 1450px)/2));
}

.image-split-section .element-split{
    gap:70px;
}

.image-left-section .element-split{
    grid-template-columns:1.18fr 1fr;
    padding-right:max(40px,calc((100vw - 1450px)/2));
}

.image-right-section .element-split{
    grid-template-columns:1fr 1.18fr;
    padding-left:max(40px,calc((100vw - 1450px)/2));
}

.image-split-section .element-media{
    min-height:590px;
}

.image-left-section .element-media{
    margin-left:-11vw;
    margin-right:0;
}

.image-right-section .element-media{
    margin-right:-11vw;
}

.image-split-section .element-media img{
    filter:contrast(108%) brightness(.86);
}

.image-split-section .wide-image img{
    -webkit-mask-image:linear-gradient(
        to right,
        transparent 0%,
        rgba(0,0,0,.18) 8%,
        rgba(0,0,0,.48) 18%,
        rgba(0,0,0,.78) 30%,
        black 44%
    );
    mask-image:linear-gradient(
        to right,
        transparent 0%,
        rgba(0,0,0,.18) 8%,
        rgba(0,0,0,.48) 18%,
        rgba(0,0,0,.78) 30%,
        black 44%
    );
}

.image-split-section .mirror-image img{
    -webkit-mask-image:linear-gradient(
        to left,
        transparent 0%,
        rgba(0,0,0,.18) 8%,
        rgba(0,0,0,.48) 18%,
        rgba(0,0,0,.78) 30%,
        black 44%
    );
    mask-image:linear-gradient(
        to left,
        transparent 0%,
        rgba(0,0,0,.18) 8%,
        rgba(0,0,0,.48) 18%,
        rgba(0,0,0,.78) 30%,
        black 44%
    );
}

.element-card,
.stat-card,
.process-step{
    transition:var(--motion-fast);
}

.element-card:hover,
.stat-card:hover,
.process-step:hover{
    transform:translateX(0) scale(1.015);
    border-color:color-mix(in srgb, rgb(var(--accent-rgb)) 26%, transparent);
}

.gallery-item{
    clip-path:polygon(
        0 0,
        100% 0,
        100% 100%,
        var(--corner-cut) 100%,
        0 calc(100% - var(--corner-cut))
    ) !important;
}

.gallery-item img{
    clip-path:inherit;
}

.gallery-item::before{
    content:"";
    position:absolute;
    inset:0;
    z-index:1;
    pointer-events:none;
    background:
        linear-gradient(to top,rgba(0,0,0,.68),transparent 56%),
        linear-gradient(to right,rgba(0,0,0,.24),transparent 42%);
}

.gallery-item div{
    z-index:3;
}

.element-dropdown details{
    transition:var(--motion-fast);
}

.element-dropdown details:hover,
.element-dropdown details[open]{
    transform:translateX(0) scale(1.01);
}

.element-panel select{
    min-height:56px;
}

.page-elements-page .buttons{
    display:flex;
    flex-wrap:wrap;
    gap:20px;
    margin-top:30px;
}

@media(max-width:1100px){
    .image-left-section .element-split,
    .image-right-section .element-split{
        grid-template-columns:1fr;
        padding-left:40px;
        padding-right:40px;
    }

    .image-left-section .element-media,
    .image-right-section .element-media{
        margin-left:-40px;
        margin-right:-40px;
        min-height:70vh;
    }
}

@media(max-width:680px){
    .image-split-section .element-section-heading{
        padding-left:24px;
        padding-right:24px;
    }

    .image-left-section .element-split,
    .image-right-section .element-split{
        padding-left:24px;
        padding-right:24px;
    }

    .image-left-section .element-media,
    .image-right-section .element-media{
        margin-left:-24px;
        margin-right:-24px;
        min-height:360px;
    }
}

@media(min-width:1200px){
    .image-left-section .element-media{
        width:50vw !important;
        max-width:50vw !important;
        margin-left:0 !important;
        justify-self:start;
    }

    .image-right-section .element-media{
        width:50vw !important;
        max-width:50vw !important;
        margin-right:0 !important;
        justify-self:end;
    }

    .image-split-section .wide-image img{
        -webkit-mask-image:linear-gradient(
            to right,
            transparent 0%,
            black 33.333%
        ) !important;
        mask-image:linear-gradient(
            to right,
            transparent 0%,
            black 33.333%
        ) !important;
    }

    .image-split-section .mirror-image img{
        -webkit-mask-image:linear-gradient(
            to left,
            transparent 0%,
            black 33.333%
        ) !important;
        mask-image:linear-gradient(
            to left,
            transparent 0%,
            black 33.333%
        ) !important;
    }
}

/* =========================================================
   Portal styles
   Scoped so the admin portal can share this stylesheet without
   changing the public site components.
   ========================================================= */
body.portal-page{
    --portal-surface:rgba(18,20,24,.64);
    --portal-surface-strong:rgba(10,12,16,.82);
    --portal-text:#ffffff;
    --portal-muted:rgba(255,255,255,.66);
    --portal-line:rgba(255,255,255,.075);
    --portal-danger:#ff8f86;
    --portal-success:#89f3bf;
    min-height:100vh;
    margin:0;
    background:var(--black);
    color:var(--portal-text);
    font-family:'Plus Jakarta Sans',sans-serif;
    font-size:16px;
    line-height:1.5;
    overflow-x:hidden;
}

body.portal-page,
body.portal-page *{
    box-sizing:border-box;
}

body.portal-page .bg-glow{
    display:block;
}

body.portal-page h1,
body.portal-page h2,
body.portal-page h3,
body.portal-page h4{
    margin-top:0;
    font-family:var(--display-heading-font);
    font-weight:var(--display-heading-weight);
    letter-spacing:var(--display-heading-letter-spacing);
    line-height:.92;
    text-transform:uppercase;
    color:var(--portal-text);
    text-shadow:none;
}

body.portal-page h1{
    font-size:clamp(40px,6vw,76px);
}

body.portal-page h2{
    font-size:clamp(25px,3vw,38px);
}

body.portal-page h3,
body.portal-page h4{
    font-size:24px;
}

body.portal-page p{
    margin-top:0;
    color:var(--portal-muted);
    font-weight:400;
    line-height:1.7;
}

body.portal-page a{
    color:white;
}

body.portal-page .shell,
body.portal-page .app-shell{
    min-height:100vh;
    display:block;
    position:relative;
    z-index:2;
}

body.portal-page .portal-site-brand{
    display:grid;
    align-content:center;
    gap:8px;
    min-width:0;
}

body.portal-page .portal-icon-links{
    display:flex;
    align-items:center;
    justify-content:flex-start;
    gap:10px;
    margin-top:2px;
}

body.portal-page .portal-icon-button{
    position:relative !important;
    isolation:isolate !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    flex:0 0 46px;
    width:46px !important;
    min-width:46px;
    height:38px;
    min-height:38px !important;
    max-width:46px !important;
    padding:0 !important;
    color:white !important;
    background:var(--control-bg) !important;
    backdrop-filter:var(--glass-blur) !important;
    -webkit-backdrop-filter:var(--glass-blur) !important;
    border:none !important;
    outline:none !important;
    clip-path:polygon(0 0,100% 0,100% 100%,var(--small-corner-cut) 100%,0 calc(100% - var(--small-corner-cut))) !important;
    box-shadow:var(--control-shadow) !important;
    overflow:hidden !important;
    text-decoration:none !important;
    text-decoration-line:none !important;
    text-underline-offset:0 !important;
    transition:var(--motion-fast) !important;
}

body.portal-page .portal-icon-button::before{
    display:none !important;
}

body.portal-page .portal-icon-button::after{
    content:"";
    position:absolute;
    left:-75%;
    top:-1px;
    bottom:-1px;
    z-index:1;
    width:250%;
    background:var(--control-shine);
    transform:translateX(-70%);
    pointer-events:none;
    will-change:transform;
}

body.portal-page .portal-icon-button:hover,
body.portal-page .portal-icon-button:focus-visible{
    transform:translateY(-2px);
    box-shadow:var(--control-hover-shadow) !important;
}

body.portal-page .portal-icon-button:hover::after,
body.portal-page .portal-icon-button:focus-visible::after{
    animation:buttonShine var(--shine-duration, var(--shine-speed)) ease forwards !important;
}

body.portal-page .portal-icon-button i{
    position:relative;
    z-index:2;
    display:block;
    width:1em;
    height:1em;
    font-size:15px;
    line-height:1;
    text-align:center;
}

body.portal-page .nav{
    width:100%;
    max-width:calc(var(--container-max) + (var(--container-pad) * 2));
    margin-left:auto;
    margin-right:auto;
    padding-left:var(--container-pad);
    padding-right:var(--container-pad);
}

body.portal-page .portal-top-nav{
    align-items:center;
}

body.portal-page .portal-nav{
    align-items:center;
}

body.portal-page .logo-sub{
    max-width:100%;
    white-space:nowrap;
}

@media(min-width:1200px) and (max-width:1280px),
       (max-width:600px){
    body.portal-page .logo-sub{
        white-space:normal;
    }
}

@media(max-width:680px){
    body.portal-page .portal-site-brand{
        flex:0 1 calc(100% - 62px) !important;
        width:auto !important;
        max-width:calc(100% - 62px) !important;
        min-width:0;
        justify-items:start;
    }

    body.portal-page .nav{
        padding-left:24px !important;
        padding-right:24px !important;
    }

    body.portal-page .menu-toggle{
        right:24px !important;
    }
}

@media(max-width:360px){
    body.portal-page .nav{
        padding-left:20px !important;
        padding-right:20px !important;
    }

    body.portal-page .menu-toggle{
        right:20px !important;
    }
}

body.portal-page .main{
    width:100%;
    max-width:calc(var(--container-max) + (var(--container-pad) * 2));
    margin:0 auto;
    padding:clamp(190px,15vw,230px) var(--container-pad) 56px;
}

body.portal-page .page-title{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:24px;
    margin-bottom:32px;
}

body.portal-page .page-title h1{
    margin-bottom:10px;
}

body.portal-page .page-title p{
    margin-bottom:0;
    color:var(--portal-muted);
}

body.portal-page .panel{
    position:relative;
    background:var(--portal-surface) !important;
    border:1px solid var(--portal-line) !important;
    box-shadow:var(--glass-shadow) !important;
    backdrop-filter:var(--glass-blur);
    -webkit-backdrop-filter:var(--glass-blur);
    padding:clamp(24px,3vw,40px);
    margin-bottom:24px;
    overflow:hidden;
    clip-path:polygon(0 0,100% 0,100% 100%,var(--corner-cut) 100%,0 calc(100% - var(--corner-cut)));
}

body.portal-page a.panel{
    color:white;
    text-decoration:none;
    transition:var(--motion-fast);
}

body.portal-page a.panel:hover,
body.portal-page a.panel:focus-visible{
    transform:translateY(-3px) scale(1.01);
    outline:none;
}

body.portal-page .panel h1,
body.portal-page .panel h2,
body.portal-page .panel h3{
    margin-bottom:16px;
}

body.portal-page .panel p:last-child{
    margin-bottom:0;
}

body.portal-page .narrow{
    max-width:540px;
}

body.portal-page .grid{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(250px, 1fr));
    gap:22px;
}

body.portal-page .grid.two{
    grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));
}

body.portal-page label{
    display:grid;
    gap:6px;
    margin-bottom:16px;
    color:white;
    font-size:12px;
    font-weight:800;
    letter-spacing:.12em;
    text-transform:uppercase;
}

body.portal-page input,
body.portal-page textarea,
body.portal-page select{
    font-family:'Plus Jakarta Sans',sans-serif;
}

body.portal-page input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]):not([type="button"]):not([type="reset"]),
body.portal-page textarea,
body.portal-page select{
    width:100%;
    min-height:52px;
    padding:18px 20px;
    border:none !important;
    border-radius:0 !important;
    background:
        linear-gradient(180deg,rgba(255,255,255,.044),rgba(255,255,255,.024)),
        rgba(255,255,255,.028);
    color:white;
    font-size:15px;
    font-weight:500;
    line-height:1.35;
    letter-spacing:0;
    outline:none !important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.045), inset 0 -1px 0 rgba(0,0,0,.18);
    clip-path:polygon(
        0 0,
        100% 0,
        100% 100%,
        var(--small-corner-cut) 100%,
        0 calc(100% - var(--small-corner-cut))
    );
    transition:var(--motion-fast);
}

body.portal-page textarea{
    min-height:160px;
    resize:vertical;
}

body.portal-page select{
    appearance:none;
    -webkit-appearance:none;
    cursor:pointer;
}

body.portal-page select option{
    color:#050609;
}

body.portal-page input::placeholder,
body.portal-page textarea::placeholder{
    color:rgba(255,255,255,.44);
}

body.portal-page input[type="checkbox"],
body.portal-page input[type="radio"]{
    width:18px;
    height:18px;
    min-width:18px;
    min-height:18px;
    margin:0 10px 0 0;
    accent-color:rgb(var(--accent-rgb));
    padding:0;
    background:rgba(255,255,255,.09);
    box-shadow:none;
    clip-path:none;
}

body.portal-page label:has(input[type="checkbox"]),
body.portal-page label:has(input[type="radio"]){
    display:flex;
    align-items:center;
    gap:0;
}

body.portal-page input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]):not([type="button"]):not([type="reset"]):focus,
body.portal-page textarea:focus,
body.portal-page select:focus{
    border:none !important;
    outline:none !important;
    background:
        linear-gradient(180deg,rgba(255,255,255,.065),rgba(255,255,255,.03)),
        rgba(255,255,255,.038);
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.06),
        inset 0 -2px 0 rgba(var(--accent-rgb),.72),
        0 0 34px color-mix(in srgb, rgb(var(--accent-rgb)) 16%, transparent);
}

body.portal-page .password-help,
body.portal-page .muted{
    color:var(--portal-muted);
    font-size:13px;
    line-height:1.55;
    letter-spacing:0;
    text-transform:none;
}

body.portal-page .strength{
    position:relative;
    height:12px;
    margin:-4px 0 10px;
    background:linear-gradient(90deg,#ff4d5e 0%,#ff714d 22%,#ffbe0b 44%,#1a8cff 66%,#00f5d4 84%,#38ff7a 100%);
    overflow:hidden;
    clip-path:polygon(0 0,100% 0,100% 100%,6px 100%,0 calc(100% - 6px));
}

body.portal-page .strength::after{
    content:"";
    position:absolute;
    inset:0;
    background:rgba(5,6,9,.70);
    transform-origin:right center;
    transform:scaleX(var(--strength-mask, 1));
    transition:transform .25s ease;
}

body.portal-page .strength-fill{
    display:block;
    position:absolute;
    inset:0;
    z-index:2;
    width:100%;
    height:100%;
    background:transparent;
}

body.portal-page .strength:has(.strength-0){ --strength-mask:.92; }
body.portal-page .strength:has(.strength-1){ --strength-mask:.78; }
body.portal-page .strength:has(.strength-2){ --strength-mask:.60; }
body.portal-page .strength:has(.strength-3){ --strength-mask:.38; }
body.portal-page .strength:has(.strength-4){ --strength-mask:.18; }
body.portal-page .strength:has(.strength-5){ --strength-mask:0; }

body.portal-page button:disabled{
    opacity:.68;
    cursor:wait;
}

body.portal-page .notice{
    padding:14px 16px;
    margin-bottom:18px;
    border:1px solid var(--portal-line);
    background:var(--portal-surface-strong);
    clip-path:polygon(0 0,100% 0,100% 100%,var(--small-corner-cut) 100%,0 calc(100% - var(--small-corner-cut)));
}

body.portal-page .notice.error{
    border-color:rgba(255,143,134,.35);
    background:rgba(180,35,24,.18);
    color:var(--portal-danger);
}

body.portal-page .notice.success{
    border-color:rgba(137,243,191,.32);
    background:rgba(8,116,67,.18);
    color:var(--portal-success);
}

body.portal-page .table-wrap{
    width:100%;
    overflow:auto;
}

body.portal-page table{
    width:100%;
    border-collapse:collapse;
    color:white;
}

body.portal-page th,
body.portal-page td{
    border-bottom:1px solid var(--portal-line);
    padding:12px 10px;
    text-align:left;
    vertical-align:top;
}

body.portal-page th{
    color:rgb(var(--accent-rgb));
    font-size:11px;
    letter-spacing:.12em;
    text-transform:uppercase;
}

body.portal-page td{
    color:var(--portal-muted);
}

body.portal-page pre{
    max-width:100%;
    overflow:auto;
    padding:16px;
    background:rgba(0,0,0,.25);
    border:1px solid var(--portal-line);
    color:white;
}

@media(max-width:760px){
    body.portal-page .main{
        padding:160px var(--container-pad) 40px;
    }

    body.portal-page .page-title{
        display:grid;
        align-items:start;
    }

    body.portal-page .grid.two{
        grid-template-columns:1fr;
    }
}

@media(max-width:420px){
    body.portal-page .main{
        padding-top:184px;
    }
}

/* Final shared media/form/footer corrections. */
.tag,
.card,
.split-copy,
.wide-caption,
.testimonial-card,
.luxury-form,
.elements-hero-panel,
.element-copy,
.element-panel,
.element-card,
.stat-card,
.gallery-item,
.gallery-item > div,
.element-dropdown details,
.process-step,
.hero-caption{
    background:var(--glass-bg) !important;
    border:1px solid var(--glass-border) !important;
    box-shadow:var(--glass-shadow) !important;
    backdrop-filter:var(--glass-blur) !important;
    -webkit-backdrop-filter:var(--glass-blur) !important;
}

.service-page-hero .hero-main-gloss{
    clip-path:none !important;
    -webkit-mask-image:linear-gradient(
        to right,
        transparent 0%,
        black 33.333%
    ) !important;
    mask-image:linear-gradient(
        to right,
        transparent 0%,
        black 33.333%
    ) !important;
}

.service-page-hero .image-overlay{
    background:
        linear-gradient(to top,rgba(0,0,0,.48),transparent 48%),
        linear-gradient(to right,rgba(5,6,9,.70),rgba(5,6,9,.32) 34%,transparent 66%) !important;
}

.hero-caption,
.wide-caption,
.gallery-item > div{
    clip-path:polygon(
        0 0,
        100% 0,
        100% 100%,
        var(--small-corner-cut) 100%,
        0 calc(100% - var(--small-corner-cut))
    ) !important;
}

.hero-caption{
    right:var(--container-x) !important;
    left:auto !important;
    text-align:right !important;
}

.image-left-section .wide-caption{
    left:var(--container-x) !important;
    right:auto !important;
    text-align:left !important;
}

.image-right-section .wide-caption{
    right:var(--container-x) !important;
    left:auto !important;
    text-align:right !important;
}

.image-left-section .mirror-image img{
    -webkit-mask-image:linear-gradient(
        to left,
        transparent 0%,
        black 33.333%
    ) !important;
    mask-image:linear-gradient(
        to left,
        transparent 0%,
        black 33.333%
    ) !important;
}

.image-right-section .wide-image img{
    -webkit-mask-image:linear-gradient(
        to right,
        transparent 0%,
        black 33.333%
    ) !important;
    mask-image:linear-gradient(
        to right,
        transparent 0%,
        black 33.333%
    ) !important;
}

.form-grid.row > input,
.form-grid.row > textarea,
.form-grid.row > select{
    padding:18px 20px !important;
}

.element-form-row.row > input,
.element-form-row.row > select{
    padding:18px 20px !important;
}

.gallery-item{
    isolation:isolate;
}

.gallery-item img{
    z-index:0;
}

.gallery-item::before{
    z-index:1 !important;
}

.gallery-item > div{
    z-index:3 !important;
    background:var(--glass-bg) !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
}

/* Keep media panels hard to their live edge at every viewport width. */
.hero .hero-image-wrap,
.service-page-hero .hero-image-wrap,
.split .wide-image{
    justify-self:end !important;
    margin-left:0 !important;
    margin-right:calc(var(--container-x) * -1) !important;
    width:calc(100% + var(--container-x)) !important;
    max-width:none !important;
}

.image-left-section .element-media{
    justify-self:start !important;
    margin-left:calc(var(--container-x) * -1) !important;
    margin-right:0 !important;
    width:calc(100% + var(--container-x)) !important;
    max-width:none !important;
}

.image-right-section .element-media{
    justify-self:end !important;
    margin-left:0 !important;
    margin-right:calc(var(--container-x) * -1) !important;
    width:calc(100% + var(--container-x)) !important;
    max-width:none !important;
}

@media(min-width:1200px){
    .hero .hero-image-wrap,
    .service-page-hero .hero-image-wrap,
    .split .wide-image,
    .image-left-section .element-media,
    .image-right-section .element-media{
        width:50vw !important;
        max-width:50vw !important;
        margin-left:0 !important;
        margin-right:0 !important;
    }

    .image-left-section .element-media{
        justify-self:start !important;
    }

    .hero .hero-image-wrap,
    .service-page-hero .hero-image-wrap,
    .split .wide-image,
    .image-right-section .element-media{
        justify-self:end !important;
    }

    .hero .hero-image-wrap,
    .service-page-hero .hero-image-wrap{
        align-self:start !important;
        margin-top:calc(var(--hero-copy-top-gap, clamp(36px,4vw,62px)) * -1) !important;
    }
}

@media(min-width:1101px) and (max-width:1199.98px){
    .hero .hero-image-wrap,
    .service-page-hero .hero-image-wrap{
        align-self:start !important;
        margin-top:calc(var(--hero-copy-top-gap, clamp(36px,4vw,62px)) * -1) !important;
    }
}

@media(min-width:1101px){
    .hero,
    .service-page-hero{
        --hero-copy-top-gap:clamp(10px,1.2vw,18px);
        padding-top:calc(var(--header-height, 91px) + var(--hero-copy-top-gap)) !important;
    }

    .hero .hero-image-wrap,
    .service-page-hero .hero-image-wrap{
        height:calc(100vh - var(--header-height, 91px)) !important;
        min-height:0 !important;
    }

    .hero .hero-copy,
    .service-page-hero .hero-copy{
        align-self:start !important;
        display:block;
        min-height:0;
        overflow:visible;
        margin-top:0 !important;
        padding-top:0 !important;
        padding-bottom:0 !important;
    }

    .hero h1,
    .service-page-hero .hero-copy h1{
        width:min(1320px,calc(100vw - (var(--container-x) + var(--container-x))));
        max-width:none;
        max-height:calc(100vh - var(--header-height, 91px) - (var(--hero-copy-top-gap) * 2));
    }

    .hero .hero-copy .hero-kicker,
    .service-page-hero .hero-copy .hero-kicker{
        margin-top:0;
        margin-bottom:clamp(16px,1.5vw,20px);
    }

    .hero .hero-copy > p:not(.kicker),
    .service-page-hero .hero-copy > p:not(.kicker){
        max-width:min(760px,100%);
        line-height:1.62;
    }

    .hero-copy > p + .buttons{
        margin-top:clamp(24px,2.2vw,30px);
    }
}

.footer-credit,
.footer-credit a{
    color:var(--copy-color) !important;
    font-size:var(--copy-size) !important;
    line-height:var(--copy-line-height) !important;
}

@media(max-width:680px){
    .hero-caption{
        right:var(--container-pad) !important;
        left:var(--container-pad) !important;
        text-align:left !important;
    }

    .image-left-section .wide-caption,
    .image-right-section .wide-caption{
        right:var(--container-pad) !important;
        left:var(--container-pad) !important;
        text-align:left !important;
    }

    .footer-credit,
    .footer-credit a{
        font-size:var(--copy-size-mobile) !important;
        line-height:var(--copy-line-height-mobile) !important;
    }
}
