/* =================== GLOBAL VARIABLES =================== */
:root {
    --font-primary: 'Inter', sans-serif;
    --color-text: #E0E0E0;
    --color-text-muted: #b0b0b0;
    --color-text-light: #ffffff;
    --color-bg-dark1: #0f172a; /* Deep Navy - Used as fallback */
    --color-bg-dark2: #1e293b; /* Slate Blue */
    --color-bg-dark3: #111827; /* Darker Base */
    --color-bg-modal: rgba(25,35,50,0.98);
    --color-bg-overlay: rgba(10,10,20,0.85);
    --color-accent1: #6366F1; /* Indigo */
    --color-accent1-rgb: 99, 102, 241;
    --color-accent2: #3B82F6; /* Blue */
    --color-accent2-rgb: 59, 130, 246;
    --color-accent3: #8B5CF6; /* Violet */
    --color-accent3-rgb: 139, 92, 246;
    --color-border-light: rgba(255, 255, 255, 0.12);
    --color-border-focus: rgba(var(--color-accent1-rgb), 0.4);
    --color-error: #f87171; /* Red for errors */

    /* Gradients */
    --gradient-text: linear-gradient(95deg, var(--color-accent1) 0%, var(--color-accent3) 50%, var(--color-accent2) 100%);
    --gradient-button: linear-gradient(95deg, var(--color-accent2) 0%, var(--color-accent1) 100%);
    --gradient-menu-hover: linear-gradient(95deg, var(--color-accent2) 0%, var(--color-accent3) 100%);
    --gradient-underline: linear-gradient(to right, var(--color-accent1), var(--color-accent2));
    --gradient-bg: linear-gradient(145deg, var(--color-bg-dark1), var(--color-bg-dark2));
    --gradient-card: linear-gradient(140deg, rgba(30,41,59,0.75), rgba(17,24,39,0.65));

    /* Other Styles */
    --border-radius-lg: 20px;
    --border-radius-md: 14px;
    --border-radius-sm: 10px;
    --shadow-soft: 0 6px 24px rgba(0,0,0,0.15);
    --shadow-medium: 0 10px 35px rgba(0,0,0,0.25);
    --shadow-float: 0 18px 50px rgba(0,0,0,0.35);
    --shadow-glow-accent1: 0 0 30px 8px rgba(var(--color-accent1-rgb),0.3);
    --shadow-glow-accent2: 0 0 30px 8px rgba(var(--color-accent2-rgb),0.3);
    --shadow-glow-accent3: 0 0 30px 8px rgba(var(--color-accent3-rgb),0.25);
    --transition-smooth: all 0.35s cubic-bezier(0.4,0,0.2,1);
    --transition-bounce: all 0.45s cubic-bezier(0.175,0.885,0.32,1.275);
    --transition-fast: all 0.2s ease-out;
    --transition-transform-opacity: transform 0.3s ease, opacity 0.3s ease;
    --header-height: 75px;

    /* === Product Accent Colors === */
    --color-forge: #F59E0B;
    --color-forge-rgb: 245, 158, 11;
    --color-fabric: #10B981;
    --color-fabric-rgb: 16, 185, 129;
    --color-gateway: #3B82F6;
    --color-gateway-rgb: 59, 130, 246;
    --color-nexus: #8B5CF6;
    --color-nexus-rgb: 139, 92, 246;
    --color-thumbnail: #06B6D4;
    --color-thumbnail-rgb: 6, 182, 212;
    --product-accent: var(--color-accent1);
    --product-accent-rgb: var(--color-accent1-rgb);

    /* Product Accent Dark/Light Variants */
    --color-forge-dark: #D97706;
    --color-forge-light: #FBBF24;
    --color-fabric-dark: #059669;
    --color-fabric-light: #34D399;
    --color-gateway-dark: #2563EB;
    --color-gateway-light: #60A5FA;
    --color-nexus-dark: #7C3AED;
    --color-nexus-light: #A78BFA;
    --color-thumbnail-dark: #0891B2;
    --color-thumbnail-light: #22D3EE;
    --product-accent-dark: var(--color-accent2);
    --product-accent-light: var(--color-accent3);

    /* Spacing Scale */
    --space-xs: 0.25rem;
    --space-sm: 0.5rem;
    --space-md: 1rem;
    --space-lg: 1.5rem;
    --space-xl: 2rem;
    --space-2xl: 3rem;
    --space-3xl: 4rem;
    --space-4xl: 6rem;

    /* Typography Scale */
    --text-xs: 0.75rem;
    --text-sm: 0.875rem;
    --text-base: 1rem;
    --text-lg: 1.125rem;
    --text-xl: 1.25rem;
    --text-2xl: 1.5rem;
    --text-3xl: 2rem;
    --text-4xl: 2.5rem;
    --text-5xl: 3rem;

    /* Z-index Scale */
    --z-base: 1;
    --z-dropdown: 100;
    --z-sticky: 500;
    --z-header: 1000;
    --z-overlay: 1500;
    --z-modal: 2000;
    --z-cookie: 3000;

    /* Code Font */
    --font-code: 'JetBrains Mono', 'Fira Code', monospace;
}

/* =================== BASE STYLES =================== */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    font-family: var(--font-primary);
    color: var(--color-text);
    /* === MODIFIED BACKGROUND with Fallback === */
    background-color: var(--color-bg-dark1); /* Dark fallback color */
    background-image: var(--gradient-bg); /* Apply gradient layer */
    background-size: cover;
    background-repeat: no-repeat;
    /* background-attachment: fixed; */ /* Consider removing if causing issues */
    /* === End Modified Background === */
    line-height: 1.7;
    padding-top: var(--header-height);
    font-size: 16px;
    overflow-x: hidden;
    transition: background-color 0.5s ease; /* Transition color change */
    position: relative;
}
main { overflow: hidden; }
a { color: var(--color-accent2); text-decoration: none; transition: color var(--transition-fast); }
a:hover { color: var(--color-accent1); }
h1, h2, h3, h4, h5, h6 { font-weight: 700; line-height: 1.3; margin-bottom: 0.75em; }
h1:last-child, h2:last-child, h3:last-child, h4:last-child, h5:last-child, h6:last-child, p:last-child {
    margin-bottom: 0;
}
img { max-width: 100%; height: auto; display: block; }
button { font-family: inherit; cursor: pointer; border: none; transition: var(--transition-fast); background: none; color: inherit; padding: 0; }
button:disabled { cursor: not-allowed; opacity: 0.6; }
button:not(:disabled):active { transform: scale(0.97); filter: brightness(0.9); }
button.inline-link {
    text-decoration: underline; color: var(--color-text-muted); display: inline; font-size: inherit;
}
button.inline-link:hover { color: var(--color-accent1); }

/* Accessibility Focus Styles */
:focus-visible {
    outline: 3px solid var(--color-accent1); outline-offset: 3px; border-radius: var(--border-radius-sm);
}
*:focus:not(:focus-visible) { outline: none; }
.modal-close:focus-visible {
    color: var(--color-text-light); box-shadow: 0 0 0 3px var(--color-border-focus);
    background-color: rgba(var(--color-accent1-rgb), 0.1);
}

/* =================== PARTICLE BACKGROUND =================== */
#particleCanvas {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    z-index: -3; /* Behind everything */ pointer-events: none;
    /* Uncomment below to test disabling particles if background issues persist */
    /* display: none !important; */
}

/* =================== HEADER & NAVIGATION =================== */
#site-header {
    position: fixed; top: 0; left: 0; width: 100%; z-index: 1000; background: rgba(15, 23, 42, 0.8); backdrop-filter: blur(10px); display: flex; align-items: center; padding: 0.8rem 2rem; transition: transform 0.3s ease, background-color 0.3s ease, box-shadow 0.3s ease; height: var(--header-height); will-change: transform;
}
#site-header.scrolled { background: rgba(15, 23, 42, 0.95); box-shadow: 0 2px 10px rgba(0,0,0,0.2); }
#site-header.header-hidden { transform: translateY(-100%); }

.logo a {
    display: inline-flex; align-items: center; gap: 0.6em; text-decoration: none; color: inherit;
}
.logo a img { width: auto; display: block; flex-shrink: 0; }
.logo a span {
    font-weight: 700; font-size: 1.7rem; background: var(--gradient-text); -webkit-background-clip: text; background-clip: text; color: transparent; -webkit-text-fill-color: transparent; letter-spacing: 1px; white-space: nowrap;
}

/* --- Desktop Default Styles --- */
header nav#nav-menu {
    display: flex; align-items: center; gap: 0.5rem; margin-left: auto; position: static; transform: none; width: auto; height: auto; background: none; padding: 0; overflow-y: visible; flex-direction: row;
}
header .hamburger#hamburger { display: none; }

/* --- Mobile Styles (@media query) --- */
@media (max-width: 960px) {
    header nav#nav-menu {
        /* Mobile Default: Panel is hidden initially */
        display: none;
        flex-direction: column;
        position: fixed; /* Ensure position is fixed */
        inset: 0; /* top, right, bottom, left = 0 */
        background: rgba(15, 23, 42, 0.98); backdrop-filter: blur(15px);
        padding: calc(var(--header-height) + 2rem) 0 2rem;
        overflow-y: auto; /* Allows scrolling if content overflows */
        transform: translateX(100%); /* Start off-screen */
        transition: transform 0.4s cubic-bezier(0.4,0,0.2,1);
        z-index: 1100; /* High z-index */
        gap: 0; align-items: center; margin-left: 0;
        width: 100%;
        height: 100dvh; /* Full viewport height */
    }
    header nav#nav-menu.active {
        /* Mobile Active: Show panel when JS adds 'active' class */
        display: flex;
        transform: translateX(0); /* Slide in */
    }
    header .hamburger#hamburger {
        /* Show hamburger icon on mobile */
        display: flex;
        margin-left: auto; /* Push hamburger right */
        flex-direction: column; cursor: pointer; gap: 5px; padding: 10px;
        z-index: 1200; /* Ensure hamburger is above menu before it slides in */
        background: none;
        border: none;
    }
    .hamburger span {
        display: block; width: 25px; height: 3px; background-color: var(--color-text); border-radius: 3px; transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
    }
    .hamburger.active span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
    .hamburger.active span:nth-child(2) { opacity: 0; transform: translateX(-10px); }
    .hamburger.active span:nth-child(3) { transform: rotate(-45deg) translate(6px, -6px); }

    body.nav-open { overflow: hidden; }
}
/* Header hiding logic only applies on mobile */
@media (min-width: 961px) { header.header-hidden { transform: translateY(0); } }


nav a, nav button.contact-trigger {
    font-size: 0.9rem; font-weight: 500; padding: 0.6rem 1.1rem; border-radius: var(--border-radius-sm);
    transition: var(--transition-smooth); color: var(--color-text-muted); background: transparent;
    position: relative; overflow: hidden; white-space: nowrap; border: none; cursor: pointer; text-align: left;
}
/* Desktop Nav Link Styles */
@media (min-width: 961px) {
    nav a:not(#contactBtn)::after {
        content: ''; position: absolute; bottom: 4px; left: 50%; width: 0; height: 2px;
        background: var(--gradient-menu-hover); border-radius: 1px; transform: translateX(-50%); transition: width 0.3s ease;
    }
    nav a:not(#contactBtn):hover::after { width: 60%; }
    nav a:not(#contactBtn):hover { color: var(--color-text-light); transform: translateY(-2px); }
    nav button#contactBtn {
        background: var(--gradient-button); color: var(--color-text-light); margin-left: 0.5rem;
        box-shadow: 0 3px 10px rgba(var(--color-accent2-rgb), 0.25);
    }
    nav button#contactBtn:hover {
        filter: brightness(1.1); transform: translateY(-2px) scale(1.04);
        box-shadow: 0 6px 20px rgba(var(--color-accent2-rgb), 0.4), var(--shadow-glow-accent2);
    }
}

/* Mobile Navigation Link Styles */
@media (max-width: 960px) {
    #site-header { padding: 0.8rem 1.5rem; } /* Adjust header padding for mobile */
    nav a, nav button.contact-trigger {
        width: 80%; max-width: 300px; text-align: center; padding: 1rem; border-radius: var(--border-radius-sm);
        color: var(--color-text-light); margin: 0.6rem 0 !important; background: rgba(255,255,255,0.03);
        border: 1px solid rgba(255,255,255,0.08);
    }
    nav a:not(#contactBtn):hover { background: var(--gradient-menu-hover); transform: none; box-shadow: none; }
    /* Ensure mobile links don't have the desktop underline effect */
    nav a:not(#contactBtn)::after { display: none; }
    nav button#contactBtn { margin-top: 1.5rem !important; width: 80%; max-width: 300px; }

    /* Mobile dropdown overrides */
    .nav-item-dropdown { width: 80%; max-width: 300px; text-align: center; }
    .nav-dropdown-trigger {
        width: 100%; justify-content: center; padding: 1rem; color: var(--color-text-light);
        background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08);
        border-radius: var(--border-radius-sm); margin: 0.6rem 0;
    }
    .nav-dropdown {
        position: static; transform: none; min-width: auto; width: 100%;
        background: rgba(15, 23, 42, 0.8); border: 1px solid rgba(255,255,255,0.08);
        border-radius: 0 0 var(--border-radius-sm) var(--border-radius-sm);
        margin-top: -0.4rem; box-shadow: none;
        max-height: 0; overflow: hidden; padding: 0;
        transition: max-height 0.35s ease, opacity 0.25s ease, padding 0.25s ease;
    }
    .nav-item-dropdown.dropdown-open .nav-dropdown {
        opacity: 1; visibility: visible; transform: none;
        max-height: 400px; padding: 0.5rem 0;
    }
    .nav-item-dropdown:hover .nav-dropdown { opacity: 0; visibility: hidden; }
    .nav-dropdown a { justify-content: center; padding: 0.8rem 1rem; }
}
@media (max-width: 640px) {
    :root { --header-height: 65px; }
    #site-header { padding: 0.7rem 1rem; }
    header nav#nav-menu { padding-top: calc(var(--header-height) + 1rem); }
}

/* =================== OPTIONAL CURSOR SPOTLIGHT =================== */
.cursor-spotlight {
    position: fixed; top: 0; left: 0; width: 500px; height: 500px; border-radius: 50%;
    background: radial-gradient(circle, rgba(var(--color-accent1-rgb), 0.1) 0%, rgba(var(--color-accent1-rgb), 0) 65%);
    pointer-events: none; z-index: 0; transform: translate(-50%, -50%); opacity: 0;
    transition: opacity 0.5s ease; will-change: transform; display: none;
}
body.has-spotlight .cursor-spotlight { display: block; }
body.has-spotlight:hover .cursor-spotlight { opacity: 1; }
@media (max-width: 768px), (hover: none), (pointer: coarse) {
    .cursor-spotlight { display: none !important; }
    body.has-spotlight { /* JS removes this class too via media query check */ }
}

/* =================== SECTION STYLING =================== */
.section-container {
    position: relative; padding: 4rem 1.5rem 0; /* Reduced top padding */
    margin: 0 auto 4.5rem; /* Reduced bottom margin */ max-width: 1200px;
    overflow: hidden; z-index: 1;
}
.section-container:last-of-type { margin-bottom: 3rem; }
#home.section-container { margin-bottom: 5rem; padding-top: 6rem; }

/* Ambient Elements */
.ambient-element {
    position: absolute; border-radius: 50%; filter: blur(100px); opacity: 0.08;
    pointer-events: none; z-index: -1; animation: subtlePulse 14s infinite alternate ease-in-out;
    will-change: transform, opacity; width: 30rem; height: 30rem;
}
@keyframes subtlePulse {
    0% { transform: scale(0.9) translate(0, 0); opacity: 0.07; }
    100% { transform: scale(1.15) translate(10px, -10px); opacity: 0.11; }
}
.ambient-indigo { background: var(--color-accent1); }
.ambient-blue { background: var(--color-accent2); }
.ambient-violet { background: var(--color-accent3); }

/* Specific positions for ambient elements */
#home .ambient-indigo { left: 5%; top: 5%; width: 45rem; height: 45rem; opacity: 0.07; animation-duration: 16s; }
#home .ambient-blue { right: 0%; bottom: -10%; width: 50rem; height: 50rem; opacity: 0.09; animation-duration: 18s; animation-delay: -2s; }
#home .ambient-violet { left: 45%; bottom: 30%; width: 30rem; height: 30rem; opacity: 0.06; animation-duration: 15s; animation-delay: -1s; }
.pos1 .ambient-indigo { right: 15%; top: -15%; } .pos1 .ambient-blue { left: 10%; bottom: -20%; } .pos1 .ambient-violet { right: 0%; bottom: 25%; }
.pos2 .ambient-indigo { left: 10%; top: -5%; width: 24rem; height: 24rem; } .pos2 .ambient-blue { right: 5%; bottom: -10%; width: 35rem; height: 35rem; } .pos2 .ambient-violet { left: 50%; bottom: 45%; width: 20rem; height: 20rem; }

.section-header { display: flex; flex-direction: column; align-items: center; margin-bottom: 3.5rem; position: relative; z-index: 2; }
.section-header h2, .section-header p, .section-header .section-underline {
    opacity: 0; transition: opacity 0.8s ease-out 0.1s, transform 0.8s ease-out 0.1s; will-change: transform, opacity;
}
/* Initial state for reveal */
[data-aos] .section-header h2 { transform: translateY(30px); }
[data-aos] .section-header p { transform: translateY(30px); transition-delay: 0.2s; }
[data-aos] .section-header .section-underline { transform: scaleX(0); transition-delay: 0.35s; transform-origin: center; }
/* Revealed state via JS Observer */
.section-header.reveal-header h2, .section-header.reveal-header p, .section-header.reveal-header .section-underline { opacity: 1; transform: translateY(0) scaleX(1); }
/* Fallback if JS observer fails or not used */
.no-js .section-header h2, .no-js .section-header p, .no-js .section-header .section-underline,
[data-aos].aos-animate .section-header h2, [data-aos].aos-animate .section-header p, [data-aos].aos-animate .section-header .section-underline {
    opacity: 1; transform: translateY(0) scaleX(1);
}

.section-header h2 {
    font-size: clamp(2rem, 5vw, 2.5rem); font-weight: 700; background: var(--gradient-text);
    -webkit-background-clip: text; background-clip: text; color: transparent; -webkit-text-fill-color: transparent;
    margin-bottom: 1rem; text-align: center;
}
.section-underline { height: 3px; width: 5rem; background: var(--gradient-underline); border-radius: 2px; margin-bottom: 1.5rem; }
.section-header p { color: var(--color-text-muted); max-width: 48rem; text-align: center; margin: 0 auto; font-size: 1.1rem; line-height: 1.8; }

/* =================== CONTENT AREA =================== */
.content-area {
    background: rgba(17, 24, 39, 0.8); backdrop-filter: blur(20px); border-radius: var(--border-radius-lg);
    padding: 3.5rem; z-index: 2; position: relative; max-width: 65rem; margin: 3.5rem auto 0;
    border: 1px solid var(--color-border-light); box-shadow: var(--shadow-float); overflow: hidden;
}
.content-area.wide { max-width: 85rem; }
.content-area.two-column { display: grid; grid-template-columns: 1fr 1fr; gap: 3.5rem; align-items: center; }
.content-area.two-column-biased { display: grid; grid-template-columns: 3fr 2fr; gap: 4rem; align-items: center; }

/* Image Container & Placeholder Styling */
.image-container { position: relative; border-radius: var(--border-radius-md); overflow: hidden; border: 1px solid rgba(255,255,255,0.15); min-height: 280px; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, rgba(255,255,255,0.04), rgba(255,255,255,0.02)); }

/* === MODIFIED .responsive-img (Rotation Disabled) === */
.responsive-img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: inherit;
    transition: opacity 0.4s ease, transform 0.4s ease, box-shadow 0.4s ease; /* Adjusted transition */
    transform: none; /* Removed rotation/perspective/translateZ */
    will-change: opacity, transform; /* Updated will-change */
}

/* === MODIFIED .image-container:hover .responsive-img (Rotation Disabled) === */
.image-container:hover .responsive-img {
    opacity: 1;
    transform: scale(1.03); /* Keep only scale on hover */
    box-shadow: var(--shadow-medium);
}

.placeholder-instruction { position: absolute; bottom: 10px; left: 50%; transform: translateX(-50%); background: rgba(0,0,0,0.6); color: #fff; padding: 4px 10px; font-size: 0.8rem; border-radius: 4px; opacity: 0.7; transition: opacity 0.3s ease; pointer-events: none; }
.image-container:hover .placeholder-instruction { opacity: 0; }

/* =================== INFO CARDS & GRIDS =================== */
.steps-container, .features-grid, .pricing-cards { display: grid; gap: 2rem; }
.steps-container { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.features-grid { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.pricing-cards { grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); align-items: stretch; }
.features-list { list-style: none; padding: 0; display: grid; gap: 2rem; }

.info-card {
    background: var(--gradient-card); background-size: 200% 200%; background-position: 50% 50%; backdrop-filter: blur(16px); padding: 2.2rem; border-radius: var(--border-radius-md); box-shadow: var(--shadow-soft); border: 1px solid var(--color-border-light); color: var(--color-text); height: 100%; display: flex; flex-direction: column; overflow: hidden; transform-style: preserve-3d; transform: perspective(1200px) rotateX(0) rotateY(0) scale(1) translateY(0); transition: transform 0.5s cubic-bezier(0.175,0.885,0.32,1.275), box-shadow 0.5s ease, border-color 0.4s ease, background-position 0.8s ease; will-change: transform, box-shadow, background-position, border-color;
}
.info-card:hover { transform: perspective(1200px) translateY(-15px) rotateX(5deg) rotateY(-6deg) scale(1.04); box-shadow: var(--shadow-medium), var(--shadow-glow-accent1); border-color: rgba(var(--color-accent1-rgb), 0.7); background-position: 100% 100%; }
.info-card h3 { font-size: 1.3rem; margin-bottom: 0.8rem; font-weight: 600; transition: color 0.3s ease; background: var(--gradient-text); -webkit-background-clip: text; background-clip: text; color: transparent; -webkit-text-fill-color: transparent; }
.info-card:hover h3 { background: linear-gradient(95deg, var(--color-text-light), #f0f0f0); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.info-card p { color: var(--color-text-muted); line-height: 1.7; font-size: 0.95rem; flex-grow: 1; }
.info-card i { font-size: 1.8rem; color: var(--color-accent1); margin-bottom: 1.2rem; display: block; text-align: center; transition: transform 0.4s ease-out, color 0.3s ease; animation: pulseGlow 3.5s infinite alternate ease-in-out; animation-delay: calc(var(--aos-delay, 0ms) + 0.6s); will-change: transform, filter, color; }
.info-card:hover i { animation-play-state: paused; transform: scale(1.2) rotate(10deg); color: var(--color-accent3); }

@keyframes pulseGlow { 0% { transform: scale(1); opacity: 0.7; filter: drop-shadow(0 0 4px rgba(var(--color-accent1-rgb), 0.3)); } 50% { transform: scale(1.08); opacity: 1; filter: drop-shadow(0 0 10px rgba(var(--color-accent1-rgb), 0.6)); } 100% { transform: scale(1); opacity: 0.7; filter: drop-shadow(0 0 4px rgba(var(--color-accent1-rgb), 0.3)); } }

/* =================== HOME SECTION =================== */
#home { min-height: 85vh; padding: 6rem 1.5rem; margin: 0 auto 5rem; max-width: 100%; display: flex; align-items: center; justify-content: center; text-align: center; position: relative; overflow: hidden; }
#home .content-area { background: none; backdrop-filter: none; border: none; box-shadow: none; padding: 0; max-width: 900px; }
#home h1 { font-size: clamp(2.5rem, 6vw, 4rem); margin-bottom: 1.5rem; text-shadow: 0 5px 25px rgba(0,0,0,0.6); line-height: 1.2; }
#home p { font-size: clamp(1rem, 2.5vw, 1.25rem); max-width: 700px; color: #c7cede; margin: 0 auto; line-height: 1.8; }

/* =================== "WHAT IS IT" SECTION =================== */
#what-is-it .content-text p { color: var(--color-text); margin-bottom: 1.8rem; line-height: 1.9; font-size: 1.05rem; }

/* =================== HOW IT WORKS SECTION =================== */
.how-step { text-align: center; }

/* =================== KEY FEATURES SECTION =================== */
.feature-card { text-align: center; }
.feature-card i { text-align: center; }

/* =================== USE CASES SECTION =================== */
.use-cases-container { backdrop-filter: blur(18px); border: 1px solid rgba(255,255,255,0.15); border-radius: var(--border-radius-lg); padding: 3rem; perspective: 1000px; box-shadow: var(--shadow-float); margin-top: 3.5rem; }
.use-cases-grid { display: flex; flex-wrap: wrap; gap: 2rem; justify-content: center; }
.use-case-card { width: 165px; height: 165px; background: transparent; border: 2px solid rgba(var(--color-accent3-rgb), 0.5); border-radius: 50%; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; transition: var(--transition-bounce), border-color 0.3s ease, background 0.3s ease, box-shadow 0.3s ease; padding: 10px; color: var(--color-text); }
.use-case-card:hover { transform: translateY(-10px) scale(1.1) rotateY(5deg); border-color: rgba(var(--color-accent3-rgb), 1); background: rgba(var(--color-accent3-rgb), 0.1); box-shadow: 0 5px 15px rgba(var(--color-accent3-rgb), 0.2); }
.use-case-card h3 { font-size: 1rem; color: var(--color-accent3); margin-bottom: 0.5rem; background: none; -webkit-background-clip: unset; background-clip: unset; -webkit-text-fill-color: unset; text-shadow: none; }
.use-case-card p { font-size: 0.85rem; color: var(--color-text-muted); line-height: 1.4; text-shadow: none; }

/* =================== SECURITY & MANAGEMENT LISTS =================== */
#security ul, #reporting ul { list-style: none; padding: 0; }
#security li, #reporting li { margin: 1rem 0; padding: 1rem 1.5rem; border-left: 4px solid var(--color-accent1); background-color: rgba(30, 41, 59, 0.7); border-radius: var(--border-radius-sm); color: var(--color-text); font-size: 1rem; transition: background-color 0.3s ease, border-color 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease; position: relative; will-change: transform, background-color, border-color; }
#security li:hover, #reporting li:hover { background-color: rgba(var(--color-accent1-rgb), 0.15); border-color: var(--color-accent3); transform: translateX(8px) scale(1.01); box-shadow: 0 4px 10px rgba(0,0,0,0.1); }
#security li strong, #reporting li strong { color: var(--color-text-light); font-weight: 600; }
#reporting li { border-left-color: var(--color-accent2); }
#reporting li:hover { background-color: rgba(var(--color-accent2-rgb), 0.15); border-color: var(--color-accent1); }

/* =================== PRICING SECTION =================== */
.pricing-cards-container { perspective: 1200px; }
.pricing-card { max-width: 400px; padding: 2.5rem; border-top: 5px solid var(--color-accent2); display: flex; flex-direction: column; position: relative; text-align: center; }
.pricing-card .card-content { flex-grow: 1; display: flex; flex-direction: column; }
.pricing-card.popular { border-color: var(--color-accent3); transform: scale(1.04) translateY(-10px); z-index: 5; box-shadow: var(--shadow-medium), var(--shadow-glow-accent3); }
.pricing-cards:has(.popular) .pricing-card:not(.popular):hover { transform: perspective(1200px) translateY(-10px) scale(1.02); box-shadow: var(--shadow-medium); border-color: rgba(var(--color-accent1-rgb), 0.5); }
.popular-badge {
    padding: 5px 15px; /* Slightly reduced padding */ font-size: 0.85rem; position: absolute; top: 5px; left: 50%;
    transform: translateX(-50%); background: var(--gradient-button); color: white; border-radius: 20px; font-weight: 600;
    letter-spacing: 0.8px; box-shadow: 0 2px 8px rgba(0,0,0,0.3);
}
.pricing-card h3 { font-size: 1.6rem; color: var(--color-text-light); text-align: center; margin-bottom: 1rem; background: none; -webkit-background-clip: unset; background-clip: unset; -webkit-text-fill-color: unset; }
.pricing-card p.price { font-size: 2.8rem; margin-bottom: 1.5rem; color: var(--color-text-light); font-weight: 700; text-align: center; line-height: 1; }
.pricing-card p.price span { font-size: 1rem; color: var(--color-text-muted); font-weight: 400; }
.pricing-card ul { list-style: none; padding: 0; margin: 2rem 0; flex-grow: 1; text-align: left; }
.pricing-card ul li { margin: 0.8rem 0; padding-left: 1.8rem; font-size: 0.95rem; color: var(--color-text-muted); position: relative; transition: color 0.3s ease; }
.pricing-card ul li::before { font-family: 'Font Awesome 6 Free'; font-weight: 900; content: '\f00c'; color: var(--color-accent2); position: absolute; left: 0; top: 5px; font-size: 0.85rem; transition: color 0.3s ease; }
.pricing-card:hover ul li { color: var(--color-text); } .pricing-card:hover ul li::before { color: var(--color-accent1); }
.pricing-card.popular ul li::before { color: var(--color-accent3); } .pricing-card.popular:hover ul li::before { color: var(--color-accent1); }
.pricing-card button.contact-trigger { padding: 0.9rem 2rem; font-size: 1rem; font-weight: 500; margin-top: auto; width: 100%; background: var(--gradient-button); border-radius: var(--border-radius-sm); color: var(--color-text-light); transition: var(--transition-smooth), transform 0.2s ease, filter 0.2s ease, box-shadow 0.2s ease; border: none; }
.pricing-card button.contact-trigger:hover { transform: scale(1.05) translateY(-3px); filter: brightness(1.2); box-shadow: 0 10px 30px rgba(var(--color-accent2-rgb), 0.45), var(--shadow-glow-accent2); }
.pricing-card button.contact-trigger:active { transform: scale(1.02) translateY(-1px); filter: brightness(1); }
#pricing .trial-text { margin-top: 3.5rem; font-size: 1rem; color: var(--color-text-muted); text-align: center; }
#pricing .trial-text strong { color: var(--color-text); } #pricing .trial-text small { font-size: 0.8em; display: block; margin-bottom: 1rem; }

/* =================== TRUSTED BY / TESTIMONIALS =================== */
#trusted-by .content-area { backdrop-filter: blur(18px); border-radius: var(--border-radius-lg); padding: 3.5rem; border: 1px solid rgba(255,255,255,0.15); overflow: hidden; box-shadow: var(--shadow-float); position: relative; }
#quote-carousel { position: relative; min-height: 150px; overflow: hidden; }
.quote-slide { opacity: 0; transition: opacity 0.6s ease-in-out, visibility 0s linear 0.6s; position: absolute; top: 0; left: 0; width: 100%; visibility: hidden; }
.quote-slide.active { opacity: 1; position: relative; visibility: visible; transition-delay: 0s; }
.quote-slide blockquote { padding: 2.5rem; font-size: 1.15rem; font-style: italic; border-radius: var(--border-radius-md); border-left: 5px solid var(--color-accent3); background: rgba(17, 24, 39, 0.85); box-shadow: inset 0 2px 5px rgba(0,0,0,0.25); color: var(--color-text); line-height: 1.8; margin: 0; }
.quote-slide span { font-size: 1rem; color: var(--color-accent3); margin-top: 1.5rem; display: block; text-align: right; font-weight: 500; font-style: normal; }
.carousel-controls { margin-top: 1.5rem; display: flex; justify-content: center; gap: 1rem; }
.carousel-arrow { width: 44px; height: 44px; font-size: 1.2rem; background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.15); color: var(--color-text-muted); border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; backdrop-filter: blur(8px); transition: var(--transition-smooth); pointer-events: auto; }
.carousel-arrow:hover { background: rgba(var(--color-accent1-rgb), 0.2); color: var(--color-text-light); transform: scale(1.15); border-color: rgba(var(--color-accent1-rgb), 0.5); }

/* =================== FAQs SECTION =================== */
#faqs { padding: 5rem 1.5rem; }
#faqs .faq-container { background: rgba(31,41,55,0.4); backdrop-filter: blur(16px); border-radius: var(--border-radius-lg); padding: 2.5rem; border: 1px solid rgba(255,255,255,0.15); box-shadow: var(--shadow-float); }
#faqs .faq-header { margin-bottom: 4rem; } .faq-list { display: flex; flex-direction: column; gap: 1rem; } .faq-item { margin-bottom: 0; overflow: hidden; border-radius: var(--border-radius-md); }
.faq-toggle-box { transition: border-color 0.3s ease, border-radius 0.3s ease; border-radius: var(--border-radius-md); border: 1px solid var(--color-border-light); background-color: rgba(17, 24, 39, 0.75); backdrop-filter: blur(12px); }
.faq-toggle-box.open { border-color: rgba(var(--color-accent1-rgb), 0.5); border-bottom-left-radius: 0; border-bottom-right-radius: 0; }
.faq-toggle-btn { padding: 1.4rem 1.8rem; transition: background-color 0.3s ease; background: transparent; width: 100%; display: flex; align-items: center; justify-content: space-between; text-align: left; cursor: pointer; border: none; color: inherit; font-size: inherit; border-radius: inherit; }
.faq-toggle-btn:hover { background-color: rgba(var(--color-accent1-rgb), 0.08); }
.faq-question { font-size: 1.15rem; font-weight: 500; color: var(--color-text); transition: color 0.3s ease; margin: 0; }
.faq-toggle-btn:hover .faq-question.closed { color: var(--color-accent1); } .faq-question.open { color: var(--color-accent1); }
.faq-plus { font-size: 1.4rem; transition: transform 0.4s cubic-bezier(0.4,0,0.2,1), color 0.3s ease; color: var(--color-text-muted); line-height: 1; flex-shrink: 0; margin-left: 1rem; }
.faq-plus.open { transform: rotate(45deg); color: var(--color-accent1); }
.faq-answer-wrapper { max-height: 0; opacity: 0; overflow: hidden; padding: 0 1.8rem; background: linear-gradient(to bottom, rgba(17,24,39,0.85), rgba(25,35,50,0.95)); border: 1px solid rgba(var(--color-accent1-rgb), 0.3); border-top: none; border-bottom-left-radius: var(--border-radius-md); border-bottom-right-radius: var(--border-radius-md); transition: max-height 0.5s cubic-bezier(0.4,0,0.2,1), opacity 0.4s ease-in-out 0.1s, padding 0.5s cubic-bezier(0.4,0,0.2,1), border-color 0.3s ease; will-change: max-height, opacity; }
.faq-answer-wrapper.open { max-height: 500px; opacity: 1; padding: 1.5rem 1.8rem; }
.faq-answer { font-size: 1rem; color: var(--color-text-muted); line-height: 1.9; } .faq-answer p + p { margin-top: 1em; }
.faq-bottom-line { margin-top: 3.5rem; height: 1px; width: 100%; background: linear-gradient(to right, transparent, rgba(var(--color-accent1-rgb), 0.25), transparent); }

/* =================== MODAL =================== */
.modal { position: fixed; z-index: 2000; inset: 0; overflow-y: auto; background-color: var(--color-bg-overlay); backdrop-filter: blur(12px); display: flex; align-items: center; /* Vertical centering */ justify-content: center; padding: 1rem; opacity: 0; visibility: hidden; transition: opacity 0.4s ease, visibility 0.4s ease; }
.modal.modal-visible { opacity: 1; visibility: visible; }
.modal-content {
    background: var(--color-bg-modal);
    padding: 2.5rem; /* Reduced padding */
    border-radius: var(--border-radius-lg); max-width: 650px; width: 95%;
    position: relative; border: 1px solid var(--color-border-light); box-shadow: var(--shadow-medium);
    transform: scale(0.95); opacity: 0;
    transition: transform 0.4s cubic-bezier(0.165,0.84,0.44,1), opacity 0.4s cubic-bezier(0.165,0.84,0.44,1);
    will-change: transform, opacity;
    max-height: 85vh; /* Limit height */
    overflow-y: auto; /* Allow internal scroll if needed */
}
.modal.modal-visible .modal-content { transform: scale(1); opacity: 1; }
.modal-close { position: absolute; top: 18px; right: 20px; font-size: 1.8rem; color: var(--color-text-muted); cursor: pointer; transition: var(--transition-smooth), color 0.2s ease; line-height: 1; padding: 0.25rem 0.5rem; background: none; border: none; }
.modal-close:hover { transform: rotate(90deg) scale(1.15); color: var(--color-text-light); }
.modal-content h2 { font-size: 2rem; margin-bottom: 2rem; background: var(--gradient-text); -webkit-background-clip: text; background-clip: text; color: transparent; -webkit-text-fill-color: transparent; text-align: center; }
.modal-content form { display: flex; flex-direction: column; gap: 1.2rem; /* Slightly reduced gap */ }
.form-group { display: flex; flex-direction: column; }
.form-group label { margin-bottom: 0.5rem; font-size: 0.9rem; color: var(--color-text-muted); font-weight: 500; }
.modal-content form input, .modal-content form textarea, .modal-content form select { width: 100%; padding: 0.9rem 1.1rem; /* Reduced padding slightly */ font-size: 1rem; background: rgba(17, 24, 39, 0.9); border: 1px solid rgba(255,255,255,0.15); border-radius: var(--border-radius-sm); color: var(--color-text); font-family: inherit; transition: border-color 0.3s ease, box-shadow 0.3s ease; -webkit-appearance: none; appearance: none; }
.modal-content form select { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23b0b0b0'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z' clip-rule='evenodd'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 1rem center; background-size: 1.2em 1.2em; padding-right: 3rem; }
.modal-content form select:required:invalid { color: var(--color-text-muted); }
.modal-content form option { background-color: var(--color-bg-dark3); color: var(--color-text); }
.modal-content form option[disabled] { color: var(--color-text-muted); }
.modal-content form input::placeholder, .modal-content form textarea::placeholder { color: var(--color-text-muted); opacity: 0.6; }
.modal-content form input:focus, .modal-content form textarea:focus, .modal-content form select:focus { outline: none; border-color: var(--color-accent1); box-shadow: 0 0 0 3px var(--color-border-focus); }
.modal-content form textarea { resize: vertical; min-height: 100px; }
.modal-content form button[type="submit"] { padding: 1rem; font-size: 1.05rem; background: var(--gradient-button); color: var(--color-text-light); border-radius: var(--border-radius-sm); font-weight: 500; margin-top: 0.5rem; cursor: pointer; border: none; transition: var(--transition-smooth), transform 0.2s ease, filter 0.2s ease, box-shadow 0.2s ease; }
.modal-content form button[type="submit"]:hover:not(:disabled) { transform: scale(1.04) translateY(-2px); filter: brightness(1.15); box-shadow: 0 8px 25px rgba(var(--color-accent2-rgb), 0.4), var(--shadow-glow-accent2); }
.modal-content form button[type="submit"]:disabled { background: var(--color-text-muted); cursor: wait; }
.form-status { margin-top: 1rem; text-align: center; font-size: 0.95rem; min-height: 1.5em; }
.form-status.success { color: #4ade80; } .form-status.error { color: var(--color-error); }

/* =================== CONTACT PAGE FORM =================== */
.contact-form-column { background: rgba(17, 24, 39, 0.6); border: 1px solid var(--color-border-light); border-radius: var(--border-radius-md); padding: 2.5rem; }
.contact-form-column h2 { margin-bottom: 1.5rem; font-size: 1.5rem; }
.contact-form-column form input:not([type="checkbox"]):not([type="hidden"]),
.contact-form-column form textarea,
.contact-form-column form select { width: 100%; padding: 0.85rem 1rem; font-size: 1rem; background: rgba(17, 24, 39, 0.9); border: 1px solid rgba(255,255,255,0.15); border-radius: var(--border-radius-sm); color: var(--color-text); font-family: inherit; transition: border-color 0.3s ease, box-shadow 0.3s ease; -webkit-appearance: none; appearance: none; }
.contact-form-column form select { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23b0b0b0'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z' clip-rule='evenodd'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 1rem center; background-size: 1.2em 1.2em; padding-right: 3rem; }
.contact-form-column form select:required:invalid { color: var(--color-text-muted); }
.contact-form-column form option { background-color: var(--color-bg-dark3); color: var(--color-text); }
.contact-form-column form option[disabled] { color: var(--color-text-muted); }
.contact-form-column form input:not([type="checkbox"])::placeholder,
.contact-form-column form textarea::placeholder { color: var(--color-text-muted); opacity: 0.6; }
.contact-form-column form input:not([type="checkbox"]):focus,
.contact-form-column form textarea:focus,
.contact-form-column form select:focus { outline: none; border-color: var(--color-accent1); box-shadow: 0 0 0 3px var(--color-border-focus); }
.contact-form-column form textarea { resize: vertical; min-height: 100px; }
.contact-form-column .submit-button { width: 100%; padding: 1rem; font-size: 1.05rem; background: var(--gradient-button); color: var(--color-text-light); border-radius: var(--border-radius-sm); font-weight: 600; margin-top: 0.5rem; cursor: pointer; border: none; transition: var(--transition-smooth), transform 0.2s ease, filter 0.2s ease; }
.contact-form-column .submit-button:hover:not(:disabled) { transform: translateY(-2px); filter: brightness(1.15); box-shadow: 0 8px 25px rgba(var(--color-accent2-rgb), 0.4); }
.contact-form-column .submit-button:disabled { background: var(--color-text-muted); cursor: wait; }
.checkbox-group { display: grid; gap: 0.6rem; margin-top: 0.5rem; }
.checkbox-label { display: flex; align-items: center; gap: 0.6rem; cursor: pointer; color: var(--color-text); font-size: 0.95rem; padding: 0.3rem 0; }
.checkbox-label input[type="checkbox"] { cursor: pointer; accent-color: var(--color-accent1); width: 1.1rem; height: 1.1rem; }

/* =================== FOOTER =================== */
footer { padding: 2.5rem 1.5rem; margin-top: 4rem; background: var(--color-bg-dark1); border-top: 1px solid var(--color-border-light); text-align: center; }
footer nav { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 0.6rem 1.4rem; margin-bottom: 1.5rem; }
footer nav a, footer nav button.contact-trigger { font-size: 0.9rem; color: var(--color-text-muted); padding: 0.3rem 0.6rem; border-radius: 5px; transition: color 0.3s ease, background-color 0.3s ease; background: none; border: none; cursor: pointer; }
footer nav a:hover, footer nav button.contact-trigger:hover { color: var(--color-text-light); background-color: rgba(255,255,255,0.06); }
footer p { font-size: 0.85rem; color: var(--color-text-muted); margin: 0;}


/* =================== MOBILE & RESPONSIVE STYLES =================== */
/* Includes adjustments from 960px and 640px breakpoints */
@media (max-width: 960px) {
    .content-area.two-column, .content-area.two-column-biased { gap: 2.5rem; }
    .pricing-cards { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 2rem; }
    .carousel-controls { display: none; } /* Hide arrows on touch devices */
    #home h1 { font-size: clamp(2.2rem, 7vw, 3rem); }
    #home p { font-size: clamp(0.95rem, 3vw, 1.1rem); }
    .section-header h2 { font-size: clamp(1.8rem, 4.5vw, 2.2rem); }
}

@media (max-width: 640px) {
    body { font-size: 15px; }
    .section-container { padding: 3rem 1rem 0; margin: 0 auto 4rem; }
    #home.section-container { padding-top: 5rem; margin-bottom: 4rem; }
    .section-header h2 { font-size: 1.9rem; }
    .section-header p { font-size: 1rem; line-height: 1.7; }
    .section-underline { width: 4.5rem; margin-bottom: 1.2rem; }
    .section-header { margin-bottom: 2.5rem; }
    .content-area { padding: 2rem; margin-top: 2.5rem; }
    .content-area.wide { padding: 2rem; }
    .content-area.two-column, .content-area.two-column-biased { grid-template-columns: 1fr; gap: 2.5rem; }
    /* Ensure images stack correctly */
    #what-is-it .image-container, #security .image-container, #reporting .image-container { grid-row: auto; }
    #what-is-it .image-container, #security .image-container { order: -1; } /* Image first */
    #reporting .image-container { order: 0; } /* Image second */

    .image-container { min-height: 220px; }
    /* Image transform override for mobile was removed as base transform is now 'none' */

    #home { min-height: 75vh; }
    .info-card { padding: 1.8rem; }
    .info-card h3 { font-size: 1.2rem; }
    .info-card p { font-size: 0.9rem; }
    .info-card i { font-size: 1.6rem; margin-bottom: 1rem; animation: none; } /* Disable pulse on mobile */
    .info-card:hover { transform: translateY(-8px); box-shadow: var(--shadow-medium); } /* Simpler hover */
    .info-card:hover i { transform: scale(1.1); color: var(--color-accent3); }
    .steps-container, .features-grid, .pricing-cards, .features-list { grid-template-columns: 1fr; gap: 1.5rem; }
    .pricing-card { max-width: none; padding: 2.2rem; }
    .pricing-card.popular { transform: scale(1); } /* No pop effect on mobile */
    .use-cases-container { padding: 2rem; }
    .use-case-card { width: 130px; height: 130px; }
    .use-case-card:hover { transform: translateY(-6px) scale(1.06); } /* Simpler hover */
    .use-cases-grid { gap: 1.2rem; }
    #security li, #reporting li { font-size: 0.95rem; padding: 0.8rem 1.2rem; }
    #security li:hover, #reporting li:hover { transform: translateX(5px) scale(1.01); } /* Simpler hover */
    #trusted-by .content-area { padding: 2rem; }
    .quote-slide blockquote { font-size: 1.05rem; padding: 1.8rem; }
    .quote-slide span { font-size: 0.95rem; }
    #faqs { padding: 4rem 1rem; }
    #faqs .faq-container { padding: 2rem; }
    .faq-toggle-btn { padding: 1.2rem 1.5rem; }
    .faq-question { font-size: 1.05rem; }
    .faq-plus { font-size: 1.3rem; }
    .faq-answer-wrapper.open { padding: 1.2rem 1.5rem; }
    .faq-answer { font-size: 0.95rem; }
    .modal-content { padding: 2rem; width: calc(100% - 2rem); }
    .modal-content h2 { font-size: 1.7rem; }
    .modal-close { top: 18px; right: 18px; }
    footer { padding: 2rem 1rem; margin-top: 3rem; }
    footer nav { gap: 0.5rem 1.2rem; margin-bottom: 1.2rem; }
}

/* Print Styles */
@media print {
    body { padding-top: 0; background: #fff !important; color: #000 !important; font-size: 12pt; }
    header, footer, #particleCanvas, .cursor-spotlight, .ambient-element, .hamburger, .carousel-controls, .modal, .placeholder-instruction, .popular-badge, .trial-text, .submit-button { display: none !important; }
    nav { display: none !important; } /* Ensure nav is hidden */
    #site-header { position: static; background: none; backdrop-filter: none; box-shadow: none; }
    .section-container { padding: 2rem 0; margin-bottom: 2rem; overflow: visible; }
    main { overflow: visible; }
    .content-area, .info-card, .faq-container { box-shadow: none !important; border: 1px solid #ccc !important; background: #fff !important; backdrop-filter: none !important; padding: 1.5rem; overflow: visible; }
    h1, h2, h3 { color: #000 !important; background: none !important; -webkit-text-fill-color: initial !important; text-shadow: none !important; }
    a { color: #000 !important; text-decoration: underline !important; }
    img { max-width: 80% !important; margin: 1rem auto; }
    .faq-item { page-break-inside: avoid; }
    .faq-answer-wrapper { max-height: none !important; opacity: 1 !important; display: block !important; padding: 1rem 0 0 1rem !important; border: none !important; background: none !important; overflow: visible; }
    .faq-plus { display: none; }
    .form-group { page-break-inside: avoid; }
}
/* In your css/style.css file */

.cta-button-hero {
    display: inline-flex; align-items: center; justify-content: center;
    padding: 1rem 2rem;
    line-height: 1;
    font-size: 1rem;
    font-weight: 600; /* Example font weight */
    background-color: var(--accent-color); /* Use your theme's accent color */
    color: var(--background-color); /* Use your theme's background color for text */
    border: none;
    border-radius: 5px; /* Match other button styles */
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.2s ease;
    text-decoration: none; /* In case it inherits underline */
    text-align: center;
}

.cta-button-hero:hover,
.cta-button-hero:focus {
    background-color: var(--accent-color-dark); /* Slightly darker on hover */
    transform: translateY(-2px); /* Slight lift effect */
    outline: 2px solid var(--accent-color-light); /* Focus outline */
    outline-offset: 2px;
}

/* Adjust styling based on your existing button styles and theme variables */

/* =================== PRODUCT THEMING =================== */
body.product-forge { --product-accent: var(--color-forge); --product-accent-rgb: var(--color-forge-rgb); --product-accent-dark: var(--color-forge-dark); --product-accent-light: var(--color-forge-light); }
body.product-fabric { --product-accent: var(--color-fabric); --product-accent-rgb: var(--color-fabric-rgb); --product-accent-dark: var(--color-fabric-dark); --product-accent-light: var(--color-fabric-light); }
body.product-gateway { --product-accent: var(--color-gateway); --product-accent-rgb: var(--color-gateway-rgb); --product-accent-dark: var(--color-gateway-dark); --product-accent-light: var(--color-gateway-light); }
body.product-nexus { --product-accent: var(--color-nexus); --product-accent-rgb: var(--color-nexus-rgb); --product-accent-dark: var(--color-nexus-dark); --product-accent-light: var(--color-nexus-light); }
body.product-thumbnail { --product-accent: var(--color-thumbnail); --product-accent-rgb: var(--color-thumbnail-rgb); --product-accent-dark: var(--color-thumbnail-dark); --product-accent-light: var(--color-thumbnail-light); }

body[class*="product-"] .section-underline { background: var(--product-accent); }
body[class*="product-"] .info-card i { color: var(--product-accent); }
body[class*="product-"] .info-card:hover { border-color: rgba(var(--product-accent-rgb), 0.7); box-shadow: var(--shadow-medium), 0 0 30px 8px rgba(var(--product-accent-rgb), 0.3); }
body[class*="product-"] .pricing-card { border-top-color: var(--product-accent); }
body[class*="product-"] nav button#contactBtn { background: linear-gradient(95deg, var(--product-accent) 0%, rgba(var(--product-accent-rgb), 0.7) 100%); }
body[class*="product-"] .cta-button-hero { background: linear-gradient(95deg, var(--product-accent) 0%, rgba(var(--product-accent-rgb), 0.7) 100%); }

/* Product Page Hero */
.product-hero { text-align: center; padding: 8rem 1.5rem 4rem; position: relative; overflow: hidden; z-index: 1; }
.product-hero .product-badge { display: inline-block; padding: 0.4rem 1.2rem; border-radius: 20px; font-size: 0.85rem; font-weight: 600; letter-spacing: 0.5px; background: rgba(var(--product-accent-rgb), 0.15); color: var(--product-accent); border: 1px solid rgba(var(--product-accent-rgb), 0.3); margin-bottom: 1.5rem; text-transform: uppercase; }
.product-hero h1 { font-size: clamp(2.5rem, 6vw, 3.5rem); margin-bottom: 1.5rem; line-height: 1.2; }
.product-hero p { font-size: clamp(1rem, 2.5vw, 1.2rem); max-width: 700px; color: var(--color-text-muted); margin: 0 auto 2rem; line-height: 1.8; }

/* Stat Grid */
.stat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 2rem; text-align: center; padding: 2rem 0; }
.stat-item .stat-number { font-size: 2.5rem; font-weight: 700; color: var(--product-accent); display: block; line-height: 1.2; }
.stat-item .stat-label { font-size: 0.9rem; color: var(--color-text-muted); margin-top: 0.5rem; }

/* Footer Grid */
.footer-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 2rem; max-width: 1200px; margin: 0 auto 2rem; text-align: left; }
.footer-col h4 { color: var(--color-text-light); font-size: 1rem; margin-bottom: 1rem; font-weight: 600; }
.footer-col a { display: block; color: var(--color-text-muted); font-size: 0.9rem; padding: 0.3rem 0; transition: color 0.3s ease; text-decoration: none; }
.footer-col a:hover { color: var(--color-text-light); }
.footer-bottom { text-align: center; padding-top: 1.5rem; border-top: 1px solid var(--color-border-light); }
.footer-bottom p { font-size: 0.85rem; color: var(--color-text-muted); margin: 0; }

/* Code Block */
.code-block { background: rgba(17, 24, 39, 0.9); border: 1px solid var(--color-border-light); border-radius: var(--border-radius-sm); padding: 1.5rem; overflow-x: auto; font-family: 'JetBrains Mono', 'Fira Code', monospace; font-size: 0.875rem; line-height: 1.6; color: var(--color-text); }

/* Breadcrumb */
.breadcrumb { display: flex; align-items: center; gap: 0.5rem; font-size: 0.875rem; color: var(--color-text-muted); padding: 1rem 2rem; max-width: 1200px; margin: 0 auto; }
.breadcrumb a { color: var(--color-text-muted); text-decoration: none; }
.breadcrumb a:hover { color: var(--product-accent); }

/* Cookie Consent */
#cookie-consent { position: fixed; bottom: 0; left: 0; right: 0; z-index: 3000; background: rgba(15, 23, 42, 0.98); backdrop-filter: blur(12px); border-top: 1px solid var(--color-border-light); padding: 1.5rem 2rem; }
.cookie-consent-inner { max-width: 1200px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap; }
.cookie-consent-inner p { color: var(--color-text-muted); font-size: 0.9rem; margin: 0; }
.cookie-consent-actions { display: flex; gap: 0.5rem; flex-shrink: 0; }
.cookie-consent-actions button { padding: 0.5rem 1.5rem; border-radius: var(--border-radius-sm); font-size: 0.9rem; font-weight: 500; cursor: pointer; transition: var(--transition-fast); }
.cookie-consent-actions .btn-accept { background: var(--gradient-button); color: var(--color-text-light); border: none; }
.cookie-consent-actions .btn-decline { background: transparent; border: 1px solid var(--color-border-light); color: var(--color-text-muted); }

/* Nav Active */
nav a.nav-active { color: var(--color-text-light); }

/* =================== NAV DROPDOWNS =================== */
.nav-item-dropdown { position: relative; }
.nav-dropdown-trigger {
    font-size: 0.9rem; font-weight: 500; padding: 0.6rem 1.1rem; border-radius: var(--border-radius-sm);
    transition: var(--transition-smooth); color: var(--color-text-muted); background: transparent;
    cursor: pointer; white-space: nowrap; display: inline-flex; align-items: center;
}
.nav-dropdown-trigger:hover { color: var(--color-text-light); }
.nav-dropdown {
    position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(8px);
    background: rgba(15, 23, 42, 0.95); backdrop-filter: blur(16px);
    border: 1px solid var(--color-border-light); border-radius: var(--border-radius-sm);
    padding: 0.5rem 0; min-width: 200px; opacity: 0; visibility: hidden;
    transition: opacity 0.25s ease, visibility 0.25s ease, transform 0.25s ease;
    box-shadow: var(--shadow-medium); z-index: 1100;
}
.nav-item-dropdown:hover .nav-dropdown,
.nav-item-dropdown.dropdown-open .nav-dropdown {
    opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0);
}
.nav-dropdown a {
    display: flex; align-items: center; gap: 0.6rem; padding: 0.6rem 1.2rem;
    font-size: 0.88rem; color: var(--color-text-muted); transition: background 0.2s ease, color 0.2s ease;
    white-space: nowrap;
}
.nav-dropdown a:hover { background: rgba(var(--color-accent1-rgb), 0.1); color: var(--color-text-light); }
.nav-product-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; flex-shrink: 0; }

/* Product page responsive */
@media (max-width: 640px) {
    .product-hero { padding: 6rem 1rem 3rem; }
    .stat-grid { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
    .footer-grid { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
    .cookie-consent-inner { flex-direction: column; text-align: center; }
}

/* =================== SKIP NAVIGATION =================== */
.skip-link {
    position: absolute; top: -100%; left: var(--space-md, 1rem);
    padding: var(--space-sm, 0.5rem) var(--space-md, 1rem);
    background: var(--color-accent1); color: var(--color-text-light);
    z-index: 9999; border-radius: var(--border-radius-sm); font-weight: 600;
    text-decoration: none;
}
.skip-link:focus { top: var(--space-md, 1rem); }

/* =================== CTA COMPONENTS =================== */
.cta-button {
    display: inline-flex; align-items: center; gap: var(--space-sm, 0.5rem);
    padding: 0.9rem 2rem; font-size: var(--text-base, 1rem); font-weight: 600;
    background: var(--gradient-button); color: var(--color-text-light);
    border: none; border-radius: var(--border-radius-sm); cursor: pointer;
    transition: var(--transition-smooth); text-decoration: none; line-height: 1;
}
.cta-button:hover {
    transform: translateY(-2px) scale(1.03); filter: brightness(1.1);
    box-shadow: 0 8px 25px rgba(var(--color-accent1-rgb), 0.4);
    color: var(--color-text-light);
}
.cta-button--product {
    background: linear-gradient(95deg, var(--product-accent) 0%, var(--product-accent-dark) 100%);
}
.cta-button--product:hover {
    box-shadow: 0 8px 25px rgba(var(--product-accent-rgb), 0.4);
}
.cta-button--ghost, .ghost-button {
    background: transparent; border: 1px solid rgba(255, 255, 255, 0.4);
    color: var(--color-text-light); display: inline-flex; align-items: center;
    justify-content: center; gap: var(--space-sm, 0.5rem); padding: 1rem 2rem;
    font-size: var(--text-base, 1rem); font-weight: 600; border-radius: var(--border-radius-sm);
    cursor: pointer; transition: var(--transition-smooth); text-decoration: none; line-height: 1;
}
.cta-button--ghost:hover, .ghost-button:hover {
    background: rgba(255, 255, 255, 0.1); border-color: rgba(255, 255, 255, 0.6);
    box-shadow: none; filter: none; color: var(--color-text-light);
}
.cta-group, .hero-cta-group {
    display: flex; gap: var(--space-md, 1rem); flex-wrap: wrap;
    margin-top: var(--space-xl, 2rem); align-items: center;
}
.cta-group--centered, .hero-cta-group--centered { justify-content: center; }

/* =================== GLASS CARD =================== */
.glass-card {
    background: var(--gradient-card); backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px); border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius-md); padding: var(--space-xl, 2rem);
    box-shadow: var(--shadow-soft); transition: var(--transition-smooth);
}
.glass-card:hover {
    box-shadow: var(--shadow-medium);
    border-color: rgba(var(--product-accent-rgb), 0.3); transform: translateY(-4px);
}
.glass-card--forge { border-top: 4px solid var(--color-forge); }
.glass-card--fabric { border-top: 4px solid var(--color-fabric); }
.glass-card--gateway { border-top: 4px solid var(--color-gateway); }
.glass-card--nexus { border-top: 4px solid var(--color-nexus); }
.glass-card--thumbnail { border-top: 4px solid var(--color-thumbnail); }

/* =================== PROBLEM CARD =================== */
.problem-card {
    background: var(--gradient-card); backdrop-filter: blur(16px);
    border: 1px solid var(--color-border-light); border-radius: var(--border-radius-md);
    padding: var(--space-xl, 2rem); box-shadow: var(--shadow-soft);
    transition: var(--transition-smooth); border-top: 4px solid var(--product-accent);
}
.problem-card:hover {
    box-shadow: var(--shadow-medium); transform: translateY(-4px);
    border-color: rgba(var(--product-accent-rgb), 0.5);
}
.problem-card h3 { color: var(--color-text-light); font-size: 1.2rem; margin-bottom: 0.8rem; }
.problem-card p { color: var(--color-text-muted); line-height: 1.7; font-size: 0.95rem; }

/* =================== STAT BLOCK =================== */
.stat-block { text-align: center; padding: var(--space-lg, 1.5rem); }
.stat-number {
    font-size: clamp(2.5rem, 4vw, 3.5rem); font-weight: 700;
    background: var(--gradient-text); -webkit-background-clip: text;
    -webkit-text-fill-color: transparent; background-clip: text; line-height: 1.1;
}
.stat-label {
    font-size: var(--text-sm, 0.875rem); color: var(--color-text-muted);
    text-transform: uppercase; letter-spacing: 1px; margin-top: var(--space-sm, 0.5rem);
}
.stats-row {
    display: flex; justify-content: center; gap: var(--space-2xl, 3rem); flex-wrap: wrap;
}

/* =================== PRODUCT CARD (HOME) =================== */
.product-card-home {
    background: var(--gradient-card); backdrop-filter: blur(16px);
    border: 1px solid var(--color-border-light); border-radius: var(--border-radius-md);
    padding: var(--space-xl, 2rem); transition: var(--transition-smooth);
    border-top: 4px solid var(--product-accent); display: flex; flex-direction: column;
}
.product-card-home:hover {
    transform: translateY(-6px); box-shadow: var(--shadow-medium),
    0 0 20px 4px rgba(var(--product-accent-rgb), 0.2);
    border-color: rgba(var(--product-accent-rgb), 0.5);
}
.product-card-home h3 { font-size: 1.3rem; color: var(--color-text-light); margin-bottom: 0.6rem; }
.product-card-home p { color: var(--color-text-muted); font-size: 0.95rem; line-height: 1.7; flex-grow: 1; }
.product-card-home .stats-line {
    display: flex; gap: var(--space-md, 1rem); margin-top: var(--space-md, 1rem);
    padding-top: var(--space-md, 1rem); border-top: 1px solid var(--color-border-light);
    font-size: var(--text-sm, 0.875rem); color: var(--color-text-muted);
}
.product-card-home .stats-line strong { color: var(--product-accent); }
.product-card-home[data-accent="forge"] { border-top-color: var(--color-forge); --product-accent: var(--color-forge); --product-accent-rgb: var(--color-forge-rgb); }
.product-card-home[data-accent="fabric"] { border-top-color: var(--color-fabric); --product-accent: var(--color-fabric); --product-accent-rgb: var(--color-fabric-rgb); }
.product-card-home[data-accent="gateway"] { border-top-color: var(--color-gateway); --product-accent: var(--color-gateway); --product-accent-rgb: var(--color-gateway-rgb); }
.product-card-home[data-accent="nexus"] { border-top-color: var(--color-nexus); --product-accent: var(--color-nexus); --product-accent-rgb: var(--color-nexus-rgb); }
.product-card-home[data-accent="thumbnail"] { border-top-color: var(--color-thumbnail); --product-accent: var(--color-thumbnail); --product-accent-rgb: var(--color-thumbnail-rgb); }

.product-card-home .product-hex {
    display: block;
    width: 64px;
    height: 64px;
    margin: 0 0 1rem;
    filter: drop-shadow(0 6px 16px rgba(0, 0, 0, 0.35));
    transition: transform 0.3s ease;
}
.product-card-home:hover .product-hex { transform: translateY(-3px) scale(1.06); }

.hero-product-logo {
    display: block;
    width: clamp(380px, 55vw, 640px);
    height: auto;
    margin: 0 auto 1.75rem;
    filter: drop-shadow(0 18px 44px rgba(0, 0, 0, 0.55));
    animation: hero-logo-float 6s ease-in-out infinite;
}

/* Inline hex logo inside section headings */
.section-product-logo {
    display: inline-block;
    width: 56px;
    height: 56px;
    object-fit: contain;
    vertical-align: middle;
    margin-right: 0.6rem;
    filter: drop-shadow(0 6px 16px rgba(0, 0, 0, 0.4));
    transform: translateY(-4px);
}

/* Hex used inside pipeline step boxes (replaces FontAwesome icon) */
.pipeline-step-logo {
    display: block;
    width: 56px;
    height: 56px;
    object-fit: contain;
    margin: 0 auto 0.5rem;
    filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.35));
}
.pipeline-step-logo.is-featured {
    width: 88px;
    height: 88px;
}

.product-card-home .product-hex {
    object-fit: contain;
}
@keyframes hero-logo-float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
}
@media (prefers-reduced-motion: reduce) {
    .hero-product-logo { animation: none; }
}

/* =================== PIPELINE VISUALIZATION =================== */
.pipeline-flow {
    display: flex; align-items: center; justify-content: center;
    gap: 0; padding: var(--space-xl, 2rem) 0; overflow-x: auto;
}
.pipeline-stage {
    display: flex; flex-direction: column; align-items: center; text-align: center;
    padding: var(--space-lg, 1.5rem) var(--space-md, 1rem);
    background: var(--gradient-card); border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius-md); min-width: 140px;
    transition: var(--transition-smooth); cursor: default; position: relative;
}
.pipeline-stage:hover {
    transform: translateY(-4px); box-shadow: var(--shadow-medium);
    border-color: rgba(var(--product-accent-rgb), 0.5);
}
.pipeline-stage i { font-size: 1.5rem; color: var(--product-accent); margin-bottom: var(--space-sm, 0.5rem); }
.pipeline-stage h4 { font-size: var(--text-sm, 0.875rem); color: var(--color-text-light); margin-bottom: 0.3rem; }
.pipeline-stage p { font-size: var(--text-xs, 0.75rem); color: var(--color-text-muted); line-height: 1.4; }
.pipeline-connector {
    width: 40px; height: 2px; background: linear-gradient(90deg, var(--color-border-light), var(--product-accent), var(--color-border-light));
    flex-shrink: 0; position: relative;
}
.pipeline-connector::after {
    content: ''; position: absolute; right: -4px; top: -3px;
    width: 0; height: 0; border-top: 4px solid transparent;
    border-bottom: 4px solid transparent; border-left: 6px solid var(--product-accent);
}

/* =================== DIFFERENTIATOR BLOCKS =================== */
.differentiator-block {
    display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3xl, 4rem);
    align-items: center; padding: var(--space-3xl, 4rem) 0;
}
.differentiator-block:nth-child(even) { direction: rtl; }
.differentiator-block:nth-child(even) > * { direction: ltr; }
.differentiator-block h3 { font-size: 1.5rem; color: var(--color-text-light); margin-bottom: var(--space-md, 1rem); }
.differentiator-block p { color: var(--color-text-muted); line-height: 1.8; font-size: 1.05rem; }
.diagram-html {
    background: var(--gradient-card); border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius-md); padding: var(--space-xl, 2rem);
    min-height: 200px; display: flex; align-items: center; justify-content: center;
}

/* =================== PERSONA CARD =================== */
.persona-card {
    background: var(--gradient-card); backdrop-filter: blur(16px);
    border: 1px solid var(--color-border-light); border-radius: var(--border-radius-lg);
    padding: var(--space-2xl, 3rem); transition: var(--transition-smooth);
    display: grid; grid-template-columns: auto 1fr; gap: var(--space-xl, 2rem);
    align-items: start;
}
.persona-card:hover {
    box-shadow: var(--shadow-medium); transform: translateY(-4px);
    border-color: rgba(var(--product-accent-rgb), 0.3);
}
.persona-card .persona-icon {
    width: 60px; height: 60px; border-radius: 50%;
    background: rgba(var(--product-accent-rgb), 0.15);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.5rem; color: var(--product-accent);
}
.persona-card h3 { font-size: 1.3rem; color: var(--color-text-light); margin-bottom: 0.4rem; }
.persona-card .persona-role { color: var(--product-accent); font-size: var(--text-sm, 0.875rem); font-weight: 500; margin-bottom: var(--space-md, 1rem); }
.persona-card p { color: var(--color-text-muted); line-height: 1.7; font-size: 0.95rem; }
.persona-card ul { list-style: none; padding: 0; margin-top: var(--space-md, 1rem); }
.persona-card ul li {
    padding: 0.4rem 0 0.4rem 1.5rem; color: var(--color-text-muted);
    font-size: var(--text-sm, 0.875rem); position: relative;
}
.persona-card ul li::before {
    content: '\f00c'; font-family: 'Font Awesome 6 Free'; font-weight: 900;
    position: absolute; left: 0; color: var(--product-accent); font-size: 0.75rem; top: 0.55rem;
}

/* =================== PERSONA CARD (HOME) =================== */
.persona-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem;
}
.persona-card-home {
    background: var(--gradient-card); backdrop-filter: blur(16px);
    border: 1px solid var(--color-border-light); border-radius: var(--border-radius-md);
    overflow: hidden; transition: var(--transition-smooth);
    display: flex; flex-direction: column;
    border-top: 4px solid var(--product-accent);
}
.persona-card-home:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-medium), 0 0 20px 4px rgba(var(--product-accent-rgb), 0.2);
    border-color: rgba(var(--product-accent-rgb), 0.5);
}
.persona-card-home .card-img-wrap {
    height: 200px; overflow: hidden; margin: 0;
    border-radius: 0;
}
.persona-card-home .card-img-wrap img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform 0.4s ease;
}
.persona-card-home:hover .card-img-wrap img {
    transform: scale(1.05);
}
.persona-card-body {
    padding: 1.8rem; display: flex; flex-direction: column; flex-grow: 1;
}
.persona-card-home i {
    font-size: 2rem; margin-bottom: 1rem; display: block;
    background: var(--gradient-text); -webkit-background-clip: text;
    background-clip: text; color: transparent; -webkit-text-fill-color: transparent;
    transition: transform 0.4s ease;
}
.persona-card-home:hover i {
    transform: scale(1.15);
}
.persona-card-home h3 {
    font-size: 1.3rem; color: var(--color-text-light); margin-bottom: 0.6rem; font-weight: 600;
}
.persona-card-home p {
    color: var(--color-text-muted); font-size: 0.95rem; line-height: 1.7; flex-grow: 1;
}
.persona-link {
    display: inline-block; margin-top: 1.2rem; color: var(--color-text-light);
    font-weight: 600; text-decoration: none; font-size: 0.95rem;
    transition: color 0.3s ease, transform 0.3s ease;
}
.persona-link:hover {
    color: var(--color-accent1);
}
.persona-link .fa-arrow-right {
    transition: transform 0.3s ease; font-size: 0.85em; margin-left: 0.3rem;
}
.persona-link:hover .fa-arrow-right {
    transform: translateX(4px);
}
/* Persona accent colors */
.persona-card-home[data-accent="exec"] {
    border-top-color: #8B5CF6; --product-accent: #8B5CF6; --product-accent-rgb: 139,92,246;
}
.persona-card-home[data-accent="tech"] {
    border-top-color: #3B82F6; --product-accent: #3B82F6; --product-accent-rgb: 59,130,246;
}
.persona-card-home[data-accent="vfx"] {
    border-top-color: #F59E0B; --product-accent: #F59E0B; --product-accent-rgb: 245,158,11;
}

/* =================== TRUST BAR =================== */
.trust-bar {
    display: flex; align-items: center; justify-content: center;
    gap: var(--space-xl, 2rem); flex-wrap: wrap;
    padding: var(--space-2xl, 3rem) var(--space-xl, 2rem);
    background: rgba(17, 24, 39, 0.5); border-radius: var(--border-radius-lg);
    border: 1px solid var(--color-border-light);
}
.compliance-badge {
    display: inline-flex; align-items: center; gap: var(--space-sm, 0.5rem);
    padding: 0.5rem 1.2rem; background: rgba(255, 255, 255, 0.05);
    border: 1px solid var(--color-border-light); border-radius: 20px;
    color: var(--color-text-muted); font-size: var(--text-sm, 0.875rem);
    font-weight: 500; transition: var(--transition-fast);
}
.compliance-badge:hover {
    background: rgba(var(--product-accent-rgb), 0.1);
    border-color: rgba(var(--product-accent-rgb), 0.3);
    color: var(--color-text-light);
}
.compliance-badge i { color: var(--product-accent); }

/* =================== FINAL CTA SECTION =================== */
.final-cta {
    text-align: center; padding: var(--space-4xl, 6rem) var(--space-xl, 2rem);
    background: linear-gradient(180deg, transparent 0%, rgba(var(--product-accent-rgb), 0.05) 50%, transparent 100%);
    position: relative;
}
.final-cta h2 {
    font-size: clamp(2rem, 5vw, 2.5rem); color: var(--color-text-light);
    margin-bottom: var(--space-md, 1rem);
}
.final-cta p {
    color: var(--color-text-muted); max-width: 600px; margin: 0 auto var(--space-xl, 2rem);
    font-size: 1.1rem; line-height: 1.8;
}

/* =================== TABBED PANEL =================== */
.tabbed-panel { margin: var(--space-xl, 2rem) 0; }
.tab-bar {
    display: flex; gap: var(--space-xs, 0.25rem); border-bottom: 1px solid var(--color-border-light);
    margin-bottom: var(--space-xl, 2rem); overflow-x: auto;
}
.tab-bar button {
    padding: 0.8rem 1.5rem; font-size: var(--text-sm, 0.875rem); font-weight: 500;
    color: var(--color-text-muted); background: transparent; border: none;
    border-bottom: 2px solid transparent; cursor: pointer; white-space: nowrap;
    transition: var(--transition-fast);
}
.tab-bar button:hover { color: var(--color-text-light); }
.tab-bar button[aria-selected="true"], .tab-bar button.active {
    color: var(--product-accent); border-bottom-color: var(--product-accent);
}
.tab-panel { display: none; }
.tab-panel.active, .tab-panel[aria-hidden="false"] { display: block; }

/* =================== FORMAT GRID =================== */
.format-grid {
    display: flex; flex-wrap: wrap; gap: var(--space-sm, 0.5rem);
    padding: var(--space-md, 1rem) 0;
}
.format-pill {
    display: inline-block; padding: 0.35rem 0.9rem;
    background: rgba(255, 255, 255, 0.05); border: 1px solid var(--color-border-light);
    border-radius: 20px; font-size: var(--text-xs, 0.75rem); color: var(--color-text-muted);
    font-family: var(--font-code, monospace); transition: var(--transition-fast);
}
.format-pill:hover {
    background: rgba(var(--product-accent-rgb), 0.1);
    border-color: rgba(var(--product-accent-rgb), 0.3); color: var(--color-text-light);
}

/* =================== CODE BLOCK (ENHANCED) =================== */
.code-block {
    position: relative; background: rgba(17, 24, 39, 0.9);
    border: 1px solid var(--color-border-light); border-radius: var(--border-radius-md);
    overflow: hidden;
}
.code-block__header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 0.6rem 1rem; background: rgba(0, 0, 0, 0.3);
    border-bottom: 1px solid var(--color-border-light);
}
.code-block__tabs { display: flex; gap: var(--space-xs, 0.25rem); }
.code-block__tab {
    padding: 0.3rem 0.8rem; font-size: var(--text-xs, 0.75rem);
    color: var(--color-text-muted); border-radius: 4px;
    transition: var(--transition-fast); cursor: pointer;
}
.code-block__tab:hover, .code-block__tab.active {
    color: var(--color-text-light); background: rgba(255, 255, 255, 0.1);
}
.code-block__copy {
    font-size: var(--text-xs, 0.75rem); color: var(--color-text-muted);
    padding: 0.3rem 0.6rem; border-radius: 4px; cursor: pointer;
    background: none; border: none;
}
.code-block__copy:hover { color: var(--color-text-light); background: rgba(255, 255, 255, 0.1); }
.code-block pre {
    padding: var(--space-lg, 1.5rem); overflow-x: auto;
    font-size: var(--text-sm, 0.875rem); line-height: 1.6;
    font-family: var(--font-code, monospace); color: var(--color-text); margin: 0;
}
.code-block code { font-family: inherit; background: none; padding: 0; }
.code-block--terminal .code-block__header::before {
    content: ''; display: flex; gap: 6px; width: 12px; height: 12px;
    background: #f87171; border-radius: 50%;
    box-shadow: 18px 0 0 #fbbf24, 36px 0 0 #34d399; margin-right: var(--space-md, 1rem);
}

/* =================== BENCHMARK BARS =================== */
.benchmark-bar {
    background: rgba(255, 255, 255, 0.05); border-radius: 6px;
    height: 28px; position: relative; overflow: hidden;
    margin-bottom: var(--space-sm, 0.5rem);
}
.benchmark-bar-fill {
    height: 100%; border-radius: 6px;
    background: linear-gradient(90deg, var(--product-accent), var(--product-accent-light, var(--product-accent)));
    width: 0; transition: width 1.2s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
}
.benchmark-bar-fill.animated { width: var(--bar-width, 0%); }
.benchmark-bar-label {
    display: flex; justify-content: space-between; align-items: center;
    font-size: var(--text-sm, 0.875rem); color: var(--color-text-muted);
    margin-bottom: 0.3rem;
}
.benchmark-bar-label strong { color: var(--color-text-light); }

/* =================== TECH PILL =================== */
.tech-pill {
    display: inline-flex; align-items: center; gap: 0.3rem;
    padding: 0.3rem 0.8rem; background: rgba(var(--product-accent-rgb), 0.1);
    border: 1px solid rgba(var(--product-accent-rgb), 0.25);
    border-radius: 20px; font-size: var(--text-xs, 0.75rem);
    color: var(--product-accent); font-weight: 500;
}

/* =================== MEGA MENU =================== */
.nav-dropdown--mega { min-width: 480px; padding: var(--space-lg, 1.5rem); }
.mega-menu-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-sm, 0.5rem); }
.mega-menu-item {
    display: flex; align-items: center; gap: var(--space-md, 1rem);
    padding: 0.8rem 1rem; border-radius: var(--border-radius-sm);
    transition: var(--transition-fast); text-decoration: none;
}
.mega-menu-item:hover { background: rgba(255, 255, 255, 0.05); }
.mega-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.mega-menu-item strong { display: block; color: var(--color-text-light); font-size: var(--text-sm, 0.875rem); }
.mega-menu-item small { color: var(--color-text-muted); font-size: var(--text-xs, 0.75rem); }

/* =================== FOOTER ENHANCEMENTS =================== */
.footer-coming-soon {
    display: block; font-size: var(--text-sm, 0.875rem);
    color: var(--color-text-muted); opacity: 0.5; padding: 0.3rem 0;
}
.footer-grid { grid-template-columns: repeat(5, 1fr); }

/* =================== FEATURE GRID =================== */
.feature-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: var(--space-xl, 2rem); }
.feature-grid--3col { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }

/* =================== AMBIENT PRODUCT GLOW =================== */
.ambient-element.ambient-product {
    background: radial-gradient(circle, rgba(var(--product-accent-rgb), 0.15) 0%, transparent 70%);
}

/* =================== SCROLL ANIMATIONS =================== */
[data-animate] { opacity: 0; transition: opacity 0.6s ease, transform 0.6s ease; }
.animate--fade-up { transform: translateY(30px); }
.animate--fade-down { transform: translateY(-30px); }
.animate--fade-left { transform: translateX(30px); }
.animate--fade-right { transform: translateX(-30px); }
.animate--zoom-in { transform: scale(0.9); }
.animate--scale-up { transform: scale(0.95) translateY(10px); }
[data-animate].animate--visible { opacity: 1; transform: translateY(0) translateX(0) scale(1); }
@media (prefers-reduced-motion: reduce) {
    [data-animate] { opacity: 1; transform: none; transition: none; }
}

/* =================== PRODUCT PAGE OVERRIDES =================== */
.forge-page .section-underline { background: var(--color-forge); }
.fabric-page .section-underline { background: var(--color-fabric); }
.page-gateway .section-underline { background: var(--color-gateway); }
.page-nexus .section-underline { background: var(--color-nexus); }
.page-thumbnail .section-underline { background: var(--color-thumbnail); }

/* =================== HERO TEMPLATE (ENHANCED) =================== */
.product-hero .hero-content {
    max-width: 1200px; margin: 0 auto;
    display: grid; grid-template-columns: 1fr 1fr;
    gap: var(--space-3xl, 4rem); align-items: center; width: 100%;
}
.product-hero--centered .hero-content {
    grid-template-columns: 1fr; text-align: center; max-width: 800px;
}
.product-hero .hero-subtitle {
    font-size: clamp(1rem, 2.5vw, 1.2rem); color: var(--color-text-muted);
    line-height: 1.8; max-width: 600px; margin-top: var(--space-lg, 1.5rem);
}
.product-hero--centered .hero-subtitle { margin-left: auto; margin-right: auto; }

/* =================== MODAL SUBTITLE =================== */
.modal-subtitle {
    text-align: center; color: var(--color-text-muted);
    font-size: var(--text-sm, 0.875rem); margin-bottom: var(--space-lg, 1.5rem);
}

/* =================== RESPONSIVE: NEW COMPONENTS (960px) =================== */
@media (max-width: 960px) {
    .product-hero .hero-content { grid-template-columns: 1fr; text-align: center; }
    .product-hero { min-height: 70vh; }
    .differentiator-block { grid-template-columns: 1fr; }
    .differentiator-block:nth-child(even) { direction: ltr; }
    .persona-card { grid-template-columns: 1fr; text-align: center; }
    .persona-card .persona-icon { margin: 0 auto; }
    .persona-grid { grid-template-columns: 1fr; max-width: 500px; margin: 0 auto; }
    .pipeline-flow { flex-wrap: wrap; gap: var(--space-md, 1rem); }
    .pipeline-connector { width: 2px; height: 30px; transform: rotate(0); }
    .pipeline-connector::after { right: auto; top: auto; bottom: -4px; left: -3px;
        border-top: 6px solid var(--product-accent); border-left: 4px solid transparent;
        border-right: 4px solid transparent; border-bottom: none; }
    .footer-grid { grid-template-columns: repeat(2, 1fr); }
    .mega-menu-grid { grid-template-columns: 1fr; }
    .nav-dropdown--mega { min-width: 0; }
}

/* =================== RESPONSIVE: NEW COMPONENTS (640px) =================== */
@media (max-width: 640px) {
    .cta-group, .hero-cta-group { flex-direction: column; align-items: stretch; }
    .cta-button, .ghost-button { justify-content: center; }
    .stats-row { gap: var(--space-lg, 1.5rem); }
    .stat-number { font-size: 2.2rem; }
    .pipeline-flow { flex-direction: column; align-items: center; }
    .pipeline-connector { width: 2px; height: 24px; }
    .trust-bar { gap: var(--space-md, 1rem); }
    .persona-card { padding: var(--space-xl, 2rem); }
    .footer-grid { grid-template-columns: 1fr; gap: var(--space-xl, 2rem); }
    .tab-bar { gap: 0; }
    .tab-bar button { padding: 0.6rem 1rem; font-size: var(--text-xs, 0.75rem); }
    .benchmark-bar { height: 22px; }
    .differentiator-block { gap: var(--space-xl, 2rem); padding: var(--space-xl, 2rem) 0; }
}

/* =================== MOBILE RESPONSIVE FIXES =================== */

/* Fix grid children overflow in all column modes */
.content-area.two-column > *,
.content-area.two-column-biased > * {
    min-width: 0;
}
/* Text wrapping only for text-content blocks, not diagrams */
.content-area .text-content {
    overflow-wrap: break-word;
    word-break: break-word;
}

@media (max-width: 640px) {
    /* ROOT FIX: content-area overflow clips text on narrow viewports */
    .content-area {
        overflow: visible !important;
    }

    /* Reduce content-area padding on small screens */
    .content-area.wide {
        padding: 1.5rem;
    }

    /* Reduce inline border-left padding on text-content blocks */
    .text-content[style*="padding-left"] {
        padding-left: 1rem !important;
        border-left-width: 3px !important;
    }

    /* Diagrams: scroll horizontally if too wide, preserve text */
    .diagram-html {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        min-width: 0;
        word-break: normal;
        overflow-wrap: normal;
    }
    .diagram-html > div {
        min-width: 0;
        word-break: normal;
    }

    /* Force 3-column diagram grids to stack vertically on mobile */
    .diagram-html [style*="grid-template-columns: 1fr auto 1fr"] {
        grid-template-columns: 1fr !important;
        gap: 1rem !important;
        text-align: center;
    }
    /* Center the arrow/icon divs when stacked */
    .diagram-html [style*="grid-template-columns: 1fr auto 1fr"] > [style*="font-size: 2"] {
        transform: rotate(90deg);
        justify-self: center;
    }

    /* Tighten spacing in inline flex/grid diagrams */
    .diagram-html [style*="gap: 2rem"] {
        gap: 0.75rem !important;
    }
    .diagram-html [style*="padding: 2rem"] {
        padding: 1rem !important;
    }
    /* Smaller text inside diagram elements */
    .diagram-html span,
    .diagram-html div {
        word-break: normal !important;
        overflow-wrap: normal !important;
    }

    /* API categories list items - tighter padding, ensure wrap */
    .content-area ul li[style*="padding: 1rem 1.5rem"] {
        padding: 0.8rem 1rem !important;
        overflow-wrap: break-word;
        word-break: break-word;
    }

    /* Code blocks: scroll horizontally, smaller font */
    .code-example,
    .code-block {
        max-width: 100%;
        overflow-x: auto;
    }
    .code-example pre,
    .code-block pre {
        font-size: 0.75rem;
    }

    /* Persona cards - tighter padding */
    .persona-card {
        padding: var(--space-lg, 1.5rem);
    }

    /* Trust bar badges - smaller on mobile */
    .compliance-badge {
        padding: 0.4rem 0.8rem;
        font-size: var(--text-xs, 0.75rem);
    }

    /* Override inline grids with min-width > viewport (e.g. minmax(500px, 1fr)) */
    [style*="minmax(500px"] {
        grid-template-columns: 1fr !important;
    }
    [style*="minmax(400px"] {
        grid-template-columns: 1fr !important;
    }

    /* Tables: tighter padding on mobile, let content-area handle overflow */
    table {
        width: 100%;
        border-collapse: collapse;
    }
    table th,
    table td {
        padding: 0.5rem 0.5rem;
        font-size: 0.8rem;
    }
    /* Content areas containing tables need scroll, not clip */
    .content-area:has(table) {
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch;
    }

    /* Prevent horizontal body scroll */
    body {
        overflow-x: hidden;
    }

    /* Info cards - prevent clipping on narrow viewports */
    .info-card {
        min-width: 0;
        max-width: 100%;
        overflow: visible;
        word-break: break-word;
        overflow-wrap: break-word;
    }
    .info-card h4 {
        word-break: break-word;
        overflow-wrap: break-word;
    }

    /* Chat mockup content - ensure text wraps properly */
    .chat-content {
        overflow-wrap: break-word !important;
        word-break: break-word !important;
        white-space: pre-wrap !important;
    }
    .chat-sources {
        overflow-wrap: break-word;
        word-break: break-word;
    }
    .chat-entity {
        word-break: break-all;
    }

    /* Reset order on diagram elements when stacked (inline order:-1 becomes unwanted) */
    .content-area.two-column .diagram-html[style*="order"],
    .content-area.two-column-biased .diagram-html[style*="order"] {
        order: 0 !important;
    }

    /* Feature grids - ensure single column on mobile */
    .features-grid {
        grid-template-columns: 1fr !important;
    }

    /* Speed bars in comparison tables - scale down aggressively for mobile */
    .speed-bar {
        max-width: 100% !important;
        font-size: 0.7rem;
    }
    .speed-bar[style*="width: 260px"] { width: 100px !important; }
    .speed-bar[style*="width: 220px"] { width: 80px !important; }
    .speed-bar[style*="width: 150px"] { width: 60px !important; }

    /* Comparison table - constrain to container */
    .comparison-table {
        table-layout: fixed;
        width: 100%;
    }

    /* Benchmark bars in thumbnail page */
    .benchmark-bar-label {
        font-size: 0.75rem;
        right: 0.5rem;
    }

    /* Routing diagram nodes - tighter on mobile */
    .routing-node {
        padding: 1rem;
        font-size: 0.85rem;
    }
    .routing-diagram {
        gap: 0.75rem;
    }

    /* Inline flex containers with gap > 1.5rem */
    [style*="gap: 3rem"] {
        gap: 1.5rem !important;
    }
    [style*="gap: 2.5rem"] {
        gap: 1.25rem !important;
    }

    /* Section containers - reduce padding */
    .section-container {
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }

    /* Hero sections - smaller text */
    .hero h1, [class*="hero"] h1 {
        font-size: 1.75rem !important;
        line-height: 1.2;
    }
    .hero p, [class*="hero"] p {
        font-size: 0.95rem;
    }

    /* CTA buttons - full width on mobile */
    .cta-buttons, [class*="cta-button"] {
        flex-direction: column;
        width: 100%;
    }
    .cta-buttons a, .cta-buttons button {
        width: 100%;
        text-align: center;
    }

    /* Specs list items */
    .specs-list li {
        padding: 0.75rem 1rem !important;
        font-size: 0.9rem;
    }

    /* Tech pills - allow wrapping */
    .tech-pill {
        font-size: 0.75rem;
        padding: 0.35rem 0.8rem;
    }

    /* Footer grid - 2-column on mobile */
    footer .footer-grid,
    footer > div > div:first-child {
        grid-template-columns: 1fr 1fr !important;
        gap: 1.5rem;
    }

    /* Footer links - meet 44px touch target minimum */
    .footer-col a {
        padding: 0.5rem 0;
        min-height: 44px;
        display: flex;
        align-items: center;
    }
}

/* Tablet refinements */
@media (max-width: 960px) and (min-width: 641px) {
    .content-area.wide.two-column {
        gap: 2rem;
    }
    /* Stack all two-column layouts top/bottom on tablet */
    .content-area.two-column,
    .content-area.two-column-biased {
        grid-template-columns: 1fr !important;
        gap: 2rem;
    }
    .content-area.two-column .diagram-html[style*="order"],
    .content-area.two-column-biased .diagram-html[style*="order"] {
        order: 0 !important;
    }
    .text-content[style*="padding-left"] {
        padding-left: 1.5rem !important;
    }
    .diagram-html {
        min-width: 0;
        overflow-x: auto;
    }

    /* Tablet - single column for feature/step grids */
    .features-grid,
    .steps-container {
        grid-template-columns: 1fr !important;
    }

    /* Speed bars - moderate scaling on tablet */
    .speed-bar[style*="width: 260px"] { width: 200px !important; }
    .speed-bar[style*="width: 220px"] { width: 180px !important; }

    /* Section padding refinement */
    .section-container {
        padding-left: 1.5rem !important;
        padding-right: 1.5rem !important;
    }

    /* Footer - 4-column on tablet */
    footer .footer-grid,
    footer > div > div:first-child {
        grid-template-columns: repeat(4, 1fr) !important;
    }
}

/* =================== GENERATED IMAGE STYLES =================== */

/* Hero background image */
.hero-bg-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    overflow: hidden;
}
.hero-bg-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.15;
    filter: blur(1px);
}
#home .content-area {
    position: relative;
    z-index: 1;
}

/* Section background images */
.section-bg-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    overflow: hidden;
    pointer-events: none;
}
.section-bg-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.08;
}

/* Card images */
.card-img-wrap {
    height: 180px;
    overflow: hidden;
    border-radius: var(--border-radius-md) var(--border-radius-md) 0 0;
    margin: -1.5rem -1.5rem 1.25rem -1.5rem;
}
.card-img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}
.info-card:hover .card-img-wrap img {
    transform: scale(1.05);
}

/* Differentiator images */
.diff-image-wrap {
    border-radius: var(--border-radius-md);
    overflow: hidden;
    border: 1px solid var(--color-border-light);
}
.diff-image-wrap img {
    width: 100%;
    height: auto;
    display: block;
}

/* Persona card images */
.persona-card .card-img-wrap {
    height: 160px;
}

@media (max-width: 768px) {
    .card-img-wrap {
        height: 140px;
    }
    .persona-card .card-img-wrap {
        height: 120px;
    }
    .persona-card-home .card-img-wrap {
        height: 160px;
    }
    .persona-card-body {
        padding: 1.4rem;
    }
}
