/* ============================================================
   SpiderLab — Master Stylesheet  v2
   File: assets/css/style.css
   ============================================================ */

/* ============================================================
   AOS SAFETY NET
   Ensures ALL content is visible even if AOS JS fails to load.
   Once AOS inits it adds .aos-init class to <body>, then
   .aos-animate handles the actual animation per element.
   ============================================================ */
[data-aos] {
    opacity: 1 !important;
    transform: translateY(0) !important;
    transition-property: opacity, transform !important;
}
body.aos-init [data-aos]:not(.aos-animate) {
    opacity: 0 !important;
    transform: translateY(24px) !important;
}
body.aos-init [data-aos].aos-animate {
    opacity: 1 !important;
    transform: translateY(0) !important;
}

/* ============================================================
   1. CSS VARIABLES
   ============================================================ */
:root {
    --color-bg:          #0a0a0f;
    --color-bg-2:        #0f0f18;
    --color-bg-3:        #13131e;
    --color-surface:     #16161f;
    --color-surface-2:   #1c1c2a;
    --color-border:      rgba(255,255,255,0.07);
    --color-border-glow: rgba(0,212,255,0.25);

    --neon-cyan:         #00d4ff;
    --neon-purple:       #7b2fff;
    --neon-cyan-dim:     rgba(0,212,255,0.12);
    --neon-purple-dim:   rgba(123,47,255,0.12);
    --neon-glow:         0 0 20px rgba(0,212,255,0.4), 0 0 60px rgba(0,212,255,0.15);
    --neon-glow-sm:      0 0 10px rgba(0,212,255,0.35);

    --grad-neon:         linear-gradient(135deg, #00d4ff 0%, #7b2fff 100%);
    --grad-neon-r:       linear-gradient(135deg, #7b2fff 0%, #00d4ff 100%);
    --grad-surface:      linear-gradient(135deg, #16161f 0%, #1c1c2a 100%);
    --grad-hero:         linear-gradient(135deg, #0a0a0f 0%, #0d0d1a 50%, #0a0a0f 100%);

    --text-primary:      #f0f0f8;
    --text-secondary:    #9999bb;
    --text-muted:        #5c5c7a;
    --text-neon:         #00d4ff;

    --font-display:      'Syne', sans-serif;
    --font-body:         'DM Sans', sans-serif;

    --section-py:        100px;
    --card-radius:       16px;
    --btn-radius:        50px;

    --transition:        all 0.3s cubic-bezier(0.4,0,0.2,1);
    --transition-slow:   all 0.6s cubic-bezier(0.4,0,0.2,1);

    --shadow-card:       0 4px 32px rgba(0,0,0,0.4);
    --shadow-card-hover: 0 8px 48px rgba(0,212,255,0.12), 0 4px 32px rgba(0,0,0,0.5);
    --shadow-btn:        0 4px 24px rgba(0,212,255,0.3);

    --navbar-h:          80px;
    --navbar-h-scrolled: 64px;
    --topbar-h:          40px;
}

/* ============================================================
   2. RESET & BASE
   ============================================================ */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.7;
    color: var(--text-primary);
    background-color: var(--color-bg);
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
}
img  { max-width:100%; height:auto; display:block; }
a    { color:var(--neon-cyan); text-decoration:none; transition:var(--transition); }
a:hover { color:var(--text-primary); }
ul,ol { list-style:none; padding:0; margin:0; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }
input,textarea,select { font-family:inherit; }

::selection      { background:var(--neon-cyan); color:var(--color-bg); }
::-moz-selection { background:var(--neon-cyan); color:var(--color-bg); }

::-webkit-scrollbar              { width:6px; }
::-webkit-scrollbar-track        { background:var(--color-bg); }
::-webkit-scrollbar-thumb        { background:var(--neon-purple); border-radius:3px; }
::-webkit-scrollbar-thumb:hover  { background:var(--neon-cyan); }

/* ============================================================
   3. TYPOGRAPHY
   ============================================================ */
h1,h2,h3,h4,h5,h6 {
    font-family:var(--font-display);
    font-weight:700;
    line-height:1.2;
    color:var(--text-primary);
}
h1 { font-size:clamp(2.4rem,5vw,4.5rem); }
h2 { font-size:clamp(1.9rem,4vw,3rem); }
h3 { font-size:clamp(1.3rem,2.5vw,1.8rem); }
h4 { font-size:1.2rem; }
h5 { font-size:1rem; }

p { color:var(--text-secondary); margin-bottom:1rem; }
p:last-child { margin-bottom:0; }

.lead { font-size:1.15rem; color:var(--text-secondary); font-weight:300; line-height:1.8; }

.sl-text-neon { color:var(--neon-cyan); }
.sl-text-gradient {
    background:var(--grad-neon);
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
}

.sl-section-label {
    display:inline-flex; align-items:center; gap:8px;
    font-size:0.75rem; font-weight:700; letter-spacing:0.14em;
    text-transform:uppercase; color:var(--neon-cyan);
    padding:6px 16px; border-radius:50px;
    background:var(--neon-cyan-dim);
    border:1px solid var(--color-border-glow);
    margin-bottom:1.25rem;
}
.sl-section-title { margin-bottom:1rem; }
.sl-section-title span { color:var(--neon-cyan); }
.sl-section-subtitle { font-size:1.05rem; color:var(--text-secondary); max-width:600px; line-height:1.8; }

.sl-divider { width:56px; height:3px; background:var(--grad-neon); border-radius:2px; margin:1rem 0 1.5rem; }
.sl-divider--center { margin:1rem auto 1.5rem; }

/* ============================================================
   4. UTILITIES
   ============================================================ */
.sl-section          { padding:var(--section-py) 0; }
.sl-section--dark    { background:var(--color-bg-2); }
.sl-section--surface { background:var(--color-bg-3); }

.sl-badge {
    display:inline-flex; align-items:center; gap:6px;
    font-size:0.75rem; font-weight:600;
    padding:4px 12px; border-radius:50px;
    background:var(--neon-cyan-dim); color:var(--neon-cyan);
    border:1px solid rgba(0,212,255,0.2);
}
.sl-tag {
    display:inline-block;
    font-size:0.72rem; font-weight:500;
    padding:3px 10px; border-radius:4px;
    background:var(--color-surface-2); color:var(--text-secondary);
    border:1px solid var(--color-border);
}
.sl-glass {
    background:rgba(22,22,31,0.8);
    backdrop-filter:blur(20px);
    -webkit-backdrop-filter:blur(20px);
    border:1px solid var(--color-border);
    border-radius:var(--card-radius);
}

/* ============================================================
   5. BUTTONS
   ============================================================ */
.sl-btn {
    display:inline-flex; align-items:center; gap:10px;
    font-family:var(--font-display); font-size:0.9rem;
    font-weight:600; letter-spacing:0.03em;
    padding:14px 30px; border-radius:var(--btn-radius);
    border:2px solid transparent;
    transition:var(--transition); white-space:nowrap;
    position:relative; overflow:hidden; cursor:pointer;
    text-decoration:none;
}
.sl-btn--neon {
    background:var(--grad-neon); color:#fff;
    box-shadow:var(--shadow-btn);
}
.sl-btn--neon:hover  { color:#fff; transform:translateY(-2px); box-shadow:0 8px 32px rgba(0,212,255,0.45); }
.sl-btn--neon i      { transition:transform 0.3s; }
.sl-btn--neon:hover i { transform:translateX(4px); }

.sl-btn--ghost {
    background:transparent; color:var(--text-primary);
    border-color:var(--color-border-glow);
}
.sl-btn--ghost:hover {
    background:var(--neon-cyan-dim); border-color:var(--neon-cyan);
    color:var(--neon-cyan); transform:translateY(-2px);
}
.sl-btn--text { background:none; border:none; padding:0; color:var(--neon-cyan); font-weight:600; border-radius:0; }
.sl-btn--text:hover { gap:14px; color:var(--neon-cyan); }

.sl-btn--sm  { padding:9px 20px;  font-size:0.8rem; }
.sl-btn--lg  { padding:16px 36px; font-size:0.95rem; }
.sl-btn--xl  { padding:18px 44px; font-size:1rem; }

/* ============================================================
   6. TOP BAR
   ============================================================ */
.topbar {
    background:var(--color-surface);
    border-bottom:1px solid var(--color-border);
    height:var(--topbar-h);
    display:flex; align-items:center;
    font-size:0.78rem;
    transition:var(--transition);
    position:relative; z-index:1000;
}
.topbar__inner { display:flex; align-items:center; justify-content:space-between; width:100%; }
.topbar__left  { display:flex; align-items:center; }
.topbar__right { display:flex; align-items:center; }

.topbar__link {
    color:var(--text-secondary); margin-right:1.5rem;
    display:inline-flex; align-items:center; gap:6px;
}
.topbar__link:hover { color:var(--neon-cyan); }
.topbar__link i     { font-size:0.7rem; color:var(--neon-cyan); }

.topbar__badge {
    font-size:0.72rem; color:var(--text-secondary);
    display:flex; align-items:center; gap:6px; margin-right:1.5rem;
}
.topbar__badge .text-success { font-size:0.45rem; animation:pulse-dot 2s infinite; }

.topbar__social { display:flex; gap:10px; }
.topbar__social a {
    color:var(--text-muted); font-size:0.8rem;
    width:24px; height:24px;
    display:flex; align-items:center; justify-content:center;
    border-radius:50%; transition:var(--transition);
}
.topbar__social a:hover { color:var(--neon-cyan); }

/* ============================================================
   7. NAVBAR
   ============================================================ */
.site-header { position:sticky; top:0; z-index:999; transition:var(--transition); }

.navbar {
    background:rgba(10,10,15,0.88);
    backdrop-filter:blur(24px);
    -webkit-backdrop-filter:blur(24px);
    border-bottom:1px solid var(--color-border);
    min-height:var(--navbar-h);
    transition:var(--transition);
    padding:0;
}
.site-header.scrolled .navbar {
    min-height:var(--navbar-h-scrolled);
    background:rgba(10,10,15,0.97);
    box-shadow:0 4px 32px rgba(0,0,0,0.5);
}

.sl-logo               { display:flex; align-items:center; gap:10px; text-decoration:none; }
.sl-logo__text         { font-family:var(--font-display); font-size:1.5rem; font-weight:800; color:var(--text-primary); letter-spacing:-0.02em; }
.sl-logo__accent       { color:var(--neon-cyan); }
.sl-logo__icon svg     { transition:var(--transition); }
.sl-logo:hover .sl-logo__icon svg { filter:drop-shadow(0 0 8px var(--neon-cyan)); }

.sl-nav__link {
    font-family:var(--font-display); font-size:0.88rem; font-weight:600;
    color:var(--text-secondary) !important;
    padding:8px 14px !important; border-radius:8px;
    position:relative; transition:var(--transition);
    letter-spacing:0.02em;
}
.sl-nav__link::after {
    content:''; position:absolute; bottom:0; left:50%;
    width:0; height:2px; background:var(--grad-neon);
    border-radius:1px; transition:var(--transition); transform:translateX(-50%);
}
.sl-nav__link:hover,
.sl-nav__link.active { color:var(--text-primary) !important; background:rgba(0,212,255,0.05); }
.sl-nav__link:hover::after,
.sl-nav__link.active::after { width:calc(100% - 28px); }
.sl-nav__caret { font-size:0.62rem; margin-left:3px; transition:transform 0.3s; }

.sl-nav__actions     { display:flex; align-items:center; gap:12px; margin-left:1rem; }
.sl-nav__whatsapp {
    width:40px; height:40px; border-radius:50%;
    background:rgba(37,211,102,0.1); border:1px solid rgba(37,211,102,0.3);
    display:flex; align-items:center; justify-content:center;
    color:#25d366; font-size:1.1rem; transition:var(--transition);
}
.sl-nav__whatsapp:hover { background:#25d366; color:#fff; box-shadow:0 0 20px rgba(37,211,102,0.4); }

.sl-toggler          { display:flex; flex-direction:column; gap:5px; padding:10px; }
.sl-toggler__bar     { display:block; width:24px; height:2px; background:var(--text-primary); border-radius:2px; transition:var(--transition); transform-origin:center; }
.sl-toggler.is-open .sl-toggler__bar:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.sl-toggler.is-open .sl-toggler__bar:nth-child(2) { opacity:0; transform:scaleX(0); }
.sl-toggler.is-open .sl-toggler__bar:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ============================================================
   8. MEGA MENU
   ============================================================ */
.sl-mega-parent { position:static !important; }
.sl-mega-menu {
    position:absolute; top:calc(100% + 1px); left:50%;
    transform:translateX(-50%) translateY(10px);
    width:min(720px,94vw);
    background:var(--color-surface);
    border:1px solid var(--color-border-glow);
    border-radius:var(--card-radius);
    box-shadow:0 24px 64px rgba(0,0,0,0.6);
    opacity:0; visibility:hidden;
    transition:var(--transition); z-index:998; overflow:hidden;
}
.sl-mega-parent:hover .sl-mega-menu,
.sl-mega-parent:focus-within .sl-mega-menu {
    opacity:1; visibility:visible;
    transform:translateX(-50%) translateY(0);
}
.sl-mega-parent:hover .sl-nav__caret { transform:rotate(180deg); }

.sl-mega-menu__header { padding:18px 22px 14px; border-bottom:1px solid var(--color-border); background:linear-gradient(90deg,var(--neon-cyan-dim),transparent); }
.sl-mega-menu__header span { font-family:var(--font-display); font-size:0.68rem; font-weight:700; letter-spacing:0.14em; text-transform:uppercase; color:var(--neon-cyan); }
.sl-mega-menu__header p    { font-size:0.8rem; color:var(--text-secondary); margin:2px 0 0; }
.sl-mega-menu__grid  { display:grid; grid-template-columns:repeat(3,1fr); padding:8px; gap:0; }
.sl-mega-menu__item  { display:flex; align-items:center; gap:10px; padding:11px 13px; border-radius:10px; color:var(--text-secondary); font-size:0.83rem; font-weight:500; transition:var(--transition); }
.sl-mega-menu__item:hover { background:var(--neon-cyan-dim); color:var(--neon-cyan); }
.sl-mega-menu__icon  { width:32px; height:32px; border-radius:8px; background:var(--color-surface-2); display:flex; align-items:center; justify-content:center; font-size:0.82rem; color:var(--neon-cyan); flex-shrink:0; transition:var(--transition); }
.sl-mega-menu__item:hover .sl-mega-menu__icon { background:var(--neon-cyan); color:var(--color-bg); }
.sl-mega-menu__arrow { margin-left:auto; font-size:0.62rem; opacity:0; transition:var(--transition); }
.sl-mega-menu__item:hover .sl-mega-menu__arrow { opacity:1; transform:translateX(3px); }
.sl-mega-menu__footer { display:flex; align-items:center; justify-content:space-between; padding:13px 22px; border-top:1px solid var(--color-border); background:var(--color-bg-3); }
.sl-mega-menu__all  { font-size:0.8rem; font-weight:600; color:var(--text-secondary); display:flex; align-items:center; gap:6px; }
.sl-mega-menu__all:hover { color:var(--neon-cyan); }
.sl-mega-menu__cta  { font-size:0.8rem; font-weight:600; padding:7px 16px; border-radius:50px; background:var(--grad-neon); color:#fff; }
.sl-mega-menu__cta:hover { color:#fff; opacity:0.9; }

/* ============================================================
   9. MOBILE DRAWER
   ============================================================ */
.sl-drawer            { position:fixed; inset:0; z-index:1050; pointer-events:none; }
.sl-drawer.is-open    { pointer-events:all; }
.sl-drawer__backdrop  { position:absolute; inset:0; background:rgba(0,0,0,0.7); backdrop-filter:blur(4px); opacity:0; transition:opacity 0.35s ease; }
.sl-drawer.is-open .sl-drawer__backdrop { opacity:1; }
.sl-drawer__panel {
    position:absolute; top:0; right:0;
    width:min(340px,88vw); height:100%;
    background:var(--color-surface);
    border-left:1px solid var(--color-border-glow);
    display:flex; flex-direction:column;
    transform:translateX(100%);
    transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);
    overflow-y:auto;
}
.sl-drawer.is-open .sl-drawer__panel { transform:translateX(0); }
.sl-drawer__head { display:flex; align-items:center; justify-content:space-between; padding:20px 22px; border-bottom:1px solid var(--color-border); }
.sl-drawer__close { width:36px; height:36px; border-radius:50%; background:var(--color-surface-2); border:1px solid var(--color-border); display:flex; align-items:center; justify-content:center; color:var(--text-secondary); font-size:0.9rem; transition:var(--transition); }
.sl-drawer__close:hover { color:var(--neon-cyan); border-color:var(--neon-cyan); }
.sl-drawer__nav  { padding:14px; flex:1; }
.sl-drawer__link { display:block; padding:12px 14px; border-radius:10px; color:var(--text-secondary); font-size:0.92rem; font-weight:500; margin-bottom:2px; transition:var(--transition); }
.sl-drawer__link:hover { color:var(--neon-cyan); background:var(--neon-cyan-dim); }
.sl-drawer__group-toggle { width:100%; display:flex; align-items:center; justify-content:space-between; padding:12px 14px; border-radius:10px; color:var(--text-secondary); font-size:0.92rem; font-weight:500; background:none; transition:var(--transition); }
.sl-drawer__group-toggle:hover { color:var(--neon-cyan); background:var(--neon-cyan-dim); }
.sl-drawer__group-toggle i { font-size:0.68rem; transition:transform 0.3s; }
.sl-drawer__group.is-open .sl-drawer__group-toggle i { transform:rotate(180deg); }
.sl-drawer__sub { padding-left:12px; max-height:0; overflow:hidden; transition:max-height 0.35s ease; }
.sl-drawer__group.is-open .sl-drawer__sub { max-height:400px; }
.sl-drawer__sub-link { display:flex; align-items:center; gap:10px; padding:9px 14px; border-radius:8px; color:var(--text-muted); font-size:0.83rem; transition:var(--transition); }
.sl-drawer__sub-link:hover { color:var(--neon-cyan); background:var(--neon-cyan-dim); }
.sl-drawer__sub-link--all { color:var(--neon-cyan); font-weight:600; margin-top:4px; }
.sl-drawer__footer { padding:18px 22px; border-top:1px solid var(--color-border); display:flex; flex-direction:column; gap:14px; }
.sl-drawer__contact { display:flex; flex-direction:column; gap:8px; }
.sl-drawer__contact a { display:flex; align-items:center; gap:8px; font-size:0.8rem; color:var(--text-secondary); }
.sl-drawer__contact a i { color:var(--neon-cyan); width:14px; }
.sl-drawer__contact a:hover { color:var(--neon-cyan); }

/* ============================================================
   10. HERO
   ============================================================ */
.sl-hero {
    position:relative; min-height:100vh; display:flex; align-items:center;
    background:var(--grad-hero); overflow:hidden; padding:120px 0 80px;
}
.sl-hero__grid {
    position:absolute; inset:0;
    background-image:linear-gradient(rgba(0,212,255,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(0,212,255,0.04) 1px,transparent 1px);
    background-size:60px 60px;
    animation:grid-drift 20s linear infinite; pointer-events:none;
}
.sl-hero__orbs { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.sl-hero__orb  { position:absolute; border-radius:50%; filter:blur(80px); animation:orb-float 8s ease-in-out infinite alternate; }
.sl-hero__orb--1 { width:500px; height:500px; background:radial-gradient(circle,rgba(0,212,255,0.12),transparent 70%); top:-150px; right:-100px; }
.sl-hero__orb--2 { width:400px; height:400px; background:radial-gradient(circle,rgba(123,47,255,0.10),transparent 70%); bottom:-100px; left:-50px; animation-delay:-4s; }
.sl-hero__orb--3 { width:300px; height:300px; background:radial-gradient(circle,rgba(0,212,255,0.06),transparent 70%); top:40%; left:40%; animation-delay:-2s; }
.sl-hero__content { position:relative; z-index:2; }
.sl-hero__eyebrow { display:inline-flex; align-items:center; gap:10px; font-size:0.75rem; font-weight:700; letter-spacing:0.14em; text-transform:uppercase; color:var(--neon-cyan); margin-bottom:1.5rem; }
.sl-hero__eyebrow-line { width:32px; height:1px; background:var(--grad-neon); }
.sl-hero__title { font-size:clamp(2.6rem,6vw,5.2rem); font-weight:800; line-height:1.08; letter-spacing:-0.03em; margin-bottom:1.5rem; }
.sl-hero__title .sl-text-neon { position:relative; display:inline-block; }
.sl-hero__title .sl-text-neon::after { content:''; position:absolute; bottom:-4px; left:0; right:0; height:3px; background:var(--grad-neon); border-radius:2px; }
.sl-hero__subtitle  { font-size:1.1rem; color:var(--text-secondary); max-width:540px; line-height:1.8; margin-bottom:2.5rem; }
.sl-hero__actions   { display:flex; align-items:center; flex-wrap:wrap; gap:14px; margin-bottom:2.5rem; }
.sl-hero__trust     { display:flex; align-items:center; gap:20px; flex-wrap:wrap; }
.sl-hero__trust-item{ display:flex; align-items:center; gap:8px; font-size:0.8rem; color:var(--text-muted); }
.sl-hero__trust-item i { color:var(--neon-cyan); font-size:0.72rem; }
.sl-hero__visual    { position:relative; display:flex; align-items:center; justify-content:center; }
.sl-hero__card-stack { position:relative; width:100%; max-width:460px; margin:0 auto; display:flex; flex-direction:column; gap:14px; }
.sl-hero__float-card { background:var(--color-surface); border:1px solid var(--color-border-glow); border-radius:14px; padding:18px 20px; box-shadow:var(--shadow-card); }
.sl-hero__float-card:nth-child(odd)  { animation:card-float 4s ease-in-out infinite alternate; }
.sl-hero__float-card:nth-child(even) { animation:card-float 4s ease-in-out infinite alternate-reverse; }
.sl-hero__float-card--metric { display:flex; align-items:center; gap:16px; }
.sl-hero__metric-icon { width:44px; height:44px; border-radius:12px; background:var(--grad-neon); display:flex; align-items:center; justify-content:center; color:#fff; font-size:1.1rem; flex-shrink:0; }
.sl-hero__metric-num  { font-family:var(--font-display); font-size:1.5rem; font-weight:800; color:var(--text-primary); line-height:1; }
.sl-hero__metric-label { font-size:0.75rem; color:var(--text-muted); margin-top:2px; }
.sl-hero__tech-stack { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.sl-hero__tech-stack span { font-size:0.75rem; font-weight:600; padding:4px 10px; border-radius:50px; background:var(--color-surface-2); color:var(--neon-cyan); border:1px solid var(--color-border-glow); }
.sl-hero__scroll { position:absolute; bottom:40px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:8px; color:var(--text-muted); font-size:0.7rem; letter-spacing:0.1em; text-transform:uppercase; z-index:2; animation:scroll-bounce 2s ease-in-out infinite; }
.sl-hero__scroll-line { width:1px; height:40px; background:linear-gradient(to bottom,var(--neon-cyan),transparent); }

/* ============================================================
   11. SECTION LAYOUTS
   ============================================================ */
.sl-section-head        { margin-bottom:3.5rem; }
.sl-section-head--center { text-align:center; }
.sl-section-head--center .sl-section-subtitle { margin:0 auto; }
.sl-section-head--center .sl-divider { margin:1rem auto 1.5rem; }

/* ============================================================
   12. SERVICE CARDS
   ============================================================ */
.sl-service-card {
    background:var(--color-surface); border:1px solid var(--color-border);
    border-radius:var(--card-radius); padding:34px 28px;
    transition:var(--transition); position:relative; overflow:hidden;
    height:100%; display:flex; flex-direction:column;
}
.sl-service-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--grad-neon); transform:scaleX(0); transform-origin:left; transition:transform 0.4s ease; }
.sl-service-card:hover   { border-color:var(--color-border-glow); box-shadow:var(--shadow-card-hover); transform:translateY(-6px); }
.sl-service-card:hover::before { transform:scaleX(1); }
.sl-service-card__icon   { width:58px; height:58px; border-radius:14px; background:var(--grad-neon); display:flex; align-items:center; justify-content:center; color:#fff; font-size:1.35rem; margin-bottom:1.4rem; flex-shrink:0; transition:var(--transition); }
.sl-service-card:hover .sl-service-card__icon { box-shadow:var(--neon-glow); transform:scale(1.08) rotate(-4deg); }
.sl-service-card__num    { position:absolute; top:18px; right:22px; font-family:var(--font-display); font-size:2.8rem; font-weight:800; color:rgba(255,255,255,0.03); line-height:1; pointer-events:none; }
.sl-service-card__title  { font-size:1.15rem; font-weight:700; margin-bottom:0.7rem; }
.sl-service-card__desc   { font-size:0.88rem; color:var(--text-secondary); line-height:1.75; flex:1; margin-bottom:1.4rem; }
.sl-service-card__link   { display:inline-flex; align-items:center; gap:8px; font-size:0.84rem; font-weight:600; color:var(--neon-cyan); transition:var(--transition); }
.sl-service-card__link i { transition:transform 0.3s; }
.sl-service-card__link:hover i { transform:translateX(5px); }
.sl-service-card__link:hover   { color:var(--neon-cyan); }

/* ============================================================
   13. PORTFOLIO CARDS
   ============================================================ */
.sl-portfolio-filter     { display:flex; align-items:center; flex-wrap:wrap; gap:10px; margin-bottom:2.5rem; }
.sl-portfolio-filter__btn { font-size:0.8rem; font-weight:600; padding:8px 18px; border-radius:50px; border:1px solid var(--color-border); color:var(--text-secondary); background:transparent; transition:var(--transition); }
.sl-portfolio-filter__btn:hover,
.sl-portfolio-filter__btn.active { background:var(--grad-neon); border-color:transparent; color:#fff; }

.sl-portfolio-card       { position:relative; border-radius:var(--card-radius); overflow:hidden; background:var(--color-surface); border:1px solid var(--color-border); transition:var(--transition); }
.sl-portfolio-card:hover { border-color:var(--color-border-glow); transform:translateY(-4px); box-shadow:var(--shadow-card-hover); }
.sl-portfolio-card__thumb { position:relative; aspect-ratio:16/10; overflow:hidden; background:var(--color-bg-2); }
.sl-portfolio-card__thumb img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease; }
.sl-portfolio-card:hover .sl-portfolio-card__thumb img { transform:scale(1.06); }
.sl-portfolio-card__overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(0,212,255,0.85),rgba(123,47,255,0.85)); display:flex; align-items:center; justify-content:center; opacity:0; transition:var(--transition); }
.sl-portfolio-card:hover .sl-portfolio-card__overlay { opacity:1; }
.sl-portfolio-card__overlay-actions { display:flex; gap:12px; transform:translateY(10px); transition:transform 0.3s ease 0.1s; }
.sl-portfolio-card:hover .sl-portfolio-card__overlay-actions { transform:translateY(0); }
.sl-portfolio-card__overlay-btn { width:44px; height:44px; border-radius:50%; background:rgba(255,255,255,0.15); border:2px solid rgba(255,255,255,0.4); display:flex; align-items:center; justify-content:center; color:#fff; font-size:0.88rem; transition:var(--transition); }
.sl-portfolio-card__overlay-btn:hover { background:#fff; color:var(--color-bg); }
.sl-portfolio-card__body { padding:22px; }
.sl-portfolio-card__category { font-size:0.7rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--neon-cyan); margin-bottom:5px; }
.sl-portfolio-card__title { font-size:1rem; font-weight:700; color:var(--text-primary); margin-bottom:7px; }
.sl-portfolio-card__desc  { font-size:0.83rem; color:var(--text-secondary); line-height:1.6; margin-bottom:1rem; }
.sl-portfolio-card__tags  { display:flex; flex-wrap:wrap; gap:5px; }

/* ============================================================
   14. TESTIMONIALS
   ============================================================ */
.sl-testimonial-card { background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--card-radius); padding:30px; position:relative; transition:var(--transition); height:100%; }
.sl-testimonial-card:hover { border-color:var(--color-border-glow); box-shadow:var(--shadow-card-hover); }
.sl-testimonial-card__quote  { font-size:2.8rem; line-height:1; color:var(--neon-cyan); opacity:0.35; font-family:Georgia,serif; position:absolute; top:18px; left:26px; }
.sl-testimonial-card__flag   { position:absolute; top:18px; right:22px; font-size:1.2rem; }
.sl-testimonial-card__stars  { display:flex; gap:3px; margin-bottom:1.2rem; color:#fbbf24; font-size:0.82rem; }
.sl-testimonial-card__text   { font-size:0.92rem; color:var(--text-secondary); line-height:1.8; margin-bottom:1.4rem; font-style:italic; }
.sl-testimonial-card__author { display:flex; align-items:center; gap:14px; }
.sl-testimonial-card__avatar { width:46px; height:46px; border-radius:50%; background:var(--grad-neon); display:flex; align-items:center; justify-content:center; color:#fff; font-family:var(--font-display); font-size:1.05rem; font-weight:700; flex-shrink:0; overflow:hidden; }
.sl-testimonial-card__avatar img { width:100%; height:100%; object-fit:cover; }
.sl-testimonial-card__name { font-family:var(--font-display); font-size:0.92rem; font-weight:700; color:var(--text-primary); }
.sl-testimonial-card__role { font-size:0.75rem; color:var(--text-muted); }

/* ============================================================
   15. STATS
   ============================================================ */
.sl-stats-section { background:var(--color-surface); border-top:1px solid var(--color-border); border-bottom:1px solid var(--color-border); padding:56px 0; }
.sl-stats-grid    { display:grid; grid-template-columns:repeat(4,1fr); }
.sl-stat-item     { text-align:center; padding:18px; position:relative; }
.sl-stat-item + .sl-stat-item::before { content:''; position:absolute; left:0; top:20%; bottom:20%; width:1px; background:var(--color-border); }
.sl-stat-item__num { font-family:var(--font-display); font-size:clamp(2.2rem,3.5vw,3.5rem); font-weight:800; line-height:1; background:var(--grad-neon); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; margin-bottom:0.5rem; }
.sl-stat-item__label { font-size:0.88rem; color:var(--text-secondary); font-weight:500; }

/* ============================================================
   16. BLOG CARDS
   ============================================================ */
.sl-blog-card { background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--card-radius); overflow:hidden; transition:var(--transition); height:100%; display:flex; flex-direction:column; }
.sl-blog-card:hover { border-color:var(--color-border-glow); box-shadow:var(--shadow-card-hover); transform:translateY(-4px); }
.sl-blog-card__thumb { aspect-ratio:16/9; overflow:hidden; background:var(--color-bg-2); position:relative; }
.sl-blog-card__thumb img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s; }
.sl-blog-card:hover .sl-blog-card__thumb img { transform:scale(1.05); }
.sl-blog-card__cat  { position:absolute; top:12px; left:12px; font-size:0.68rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; padding:4px 11px; border-radius:50px; background:var(--grad-neon); color:#fff; }
.sl-blog-card__body { padding:22px; flex:1; display:flex; flex-direction:column; }
.sl-blog-card__meta { display:flex; align-items:center; gap:14px; font-size:0.74rem; color:var(--text-muted); margin-bottom:0.7rem; }
.sl-blog-card__meta i { color:var(--neon-cyan); }
.sl-blog-card__title  { font-size:1rem; font-weight:700; color:var(--text-primary); margin-bottom:0.7rem; line-height:1.4; flex:1; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.sl-blog-card__title:hover { color:var(--neon-cyan); }
.sl-blog-card__excerpt { font-size:0.83rem; color:var(--text-secondary); line-height:1.6; margin-bottom:1.2rem; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.sl-blog-card__footer { display:flex; align-items:center; justify-content:space-between; margin-top:auto; }
.sl-blog-card__read   { font-size:0.8rem; font-weight:600; color:var(--neon-cyan); display:flex; align-items:center; gap:6px; }
.sl-blog-card__read i { transition:transform 0.3s; }
.sl-blog-card:hover .sl-blog-card__read i { transform:translateX(4px); }

/* ============================================================
   17. FAQ
   ============================================================ */
.sl-faq        { max-width:780px; margin:0 auto; }
.sl-faq__item  { border:1px solid var(--color-border); border-radius:12px; margin-bottom:10px; overflow:hidden; transition:var(--transition); }
.sl-faq__item.is-open { border-color:var(--color-border-glow); box-shadow:0 0 20px rgba(0,212,255,0.06); }
.sl-faq__question { width:100%; display:flex; align-items:center; justify-content:space-between; gap:16px; padding:20px 22px; background:transparent; color:var(--text-primary); font-family:var(--font-display); font-size:0.96rem; font-weight:600; text-align:left; transition:var(--transition); }
.sl-faq__question:hover { color:var(--neon-cyan); }
.sl-faq__item.is-open .sl-faq__question { color:var(--neon-cyan); }
.sl-faq__icon  { width:26px; height:26px; flex-shrink:0; border-radius:50%; border:1px solid var(--color-border); display:flex; align-items:center; justify-content:center; font-size:0.65rem; color:var(--text-muted); transition:var(--transition); }
.sl-faq__item.is-open .sl-faq__icon { background:var(--neon-cyan); border-color:var(--neon-cyan); color:var(--color-bg); transform:rotate(45deg); }
.sl-faq__answer { max-height:0; overflow:hidden; transition:max-height 0.4s ease, padding 0.3s ease; padding:0 22px; }
.sl-faq__item.is-open .sl-faq__answer { max-height:400px; padding-bottom:20px; }
.sl-faq__answer p { font-size:0.9rem; color:var(--text-secondary); line-height:1.8; margin:0; }

/* ============================================================
   18. CONTACT FORM
   ============================================================ */
.sl-contact-form   { background:var(--color-surface); border:1px solid var(--color-border); border-radius:20px; padding:38px; }
.sl-form-group     { margin-bottom:1.4rem; }
.sl-form-label     { display:block; font-size:0.8rem; font-weight:600; color:var(--text-secondary); margin-bottom:7px; letter-spacing:0.04em; }
.sl-form-label span { color:var(--neon-cyan); }
.sl-form-control   { width:100%; background:var(--color-bg-2); border:1px solid var(--color-border); border-radius:10px; padding:13px 16px; color:var(--text-primary); font-size:0.9rem; font-family:var(--font-body); transition:var(--transition); outline:none; appearance:none; }
.sl-form-control::placeholder { color:var(--text-muted); }
.sl-form-control:focus { border-color:var(--neon-cyan); box-shadow:0 0 0 3px rgba(0,212,255,0.1); background:var(--color-bg-3); }
.sl-form-control.error { border-color:#ff4d6d; }
textarea.sl-form-control { resize:vertical; min-height:130px; }
select.sl-form-control { background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%239999bb'%3E%3Cpath d='M5.23 7.21a.75.75 0 011.06.02L10 11.17l3.71-3.94a.75.75 0 111.08 1.04l-4.25 4.5a.75.75 0 01-1.08 0l-4.25-4.5a.75.75 0 01.02-1.06z'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 13px center; background-size:18px; padding-right:40px; }
select.sl-form-control option { background:var(--color-surface); color:var(--text-primary); }
.sl-form-msg { padding:11px 15px; border-radius:8px; font-size:0.86rem; margin-top:1rem; display:none; }
.sl-form-msg.success { background:rgba(16,185,129,0.1); border:1px solid rgba(16,185,129,0.3); color:#10b981; display:block; }
.sl-form-msg.error   { background:rgba(255,77,109,0.1);  border:1px solid rgba(255,77,109,0.3);  color:#ff4d6d; display:block; }

/* ============================================================
   19. pSEO LANDING PAGE
   ============================================================ */
.sl-pseo-hero { padding:100px 0 60px; background:var(--color-bg-2); border-bottom:1px solid var(--color-border); position:relative; overflow:hidden; }
.sl-pseo-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(0,212,255,0.06),transparent 70%); pointer-events:none; }
.sl-pseo-breadcrumb { display:flex; align-items:center; flex-wrap:wrap; gap:8px; font-size:0.78rem; color:var(--text-muted); margin-bottom:1.4rem; }
.sl-pseo-breadcrumb a { color:var(--text-secondary); }
.sl-pseo-breadcrumb a:hover { color:var(--neon-cyan); }
.sl-pseo-breadcrumb i { font-size:0.62rem; }
.sl-pseo-tags { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:1.4rem; }
.sl-pseo-tag  { display:inline-flex; align-items:center; gap:6px; font-size:0.73rem; font-weight:600; padding:5px 13px; border-radius:50px; background:var(--neon-cyan-dim); color:var(--neon-cyan); border:1px solid rgba(0,212,255,0.2); }

/* ============================================================
   20. PRE-FOOTER CTA
   ============================================================ */
.sl-prefooter { background:var(--color-bg-2); padding:80px 0; position:relative; overflow:hidden; border-top:1px solid var(--color-border); }
.sl-prefooter__glow { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:600px; height:200px; background:radial-gradient(ellipse,rgba(0,212,255,0.07),transparent 70%); pointer-events:none; }
.sl-prefooter__inner { display:flex; align-items:center; justify-content:space-between; gap:3rem; flex-wrap:wrap; }
.sl-prefooter__text h2 { font-size:clamp(1.7rem,3vw,2.4rem); margin-bottom:0.5rem; }
.sl-prefooter__text p  { font-size:1rem; color:var(--text-secondary); margin:0; }
.sl-prefooter__actions { display:flex; align-items:center; gap:12px; flex-wrap:wrap; flex-shrink:0; }

/* ============================================================
   21. FOOTER
   ============================================================ */
.sl-footer { background:var(--color-bg-2); padding:80px 0 0; position:relative; overflow:hidden; border-top:1px solid var(--color-border); }
.sl-footer__mesh      { position:absolute; inset:0; pointer-events:none; }
.sl-footer__mesh-dot  { position:absolute; border-radius:50%; filter:blur(120px); }
.sl-footer__mesh-dot--1 { width:500px; height:300px; background:rgba(0,212,255,0.025); top:0; right:10%; }
.sl-footer__mesh-dot--2 { width:400px; height:400px; background:rgba(123,47,255,0.025); bottom:0; left:5%; }

.sl-footer__top { display:grid; grid-template-columns:1.5fr 1fr 1fr 1.5fr; gap:3rem; padding-bottom:56px; border-bottom:1px solid var(--color-border); position:relative; }
.sl-footer__logo  { margin-bottom:1.2rem; display:block; }
.sl-footer__about { font-size:0.86rem; color:var(--text-secondary); line-height:1.8; margin-bottom:1.4rem; }
.sl-footer__badges { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:1.4rem; }
.sl-footer__badge  { display:flex; align-items:center; gap:6px; font-size:0.7rem; font-weight:600; padding:5px 11px; border-radius:50px; background:var(--color-surface-2); border:1px solid var(--color-border); color:var(--text-secondary); }
.sl-footer__badge i { color:var(--neon-cyan); font-size:0.72rem; }
.sl-footer__social      { display:flex; gap:10px; }
.sl-footer__social-link { width:36px; height:36px; border-radius:50%; background:var(--color-surface-2); border:1px solid var(--color-border); display:flex; align-items:center; justify-content:center; color:var(--text-muted); font-size:0.8rem; transition:var(--transition); }
.sl-footer__social-link:hover { background:var(--neon-cyan-dim); border-color:var(--neon-cyan); color:var(--neon-cyan); }

.sl-footer__heading { font-size:0.76rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--text-primary); margin-bottom:1.2rem; padding-bottom:0.7rem; border-bottom:1px solid var(--color-border); }
.sl-footer__links   { display:flex; flex-direction:column; gap:3px; }
.sl-footer__link    { display:flex; align-items:center; gap:8px; font-size:0.84rem; color:var(--text-secondary); padding:4px 0; transition:var(--transition); }
.sl-footer__link i  { font-size:0.58rem; color:var(--text-muted); transition:var(--transition); }
.sl-footer__link:hover { color:var(--neon-cyan); padding-left:5px; }
.sl-footer__link:hover i { color:var(--neon-cyan); }
.sl-footer__link--all { color:var(--neon-cyan); font-weight:600; margin-top:5px; }

.sl-footer__posts { display:flex; flex-direction:column; gap:11px; }
.sl-footer__post-link { display:block; }
.sl-footer__post-date  { font-size:0.7rem; color:var(--text-muted); display:block; margin-bottom:2px; }
.sl-footer__post-date i { color:var(--neon-cyan); margin-right:3px; }
.sl-footer__post-title { font-size:0.83rem; color:var(--text-secondary); line-height:1.4; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; transition:var(--transition); }
.sl-footer__post-link:hover .sl-footer__post-title { color:var(--neon-cyan); }

.sl-footer__cities    { display:flex; flex-wrap:wrap; gap:6px; }
.sl-footer__city-tag  { display:inline-flex; align-items:center; gap:4px; font-size:0.7rem; font-weight:500; padding:3px 9px; border-radius:4px; background:var(--color-surface-2); color:var(--text-muted); border:1px solid var(--color-border); transition:var(--transition); white-space:nowrap; }
.sl-footer__city-tag:hover { color:var(--neon-cyan); border-color:rgba(0,212,255,0.2); background:var(--neon-cyan-dim); }

.sl-footer__contact    { display:flex; flex-direction:column; gap:9px; }
.sl-footer__contact li { display:flex; align-items:flex-start; gap:10px; }
.sl-footer__contact li i { color:var(--neon-cyan); width:14px; margin-top:3px; flex-shrink:0; font-size:0.8rem; }
.sl-footer__contact li a,
.sl-footer__contact li span { font-size:0.84rem; color:var(--text-secondary); }
.sl-footer__contact li a:hover { color:var(--neon-cyan); }

.sl-footer__newsletter    { margin-top:1.4rem; padding:18px; background:var(--color-surface-2); border:1px solid var(--color-border); border-radius:12px; }
.sl-footer__newsletter h5 { font-size:0.88rem; font-weight:700; color:var(--text-primary); margin-bottom:4px; }
.sl-footer__newsletter p  { font-size:0.76rem; color:var(--text-muted); margin-bottom:11px; }
.sl-newsletter-form__group { display:flex; }
.sl-newsletter-form__input { flex:1; background:var(--color-bg-2); border:1px solid var(--color-border); border-right:none; border-radius:8px 0 0 8px; padding:9px 13px; color:var(--text-primary); font-size:0.8rem; outline:none; transition:var(--transition); }
.sl-newsletter-form__input:focus { border-color:var(--neon-cyan); }
.sl-newsletter-form__btn   { background:var(--grad-neon); border:none; border-radius:0 8px 8px 0; padding:9px 15px; color:#fff; cursor:pointer; transition:var(--transition); }
.sl-newsletter-form__btn:hover { opacity:0.9; }
.sl-newsletter-form__msg   { font-size:0.73rem; margin-top:5px; }
.sl-newsletter-form__msg .success { color:#10b981; }
.sl-newsletter-form__msg .error   { color:#ff4d6d; }

.sl-footer__stats  { display:flex; align-items:center; justify-content:center; padding:28px 0; border-bottom:1px solid var(--color-border); flex-wrap:wrap; }
.sl-footer__stat   { text-align:center; padding:8px 36px; position:relative; display:flex; flex-direction:column; align-items:center; }
.sl-footer__stat + .sl-footer__stat::before { content:''; position:absolute; left:0; top:20%; bottom:20%; width:1px; background:var(--color-border); }
.sl-footer__stat-num { font-family:var(--font-display); font-size:1.8rem; font-weight:800; background:var(--grad-neon); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; line-height:1; }
.sl-footer__stat-divider { display:none; }
.sl-footer__stat-label   { font-size:0.74rem; color:var(--text-muted); margin-top:3px; }

.sl-footer__bottom { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem; padding:22px 0; }
.sl-footer__copy   { font-size:0.8rem; color:var(--text-muted); margin:0; }
.sl-footer__bottom-links { display:flex; align-items:center; gap:14px; }
.sl-footer__bottom-links a    { font-size:0.8rem; color:var(--text-muted); }
.sl-footer__bottom-links a:hover { color:var(--neon-cyan); }
.sl-footer__bottom-links span { color:var(--color-border); }

/* ============================================================
   22. SCROLL TO TOP & WHATSAPP FLOAT
   ============================================================ */
.sl-scroll-top { position:fixed; bottom:90px; right:22px; width:42px; height:42px; border-radius:50%; background:var(--color-surface); border:1px solid var(--color-border-glow); color:var(--neon-cyan); font-size:0.82rem; display:flex; align-items:center; justify-content:center; z-index:900; opacity:0; visibility:hidden; transform:translateY(10px); transition:var(--transition); box-shadow:0 4px 16px rgba(0,0,0,0.4); }
.sl-scroll-top.is-visible { opacity:1; visibility:visible; transform:translateY(0); }
.sl-scroll-top:hover { background:var(--neon-cyan); color:var(--color-bg); }

.sl-whatsapp-float { position:fixed; bottom:22px; right:22px; width:54px; height:54px; border-radius:50%; background:#25d366; color:#fff; font-size:1.5rem; display:flex; align-items:center; justify-content:center; z-index:900; box-shadow:0 4px 20px rgba(37,211,102,0.4); transition:var(--transition); }
.sl-whatsapp-float:hover { color:#fff; transform:scale(1.1); box-shadow:0 6px 28px rgba(37,211,102,0.55); }
.sl-whatsapp-float__pulse { position:absolute; inset:-6px; border-radius:50%; border:2px solid rgba(37,211,102,0.4); animation:whatsapp-pulse 2.5s ease-in-out infinite; }

/* ============================================================
   23. PAGINATION
   ============================================================ */
.pagination { margin-top:3rem; }
.pagination__list { display:flex; align-items:center; justify-content:center; flex-wrap:wrap; gap:7px; }
.pagination__btn  { display:inline-flex; align-items:center; justify-content:center; min-width:38px; height:38px; padding:0 13px; border-radius:8px; font-size:0.83rem; font-weight:600; background:var(--color-surface); border:1px solid var(--color-border); color:var(--text-secondary); transition:var(--transition); }
.pagination__btn:hover { border-color:var(--neon-cyan); color:var(--neon-cyan); }
.pagination__btn--active { background:var(--grad-neon); border-color:transparent; color:#fff; }

/* ============================================================
   24. PROCESS STEPS
   ============================================================ */
.sl-process-step { display:flex; gap:22px; align-items:flex-start; margin-bottom:2.2rem; }
.sl-process-step:not(:last-child) { position:relative; }
.sl-process-step:not(:last-child)::after { content:''; position:absolute; left:23px; top:54px; width:2px; height:calc(100% - 28px); background:linear-gradient(to bottom,var(--neon-cyan),transparent); opacity:0.25; }
.sl-process-step__num { width:46px; height:46px; flex-shrink:0; border-radius:50%; background:var(--grad-neon); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:0.95rem; font-weight:800; color:#fff; box-shadow:var(--neon-glow-sm); position:relative; z-index:1; }
.sl-process-step__content h4 { font-size:1rem; margin-bottom:0.35rem; }
.sl-process-step__content p  { font-size:0.86rem; color:var(--text-secondary); margin:0; }

/* ============================================================
   25. ANIMATIONS
   ============================================================ */
@keyframes grid-drift    { from{transform:translateY(0)} to{transform:translateY(60px)} }
@keyframes orb-float     { from{transform:translate(0,0) scale(1)} to{transform:translate(30px,-20px) scale(1.05)} }
@keyframes card-float    { from{transform:translateY(0)} to{transform:translateY(-10px)} }
@keyframes scroll-bounce { 0%,100%{opacity:0.5;transform:translateX(-50%) translateY(0)} 50%{opacity:1;transform:translateX(-50%) translateY(-8px)} }
@keyframes pulse-dot     { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.4;transform:scale(0.7)} }
@keyframes whatsapp-pulse{ 0%{transform:scale(1);opacity:1} 100%{transform:scale(1.6);opacity:0} }
@keyframes shimmer       { from{background-position:-200% center} to{background-position:200% center} }
.sl-skeleton { background:linear-gradient(90deg,var(--color-surface) 25%,var(--color-surface-2) 50%,var(--color-surface) 75%); background-size:200% 100%; animation:shimmer 1.5s infinite; border-radius:6px; }

/* Tech pills */
.sl-tech-grid { display:flex; flex-wrap:wrap; justify-content:center; gap:11px; margin-top:2.5rem; }
.sl-tech-pill { display:inline-flex; align-items:center; padding:10px 20px; border-radius:50px; background:var(--color-surface); border:1px solid var(--color-border); font-size:0.86rem; font-weight:600; color:var(--text-secondary); transition:var(--transition); cursor:default; }
.sl-tech-pill:hover { border-color:var(--neon-cyan); color:var(--neon-cyan); background:var(--neon-cyan-dim); transform:translateY(-2px); }

/* ============================================================
   26. RESPONSIVE
   ============================================================ */
@media (max-width:1199px) {
    :root { --section-py:80px; }
    .sl-mega-menu { width:640px; }
    .sl-mega-menu__grid { grid-template-columns:repeat(2,1fr); }
    .sl-stats-grid { grid-template-columns:repeat(2,1fr); }
    .sl-footer__top { grid-template-columns:1fr 1fr; }
}
@media (max-width:991px) {
    :root { --section-py:70px; --navbar-h:68px; }
    .topbar { display:none; }
    .navbar-collapse { display:none !important; }
    .sl-toggler { display:flex; }
    .sl-hero { padding:100px 0 70px; min-height:auto; }
    .sl-hero__visual { margin-top:3rem; }
    .sl-prefooter__inner { flex-direction:column; text-align:center; }
    .sl-prefooter__actions { justify-content:center; }
}
@media (max-width:767px) {
    :root { --section-py:60px; }
    .sl-stats-grid { grid-template-columns:repeat(2,1fr); }
    .sl-stat-item + .sl-stat-item::before { display:none; }
    .sl-hero__actions { flex-direction:column; align-items:flex-start; }
    .sl-footer__top { grid-template-columns:1fr; gap:2rem; }
    .sl-footer__stats { flex-direction:column; }
    .sl-footer__stat + .sl-footer__stat::before { display:none; }
    .sl-footer__bottom { flex-direction:column; text-align:center; }
    .sl-contact-form { padding:24px; }
}
@media (max-width:479px) {
    .sl-btn--xl,.sl-btn--lg { padding:13px 26px; font-size:0.88rem; }
    .sl-hero__float-card { padding:14px 15px; }
}