/* ============================================
   TECH MOTION — Main Stylesheet v2
   Premium light theme · Cyan/Violet accents
   Fully responsive · All components styled
   ============================================ */

:root {
    --bg-primary: #f9f9f9;
    --bg-secondary: #ffffff;
    --bg-card: #ffffff;
    --bg-card-hover: #f0f4f8;
    --bg-glass: rgba(255,255,255,0.8);
    --text-primary: #1a1a2e;
    --text-secondary: #4b5563;
    --text-muted: #6b7280;
    --accent-cyan: #0078d4;
    --accent-violet: #8b5cf6;
    --accent-gradient: linear-gradient(135deg, #0099ff, #8b5cf6);
    --border-color: rgba(0,0,0,0.08);
    --border-light: rgba(0,0,0,0.12);
    --font-display: 'Syne', sans-serif;
    --font-body: 'Outfit', sans-serif;
    --font-mono: 'JetBrains Mono', monospace;
    --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
    --nav-height: 80px;
    --container: 1280px;
    --container-wide: 1440px;
}

/* ---- RESET ---- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-height) + 16px);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);overflow-x:hidden;line-height:1.6}
body.loading{overflow:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{border:none;background:none;cursor:pointer;font-family:inherit;color:inherit}
input,textarea,select{font-family:inherit;font-size:inherit}
:where(section,div,footer)[id]{scroll-margin-top:calc(var(--nav-height) + 16px)}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}
::selection{background:var(--accent-cyan);color:#fff}
.container{max-width:var(--container);margin:0 auto;padding:0 40px}
.container-wide{max-width:var(--container-wide);margin:0 auto;padding:0 40px}

/* ---- CURSOR ---- */
.cursor{position:fixed;top:0;left:0;z-index:10000;pointer-events:none;mix-blend-mode:difference}
.cursor-dot{position:absolute;width:6px;height:6px;background:#fff;border-radius:50%;transform:translate(-50%,-50%)}
.cursor-ring{position:absolute;width:40px;height:40px;border:1.5px solid rgba(255,255,255,.5);border-radius:50%;transform:translate(-50%,-50%);transition:width .3s var(--ease-out-expo),height .3s var(--ease-out-expo)}
@media(max-width:768px){.cursor{display:none}}

/* ---- LOADER ---- */
.loader{position:fixed;inset:0;z-index:9999;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;transition:opacity 0.8s var(--ease-out-expo), visibility 0.8s}
.loader.hidden{opacity:0;visibility:hidden}
.loader-inner{text-align:center;width:300px;opacity:0;animation:fadeIn 0.8s ease forwards}
@keyframes fadeIn{to{opacity:1}}
.loader-logo{margin-bottom:40px;display:flex;justify-content:center}
.loader-logo-img{width:320px;height:auto;animation:loaderPulse 2.5s ease-in-out infinite}
@keyframes loaderPulse{0%,100%{transform:scale(1);opacity:0.9}50%{transform:scale(1.08);opacity:1}}
.loader-bar{width:240px;height:3px;background:rgba(0,0,0,0.05);border-radius:10px;overflow:hidden;margin:0 auto 16px;position:relative}
.loader-progress{width:0%;height:100%;background:var(--accent-gradient);border-radius:10px;transition:width 0.15s ease-out}
.loader-text{display:flex;justify-content:space-between;width:240px;margin:0 auto}
.loader-label{font-family:var(--font-mono);font-size:10px;letter-spacing:3px;color:var(--text-muted);text-transform:uppercase}
.loader-percent{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--accent-cyan)}

/* ---- NAVIGATION (Neumorphic Design) ---- */
.nav{
    position:fixed;
    top:12px;
    left:50%;
    transform:translateX(-50%);
    width:calc(100% - 48px);
    max-width:var(--container-wide);
    z-index:1000;
    height:var(--nav-height);
    transition:all .4s var(--ease-out-expo);
    /* Neumorphic styling */
    background: linear-gradient(145deg, #ffffff, #e6e6e6);
    border-radius:24px;
    border: none;
    box-shadow:
        8px 8px 20px rgba(0,0,0,0.08),
        -8px -8px 20px rgba(255,255,255,0.9),
        inset 0 1px 0 rgba(255,255,255,0.8),
        inset 0 -1px 0 rgba(0,0,0,0.03);
}
.nav.scrolled{
    background: linear-gradient(145deg, #f5f5f5, #e0e0e0);
    box-shadow:
        10px 10px 30px rgba(0,0,0,0.1),
        -10px -10px 30px rgba(255,255,255,0.95),
        inset 0 1px 0 rgba(255,255,255,0.9),
        inset 0 -1px 0 rgba(0,0,0,0.04);
}
.nav-inner{padding:0 32px;height:100%;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:12px;z-index:10}
.nav-logo-img{height:48px;width:auto;object-fit:contain}
.nav-logo-text{font-family:var(--font-display);font-weight:700;font-size:16px;letter-spacing:1px;color:var(--text-primary)}
.nav-links{display:flex;gap:36px}
.nav-link{font-size:14px;font-weight:500;color:var(--text-secondary);padding:4px 0;position:relative;transition:color .3s}
.nav-link::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--accent-cyan);transition:width .4s var(--ease-out-expo)}
.nav-right{display:flex;align-items:center;gap:16px}
.nav-contact{font-family:var(--font-mono);font-size:12px;color:var(--text-muted);transition:color .3s}
.nav-contact:hover{color:var(--accent-cyan)}
.nav-burger{display:none;flex-direction:column;gap:6px;padding:8px}
.nav-burger span{display:block;width:24px;height:1.5px;background:var(--text-primary);transition:transform .3s var(--ease-out-expo),opacity .3s}
.nav-burger.active span:first-child{transform:translateY(3.75px) rotate(45deg)}
.nav-burger.active span:last-child{transform:translateY(-3.75px) rotate(-45deg)}

/* LANG SWITCHER */
.lang-switcher{position:relative}
.lang-current{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:100px;cursor:pointer;transition:all .3s;font-family:var(--font-mono);font-size:13px;font-weight:500;color:var(--text-primary)}
.lang-current:hover{border-color:var(--accent-cyan);background:var(--bg-card-hover)}
.lang-current:focus-visible{border-color:var(--accent-cyan);box-shadow:0 0 0 3px rgba(0,120,212,.16)}
.lang-current svg{width:10px;transition:transform .3s}
.lang-switcher:hover .lang-current svg,.lang-switcher:focus-within .lang-current svg{transform:rotate(180deg)}
.lang-dropdown{position:absolute;top:calc(100% + 10px);right:0;width:150px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;padding:6px;opacity:0;visibility:hidden;transform:translateY(8px);transition:all .3s var(--ease-out-expo);box-shadow:0 10px 30px rgba(0,0,0,.08);z-index:100}
.lang-switcher:hover .lang-dropdown,.lang-switcher:focus-within .lang-dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.lang-option{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;font-size:14px;color:var(--text-secondary);transition:all .2s}
.lang-option:hover{background:var(--bg-card-hover);color:var(--text-primary)}
.lang-option.active{background:rgba(0,153,255,.06);color:var(--accent-cyan);font-weight:600}
.lang-flag{width:20px;height:auto;display:flex;align-items:center}
.lang-flag img{width:100%;border-radius:2px;box-shadow:0 1px 3px rgba(0,0,0,0.1)}

/* MOBILE MENU */
.mobile-menu{position:fixed;inset:0;z-index:999;background:rgba(7,7,15,.95);backdrop-filter:blur(30px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .5s var(--ease-out-expo),visibility .5s}
.mobile-menu.active{opacity:1;visibility:visible}
.mobile-menu-inner{text-align:center}
.mobile-link{display:block;font-family:var(--font-display);font-size:clamp(32px,8vw,56px);font-weight:800;margin-bottom:16px;color:rgba(255,255,255,.6);transition:color .3s}
.mobile-link:hover{color:var(--accent-cyan)}
.mobile-lang-selector{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:32px;padding:0 20px}
.mobile-lang-link{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:100px;font-size:13px;font-weight:500;color:rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.05);transition:all .3s}
.mobile-lang-link img{width:18px;height:auto;border-radius:2px}
.mobile-lang-link:hover{color:#fff;border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.1)}
.mobile-lang-link.active{color:var(--accent-cyan);border-color:var(--accent-cyan);background:rgba(0,153,255,.1);font-weight:600}
.mobile-menu-footer{margin-top:40px;display:flex;flex-direction:column;gap:8px}
.mobile-menu-footer a{font-family:var(--font-mono);font-size:13px;color:rgba(255,255,255,.78)}
.mobile-menu-footer a:hover{color:#fff}

/* ---- HERO ---- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:120px 40px 140px}
.hero-bg{position:absolute;inset:0;z-index:0}
#heroCanvas{position:absolute;inset:0;width:100%;height:100%}
.hero-gradient{position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,transparent 0%,var(--bg-primary) 100%);pointer-events:none}
.hero-content{position:relative;z-index:2;text-align:center;max-width:850px;margin:0 auto}
.hero-badge{display:inline-flex;align-items:center;gap:10px;padding:8px 20px;border:1px solid var(--border-light);border-radius:100px;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:32px;backdrop-filter:blur(10px)}
.hero-badge-dot{width:6px;height:6px;background:var(--accent-cyan);border-radius:50%;animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(0,229,255,.4)}50%{opacity:.8;box-shadow:0 0 0 8px rgba(0,229,255,0)}}
.hero-title{font-family:var(--font-display);font-weight:800;margin-bottom:8px}
.hero-line{display:block;overflow:hidden}
.hero-line-inner{display:block;font-size:clamp(32px,5vw,68px);line-height:1.08;letter-spacing:-1px}
.hero-line-accent .hero-line-inner{background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-subtitle{margin-bottom:20px}
.hero-sub-line{display:block;overflow:hidden}
.hero-sub-inner{display:block;font-family:var(--font-display);font-size:clamp(20px,3.5vw,36px);font-weight:500;color:var(--text-secondary);letter-spacing:1px}
.hero-desc{font-size:clamp(15px,1.6vw,17px);color:var(--text-secondary);max-width:580px;margin:0 auto 32px;line-height:1.7}
.hero-cta{display:flex;gap:16px;justify-content:center}

/* Buttons */
.btn-primary{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;background:var(--accent-gradient);color:#fff;font-weight:600;font-size:15px;border-radius:100px;transition:transform .3s var(--ease-out-expo),box-shadow .3s;position:relative;overflow:hidden}
.btn-primary::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,#8b5cf6,#00e5ff);opacity:0;transition:opacity .3s;border-radius:100px}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 40px rgba(0,153,255,.25)}
.btn-primary:hover::before{opacity:1}
.btn-primary span,.btn-primary svg{position:relative;z-index:1}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;border:1px solid var(--border-light);color:var(--text-primary);font-weight:500;font-size:15px;border-radius:100px;transition:border-color .3s,background .3s}
.btn-ghost:hover{border-color:var(--accent-cyan);background:rgba(0,229,255,.05)}
.btn-full{width:100%;justify-content:center}

/* Hero Scroll */
.hero-scroll{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:2}
.hero-scroll a{display:flex;flex-direction:column;align-items:center;gap:10px}
.hero-scroll-text{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);font-family:var(--font-mono)}
.hero-scroll-line{width:1px;height:36px;background:linear-gradient(to bottom,var(--accent-cyan),transparent);animation:scrollLine 2s ease infinite}
@keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top;opacity:1}50%{transform:scaleY(1);transform-origin:top;opacity:1}50.1%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom;opacity:1}}

/* Floating Cards */
.hero-float{position:absolute;z-index:1}
.float-card{display:flex;align-items:center;gap:10px;padding:12px 20px;background:var(--bg-glass);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:16px;font-size:13px;font-weight:500;color:var(--text-secondary);animation:float 6s ease-in-out infinite}
.float-icon{font-size:20px}
.hero-float-1{top:30%;left:8%}
.hero-float-2{top:20%;right:6%;animation-delay:-2s}
.hero-float-3{bottom:22%;right:10%;animation-delay:-4s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}

/* Floating tech images */
.floating-tech-img{position:absolute;border-radius:12px;box-shadow:0 30px 60px rgba(0,0,0,.15);border:1px solid var(--border-light);z-index:1;pointer-events:none;opacity:.85}

.img-hero-2{bottom:12%;left:4%;transform:rotate(-5deg);width:300px}

/* Slider System */
.hero{position:relative;overflow:hidden;padding:0;display:block;min-height:100vh}
.hero-slider{position:absolute;inset:0;width:100%;height:100%}
.hero-slide{position:absolute;inset:0;width:100%;height:100%;opacity:0;visibility:hidden;z-index:1;display:flex;align-items:center;justify-content:center;pointer-events:none;overflow:hidden;background:var(--bg-primary)}
.hero-slide.active{opacity:1;visibility:visible;z-index:2;pointer-events:auto}

.hero-slide-bg{position:absolute;inset:0;z-index:0}
.hero-slide-bg video, .hero-slide-bg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-slide-overlay{position:absolute;inset:0;background:radial-gradient(circle at center, transparent 0%, rgba(255,255,255,0.1) 100%), linear-gradient(to bottom, transparent 60%, var(--bg-primary) 100%);z-index:1}

.hero-slide-content{position:relative;z-index:5;text-align:center;width:100%;display:flex;justify-content:center;align-items:center;padding:0 40px}




/* ---- ABOUT ---- */
.about{position:relative;padding-top:20px}
.about-intro{padding:50px 0 60px;border-bottom:1px solid var(--border-color)}
.about-lead{font-family:var(--font-display);font-size:clamp(18px,2.5vw,28px);font-weight:500;line-height:1.5;color:var(--text-secondary);max-width:900px}
.about-lead strong{color:var(--text-primary)}
.about-meta{display:flex;align-items:flex-end;gap:20px;margin-top:28px}
.about-meta-item{display:flex;flex-direction:column;gap:4px}
.about-meta-label{font-family:var(--font-mono);font-size:12px;letter-spacing:1px;color:var(--text-muted);text-transform:uppercase}
.about-meta-sub{font-size:14px;color:var(--text-secondary)}
.about-meta-year{font-family:var(--font-display);font-size:clamp(48px,8vw,80px);font-weight:800;line-height:1;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* Photo Grid */
.photo-reveal-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;margin-bottom:48px}
.photo-container{position:relative;border-radius:20px;overflow:hidden;aspect-ratio:16/10;box-shadow:0 20px 50px rgba(0,0,0,.1)}
.photo-container img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease-out-expo)}
.photo-container:hover img{transform:scale(1.05)}
.photo-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent,rgba(255,255,255,.2))}
.section-title-sm{font-family:var(--font-display);font-size:clamp(24px,3vw,36px);font-weight:800;line-height:1.2;margin-bottom:16px}
.section-title-sm span{background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* Values Grid */
.about-values{padding:60px 0 40px}
.values-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px}
.value-card{padding:36px;background:var(--bg-card);border:1px solid var(--border-color);transition:background .4s,border-color .4s;position:relative;overflow:hidden}
.value-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:2px;background:var(--accent-gradient);transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease-out-expo)}
.value-card:hover{background:var(--bg-card-hover);border-color:var(--border-light)}
.value-card:hover::before{transform:scaleX(1)}
.value-number{font-family:var(--font-mono);font-size:12px;color:var(--accent-cyan);margin-bottom:14px;letter-spacing:2px}
.value-title{font-family:var(--font-display);font-size:20px;font-weight:700;margin-bottom:10px}
.value-desc{font-size:14px;line-height:1.7;color:var(--text-secondary)}

/* Stats Bar */
.stats-bar{border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);padding:36px 0}
.stats-bar-inner{max-width:var(--container);margin:0 auto;padding:0 40px;display:flex;justify-content:space-between;align-items:center}
.stat-item{text-align:center}
.stat-number{font-family:var(--font-display);font-size:clamp(32px,4.5vw,52px);font-weight:800;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.stat-suffix{font-family:var(--font-display);font-size:clamp(20px,2.5vw,32px);font-weight:700;color:var(--accent-cyan)}
.stat-label{display:block;font-size:12px;color:var(--text-muted);margin-top:6px;font-family:var(--font-mono);letter-spacing:.5px}
.stat-divider{width:1px;height:50px;background:var(--border-color)}

/* Section bg photo */
.section-bg-photo{position:absolute;inset:0;z-index:-1;opacity:.06;filter:grayscale(1)}
.section-bg-photo img{width:100%;height:100%;object-fit:cover}

/* ---- SECTION HEADERS ---- */
.section-header{margin-bottom:40px}
.section-tag{display:inline-block;font-family:var(--font-mono);font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--accent-cyan);margin-bottom:16px;position:relative;padding-left:24px}
.section-tag::before{content:'';position:absolute;left:0;top:50%;width:12px;height:1px;background:var(--accent-cyan)}
.section-title{font-family:var(--font-display);font-weight:800}
.title-line{display:block;overflow:hidden}
.title-line span{display:block;font-size:clamp(32px,5.5vw,64px);line-height:1.1;letter-spacing:-1px}
.title-line-accent span{background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.section-title-center{text-align:center}

/* ---- SERVICES ---- */
.services{padding:80px 0;position:relative}
.services::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--border-color)}
.services-header-visual{flex-shrink:0}
.services-row{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.service-card{position:relative;padding:36px 28px;background:var(--bg-card);border:1px solid var(--border-color);transition:all .5s var(--ease-out-expo);overflow:hidden;cursor:pointer}
.service-card-bg{position:absolute;inset:0;opacity:0;transition:opacity .5s}
.service-card[data-service="mobile"] .service-card-bg{background:radial-gradient(circle at 30% 70%,rgba(0,229,255,.08),transparent 60%)}
.service-card[data-service="web"] .service-card-bg{background:radial-gradient(circle at 70% 30%,rgba(139,92,246,.08),transparent 60%)}
.service-card[data-service="ai"] .service-card-bg{background:radial-gradient(circle at 50% 50%,rgba(0,229,255,.06),rgba(139,92,246,.06),transparent 60%)}
.service-card[data-service="games"] .service-card-bg{background:radial-gradient(circle at 30% 30%,rgba(236,72,153,.08),transparent 60%)}
.service-card[data-service="cloud"] .service-card-bg{background:radial-gradient(circle at 70% 70%,rgba(34,197,94,.08),transparent 60%)}
.service-card[data-service="design"] .service-card-bg{background:radial-gradient(circle at 50% 70%,rgba(251,191,36,.08),transparent 60%)}
.service-card:hover{background:var(--bg-card-hover);border-color:var(--border-light);transform:translateY(-4px)}
.service-card:hover .service-card-bg{opacity:1}
.service-icon{width:48px;height:48px;margin-bottom:20px;color:var(--accent-cyan);transition:color .3s}
.service-card:hover .service-icon{color:var(--text-primary)}
.service-icon svg{width:100%;height:100%}
.service-title{font-family:var(--font-display);font-size:20px;font-weight:700;margin-bottom:10px}
.service-desc{font-size:14px;color:var(--text-secondary);line-height:1.7;margin-bottom:16px}
.service-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.service-tags span{padding:4px 10px;font-size:11px;font-family:var(--font-mono);color:var(--text-muted);border:1px solid var(--border-color);border-radius:100px;transition:border-color .3s,color .3s}
.service-card:hover .service-tags span{border-color:var(--border-light);color:var(--text-secondary)}
.service-arrow{position:absolute;top:28px;right:28px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-color);border-radius:50%;color:var(--text-muted);transition:all .4s var(--ease-out-expo);opacity:0;transform:translate(-10px,10px)}
.service-card:hover .service-arrow{opacity:1;transform:translate(0,0);border-color:var(--accent-cyan);color:var(--accent-cyan)}

/* ---- SERVICES — Entrance Animations ---- */
.service-card {
    opacity: 0;
    transform: translateY(40px) scale(0.95);
    transition: all .6s var(--ease-out-expo);
}
.service-card.revealed {
    opacity: 1;
    transform: translateY(0) scale(1);
}
.service-card.revealed:nth-child(1) { transition-delay: 0s; }
.service-card.revealed:nth-child(2) { transition-delay: 0.1s; }
.service-card.revealed:nth-child(3) { transition-delay: 0.2s; }
.service-card.revealed:nth-child(4) { transition-delay: 0.3s; }
.service-card.revealed:nth-child(5) { transition-delay: 0.4s; }
.service-card.revealed:nth-child(6) { transition-delay: 0.5s; }

/* Service card icon float animation */
@keyframes serviceIconFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-6px); }
}
.service-card:hover .service-icon {
    animation: serviceIconFloat 2s ease-in-out infinite;
}

/* Service card glow pulse on hover */
@keyframes serviceGlow {
    0%, 100% { box-shadow: 0 0 0 0 rgba(0,153,255,0); }
    50% { box-shadow: 0 0 30px 4px rgba(0,153,255,0.08); }
}
.service-card:hover {
    animation: serviceGlow 2.5s ease-in-out infinite;
}

/* Service tags slide-in */
.service-card .service-tags span {
    opacity: 0;
    transform: translateX(-8px);
    transition: all 0.4s var(--ease-out-expo);
}
.service-card:hover .service-tags span {
    opacity: 1;
    transform: translateX(0);
}
.service-card:hover .service-tags span:nth-child(1) { transition-delay: 0.05s; }
.service-card:hover .service-tags span:nth-child(2) { transition-delay: 0.1s; }
.service-card:hover .service-tags span:nth-child(3) { transition-delay: 0.15s; }
.service-card:hover .service-tags span:nth-child(4) { transition-delay: 0.2s; }

/* ---- WORK SECTION — Collapsed by default ---- */
.work-showcase {
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: max-height 0.8s var(--ease-out-expo), opacity 0.5s ease;
}
.work-showcase.expanded {
    max-height: 8000px;
    opacity: 1;
}
.work-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin: 32px auto 0;
    padding: 14px 36px;
    font-family: var(--font-mono);
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--accent-cyan);
    background: transparent;
    border: 1px solid var(--accent-cyan);
    border-radius: 50px;
    cursor: pointer;
    transition: all 0.4s var(--ease-out-expo);
}
.work-toggle:hover {
    background: rgba(0,153,255,0.08);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0,153,255,0.12);
}
.work-toggle svg {
    width: 18px; height: 18px;
    transition: transform 0.4s var(--ease-out-expo);
}
.work-toggle.active svg {
    transform: rotate(180deg);
}
body.dark-mode .work-toggle {
    border-color: rgba(0,153,255,0.4);
}
body.dark-mode .work-toggle:hover {
    background: rgba(0,153,255,0.06);
}

/* ---- WORK SECTION ---- */
.work{padding:100px 0;position:relative}
.work::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--border-color)}

/* BENTO GRID LAYOUT */
.work-bento-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:minmax(300px, auto);gap:24px}
.work-card{position:relative;border-radius:24px;overflow:hidden;background:var(--bg-card);border:1px solid var(--border-color);transition:all .6s var(--ease-out-expo);display:flex;flex-direction:column}
.work-card:hover{border-color:var(--border-light);transform:translateY(-8px);box-shadow:0 30px 60px rgba(0,0,0,.12)}

/* Bento Area Mapping */
.work-card-camtel{grid-column:span 8;grid-row:span 2}
.work-card-bw{grid-column:span 4;grid-row:span 2}
.work-card-diagora{grid-column:span 4;grid-row:span 2}
.work-card-edunova{grid-column:span 4;grid-row:span 2}
.work-card-guezs{grid-column:span 4;grid-row:span 2}
.work-card-browser{grid-column:span 8;grid-row:span 2}
.work-card-cleo{grid-column:span 4;grid-row:span 2}
.work-card-omnio{grid-column:span 4;grid-row:span 2}
.work-card-pain{grid-column:span 4;grid-row:span 2}
.work-card-closer{grid-column:span 4;grid-row:span 2}
.work-card-linson{grid-column:span 8;grid-row:span 2}
.work-card-films{grid-column:span 4;grid-row:span 2}

@media(max-width:1024px){
    .work-card-camtel, .work-card-bw, .work-card-diagora, .work-card-edunova, .work-card-guezs,
    .work-card-browser, .work-card-cleo, .work-card-omnio, .work-card-pain, .work-card-closer, .work-card-linson, .work-card-films{grid-column:span 6}
}
@media(max-width:768px){
    .work-card-camtel, .work-card-bw, .work-card-diagora, .work-card-edunova, .work-card-guezs,
    .work-card-browser, .work-card-cleo, .work-card-omnio, .work-card-pain, .work-card-closer, .work-card-linson, .work-card-films{grid-column:span 12}
}

/* Visual Area */
.work-card-visual{height:100%;flex:1;position:relative;overflow:hidden;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;padding:40px}
.work-card-camtel .work-card-visual{background:linear-gradient(135deg, #0f172a 0%, #1e3a8a 100%)}
.work-card-bw .work-card-visual{background:linear-gradient(135deg, #1e1b4b 0%, #4c1d95 100%)}
.work-card-diagora .work-card-visual{background:linear-gradient(135deg, #0f172a 0%, #0369a1 100%)}
.work-card-edunova .work-card-visual{background:linear-gradient(135deg, #064e3b 0%, #047857 100%)}
.work-card-guezs .work-card-visual{background:linear-gradient(135deg, #1a1a1a 0%, #444 100%)}
.work-card-browser .work-card-visual{background:linear-gradient(135deg, #0a1f33 0%, #c2410c 100%)}
.work-card-cleo .work-card-visual{background:linear-gradient(135deg, #2e1065 0%, #be185d 100%)}
.work-card-omnio .work-card-visual{background:linear-gradient(135deg, #1e1b4b 0%, #4338ca 100%)}
.work-card-pain .work-card-visual{background:linear-gradient(135deg, #451a03 0%, #92400e 100%)}
.work-card-closer .work-card-visual{background:linear-gradient(135deg, #064e3b 0%, #0d9488 100%)}
.work-card-linson .work-card-visual{background:linear-gradient(135deg, #064e14 0%, #059669 100%)}
.work-card-films .work-card-visual{background:linear-gradient(135deg, #312e81 0%, #4c1d95 100%)}

.work-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0.4;mix-blend-mode:overlay;transition:transform 0.8s var(--ease-out-expo)}
.work-card:hover .work-img{transform:scale(1.1)}

/* REALISTIC DEVICE FRAMES */
/* REALISTIC DEVICE FRAMES (iPhone 15 Pro style) */
.device-frame-iphone{
    width:210px;height:425px;background:#1a1a1a;border-radius:42px;padding:9px;
    box-shadow:
        0 40px 100px rgba(0,0,0,0.5),
        0 0 0 2px rgba(255,255,255,0.05) inset,
        0 10px 20px -5px rgba(255,255,255,0.1) inset;
    position:relative;z-index:2;
    transform:perspective(1200px) rotateY(-12deg) rotateX(4deg);
    transition:transform .6s var(--ease-out-expo);
}
.work-card:hover .device-frame-iphone{transform:perspective(1200px) rotateY(-4deg) rotateX(2deg) scale(1.02)}

/* Dynamic Island */
.device-island{
    position:absolute;top:22px;left:50%;transform:translateX(-50%);
    width:54px;height:18px;background:#000;border-radius:100px;z-index:10;
}

/* Glass Reflection Overlay */
.device-reflection{
    position:absolute;inset:9px;border-radius:33px;z-index:9;pointer-events:none;overflow:hidden;
}
.device-reflection::after{
    content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;
    background:linear-gradient(135deg,rgba(255,255,255,0.15) 0%,rgba(255,255,255,0) 40%,rgba(255,255,255,0.05) 60%,rgba(255,255,255,0) 100%);
}

/* Side Buttons */
.device-btns::before,.device-btns::after{
    content:'';position:absolute;left:-2.5px;width:2.5px;background:#1a1a1a;border-radius:2px 0 0 2px;
}
.device-btns::before{top:85px;height:35px;box-shadow:-1px 0 2px rgba(255,255,255,0.1) inset} /* Volume Up */
.device-btns::after{top:130px;height:35px;box-shadow:-1px 0 2px rgba(255,255,255,0.1) inset} /* Volume Down */
.device-power{position:absolute;right:-2.5px;top:100px;width:2.5px;height:55px;background:#1a1a1a;border-radius:0 2px 2px 0;box-shadow:1px 0 2px rgba(255,255,255,0.1) inset}

.device-screen{
    width:100%;height:100%;background:#000;border-radius:33px;overflow:hidden;
    position:relative;border:1.5px solid #000;
}
.device-screen img{width:100%;height:100%;object-fit:cover}

.device-frame-laptop{width:90%;max-width:450px;aspect-ratio:16/10;background:#111;border-radius:12px 12px 0 0;padding:15px;box-shadow:0 30px 80px rgba(0,0,0,0.4);border:1.5px solid rgba(255,255,255,0.08);position:relative;z-index:2}
.device-frame-laptop::after{content:'';position:absolute;bottom:-15px;left:-5%;right:-5%;height:15px;background:#222;border-radius:0 0 10px 10px}
.device-frame-laptop .device-screen{border-radius:4px}

/* Info Area Overlay */
.work-card-info{position:absolute;bottom:0;left:0;right:0;padding:30px;background:linear-gradient(to top, rgba(7,7,15,0.9), transparent);backdrop-filter:blur(10px);z-index:3}
.work-card-tags{display:flex;gap:8px;margin-bottom:12px}
.work-card-tags span{padding:4px 12px;font-size:10px;font-family:var(--font-mono);color:var(--accent-cyan);background:rgba(0,153,255,0.1);border:1px solid rgba(0,153,255,0.2);border-radius:100px;text-transform:uppercase;letter-spacing:1px}
.work-card-title{font-family:var(--font-display);font-size:24px;font-weight:700;color:#fff;margin-bottom:8px}
.work-card-desc{font-size:14px;color:rgba(255,255,255,0.7);line-height:1.6;max-width:80%}
.mockup-content-line{height:6px;background:rgba(255,255,255,.08);border-radius:3px}
.mockup-content-line:nth-child(2){width:80%}
.mockup-content-line:nth-child(3){width:60%}

/* Search bar mockup */
.mockup-search-bar{height:16px;background:rgba(255,255,255,.06);border-radius:8px;margin-bottom:6px}

/* Grid items mockup */
.mockup-grid-items{display:grid;grid-template-columns:repeat(2,1fr);gap:5px;flex:1}
.mockup-grid-item{background:rgba(255,255,255,.05);border-radius:5px;min-height:32px}

/* Video mockup */
.mockup-video-block{width:100%;height:60px;background:rgba(255,255,255,.06);border-radius:6px;position:relative;display:flex;align-items:center;justify-content:center}
.mockup-play-btn{width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center}
.mockup-play-btn::after{content:'';width:0;height:0;border-left:8px solid rgba(255,255,255,.5);border-top:5px solid transparent;border-bottom:5px solid transparent;margin-left:2px}

/* Crown mockup (beauty app) */
.mockup-crown{width:28px;height:28px;margin:0 auto 6px;background:linear-gradient(135deg,rgba(251,191,36,.4),rgba(236,72,153,.4));border-radius:50%}

/* Tab bar mockup (productivity) */
.mockup-tab-bar{display:flex;gap:4px;margin-bottom:4px}
.mockup-tab{flex:1;height:8px;background:rgba(255,255,255,.06);border-radius:4px}
.mockup-tab:first-child{background:rgba(0,229,255,.2)}

/* Cross icon mockup (faith app) */
.mockup-cross-icon{width:20px;height:20px;margin:0 auto 6px;position:relative}
.mockup-cross-icon::before,.mockup-cross-icon::after{content:'';position:absolute;background:rgba(255,255,255,.2);border-radius:2px}
.mockup-cross-icon::before{width:20px;height:3px;top:50%;transform:translateY(-50%)}
.mockup-cross-icon::after{width:3px;height:20px;left:50%;transform:translateX(-50%)}

/* Feed mockup (social apps) */
.mockup-feed{display:flex;flex-direction:column;gap:6px}
.mockup-feed-item{display:flex;gap:6px;align-items:flex-start}
.mockup-feed-avatar{width:18px;height:18px;border-radius:50%;background:rgba(255,255,255,.1);flex-shrink:0}
.mockup-feed-text{flex:1;display:flex;flex-direction:column;gap:3px}
.mockup-feed-line{height:5px;background:rgba(255,255,255,.07);border-radius:3px}
.mockup-feed-line:last-child{width:60%}

/* ---- PROCESS ---- */
.process{padding:80px 0;position:relative}
.process::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--border-color)}
.process-timeline{position:relative;max-width:700px;margin:0 auto;padding-left:60px}
.process-line{position:absolute;left:20px;top:0;bottom:0;width:1px;background:var(--border-color)}
.process-step{position:relative;padding:0 0 40px}
.process-step:last-child{padding-bottom:0}
.process-dot{position:absolute;left:-60px;top:0;width:40px;height:40px;border-radius:50%;border:1px solid var(--border-light);background:var(--bg-primary);display:flex;align-items:center;justify-content:center;z-index:1;transition:border-color .4s,background .4s}
.process-step:hover .process-dot{border-color:var(--accent-cyan);background:rgba(0,229,255,.05)}
.process-num{font-family:var(--font-mono);font-size:11px;color:var(--accent-cyan);letter-spacing:1px}
.process-content h3{font-family:var(--font-display);font-size:22px;font-weight:700;margin-bottom:8px}
.process-content p{font-size:14px;color:var(--text-secondary);line-height:1.7}

/* ---- TECH MARQUEE ---- */
.tech-marquee{padding:32px 0;border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);overflow:hidden}
.marquee-track{overflow:hidden}
.marquee-content{display:flex;align-items:center;gap:36px;white-space:nowrap;animation:marquee 30s linear infinite}
.marquee-item{font-family:var(--font-display);font-size:clamp(24px,3.5vw,42px);font-weight:700;color:var(--text-muted);opacity:.35;transition:opacity .3s,color .3s;flex-shrink:0}
.marquee-item:hover{opacity:1;color:var(--text-primary)}
.marquee-dot{font-size:10px;color:var(--accent-cyan);opacity:.5;flex-shrink:0}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ---- GLOBAL ---- */
.global{padding:60px 0 0;position:relative}
.global-top{padding-bottom:36px;border-bottom:1px solid var(--border-color)}
.global-info{display:flex;gap:60px}
.global-stat{display:flex;flex-direction:column;gap:4px}
.global-stat-label{font-family:var(--font-mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted)}
.global-stat-value{font-family:var(--font-display);font-size:20px;font-weight:700}
.global-main{padding:40px 0}
.globe-wrapper{position:relative;width:100%;height:600px;margin:32px 0 0;background:radial-gradient(circle at center, rgba(0,25,50,0.5), rgba(0,0,0,0));border-radius:24px;overflow:hidden}
#globe3d{width:100%;height:100%}
.globe-cities{position:absolute;bottom:0;left:0;right:0;overflow:hidden}
.globe-city-marquee{overflow:hidden}
.city-track{display:flex;gap:36px;white-space:nowrap;animation:marquee 40s linear infinite}
.city-track span{font-family:var(--font-display);font-size:clamp(16px,2.2vw,24px);font-weight:600;color:var(--text-muted);opacity:.3;flex-shrink:0;transition:opacity .3s}
.city-track span:hover{opacity:1;color:var(--accent-cyan)}
.global-bottom{padding:36px 0 60px;border-top:1px solid var(--border-color)}
.global-cta{display:grid;grid-template-columns:280px 1fr;gap:48px;align-items:start}
.global-cta-text h3{font-family:var(--font-display);font-size:32px;font-weight:800;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.global-cta-text p{font-size:14px;color:var(--text-muted);font-family:var(--font-mono)}
.global-cta-desc{font-size:15px;color:var(--text-secondary);line-height:1.7}

/* ---- CONTACT ---- */
.contact{padding:80px 0;position:relative}
.contact::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--border-color)}
.contact-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-desc{font-size:15px;color:var(--text-secondary);line-height:1.7;margin-top:16px;max-width:400px}
.contact-details{margin-top:28px;display:flex;flex-direction:column;gap:20px}
.contact-detail{display:flex;flex-direction:column;gap:4px}
.contact-detail-label{font-family:var(--font-mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted)}
.contact-detail a,.contact-detail span{font-size:15px;color:var(--text-primary);transition:color .3s}
.contact-detail a{overflow-wrap:anywhere}
.contact-detail a:hover{color:var(--accent-cyan)}
.contact-form{display:flex;flex-direction:column;gap:20px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-family:var(--font-mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted)}
.form-group input,.form-group textarea,.form-group select{padding:14px 18px;background:var(--bg-card);border:1px solid #0099ff;border-radius:12px;color:var(--text-primary);font-size:14px;outline:none;transition:border-color .3s,background .3s,box-shadow .3s}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:#0099ff;background:rgba(0,153,255,0.02);box-shadow:0 0 0 4px rgba(0,153,255,0.1)}
.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23555570' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.form-group select option{background:var(--bg-card);color:var(--text-primary)}
.form-group textarea{resize:vertical;min-height:100px}

/* ---- FOOTER ---- */
.footer{padding:80px 0 32px;border-top:1px solid var(--border-color);background:var(--bg-secondary)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1.2fr 1fr 1fr;gap:40px;margin-bottom:60px}
.footer-logo{font-family:var(--font-display);font-weight:800;font-size:32px;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px}
.footer-tagline{font-size:15px;color:var(--text-muted);max-width:300px}

.footer-heading{font-family:var(--font-display);font-size:16px;font-weight:600;margin-bottom:24px;color:var(--text-primary)}

.footer-contact-list{display:flex;flex-direction:column;gap:16px}
.footer-link-item{display:flex;align-items:center;gap:12px;font-size:14px;color:var(--text-secondary);transition:color .3s}
.footer-link-item svg{color:var(--accent-cyan);transition:transform .3s}
.footer-link-item:hover{color:var(--accent-cyan)}
.footer-link-item:hover svg{transform:translateX(4px)}

.footer-links-col{display:flex;flex-direction:column;gap:12px}
.footer-links-col a{font-size:14px;color:var(--text-secondary);transition:all .3s}
.footer-links-col a:hover{color:var(--accent-cyan);transform:translateX(4px)}

.footer-bottom{display:flex;justify-content:space-between;padding-top:32px;border-top:1px solid var(--border-color);font-size:13px;color:var(--text-muted)}
.footer-made{font-family:var(--font-mono);letter-spacing:.5px}

@media(max-width:992px){
    .footer-grid{grid-template-columns:1fr 1fr;gap:40px 24px}
    .footer-col:first-child{grid-column:span 2}
}
@media(max-width:576px){
    .footer-grid{grid-template-columns:1fr;gap:48px}
    .footer-col:first-child{grid-column:span 1}
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1200px){
    .work-grid-expanded{grid-template-columns:repeat(2,1fr)}
    .work-card-large{grid-column:span 2}
}

@media(max-width:1024px){
    .services-row{grid-template-columns:repeat(2,1fr)}
    .contact-wrapper{grid-template-columns:1fr;gap:40px}
    .global-cta{grid-template-columns:1fr;gap:16px}
    .values-grid{grid-template-columns:1fr}
    .services-header-visual{display:none !important}
}

@media(max-width:768px){
    :root{--nav-height:64px}
    .container,.container-wide{padding:0 20px}
    .nav{top:8px;width:calc(100% - 24px);border-radius:16px}
    .nav-links,.nav-right{display:none}
    .nav-burger{display:flex}
    .nav-inner{padding:0 20px}

    .hero{padding:100px 20px 60px;min-height:90vh}
    .hero-float,.floating-tech-img{display:none}
    .hero-cta{flex-direction:column;align-items:center}
    .hero-line-inner{font-size:clamp(28px,8vw,48px) !important}
    .nav-logo-img{height:34px}

    .photo-reveal-grid{grid-template-columns:1fr;gap:24px}
    .about-intro{padding:32px 0 40px}
    .about-values{padding:40px 0 24px}
    .about-meta{flex-direction:column;align-items:flex-start;gap:12px}

    .services{padding:48px 0}
    .services-row{grid-template-columns:1fr}

    .work{padding:48px 0}
    .work-grid-expanded{grid-template-columns:1fr}
    .work-card-large{grid-column:span 1}
    .work-card-visual{height:200px !important}
    .work-card-large .work-card-visual{height:200px !important}

    .process{padding:48px 0}
    .process-timeline{padding-left:48px}
    .process-dot{left:-48px;width:32px;height:32px}

    .stats-bar-inner{flex-wrap:wrap;gap:24px;justify-content:center;padding:0 20px}
    .stat-divider{display:none}
    .stat-item{width:40%}

    .global{padding:40px 0 0}
    .global-info{flex-direction:column;gap:20px}
    .globe-wrapper{height:280px}

    .contact{padding:48px 0}

    .footer-top{flex-direction:column;gap:24px}
    .footer-bottom{flex-direction:column;gap:6px}

    .value-card{padding:24px 20px}
    .service-card{padding:24px 20px}
    .section-header{margin-bottom:28px}
}

@media(max-width:480px){
    .hero-line-inner{letter-spacing:-1px}
    .about-lead{font-size:17px}
    .title-line span{font-size:28px !important}
    .work-card-info{padding:16px}
    .work-card-title{font-size:18px}
    .stat-item{width:45%}
    .mockup-phone{width:120px;height:240px;border-radius:18px}
    .mockup-phone.mockup-sm{width:100px;height:200px;border-radius:16px}
    .mockup-browser{max-width:200px}
}

/* ============================================
   WHATSAPP FAB
   ============================================ */
.whatsapp-fab{position:fixed;bottom:100px;right:28px;z-index:900;width:56px;height:56px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.4);transition:transform .3s var(--ease-out-expo),box-shadow .3s;animation:fabPulse 3s ease infinite}
.whatsapp-fab:hover{transform:scale(1.1);box-shadow:0 6px 30px rgba(37,211,102,.5)}
@keyframes fabPulse{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.4)}50%{box-shadow:0 4px 20px rgba(37,211,102,.4),0 0 0 12px rgba(37,211,102,.1)}}

/* ============================================
   AI CHAT WIDGET
   ============================================ */
.chat-fab{position:fixed;bottom:28px;right:28px;z-index:900;width:56px;height:56px;background:var(--accent-gradient);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,153,255,.35);cursor:pointer;transition:transform .3s var(--ease-out-expo),box-shadow .3s,opacity .3s}
.chat-fab:hover{transform:scale(1.1);box-shadow:0 6px 30px rgba(0,153,255,.45)}
.chat-fab.hidden{opacity:0;pointer-events:none;transform:scale(0.5)}

.chat-window{position:fixed;bottom:28px;right:28px;z-index:950;width:380px;max-width:calc(100vw - 40px);height:520px;max-height:calc(100vh - 80px);background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 20px 60px rgba(0,0,0,.15);display:flex;flex-direction:column;overflow:hidden;opacity:0;visibility:hidden;transform:translateY(20px) scale(0.95);transition:all .4s var(--ease-out-expo)}
.chat-window.active{opacity:1;visibility:visible;transform:translateY(0) scale(1)}

.chat-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--accent-gradient);color:#fff;flex-shrink:0}
.chat-header-info{display:flex;align-items:center;gap:12px}
.chat-header-avatar{width:36px;height:36px;background:rgba(255,255,255,.2);border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:13px;backdrop-filter:blur(10px)}
.chat-header-name{font-family:var(--font-display);font-weight:700;font-size:15px}
.chat-header-status{font-size:11px;opacity:.8;font-family:var(--font-mono)}
.chat-close{color:#fff;font-size:18px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background .2s}
.chat-close:hover{background:rgba(255,255,255,.15)}

.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;background:var(--bg-primary)}
.chat-messages::-webkit-scrollbar{width:4px}
.chat-messages::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}

.chat-msg{display:flex;max-width:85%}
.chat-msg-bot{align-self:flex-start}
.chat-msg-user{align-self:flex-end}
.chat-msg-bubble{padding:10px 14px;border-radius:14px;font-size:13px;line-height:1.6;word-break:break-word}
.chat-msg-bot .chat-msg-bubble{background:var(--bg-card);border:1px solid var(--border-color);border-bottom-left-radius:4px;color:var(--text-primary)}
.chat-msg-bot .chat-msg-bubble a{color:var(--accent-cyan);text-decoration:underline}
.chat-msg-user .chat-msg-bubble{background:var(--accent-gradient);color:#fff;border-bottom-right-radius:4px}

.chat-typing{display:flex;gap:4px;padding:12px 16px !important;align-items:center}
.chat-typing span{width:6px;height:6px;background:var(--text-muted);border-radius:50%;animation:typingDot 1.2s ease infinite}
.chat-typing span:nth-child(2){animation-delay:.2s}
.chat-typing span:nth-child(3){animation-delay:.4s}
@keyframes typingDot{0%,100%{opacity:.3;transform:translateY(0)}50%{opacity:1;transform:translateY(-4px)}}

.chat-input-area{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border-color);background:var(--bg-card);flex-shrink:0}
.chat-input{flex:1;padding:10px 14px;border:1px solid var(--border-color);border-radius:12px;font-size:13px;outline:none;background:var(--bg-primary);color:var(--text-primary);transition:border-color .3s}
.chat-input:focus{border-color:var(--accent-cyan)}
.chat-input::placeholder{color:var(--text-muted)}
.chat-send{width:38px;height:38px;background:var(--accent-gradient);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;transition:transform .2s,box-shadow .2s}
.chat-send:hover{transform:scale(1.05);box-shadow:0 4px 12px rgba(0,153,255,.3)}

@media(max-width:480px){
    .chat-window{width:calc(100vw - 20px);height:calc(100vh - 100px);right:10px;bottom:calc(10px + env(safe-area-inset-bottom));border-radius:16px}
    .whatsapp-fab,.chat-fab{width:48px;height:48px;right:16px}
    .whatsapp-fab{bottom:calc(80px + env(safe-area-inset-bottom))}
    .chat-fab{bottom:calc(20px + env(safe-area-inset-bottom))}
}

/* ============================================
   SCROLL NAVIGATION BUTTONS
   ============================================ */
.scroll-nav{
    position:fixed;
    left:28px;
    bottom:28px;
    z-index:900;
    display:flex;
    flex-direction:column;
    gap:12px;
}

.scroll-btn{
    width:44px;
    height:44px;
    border-radius:14px;
    display:flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
    transition:all .3s var(--ease-out-expo);
    /* Glassmorphism + Neumorphism */
    background:linear-gradient(145deg, rgba(255,255,255,0.9), rgba(230,230,230,0.8));
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    border:1px solid rgba(255,255,255,0.6);
    box-shadow:
        4px 4px 12px rgba(0,0,0,0.08),
        -4px -4px 12px rgba(255,255,255,0.9),
        inset 0 1px 0 rgba(255,255,255,0.8);
}

.scroll-btn:hover{
    transform:translateY(-3px);
    box-shadow:
        6px 6px 20px rgba(0,0,0,0.12),
        -6px -6px 20px rgba(255,255,255,0.95),
        inset 0 1px 0 rgba(255,255,255,0.9);
}

.scroll-btn:active{
    transform:translateY(0);
    box-shadow:
        2px 2px 8px rgba(0,0,0,0.08),
        -2px -2px 8px rgba(255,255,255,0.85),
        inset 2px 2px 6px rgba(0,0,0,0.05);
}

.scroll-btn svg{
    width:20px;
    height:20px;
    color:var(--text-secondary);
    transition:color .3s, transform .3s;
}

.scroll-btn:hover svg{
    color:var(--accent-cyan);
}

.scroll-btn-top:hover svg{
    transform:translateY(-2px);
}

.scroll-btn-bottom:hover svg{
    transform:translateY(2px);
}

/* Hide when at top/bottom respectively */
.scroll-btn-top{
    opacity:0;
    visibility:hidden;
    transform:translateY(10px);
}

.scroll-btn-top.visible{
    opacity:1;
    visibility:visible;
    transform:translateY(0);
}

@media(max-width:768px){
    .scroll-nav{
        left:16px;
        bottom:calc(20px + env(safe-area-inset-bottom));
    }
    .scroll-btn{
        width:40px;
        height:40px;
        border-radius:12px;
    }
}

@media(prefers-reduced-motion:reduce){
    html{scroll-behavior:auto}
    *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
    .marquee-content,.city-track{animation:none !important}
}

/* ============================================
   VISIBILITY FIXES — Hide only when JS is active
   ============================================ */
.js .hero-badge{opacity:0;transform:translateY(20px)}
.js .hero-desc{opacity:0;transform:translateY(20px)}
.js .hero-cta{opacity:0;transform:translateY(20px)}
.js .hero-scroll{opacity:0}
.js .hero-float{opacity:0}
.js .hero-line-inner{transform:translateY(110%)}
.js .hero-sub-inner{transform:translateY(110%)}

/* Marquee items & cities must ALWAYS be visible */
.marquee-item{opacity:.5 !important}
.marquee-item:hover{opacity:1 !important}
.marquee-dot{opacity:.5 !important}
.city-track span{opacity:.5 !important}
.city-track span:hover{opacity:1 !important;color:var(--accent-cyan) !important}

/* Ensure about-text-content is visible */
.about-text-content{opacity:1 !important}
.about-text-content p{opacity:1 !important;transform:none !important}

/* ============================================
   FIBER OPTIC TEXT ANIMATION — Per-letter
   Luminous filaments traverse each letter sequentially
   ============================================ */

/* Each letter wrapper */
.fiber-char{
    position:relative;
    display:inline-block;
    color:inherit;
    -webkit-text-fill-color:inherit;
    margin:0 -1px;
}

/* Spaces */
.fiber-char-space{width:.28em;margin:0}

/* The glowing filament overlay on each letter */
.fiber-char::after{
    content:attr(data-char);
    position:absolute;
    inset:0;
    font-family:inherit;
    font-size:inherit;
    font-weight:inherit;
    letter-spacing:inherit;
    line-height:inherit;
    color:transparent;
    -webkit-text-fill-color:transparent;
    background:
        radial-gradient(ellipse 120% 80% at 50% 50%,
            rgba(255,255,255,.95) 0%,
            rgba(0,229,255,.8) 25%,
            rgba(139,92,246,.6) 50%,
            rgba(0,229,255,.3) 70%,
            transparent 100%
        );
    -webkit-background-clip:text;
    background-clip:text;
    opacity:0;
    filter:blur(0px);
    pointer-events:none;
    z-index:2;
}

/* When a letter is "lit" by the filament */
.fiber-char.fiber-lit::after{
    animation:fiberLetterPulse .5s ease-out forwards;
}

/* The subtle trailing afterglow on recently-lit letters */
.fiber-char.fiber-trail::after{
    animation:fiberLetterTrail .8s ease-out forwards;
}

@keyframes fiberLetterPulse{
    0%{opacity:0;filter:blur(2px);transform:scale(1.05)}
    30%{opacity:1;filter:blur(0px);transform:scale(1.02)}
    100%{opacity:.15;filter:blur(0px);transform:scale(1)}
}

@keyframes fiberLetterTrail{
    0%{opacity:.25;filter:blur(0px)}
    100%{opacity:0;filter:blur(1px)}
}

/* Glowing dot that travels across letters */
.fiber-runner{
    position:absolute;
    width:8px;height:8px;
    border-radius:50%;
    background:radial-gradient(circle,rgba(255,255,255,.95) 0%,rgba(0,229,255,.8) 40%,transparent 70%);
    box-shadow:
        0 0 12px 4px rgba(0,229,255,.6),
        0 0 30px 8px rgba(139,92,246,.3),
        0 0 50px 14px rgba(0,229,255,.15);
    pointer-events:none;
    z-index:10;
    opacity:0;
    transition:opacity .15s ease;
}

.fiber-runner.fiber-runner-active{
    opacity:1;
    transition:left 60ms linear, top 60ms linear, opacity .15s ease;
}

/* Second runner for visual richness — slightly different color */
.fiber-runner-2{
    width:5px;height:5px;
    background:radial-gradient(circle,rgba(255,255,255,.9) 0%,rgba(139,92,246,.7) 40%,transparent 70%);
    box-shadow:
        0 0 10px 3px rgba(139,92,246,.5),
        0 0 25px 6px rgba(0,229,255,.25);
}

/* Subtle ambient glow behind the title */
.hero-title{position:relative}
.hero-title::after{
    content:'';
    position:absolute;
    top:50%;left:50%;
    width:60%;height:40%;
    transform:translate(-50%,-50%);
    background:radial-gradient(ellipse,rgba(0,229,255,.06) 0%,rgba(139,92,246,.04) 40%,transparent 70%);
    animation:fiberGlow 4s ease-in-out infinite alternate;
    pointer-events:none;
    z-index:0;
}

@keyframes fiberGlow{
    0%{opacity:.3;transform:translate(-50%,-50%) scale(1)}
    100%{opacity:.6;transform:translate(-50%,-50%) scale(1.12)}
}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
    .fiber-char::after{animation:none !important;opacity:0 !important}
    .fiber-runner{display:none !important}
    .hero-title::after{animation:none !important;opacity:0 !important}
}

/* ---- SCROLL PROGRESS BAR ---- */
.scroll-progress-container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 4px;
    z-index: 10000;
    background: transparent;
}
.scroll-progress-bar {
    height: 100%;
    background: var(--accent-gradient);
    width: 0%;
    box-shadow: 0 0 10px rgba(0, 153, 255, 0.4);
}

/* ---- DARK MODE SWITCHER ---- */
.theme-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    cursor: pointer;
    transition: all 0.3s;
    overflow: hidden;
}
.theme-toggle:hover {
    border-color: var(--accent-cyan);
    background: var(--bg-card-hover);
}
.theme-toggle svg {
    width: 20px;
    height: 20px;
    transition: transform 0.5s var(--ease-out-expo);
}
.theme-toggle .sun-icon { display: block; }
.theme-toggle .moon-icon { display: none; }

/* ---- DARK MODE OVERRIDES ---- */
body.dark-mode {
    --bg-primary: #07070f;
    --bg-secondary: #0c0c16;
    --bg-card: #12121e;
    --bg-card-hover: #1a1a2e;
    --bg-glass: rgba(12,12,22,0.8);
    --text-primary: #f9f9f9;
    --text-secondary: #cbd5e1;
    --text-muted: #94a3b8;
    --border-color: rgba(255,255,255,0.08);
    --border-light: rgba(255,255,255,0.12);
}
body.dark-mode .nav {
    background: linear-gradient(145deg, #0c0c16, #07070f);
    box-shadow: 8px 8px 20px rgba(0,0,0,0.5), -4px -4px 12px rgba(255,255,255,0.02);
}
body.dark-mode .theme-toggle .sun-icon { display: none; }
body.dark-mode .theme-toggle .moon-icon { display: block; }
body.dark-mode .photo-overlay { background: linear-gradient(to bottom, transparent, rgba(7,7,15,0.3)); }

/* Dark mode — Stats bar */
body.dark-mode .stats-bar-inner { background: var(--bg-secondary); }

/* Dark mode — Contact form */
body.dark-mode .form-group input,
body.dark-mode .form-group textarea,
body.dark-mode .form-group select {
    background: var(--bg-secondary);
    border-color: rgba(0,153,255,0.3);
    color: var(--text-primary);
}
body.dark-mode .form-group input::placeholder,
body.dark-mode .form-group textarea::placeholder { color: var(--text-muted); }
body.dark-mode .form-group select option { background: var(--bg-card); color: var(--text-primary); }

/* Dark mode — Testimonials */
body.dark-mode .testimonial-card {
    background: var(--bg-card);
    border-color: var(--border-color);
}
body.dark-mode .testimonial-card:hover { border-color: var(--accent-cyan); }

/* Dark mode — Process dots */
body.dark-mode .process-dot { background: var(--bg-secondary); }

/* Dark mode — Blog cards */
body.dark-mode .blog-card { background: var(--bg-card); border-color: var(--border-color); }
body.dark-mode .blog-card:hover { border-color: var(--accent-cyan); }

/* Dark mode — Scroll nav buttons */
body.dark-mode .scroll-btn {
    background: linear-gradient(145deg, rgba(18,18,30,0.9), rgba(12,12,22,0.8));
    border-color: rgba(255,255,255,0.06);
    box-shadow: 4px 4px 12px rgba(0,0,0,0.4), -2px -2px 8px rgba(255,255,255,0.02);
}
body.dark-mode .scroll-btn:hover {
    box-shadow: 6px 6px 20px rgba(0,0,0,0.5), -3px -3px 12px rgba(255,255,255,0.03);
}

/* Dark mode — Footer */
body.dark-mode .footer { background: var(--bg-secondary); }

/* Dark mode — FAQ */
body.dark-mode .faq-item { background: var(--bg-card); border-color: var(--border-color); }
body.dark-mode .faq-question:hover { background: var(--bg-card-hover); }


/* ---- TESTIMONIALS ---- */
.testimonials { padding: 80px 0; position: relative; }
.testimonials-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 30px; margin-top: 40px; }
.testimonial-card {
    padding: 32px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 20px;
    transition: all 0.4s var(--ease-out-expo);
}
.testimonial-card:hover { transform: translateY(-5px); border-color: var(--accent-cyan); }
.testimonial-text { font-size: 16px; color: var(--text-secondary); font-style: italic; margin-bottom: 24px; position: relative; }
.testimonial-text::before { content: '"'; font-family: var(--font-display); font-size: 40px; color: var(--accent-cyan); opacity: 0.2; position: absolute; top: -20px; left: -10px; }
.testimonial-author { display: flex; align-items: center; gap: 12px; }
.testimonial-avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--accent-gradient); display: flex; align-items: center; justify-content: center; font-weight: 700; color: #fff; }
.testimonial-info h4 { font-family: var(--font-display); font-size: 15px; font-weight: 700; }
.testimonial-info p { font-size: 12px; color: var(--text-muted); }

/* ---- BLOG LISTING ---- */
.blog-hero { padding: 140px 0 80px; text-align: center; background: linear-gradient(to bottom, var(--bg-secondary), var(--bg-primary)); }
.blog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 32px; padding: 60px 0; }
.blog-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 24px;
    overflow: hidden;
    transition: all 0.4s var(--ease-out-expo);
}
.blog-card:hover { transform: translateY(-8px); border-color: var(--accent-cyan); box-shadow: 0 20px 40px rgba(0,0,0,0.08); }
.blog-card-img { width: 100%; aspect-ratio: 16/9; overflow: hidden; }
.blog-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s; }
.blog-card:hover .blog-card-img img { transform: scale(1.05); }
.blog-card-content { padding: 24px; }
.blog-category { font-family: var(--font-mono); font-size: 10px; color: var(--accent-cyan); text-transform: uppercase; letter-spacing: 2px; margin-bottom: 12px; display: block; }
.blog-title { font-family: var(--font-display); font-size: 20px; font-weight: 700; margin-bottom: 12px; line-height: 1.3; }
.blog-excerpt { font-size: 14px; color: var(--text-secondary); margin-bottom: 20px; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; line-clamp: 3; }
.blog-meta { display: flex; justify-content: space-between; align-items: center; padding-top: 16px; border-top: 1px solid var(--border-color); }
.blog-date { font-size: 12px; color: var(--text-muted); }
.blog-read-more { font-size: 13px; font-weight: 600; color: var(--accent-cyan); display: flex; align-items: center; gap: 6px; }

/* ---- TEAM SECTION ---- */
.team { padding: 80px 0; position: relative; }
.team::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: var(--border-color); }
.team-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 32px;
    margin-top: 48px;
}
.team-card {
    text-align: center;
    padding: 36px 24px 32px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 20px;
    transition: all 0.5s var(--ease-out-expo);
    position: relative;
    overflow: hidden;
}
.team-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 4px;
    background: linear-gradient(90deg, #003366, #0099FF, #D4AF37);
    opacity: 0;
    transition: opacity 0.4s;
}
.team-card:hover {
    transform: translateY(-8px);
    border-color: rgba(212,175,55,0.3);
    box-shadow: 0 16px 48px rgba(0,0,0,0.1), 0 0 0 1px rgba(212,175,55,0.1);
}
.team-card:hover::before { opacity: 1; }
.team-photo {
    width: 130px;
    height: 130px;
    border-radius: 50%;
    margin: 0 auto 20px;
    overflow: hidden;
    border: 3px solid var(--border-color);
    transition: border-color 0.4s, box-shadow 0.4s;
    position: relative;
}
.team-card:hover .team-photo {
    border-color: #D4AF37;
    box-shadow: 0 0 0 4px rgba(212,175,55,0.15), 0 8px 24px rgba(212,175,55,0.12);
}
.team-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s var(--ease-out-expo);
}
.team-card:hover .team-photo img { transform: scale(1.08); }
.team-name {
    font-family: var(--font-display);
    font-size: 20px;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 6px;
}
.team-role {
    font-family: var(--font-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: #D4AF37;
    margin-bottom: 14px;
    display: inline-block;
    padding: 4px 14px;
    border-radius: 50px;
    background: rgba(212,175,55,0.08);
    border: 1px solid rgba(212,175,55,0.15);
}
.team-bio {
    font-size: 14px;
    color: var(--text-secondary);
    line-height: 1.7;
}
.team-socials {
    display: flex;
    justify-content: center;
    gap: 12px;
    margin-top: 18px;
}
.team-social-link {
    width: 36px; height: 36px;
    border-radius: 50%;
    border: 1px solid var(--border-color);
    display: flex; align-items: center; justify-content: center;
    color: var(--text-muted);
    transition: all 0.3s;
    text-decoration: none;
}
.team-social-link:hover {
    border-color: var(--accent-cyan);
    color: var(--accent-cyan);
    background: rgba(0,153,255,0.05);
}
.team-social-link svg { width: 16px; height: 16px; }

/* Dark mode — Team */
body.dark-mode .team-card { background: var(--bg-card); border-color: var(--border-color); }
body.dark-mode .team-card:hover { border-color: rgba(212,175,55,0.4); box-shadow: 0 16px 48px rgba(0,0,0,0.3), 0 0 0 1px rgba(212,175,55,0.15); }
body.dark-mode .team-role { background: rgba(212,175,55,0.06); border-color: rgba(212,175,55,0.12); }

@media(max-width:1024px){
    .team-grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }
}
@media(max-width:576px){
    .team-grid { grid-template-columns: 1fr; gap: 20px; }
    .team-card { padding: 28px 20px 24px; }
    .team-photo { width: 110px; height: 110px; }
}

/* ---- FAQ SECTION ---- */
.faq { padding: 80px 0; position: relative; }
.faq::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: var(--border-color); }
.faq-list { max-width: 780px; margin: 40px auto 0; display: flex; flex-direction: column; gap: 12px; }
.faq-item {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    overflow: hidden;
    transition: border-color 0.3s, box-shadow 0.3s;
}
.faq-item:hover { border-color: var(--border-light); }
.faq-item.active { border-color: var(--accent-cyan); box-shadow: 0 4px 20px rgba(0,153,255,0.08); }
.faq-question {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px;
    cursor: pointer;
    font-family: var(--font-display);
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
    transition: background 0.3s;
    gap: 16px;
}
.faq-question:hover { background: var(--bg-card-hover); }
.faq-icon {
    width: 28px; height: 28px; flex-shrink: 0;
    border-radius: 50%;
    border: 1px solid var(--border-color);
    display: flex; align-items: center; justify-content: center;
    transition: transform 0.4s var(--ease-out-expo), border-color 0.3s, background 0.3s;
}
.faq-item.active .faq-icon {
    transform: rotate(45deg);
    border-color: var(--accent-cyan);
    background: rgba(0,153,255,0.05);
}
.faq-icon svg { width: 14px; height: 14px; color: var(--text-muted); transition: color 0.3s; }
.faq-item.active .faq-icon svg { color: var(--accent-cyan); }
.faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s var(--ease-out-expo), padding 0.3s;
}
.faq-answer-inner {
    padding: 0 24px 20px;
    font-size: 14px;
    color: var(--text-secondary);
    line-height: 1.8;
}
.faq-item.active .faq-answer { max-height: 300px; }

@media(max-width:768px){
    .faq-question { padding: 16px 20px; font-size: 15px; }
    .faq-answer-inner { padding: 0 20px 16px; }
}

