/* Services Page Specific Styles */
.mx-auto { margin-left: auto; margin-right: auto; }
.text-center { text-align: center; }
.bg-darker { background-color: #020202; }

.services-hero {
    height: 70vh;
    display: flex;
    align-items: center;
    position: relative;
    padding-top: 10vh;
}

.process-header {
    margin-bottom: 8rem;
    text-align: center;
}

/* Vertical Timeline Draw */
.timeline-container {
    position: relative;
    max-width: 800px;
    margin: 0 auto;
    padding: 2rem 0;
}
.timeline-line {
    position: absolute;
    left: 20px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: rgba(255, 255, 255, 0.1);
}
.timeline-line-progress {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 0%; /* JS will animate this */
    background: var(--accent);
    box-shadow: 0 0 10px var(--accent);
}

.timeline-step {
    position: relative;
    padding-left: 60px;
    margin-bottom: 6rem;
    opacity: 0.3; /* JS will animate opacity */
    transform: translateX(-20px);
}
.step-dot {
    position: absolute;
    left: 14px;
    top: 5px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: #111;
    border: 2px solid var(--accent);
    z-index: 2;
    transition: background 0.3s;
}
.step-dot.active {
    background: var(--accent);
    box-shadow: 0 0 15px var(--accent);
}

.step-content {
    background: rgba(255, 255, 255, 0.02);
    padding: 3rem;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.05);
}
.step-num {
    font-family: var(--font-heading);
    color: var(--accent);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 1rem;
    display: inline-block;
}
.step-content h3 {
    font-size: 2rem;
    margin-bottom: 1rem;
}
.step-content p {
    color: var(--text-muted);
    font-size: 1.1rem;
}

/* Card Stacking */
.aeo-process {
    padding-bottom: 20vh;
}
.card-stack-container {
    position: relative;
    max-width: 1000px;
    margin: 0 auto;
}
.stack-card {
    position: sticky;
    top: 20vh; /* Sticking point */
    margin-bottom: 5vh;
}
.card-inner {
    background: #0d0d0d;
    padding: 4rem;
    border-radius: 20px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 -10px 30px rgba(0,0,0,0.5);
    display: flex;
    flex-direction: column;
}
.matrix-bg {
    position: relative;
    overflow: hidden;
}
.matrix-bg::before {
    content: '';
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    background-image: radial-gradient(circle at 100% 0, rgba(44,252,163,0.05) 0%, transparent 60%);
    z-index: 0;
}
.matrix-bg > * { position: relative; z-index: 1; }
.card-inner .big-num {
    font-family: var(--font-heading);
    font-size: 6rem;
    font-weight: 900;
    color: var(--accent);
    line-height: 1;
    margin-bottom: 2rem;
    opacity: 0.8;
}
.card-inner h3 { font-size: 2.5rem; margin-bottom: 1.5rem; }
.card-inner p { color: var(--text-muted); font-size: 1.2rem; max-width: 80%; }

@media(max-width: 768px){
    .step-content { padding: 2rem; }
    .card-inner { padding: 2rem; }
    .card-inner h3 { font-size: 1.8rem; }
    .card-inner p { max-width: 100%; }
}
