.elementor-1385 .elementor-element.elementor-element-b532a12{--display:flex;}/* Start custom CSS for html, class: .elementor-element-b9c1d6a */:root {
        --bg-deep: #030307;
        --text-primary: #ffffff;
        --text-dim: #8e8e9f;
        --accent-purple: #7f00ff;
        --accent-cyan: #00f3ff;
        --card-surface: rgba(255, 255, 255, 0.015);
        --card-edge: rgba(255, 255, 255, 0.06);
        --glow-follow: radial-gradient(350px circle at var(--x, 0px) var(--y, 0px), rgba(0, 243, 255, 0.12) 0%, rgba(127, 0, 255, 0.03) 50%, transparent 100%);
        --transition-smooth: cubic-bezier(0.25, 1, 0.5, 1);
    }
    * {
        box-sizing: border-box;
        margin: 0;
        padding: 0;
        scrollbar-width: thin;
        scrollbar-color: #1a1a2e #030307;
        scroll-behavior: smooth;
    }
    html, body {
        width: 100%;
        overflow-x: hidden;
        background-color: var(--bg-deep);
        color: var(--text-primary);
        font-family: "Outfit", -apple-system, BlinkMacSystemFont, sans-serif;
        scroll-behavior: smooth;
        -webkit-font-smoothing: antialiased;
    }
    ::-webkit-scrollbar { width: 8px; }
    ::-webkit-scrollbar-track { background: #030307; }
    ::-webkit-scrollbar-thumb { background: #1a1a2e; border-radius: 4px; }
    ::-webkit-scrollbar-thumb:hover { background: var(--accent-purple); }

    .canvas-container {
        position: fixed; top: 0; left: 0; width: 100vw; height: 100vh;
        z-index: 1; pointer-events: none; will-change: transform;
    }

    .vibe-wrapper { position: relative; width: 100%; z-index: 2; }
    .vibe-section {
        position: relative; min-height: 100vh; display: flex; flex-direction: column;
        justify-content: center; padding: 0 8%; box-sizing: border-box; overflow: hidden;
    }
    #hero-section { align-items: flex-start; height: 100vh; }
    .hero-title {
        font-size: clamp(3.2rem, 8.5vw, 7.5rem); font-weight: 800; line-height: 1.05;
        letter-spacing: -0.05em; margin: 0;
        background: linear-gradient(180deg, #ffffff 0%, #a2a2b5 100%);
        -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
    }
    .hero-tagline {
        font-size: clamp(1.1rem, 2vw, 1.5rem); color: var(--text-dim);
        margin-top: 30px; max-width: 580px; line-height: 1.6; font-weight: 400;
    }
    #pin-section { display: flex; align-items: center; min-height: 100vh; }
    .pin-container { display: flex; justify-content: space-between; width: 100%; align-items: flex-start; }
    .pin-left { width: 40%; position: sticky; top: 35vh; }
    .pin-left h2 {
        font-size: clamp(2.5rem, 5.5vw, 4.5rem); font-weight: 800; line-height: 1.1;
        letter-spacing: -0.04em; margin: 0;
        background: linear-gradient(180deg, #ffffff 0%, #8e8e9f 100%);
        -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
    }
    .pin-right { width: 50%; display: flex; flex-direction: column; gap: 120px; padding-top: 15vh; padding-bottom: 25vh; }
    .scroll-card {
        background: var(--card-surface); border: 1px solid var(--card-edge);
        backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); padding: 48px;
        border-radius: 28px; box-shadow: 0 30px 60px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.03);
        opacity: 0.2; transform: translateY(60px); will-change: opacity, border-color, transform;
    }
    .scroll-card h3 { font-size: 1.5rem; font-weight: 600; margin: 0 0 15px 0; color: #ffffff; }
    .scroll-card p { font-size: 1.05rem; color: var(--text-dim); line-height: 1.6; margin: 0; }
    #grid-section { min-height: 100vh; display: flex; flex-direction: column; justify-content: center; padding-top: 10vh; padding-bottom: 10vh; }
    #grid-section h2 { font-size: clamp(2.5rem, 5vw, 4rem); text-align: center; margin-bottom: 70px; letter-spacing: -0.04em; font-weight: 800; }
    .tech-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; width: 100%; }
    .grid-item {
        position: relative; background: var(--card-surface); border: 1px solid var(--card-edge);
        box-shadow: inset 0 1px 0 rgba(255,255,255,0.02); padding: 48px; border-radius: 24px;
        overflow: hidden; transition: transform 0.6s var(--transition-smooth), opacity 0.6s var(--transition-smooth), border-color 0.6s var(--transition-smooth);
        will-change: transform, opacity;
    }
    .grid-item h4 { font-size: 1.4rem; margin: 0 0 15px 0; font-weight: 600; color: #ffffff; }
    .grid-item p { font-size: 1rem; color: var(--text-dim); line-height: 1.6; margin: 0; }
    .grid-item::before {
        content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 100%;
        background: var(--glow-follow); opacity: 0; transition: opacity 0.5s ease;
        pointer-events: none; z-index: 1;
    }
    .grid-item:hover::before { opacity: 1; }
    .grid-item:hover { transform: translateY(-8px) scale(1.02); border-color: rgba(0,243,255,0.25); background: rgba(255,255,255,0.02); }
    .grid-item * { position: relative; z-index: 2; }
    .tech-grid:has(.grid-item:hover) .grid-item:not(:hover) { opacity: 0.3; transform: scale(0.96); }

    #cta-section { align-items: center; text-align: center; min-height: 100vh; justify-content: center; }
    .cta-title {
        font-size: clamp(3rem, 8vw, 6.5rem); font-weight: 800; letter-spacing: -0.05em;
        line-height: 1.05; margin: 0 0 45px 0;
        background: linear-gradient(180deg, #ffffff 0%, #8e8e9f 100%);
        -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
    }
    .action-btn {
        background: #ffffff; color: #000000; padding: 18px 40px; font-weight: 600;
        border-radius: 50px; text-decoration: none; font-size: 1.1rem;
        transition: all 0.3s var(--transition-smooth); display: inline-block;
        box-shadow: 0 10px 30px rgba(255,255,255,0.1);
    }
    .action-btn:hover { transform: translateY(-4px) scale(1.05); box-shadow: 0 15px 40px rgba(0,243,255,0.35); background: var(--accent-cyan); color: #000000; }

    #faq-section { min-height: 100vh; display: flex; flex-direction: column; justify-content: center; padding-top: 10vh; padding-bottom: 10vh; }
    .faq-container { display: flex; justify-content: space-between; width: 100%; align-items: flex-start; gap: 60px; }
    .faq-left { width: 40%; position: sticky; top: 25vh; }
    .faq-left h2 {
        font-size: clamp(2.5rem, 5.5vw, 4.5rem); font-weight: 800; line-height: 1.1;
        letter-spacing: -0.04em; margin: 0 0 20px 0;
        background: linear-gradient(180deg, #ffffff 0%, #8e8e9f 100%);
        -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
    }
    .faq-left p { font-size: 1.1rem; color: var(--text-dim); line-height: 1.6; max-width: 360px; }
    .faq-right { width: 55%; display: flex; flex-direction: column; gap: 20px; }
    .faq-item {
        background: var(--card-surface); border: 1px solid var(--card-edge);
        backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); border-radius: 20px;
        overflow: hidden; transition: border-color 0.4s var(--transition-smooth), background-color 0.4s var(--transition-smooth), box-shadow 0.4s var(--transition-smooth);
        box-shadow: 0 10px 30px rgba(0,0,0,0.2), inset 0 1px 0 rgba(255,255,255,0.02);
    }
    .faq-item:hover { border-color: rgba(0,243,255,0.25); background-color: rgba(255,255,255,0.02); box-shadow: 0 15px 40px rgba(0,243,255,0.05); }
    .faq-item.is-active { border-color: rgba(127,0,255,0.4); background-color: rgba(127,0,255,0.01); }
    .faq-trigger {
        width: 100%; background: none; border: none; padding: 30px 40px;
        display: flex; justify-content: space-between; align-items: center; cursor: pointer;
        text-align: left; color: #ffffff; outline: none; gap: 20px;
    }
    .faq-question-wrap { display: flex; flex-direction: column; gap: 8px; }
    .faq-index { font-family: "Space Mono", monospace; font-size: 0.85rem; color: var(--accent-cyan); letter-spacing: 0.05em; }
    .faq-question { font-size: 1.25rem; font-weight: 600; letter-spacing: -0.02em; transition: color 0.3s ease; }
    .faq-item:hover .faq-question { color: var(--accent-cyan); }
    .faq-icon-box {
        width: 44px; height: 44px; border-radius: 50%; background: rgba(255,255,255,0.03);
        border: 1px solid var(--card-edge); display: flex; align-items: center; justify-content: center;
        transition: all 0.4s var(--transition-smooth); flex-shrink: 0;
    }
    .faq-item:hover .faq-icon-box { background: rgba(0,243,255,0.1); border-color: rgba(0,243,255,0.3); }
    .faq-item.is-active .faq-icon-box { background: rgba(127,0,255,0.15); border-color: rgba(127,0,255,0.4); transform: rotate(45deg); }
    .faq-icon { font-size: 0.95rem; color: #ffffff; transition: color 0.3s ease; }
    .faq-content { height: 0; overflow: hidden; transition: height 0.4s var(--transition-smooth); }
    .faq-content-inner { padding: 0 40px 40px 40px; font-size: 1.05rem; color: var(--text-dim); line-height: 1.6; }

    @media (max-width: 968px) {
        .pin-container { flex-direction: column; }
        .pin-left { width: 100%; position: relative; top: 0; margin-bottom: 50px; }
        .pin-right { width: 100%; gap: 50px; padding-top: 0; padding-bottom: 10vh; }
        .tech-grid { grid-template-columns: 1fr; gap: 20px; }
        .faq-container { flex-direction: column; gap: 40px; }
        .faq-left { width: 100%; position: relative; top: 0; }
        .faq-right { width: 100%; }
        .faq-trigger { padding: 24px 30px; }
        .faq-content-inner { padding: 0 30px 30px 30px; }
    }/* End custom CSS */