.elementor-2254 .elementor-element.elementor-element-126ef2b{--display:flex;--flex-direction:row;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--align-items:stretch;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:50px;--padding-right:50px;}.elementor-2254 .elementor-element.elementor-element-126ef2b:not(.elementor-motion-effects-element-type-background), .elementor-2254 .elementor-element.elementor-element-126ef2b > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:var( --e-global-color-686d7a3 );}.elementor-2254 .elementor-element.elementor-element-377012a{--display:flex;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2254 .elementor-element.elementor-element-e3977d8.xpro-widget-bg-overlay:before{transition:background 0.3s;}.elementor-theme-builder-content-area{height:400px;}.elementor-location-header:before, .elementor-location-footer:before{content:"";display:table;clear:both;}@media(min-width:768px){.elementor-2254 .elementor-element.elementor-element-126ef2b{--width:100%;}}@media(max-width:1024px){.elementor-2254 .elementor-element.elementor-element-126ef2b{--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}}@media(max-width:767px){.elementor-2254 .elementor-element.elementor-element-126ef2b{--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2254 .elementor-element.elementor-element-377012a{--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}}/* Start custom CSS for container, class: .elementor-element-126ef2b *//* =============================================================
   NORDLUX — FOOTER STYLES
   ---------------------------------------------------------------
   IMPORTANT: This file uses CSS variables defined in main.css
   (–-nl-background, --nl-primary, etc.). Load main.css FIRST.

   Where to put it in Elementor:
   - If you have Elementor Pro: Templates → Theme Builder → Footer
     → Edit template → Site settings (gear icon) → Custom CSS
   - OR globally: Elementor → Site Settings → Custom CSS
   ============================================================= */

.nl-footer {
    position: relative;
    border-top: 1px solid var(--nl-border);
    background: var(--nl-background);
    padding: 5rem 0 2.5rem;
    color: var(--nl-foreground);
    font-family: var(--nl-font-sans);
}

.nl-footer__top {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 2.5rem;
    padding-bottom: 4rem;
}

.nl-footer__brand-col {
    grid-column: span 12;
}

@media (min-width: 768px) {
    .nl-footer__brand-col {
        grid-column: span 4;
    }
}

.nl-footer__brand {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.nl-footer__diamond {
    height: 1.75rem;
    width: 1.75rem;
    transform: rotate(45deg);
    border: 1px solid var(--nl-primary);
    box-shadow: var(--nl-shadow-glow);
}

.nl-footer__brand-name {
    font-family: var(--nl-font-display);
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-size: 1rem;
    color: var(--nl-foreground);
}

.nl-footer__brand-desc {
    margin-top: 1.5rem;
    max-width: 20rem;
    font-size: 0.875rem;
    color: var(--nl-muted-foreground);
    line-height: 1.6;
}

.nl-footer__badge {
    margin-top: 2rem;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    border: 1px solid var(--nl-border);
    padding: 0.5rem 0.75rem;
}

.nl-footer__badge-dot {
    height: 6px;
    width: 6px;
    background: var(--nl-primary);
    box-shadow: 0 0 8px oklch(0.85 0.13 230);
    animation: nl-pulse 2s ease-in-out infinite;
}

.nl-footer__badge-text {
    font-family: var(--nl-font-mono);
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--nl-muted-foreground);
}

.nl-footer__col {
    grid-column: span 6;
}

@media (min-width: 768px) {
    .nl-footer__col {
        grid-column: span 2;
    }
}

.nl-footer__col-title {
    font-family: var(--nl-font-mono);
    font-size: 0.68rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--nl-muted-foreground);
    margin: 0 0 1.25rem;
}

.nl-footer__col ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.nl-footer__col a {
    position: relative;
    display: inline-block;
    font-size: 0.875rem;
    color: oklch(0.97 0.005 240 / 0.85);
    text-decoration: none;
    transition: color 0.3s ease;
}

.nl-footer__col a:hover {
    color: var(--nl-primary);
}

.nl-footer__col a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -2px;
    height: 1px;
    width: 100%;
    background: currentColor;
    transform: scaleX(0);
    transform-origin: right;
    transition: transform 0.45s cubic-bezier(0.65, 0, 0.35, 1);
}

.nl-footer__col a:hover::after {
    transform: scaleX(1);
    transform-origin: left;
}

/* Bottom row */
.nl-footer__bottom {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    border-top: 1px solid var(--nl-border);
    padding-top: 2rem;
}

@media (min-width: 768px) {
    .nl-footer__bottom {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }
}

.nl-footer__legal {
    font-family: var(--nl-font-mono);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--nl-muted-foreground);
}

.nl-footer__links {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
}

.nl-footer__links a {
    position: relative;
    display: inline-block;
    font-family: var(--nl-font-mono);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--nl-muted-foreground);
    text-decoration: none;
    transition: color 0.3s ease;
}

.nl-footer__links a:hover {
    color: var(--nl-foreground);
}

.nl-footer__links a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -2px;
    height: 1px;
    width: 100%;
    background: currentColor;
    transform: scaleX(0);
    transform-origin: right;
    transition: transform 0.45s cubic-bezier(0.65, 0, 0.35, 1);
}

.nl-footer__links a:hover::after {
    transform: scaleX(1);
    transform-origin: left;
}

/* Fallback pulse keyframe (in case main.css isn't loaded for the footer alone) */
@keyframes nl-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}/* End custom CSS */