/* CSS Variables */
:root {
    /* Stable palette */
    --sa-dark: #0f172a;
    --sa-dark-lighter: #1e293b;
    --sa-dark-deep: #090e16;
    --sa-gray: #64748b;
    --sa-gray-light: #94a3b8;
    --sa-light: #f8fafc;
    --sa-white: #ffffff;
    --sa-black: #000000;
    --sa-black-50: rgba(0, 0, 0, 0.5);
    --sa-cyan: #00d8ff;
    --sa-cyan-rgb: 0, 216, 255;
    --sa-cyan-04: rgba(0, 216, 255, 0.04);
    --sa-cyan-08: rgba(0, 216, 255, 0.08);
    --sa-cyan-10: rgba(0, 216, 255, 0.1);
    --sa-cyan-15: rgba(0, 216, 255, 0.15);
    --sa-cyan-20: rgba(0, 216, 255, 0.2);
    --sa-cyan-30: rgba(0, 216, 255, 0.3);
    --sa-cyan-40: rgba(0, 216, 255, 0.4);
    --sa-cyan-60: rgba(0, 216, 255, 0.6);

    /* Semantic theme roles */
    --bg: var(--sa-dark);
    --bg-elevated: var(--sa-dark-lighter);
    --bg-deep: var(--sa-dark-deep);
    --bg-overlay: rgba(9, 14, 22, 0.82);
    --bg-overlay-strong: rgba(15, 23, 42, 0.95);
    --bg-overlay-max: rgba(8, 10, 20, 0.97);
    --bg-scrim: rgba(15, 23, 42, 0.5);
    --bg-hover: rgba(255, 255, 255, 0.05);
    --fg: var(--sa-light);
    --fg-muted: var(--sa-gray-light);
    --fg-subtle: var(--sa-gray);
    --fg-soft: rgba(248, 250, 252, 0.4);
    --fg-soft-strong: rgba(248, 250, 252, 0.75);
    --border: rgba(255, 255, 255, 0.05);
    --border-strong: rgba(255, 255, 255, 0.1);
    --border-stronger: rgba(255, 255, 255, 0.2);
    --accent: var(--sa-cyan);
    --accent-rgb: var(--sa-cyan-rgb);
    --accent-04: var(--sa-cyan-04);
    --accent-08: var(--sa-cyan-08);
    --accent-10: var(--sa-cyan-10);
    --accent-15: var(--sa-cyan-15);
    --accent-20: var(--sa-cyan-20);
    --accent-30: var(--sa-cyan-30);
    --accent-40: var(--sa-cyan-40);
    --accent-60: var(--sa-cyan-60);
    --accent-ink: var(--sa-dark);
    --service-ink: var(--accent-ink);
    --focus-ring: 0 0 0 3px rgba(var(--accent-rgb), 0.18);
    --shadow-strong: var(--sa-black-50);
    --particle-line-opacity: 0.3;
    --particle-glow-opacity: 0.08;
    --particle-node-opacity: 0.6;
    --particle-node-pulse-opacity: 0.4;
    --page-particle-line-opacity: 0.15;
    --page-particle-glow-opacity: 0.04;
    --page-particle-node-opacity: 0.4;
    --page-particle-node-pulse-opacity: 0.3;
    --logo-node-stroke-opacity: 0.6;
    --logo-node-ring-opacity: 0.4;

    /* Stable palette families */
    --blue: #4f6cf7;
    --blue-fill: #2563eb;
    --blue-rgb: 79, 108, 247;
    --blue-08: rgba(79, 108, 247, 0.08);
    --blue-10: rgba(79, 108, 247, 0.1);
    --blue-15: rgba(79, 108, 247, 0.15);
    --blue-20: rgba(79, 108, 247, 0.2);
    --blue-40: rgba(79, 108, 247, 0.4);
    --blue-60: rgba(79, 108, 247, 0.6);

    /* Green family */
    --green: #10b981;
    --green-08: rgba(16, 185, 129, 0.08);
    --green-10: rgba(16, 185, 129, 0.1);
    --green-15: rgba(16, 185, 129, 0.15);
    --green-20: rgba(16, 185, 129, 0.2);

    /* Amber / orange family */
    --amber: #f59e0b;
    --amber-08: rgba(245, 158, 11, 0.08);
    --amber-10: rgba(245, 158, 11, 0.1);
    --amber-15: rgba(245, 158, 11, 0.15);
    --amber-20: rgba(245, 158, 11, 0.2);

    /* Rose family */
    --rose: #f43f5e;
    --rose-08: rgba(244, 63, 94, 0.08);
    --rose-15: rgba(244, 63, 94, 0.15);
    --rose-20: rgba(244, 63, 94, 0.2);

    /* Purple family */
    --purple: #6366f1;
    --purple-fill: #4f46e5;
    --purple-08: rgba(99, 102, 241, 0.08);
    --purple-10: rgba(99, 102, 241, 0.1);
    --purple-15: rgba(99, 102, 241, 0.15);
    --purple-20: rgba(99, 102, 241, 0.2);
    --purple-40: rgba(99, 102, 241, 0.4);
    --purple-60: rgba(99, 102, 241, 0.6);
    --purple-soft: #8b5cf6;
    --purple-soft-fill: #7c3aed;
    --purple-soft-08: rgba(139, 92, 246, 0.08);
    --purple-soft-10: rgba(139, 92, 246, 0.1);
    --purple-soft-15: rgba(139, 92, 246, 0.15);
    --purple-soft-20: rgba(139, 92, 246, 0.2);
    --purple-soft-40: rgba(139, 92, 246, 0.4);
    --purple-soft-60: rgba(139, 92, 246, 0.6);
}

[data-theme="light"] {
    --bg: #bfd6f1;
    --bg-elevated: #cadef6;
    --bg-deep: #aec6e4;
    --bg-overlay: rgba(191, 214, 241, 0.9);
    --bg-overlay-strong: rgba(201, 220, 245, 0.95);
    --bg-overlay-max: rgba(206, 224, 247, 0.98);
    --bg-scrim: rgba(191, 214, 241, 0.77);
    --bg-hover: rgba(15, 23, 42, 0.05);
    --fg: #172233;
    --fg-muted: #4d6074;
    --fg-subtle: #667a8f;
    --fg-soft: rgba(23, 34, 51, 0.41);
    --fg-soft-strong: rgba(23, 34, 51, 0.69);
    --border: rgba(23, 34, 51, 0.073);
    --border-strong: rgba(23, 34, 51, 0.125);
    --border-stronger: rgba(23, 34, 51, 0.21);
    --accent-ink: var(--sa-dark);
    --service-ink: var(--accent-ink);
    --accent: #0891b2;
    --accent-rgb: 8, 145, 178;
    --accent-04: rgba(8, 145, 178, 0.04);
    --accent-08: rgba(8, 145, 178, 0.08);
    --accent-10: rgba(8, 145, 178, 0.1);
    --accent-15: rgba(8, 145, 178, 0.15);
    --accent-20: rgba(8, 145, 178, 0.2);
    --accent-30: rgba(8, 145, 178, 0.3);
    --accent-40: rgba(8, 145, 178, 0.4);
    --accent-60: rgba(8, 145, 178, 0.6);
    --shadow-strong: rgba(15, 23, 42, 0.165);
    --particle-line-opacity: 0.42;
    --particle-glow-opacity: 0.14;
    --particle-node-opacity: 0.76;
    --particle-node-pulse-opacity: 0.5;
    --page-particle-line-opacity: 0.24;
    --page-particle-glow-opacity: 0.08;
    --page-particle-node-opacity: 0.58;
    --page-particle-node-pulse-opacity: 0.38;
    --logo-node-stroke-opacity: 0.82;
    --logo-node-ring-opacity: 0.58;
}

@media (prefers-color-scheme: light) {
    :root:not([data-theme="dark"]) {
        --bg: #bfd6f1;
        --bg-elevated: #cadef6;
        --bg-deep: #aec6e4;
        --bg-overlay: rgba(191, 214, 241, 0.9);
        --bg-overlay-strong: rgba(201, 220, 245, 0.95);
        --bg-overlay-max: rgba(206, 224, 247, 0.98);
        --bg-scrim: rgba(191, 214, 241, 0.77);
        --bg-hover: rgba(15, 23, 42, 0.05);
        --fg: #172233;
        --fg-muted: #4d6074;
        --fg-subtle: #667a8f;
        --fg-soft: rgba(23, 34, 51, 0.41);
        --fg-soft-strong: rgba(23, 34, 51, 0.69);
        --border: rgba(23, 34, 51, 0.073);
        --border-strong: rgba(23, 34, 51, 0.125);
        --border-stronger: rgba(23, 34, 51, 0.21);
        --accent-ink: var(--sa-dark);
        --service-ink: var(--accent-ink);
        --accent: #0891b2;
        --accent-rgb: 8, 145, 178;
        --accent-04: rgba(8, 145, 178, 0.04);
        --accent-08: rgba(8, 145, 178, 0.08);
        --accent-10: rgba(8, 145, 178, 0.1);
        --accent-15: rgba(8, 145, 178, 0.15);
        --accent-20: rgba(8, 145, 178, 0.2);
        --accent-30: rgba(8, 145, 178, 0.3);
        --accent-40: rgba(8, 145, 178, 0.4);
        --accent-60: rgba(8, 145, 178, 0.6);
        --shadow-strong: rgba(15, 23, 42, 0.165);
        --particle-line-opacity: 0.42;
        --particle-glow-opacity: 0.14;
        --particle-node-opacity: 0.76;
        --particle-node-pulse-opacity: 0.5;
        --page-particle-line-opacity: 0.24;
        --page-particle-glow-opacity: 0.08;
        --page-particle-node-opacity: 0.58;
        --page-particle-node-pulse-opacity: 0.38;
        --logo-node-stroke-opacity: 0.82;
        --logo-node-ring-opacity: 0.58;
    }
}

/* Per-service accent colors — applied to service buttons, desktop panels, and mobile accordion panels */
[data-service="ai"], [data-panel="ai"], [data-mobile-panel="ai"] {
    --service-color: var(--blue);
    --service-color-20: var(--blue-20);
    --service-color-15: var(--blue-15);
    --service-color-08: var(--blue-08);
    --service-ink: var(--sa-white);
    --service-fill: var(--blue-fill);
    --service-fill-ink: var(--sa-white);
}

[data-service="agentic"], [data-panel="agentic"], [data-mobile-panel="agentic"] {
    --service-color: var(--accent);
    --service-color-20: var(--accent-20);
    --service-color-15: var(--accent-15);
    --service-color-08: var(--accent-08);
    --service-ink: var(--accent-ink);
    --service-fill: var(--accent);
    --service-fill-ink: var(--accent-ink);
}

[data-service="automation"], [data-panel="automation"], [data-mobile-panel="automation"] {
    --service-color: var(--green);
    --service-color-20: var(--green-20);
    --service-color-15: var(--green-15);
    --service-color-08: var(--green-08);
    --service-ink: var(--sa-dark);
    --service-fill: var(--green);
    --service-fill-ink: var(--sa-dark);
}

[data-service="process"], [data-panel="process"], [data-mobile-panel="process"] {
    --service-color: var(--amber);
    --service-color-20: var(--amber-20);
    --service-color-15: var(--amber-15);
    --service-color-08: var(--amber-08);
    --service-ink: var(--sa-dark);
    --service-fill: var(--amber);
    --service-fill-ink: var(--sa-dark);
}

[data-service="secure"], [data-panel="secure"], [data-mobile-panel="secure"] {
    --service-color: var(--rose);
    --service-color-20: var(--rose-20);
    --service-color-15: var(--rose-15);
    --service-color-08: var(--rose-08);
    --service-ink: var(--sa-dark);
    --service-fill: var(--rose);
    --service-fill-ink: var(--sa-dark);
}

[data-service="training"], [data-panel="training"], [data-mobile-panel="training"] {
    --service-color: var(--purple);
    --service-color-20: var(--purple-20);
    --service-color-15: var(--purple-15);
    --service-color-08: var(--purple-08);
    --service-ink: var(--sa-white);
    --service-fill: var(--purple-fill);
    --service-fill-ink: var(--sa-white);
}

[data-service="smartscan"], [data-panel="smartscan"], [data-mobile-panel="smartscan"] {
    --service-color: var(--blue);
    --service-color-20: var(--blue-20);
    --service-color-15: var(--blue-15);
    --service-color-08: var(--blue-08);
    --service-ink: var(--sa-white);
    --service-fill: var(--blue-fill);
    --service-fill-ink: var(--sa-white);
}

[data-service="ontwerp"], [data-panel="ontwerp"], [data-mobile-panel="ontwerp"] {
    --service-color: var(--rose);
    --service-color-20: var(--rose-20);
    --service-color-15: var(--rose-15);
    --service-color-08: var(--rose-08);
    --service-ink: var(--sa-dark);
    --service-fill: var(--rose);
    --service-fill-ink: var(--sa-dark);
}

[data-service="ontwikkeling"], [data-panel="ontwikkeling"], [data-mobile-panel="ontwikkeling"] {
    --service-color: var(--green);
    --service-color-20: var(--green-20);
    --service-color-15: var(--green-15);
    --service-color-08: var(--green-08);
    --service-ink: var(--sa-dark);
    --service-fill: var(--green);
    --service-fill-ink: var(--sa-dark);
}

[data-service="implementatie"], [data-panel="implementatie"], [data-mobile-panel="implementatie"] {
    --service-color: var(--amber);
    --service-color-20: var(--amber-20);
    --service-color-15: var(--amber-15);
    --service-color-08: var(--amber-08);
    --service-ink: var(--sa-dark);
    --service-fill: var(--amber);
    --service-fill-ink: var(--sa-dark);
}

[data-service="optimalisatie"], [data-panel="optimalisatie"], [data-mobile-panel="optimalisatie"] {
    --service-color: var(--purple);
    --service-color-20: var(--purple-20);
    --service-color-15: var(--purple-15);
    --service-color-08: var(--purple-08);
    --service-ink: var(--sa-white);
    --service-fill: var(--purple-fill);
    --service-fill-ink: var(--sa-white);
}

[data-service="smartspace"], [data-panel="smartspace"], [data-mobile-panel="smartspace"] {
    --service-color: var(--purple-soft);
    --service-color-20: var(--purple-soft-20);
    --service-color-15: var(--purple-soft-15);
    --service-color-08: var(--purple-soft-08);
    --service-ink: var(--sa-white);
    --service-fill: var(--purple-soft-fill);
    --service-fill-ink: var(--sa-white);
}

/* Reset & Base */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    color-scheme: dark;
}

html[data-theme="dark"] {
    color-scheme: dark;
}

html[data-theme="light"] {
    color-scheme: light;
}

@media (prefers-color-scheme: light) {
    html:not([data-theme="dark"]) {
        color-scheme: light;
    }
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    background-color: var(--bg);
    color: var(--fg);
    line-height: 1.6;
    overflow-x: hidden;
}

a {
    text-decoration: none;
    color: inherit;
}

ul {
    list-style: none;
}

.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

/* Typography */
h1, h2, h3, h4 {
    font-weight: 600;
    line-height: 1.2;
}

h1 {
    font-size: clamp(2.5rem, 5vw, 4rem);
}

h2 {
    font-size: clamp(2rem, 4vw, 3rem);
}

h3 {
    font-size: 1.5rem;
}

.gradient-text {
    color: var(--accent);
    -webkit-text-fill-color: var(--accent);
}

.section-title {
    text-align: center;
    margin-bottom: 16px;
}

.section-subtitle {
    text-align: center;
    color: var(--fg-muted);
    max-width: 900px;
    margin: 0 auto 60px;
}

/* Buttons */
.btn {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 14px 32px;
    border-radius: 8px;
    font-weight: 500;
    font-size: 1rem;
    cursor: pointer;
    transition: all 0.3s ease;
    border: none;
}

.btn-primary {
    background: var(--service-fill, var(--service-color, var(--accent)));
    color: var(--service-fill-ink, var(--service-ink, var(--accent-ink)));
    font-weight: 600;
}

.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 40px var(--service-color-20, var(--accent-40));
}

.btn-secondary {
    background: transparent;
    color: var(--fg);
    border: 1px solid var(--accent);
}

.btn-secondary:hover {
    border-color: var(--accent);
    color: var(--accent);
}

/* Service panels: "meer info" button uses the service accent color */
.services-panel-content .btn-secondary,
.services-mobile-content .btn-secondary {
    border-color: var(--service-color);
    color: var(--service-color);
}

.services-panel-content .btn-secondary:hover,
.services-mobile-content .btn-secondary:hover {
    border-color: var(--service-color);
    color: var(--service-color);
    background: var(--service-color-08);
}

.btn-sm {
    padding: 8px 20px;
    font-size: 0.875rem;
}
