        /* ---- Reset edges — kill ALL Elementor spacing ---- */
        html, body {
            margin: 0 !important;
            padding: 0 !important;
            overflow-x: hidden !important;
        }
        /* Elementor modern (Flexbox / Grid) containers */
        .e-con, .e-con-inner,
        .elementor-section, .elementor-top-section,
        .elementor-section.elementor-section-boxed > .elementor-container,
        .elementor-container,
        .elementor-widget-wrap,
        .elementor-section-wrap,
        .elementor-location-header,
        .elementor-page,
        .elementor, .elementor-inner,
        #page, main, .site-main, .site, #content {
            margin-top: 0 !important;
            padding-top: 0 !important;
        }
        /* Elementor boxed containers — keep full width for hero */
        .elementor-section.elementor-section-boxed > .elementor-container,
        .container {
            max-width: 100% !important;
            padding-left: 0 !important;
            padding-right: 0 !important;
        }

        /* ---- Custom cursor ---- */
        body.st-cursor-active * { cursor: none !important; }

        .st-cursor {
            position: fixed;
            top: 0; left: 0;
            pointer-events: none;
            z-index: 99999;
            transform: translate(-50%, -50%);
            will-change: transform;
            opacity: 0;
            transition: opacity 0.3s;
        }
        .st-cursor.visible { opacity: 1; }

        .st-cursor-dot {
            position: absolute;
            top: 50%; left: 50%;
            transform: translate(-50%, -50%);
            width: 5px; height: 5px;
            background: var(--text-primary);
            border-radius: 50%;
        }

        .st-cursor-ring {
            width: 32px; height: 32px;
            border: 1px solid var(--border-medium);
            border-radius: 50%;
            position: absolute;
            top: 50%; left: 50%;
            transform: translate(-50%, -50%);
            transition: width 0.25s ease, height 0.25s ease, border-color 0.25s;
        }
        .st-cursor.on-link .st-cursor-ring {
            width: 50px; height: 50px;
            border-color: var(--color-primary);
        }

        /* Crosshair lines */
        .st-cursor::before,
        .st-cursor::after {
            content: '';
            position: absolute;
            top: 50%; left: 50%;
            background: var(--text-secondary);
        }
        .st-cursor::before {
            width: 1px; height: 14px;
            transform: translate(-50%, -50%);
        }
        .st-cursor::after {
            width: 14px; height: 1px;
            transform: translate(-50%, -50%);
        }

        /* ---- RGB split layers ---- */
        .st-rgb-layer {
            position: absolute;
            inset: 0;
            width: 100%;
            height: 100%;
            pointer-events: none;
            display: block;
        }
        #st-rgb-r { z-index: 1; mix-blend-mode: screen; opacity: 0.95; }
        #st-rgb-g { z-index: 1; mix-blend-mode: screen; opacity: 0.95; }
        #st-rgb-b { z-index: 1; mix-blend-mode: screen; opacity: 0.95; }

        /* ---- Hero section ---- */
        .st-hero-section {
            position: relative;
            width: 100vw;
            height: 100vh;
            min-height: 600px;
            margin-left: calc(-50vw + 50%);
            margin-right: calc(-50vw + 50%);
            left: 0;
            background: var(--bg-body);
            overflow: hidden;
        }

        .st-hero-slider {
            position: relative;
            width: 100%;
            height: 100%;
        }

        .st-hero-slide {
            position: relative;
            width: 100%;
            height: 100%;
            background-size: cover;
            background-position: center;
            background-repeat: no-repeat;
        }

        .st-hero-overlay {
            position: absolute;
            inset: 0;
            background: linear-gradient(
                to right,
                rgba(0, 0, 0, 0.72) 0%,
                rgba(0, 0, 0, 0.3) 50%,
                rgba(0, 0, 0, 0.1) 100%
            );
            z-index: 2;
            pointer-events: none;
        }

        .st-hero-content {
            position: relative;
            z-index: 10;
            height: 100%;
            display: flex;
            flex-direction: column;
            justify-content: center;
            align-items: flex-start;
            padding: 55px 60px 50px 55px;
            width: 100%;
            box-sizing: border-box;
            pointer-events: none;
        }
        .st-hero-content > * { pointer-events: auto; }

        /* Bottom row pinned to bottom */
        .st-hero-bottom {
            position: absolute;
            bottom: 50px;
            left: 55px;
            right: 60px;
        }

        /* ---- Heading ---- */
        .st-hero-heading {
            text-align: left;
            margin-top: 60px;
        }
        .st-hero-heading h1 {
            font-family: var(--font-heading, 'Oswald', sans-serif);
            font-weight: 700;
            font-size: clamp(2.6rem, 5vw, 4.6rem);
            color: #fff;
            text-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
            line-height: 1.0;
            margin: 0 0 2px 0;
            text-transform: uppercase;
            letter-spacing: -0.03em;
            text-align: left;
        }

        /* ---- Typewriter span — no underline, original red color ---- */
        .st-typewriter {
            position: relative;
            display: inline-block;
            color: var(--color-primary);
            white-space: nowrap;
            min-width: 2ch;
        }
        /* Blinking cursor */
        .st-typewriter-cursor {
            display: inline-block;
            width: 3px;
            height: 0.85em;
            background: var(--color-primary);
            margin-left: 3px;
            vertical-align: middle;
            animation: st-blink 0.7s step-end infinite;
        }
        @keyframes st-blink {
            0%, 100% { opacity: 1; }
            50%       { opacity: 0; }
        }

        /* ---- Bottom row (pinned via absolute in content) ---- */
        .st-hero-bottom {
            display: flex;
            align-items: flex-end;
            justify-content: space-between;
            gap: 40px;
            flex-wrap: wrap;
        }

        .st-hero-bottom-left {
            display: flex;
            align-items: flex-end;
            gap: 30px;
            flex-wrap: wrap;
            max-width: 600px;
        }

        .st-hero-subtext {
            font-family: var(--font-text, sans-serif);
            font-weight: 400;
            font-size: 0.95rem;
            color: rgba(255,255,255,0.85);
            line-height: 1.6;
            max-width: 240px;
            margin: 0;
        }

        /* ---- CTA Button ---- */
        .st-hero-btn {
            display: inline-flex;
            align-items: center;
            gap: 16px;
            padding: 16px 32px;
            border: 1.5px solid rgba(255,255,255,0.3);
            color: #fff;
            font-family: var(--font-text, sans-serif);
            font-weight: 400;
            font-size: 0.85rem;
            letter-spacing: 0.15em;
            text-transform: uppercase;
            text-decoration: none;
            transition: all 0.4s ease;
            background: transparent;
            white-space: nowrap;
        }
        .st-hero-btn:hover {
            background: var(--color-primary);
            border-color: var(--color-primary);
            color: var(--text-primary);
            transform: translateY(-2px);
        }
        .st-hero-btn svg { transition: transform 0.3s ease; }
        .st-hero-btn:hover svg { transform: translateX(5px); }

        /* ---- Right subtext ---- */
        .st-hero-bottom-right { max-width: 300px; }
        .st-hero-subtext-right {
            font-family: var(--font-text, sans-serif);
            font-weight: 400;
            font-size: 0.9rem;
            color: rgba(255,255,255,0.65);
            line-height: 1.6;
            margin: 0;
        }

        /* ---- Follow (vertical right) ---- */
        .st-hero-follow {
            position: absolute;
            right: 26px;
            top: 50%;
            transform: translateY(-50%);
            z-index: 10;
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 18px;
            font-family: var(--font-text, sans-serif);
            font-size: 0.72rem;
            color: rgba(255,255,255,0.5);
            letter-spacing: 0.12em;
            text-transform: uppercase;
        }
        .st-hero-follow-label { writing-mode: vertical-rl; margin-bottom: 6px; }
        .st-hero-follow-sep {
            display: block;
            width: 1px;
            height: 20px;
            background: rgba(255,255,255,0.2);
        }
        .st-hero-follow-link {
            display: flex;
            align-items: center;
            justify-content: center;
            color: rgba(255,255,255,0.5);
            transition: color 0.3s, transform 0.3s;
        }
        .st-hero-follow-link:hover {
            color: var(--color-primary);
            transform: translateX(2px);
        }
        .st-hero-follow svg { width: 18px; height: 18px; }

        /* ---- Responsive ---- */
        @media (max-width: 1024px) {
            .st-hero-content { padding: 60px 40px 40px; }
            .st-hero-heading h1 { font-size: clamp(2rem, 5vw, 3.5rem); }
            .st-hero-follow { display: none; }
        }

        @media (max-width: 768px) {
            /* Overlay: gradient top→bottom for mobile readability */
            .st-hero-overlay {
                background: linear-gradient(
                    to bottom,
                    rgba(0, 0, 0, 0.35) 0%,
                    rgba(0, 0, 0, 0.55) 50%,
                    rgba(0, 0, 0, 0.75) 100%
                );
            }

            /* Content: vertically centred, flush left */
            .st-hero-content {
                padding: 70px 22px 30px 22px;
                justify-content: center;
                align-items: flex-start;
            }

            /* Heading: compact — each line should stay on ONE row */
            .st-hero-heading {
                margin-top: 0;
                width: 100%;
            }
            .st-hero-heading h1 {
                font-size: clamp(1.6rem, 7vw, 2.2rem);
                line-height: 1.05;
                margin: 0 0 2px 0;
                letter-spacing: -0.02em;
            }

            /* Bottom row: static flow, stacked column below heading */
            .st-hero-bottom {
                position: static;
                left: auto;
                right: auto;
                bottom: auto;
                flex-direction: column;
                gap: 16px;
                align-items: flex-start;
                width: 100%;
                margin-top: 18px;
            }

            .st-hero-bottom-left {
                flex-direction: column;
                gap: 16px;
                align-items: flex-start;
                max-width: 100%;
                width: 100%;
            }

            .st-hero-subtext {
                max-width: 100%;
                font-size: 0.875rem;
                line-height: 1.55;
            }

            .st-hero-btn {
                padding: 13px 24px;
                font-size: 0.78rem;
                letter-spacing: 0.12em;
            }

            /* Hide secondary content & follow on mobile */
            .st-hero-bottom-right { display: none; }
            .st-hero-follow { display: none; }

            /* Disable GPU-heavy canvas effects on mobile */
            #st-rgb-r, #st-rgb-g, #st-rgb-b { display: none; }
            .st-cursor { display: none; }
        }

        /* Very small phones */
        @media (max-width: 390px) {
            .st-hero-content { padding: 90px 18px 32px 18px; }
            .st-hero-heading h1 { font-size: clamp(1.45rem, 6.5vw, 1.9rem); }
            .st-hero-subtext { font-size: 0.82rem; }
        }
