/* ===========================================================
   ELIAS TECH & ANALYTICS — STYLES
   A jaw-dropping dark-mode tech website
   =========================================================== */

/* ===== CSS VARIABLES — eliastech.tech color palette ===== */
:root {
  /* Backgrounds — pure black base like eliastech.tech */
  --bg: #000000;
  --bg-2: #0a0a0a;
  --bg-3: #111111;
  --surface: #1a1a1a;
  --surface-2: #222222;
  --border: rgba(255,255,255,.07);
  --border-2: rgba(255,255,255,.12);

  /* Text */
  --white: #ffffff;
  --gray-1: #cccccc;
  --gray-2: #999999;
  --gray-3: #666666;

  /* Brand accent — the signature eliastech cyan */
  --accent: #37AFE1;
  --accent-2: #5bc4ed;
  --accent-3: #8ed7f3;
  --neon: #37AFE1;
  --neon-2: #2a8bb7;
  --pink: #37AFE1;
  --green: #10b981;
  --orange: #f97316;
  --gold: #fbbf24;

  /* Glows & gradients — cyan-based */
  --glow: rgba(55,175,225,.30);
  --glow-neon: rgba(55,175,225,.20);
  --gradient: linear-gradient(135deg, #2a8bb7, #37AFE1, #5bc4ed);
  --gradient-2: linear-gradient(135deg, #1e7ba5, #37AFE1);
  --gradient-warm: linear-gradient(135deg, #37AFE1, #22d3ee);

  /* Radius */
  --radius: 16px;
  --radius-sm: 10px;
  --radius-xs: 6px;
  --radius-full: 100px;

  /* Shadows */
  --shadow: 0 4px 30px rgba(0,0,0,.5);
  --shadow-lg: 0 10px 60px rgba(0,0,0,.6);
  --shadow-glow: 0 0 40px var(--glow);

  /* Easings & fonts */
  --ease: cubic-bezier(.4,0,.2,1);
  --bounce: cubic-bezier(.34,1.56,.64,1);
  --font: 'Inter', system-ui, sans-serif;
  --font-display: 'Syne', 'Inter', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
}

/* ===== RESET ===== */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; overflow-x:hidden; }
body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--white);
  line-height: 1.7;
  overflow-x: hidden;
  cursor: none;
  -webkit-font-smoothing: antialiased;
  -webkit-tap-highlight-color: transparent;
  -webkit-text-size-adjust: 100%;
}
a { text-decoration:none; color:inherit; transition:.3s var(--ease); }
ul { list-style:none; }
img { max-width:100%; height:auto; display:block; }
button { font-family:var(--font); }
iframe { max-width:100%; }

.container { max-width:1200px; margin:0 auto; padding:0 24px; }
.section { padding:120px 0; position:relative; }
.section-alt { background:var(--bg-2); }
.text-left { text-align:left !important; }

/* ===== GRADIENT TEXT ===== */
.gradient-text {
  background: var(--gradient);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.accent { color:var(--accent-2); }

/* ===== CUSTOM CURSOR ===== */
.cursor-dot {
  width:8px; height:8px;
  background:var(--neon);
  border-radius:50%;
  position:fixed; top:0; left:0;
  pointer-events:none;
  z-index:99999;
  transition: width .3s var(--ease), height .3s var(--ease), background .3s;
  mix-blend-mode: difference;
}
.cursor-ring {
  width:40px; height:40px;
  border:1.5px solid var(--accent-2);
  border-radius:50%;
  position:fixed; top:0; left:0;
  pointer-events:none;
  z-index:99998;
  transition: width .4s var(--ease), height .4s var(--ease), border-color .3s;
  opacity:.5;
}
.cursor-dot.hover { width:60px; height:60px; background:rgba(55,175,225,.15); }
.cursor-ring.hover { width:80px; height:80px; border-color:var(--neon); opacity:.3; }

/* ===== PRELOADER ===== */
.preloader {
  position:fixed; inset:0; z-index:100000;
  background:var(--bg);
  display:flex; align-items:center; justify-content:center;
  transition: opacity .6s var(--ease), visibility .6s;
}
.preloader.done { opacity:0; visibility:hidden; pointer-events:none; }
.preloader-inner { text-align:center; }
.preloader-logo { position:relative; width:70px; height:70px; margin:0 auto 24px; }
.preloader-svg { width:70px; height:70px; animation:preloader-spin 1.5s linear infinite; }
.preloader-circle {
  fill:none; stroke:var(--accent); stroke-width:2;
  stroke-dasharray:163; stroke-dashoffset:163;
  animation:preloader-dash 1.5s ease-in-out infinite;
}
.preloader-icon {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  font-size:1.5rem; color:var(--neon);
}
.preloader-text {
  display:flex; gap:3px; justify-content:center; margin-bottom:20px;
}
.preloader-text span {
  font-family:var(--font-display); font-weight:800; font-size:1.3rem;
  opacity:0; animation:preloader-letter .5s var(--ease) forwards;
  color:var(--white);
}
.preloader-text span:nth-child(1){animation-delay:.1s}
.preloader-text span:nth-child(2){animation-delay:.15s}
.preloader-text span:nth-child(3){animation-delay:.2s}
.preloader-text span:nth-child(4){animation-delay:.25s}
.preloader-text span:nth-child(5){animation-delay:.3s}
.preloader-dot{color:var(--neon) !important}
.preloader-text span:nth-child(6){animation-delay:.4s}
.preloader-text span:nth-child(7){animation-delay:.45s}
.preloader-text span:nth-child(8){animation-delay:.5s}
.preloader-text span:nth-child(9){animation-delay:.55s}
.preloader-text span:nth-child(10){animation-delay:.6s}

.preloader-bar { width:180px; height:3px; background:var(--surface); border-radius:3px; overflow:hidden; margin:0 auto; }
.preloader-bar-fill { width:0; height:100%; background:var(--gradient); animation:preloader-fill 1.8s var(--ease) forwards; }

@keyframes preloader-spin { to { transform:rotate(360deg); } }
@keyframes preloader-dash {
  0% { stroke-dashoffset:163; }
  50% { stroke-dashoffset:40; }
  100% { stroke-dashoffset:163; }
}
@keyframes preloader-letter { to { opacity:1; transform:translateY(0); } from { opacity:0; transform:translateY(10px); } }
@keyframes preloader-fill { to { width:100%; } }

/* ===== PAGE TRANSITION ===== */
.page-transition {
  position:fixed; inset:0; z-index:9999; pointer-events:none;
  display:flex; flex-direction:column;
}
.transition-layer {
  flex:1; background:var(--accent);
  transform:scaleY(0); transform-origin:bottom;
  transition: transform .5s var(--ease);
}
.transition-layer:nth-child(2) { background:var(--bg); transform-origin:top; }
.page-transition.active .transition-layer { transform:scaleY(1); }
.page-transition.active .transition-layer:nth-child(2) { transition-delay:.15s; }

/* ===== BUTTONS ===== */
.btn {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font); font-weight:600; font-size:.9rem;
  border:none; cursor:pointer; border-radius:var(--radius-full);
  transition: all .3s var(--ease);
  position:relative; overflow:hidden;
}
.btn-sm { padding:12px 26px; font-size:.85rem; }
.btn-lg { padding:18px 36px; font-size:.95rem; }
.btn-full { width:100%; justify-content:center; }

.btn-primary {
  background:var(--gradient); color:#fff;
  box-shadow: var(--shadow-glow);
}
.btn-primary:hover {
  transform:translateY(-3px) scale(1.02);
  box-shadow: 0 0 50px var(--glow), var(--shadow);
}

.btn-outline {
  background:transparent; color:var(--white);
  border:1.5px solid var(--border-2);
}
.btn-outline:hover {
  border-color:var(--accent);
  color:var(--accent-2);
  transform:translateY(-3px);
}

.btn-glass {
  background:rgba(255,255,255,.05); color:var(--white);
  border:1px solid var(--border-2);
  backdrop-filter:blur(10px);
}
.btn-glass:hover {
  background:rgba(255,255,255,.1);
  border-color:var(--accent);
  transform:translateY(-3px);
}
.btn-glass .btn-shine {
  position:absolute; top:0; left:-100%; width:100%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);
  transition:.6s;
}
.btn-glass:hover .btn-shine { left:100%; }

.btn-glow { animation: btn-pulse 2s infinite; }
@keyframes btn-pulse {
  0%,100% { box-shadow: 0 0 20px var(--glow); }
  50% { box-shadow: 0 0 40px var(--glow), 0 0 60px rgba(55,175,225,.15); }
}

/* ===== NAVBAR ===== */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:18px 0; transition:.4s var(--ease);
}
.navbar.scrolled {
  background:rgba(0,0,0,.9);
  backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);
  padding:12px 0;
}
.nav-container {
  max-width:1200px; margin:0 auto; padding:0 24px;
  display:flex; align-items:center; justify-content:space-between;
}
.nav-logo {
  display:flex; align-items:center; gap:10px;
  font-family:var(--font-display); font-size:1.4rem; font-weight:800;
}
.logo-icon {
  width:40px; height:40px; display:flex; align-items:center; justify-content:center;
  background:var(--gradient); border-radius:var(--radius-sm); color:#fff;
}
.nav-links { display:flex; gap:8px; }
.nav-link {
  padding:8px 16px; font-size:.88rem; font-weight:500;
  color:var(--gray-2); border-radius:var(--radius-full);
  transition:.3s var(--ease); position:relative;
}
.nav-link:hover, .nav-link.active { color:var(--white); background:rgba(255,255,255,.05); }
.nav-link.active::after {
  content:''; position:absolute; bottom:4px; left:50%; transform:translateX(-50%);
  width:4px; height:4px; background:var(--neon); border-radius:50%;
}
.nav-actions { display:flex; align-items:center; gap:16px; }
.nav-cta i { font-size:.75rem; }

.mobile-toggle {
  display:none; background:none; border:none; cursor:pointer;
  width:40px; height:40px; padding:8px;
}
.hamburger { display:flex; flex-direction:column; gap:6px; }
.hamburger span {
  display:block; width:24px; height:2px;
  background:var(--white); border-radius:2px;
  transition:.3s var(--ease);
}
.mobile-toggle.active .hamburger span:nth-child(1) { transform:rotate(45deg) translate(5px,6px); }
.mobile-toggle.active .hamburger span:nth-child(2) { opacity:0; }
.mobile-toggle.active .hamburger span:nth-child(3) { transform:rotate(-45deg) translate(5px,-6px); }

/* ===== HERO ===== */
.hero {
  position:relative; min-height:100vh; min-height:100dvh;
  display:flex; align-items:center; justify-content:center; overflow:hidden;
  padding:clamp(100px,12vh,140px) 0 clamp(60px,8vh,100px);
  box-sizing:border-box;
}
.hero-canvas { position:absolute; inset:0; z-index:0; }
.hero-overlay {
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(to bottom, rgba(0,0,0,.3) 0%, rgba(0,0,0,.5) 50%, rgba(0,0,0,.92) 85%, var(--bg) 100%),
    linear-gradient(135deg, rgba(55,175,225,.08) 0%, transparent 50%);
}
.hero-img-bg {
  position:absolute; inset:0; z-index:0;
  background-size:cover; background-position:center;
  opacity:.55;
  animation: heroImgZoom 25s ease-in-out infinite alternate;
}
@keyframes heroImgZoom {
  0% { transform:scale(1); }
  100% { transform:scale(1.08); }
}
.hero-content {
  position:relative; z-index:2; text-align:center;
  max-width:850px; margin:0 auto; width:100%;
  display:flex; flex-direction:column; align-items:center;
}

.hero-badge {
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 22px; background:rgba(55,175,225,.1);
  border:1px solid rgba(55,175,225,.25); border-radius:var(--radius-full);
  font-size:.85rem; font-weight:600; color:var(--accent-2);
  margin-bottom:clamp(16px,2.5vh,28px);
}
.badge-dot {
  width:8px; height:8px; border-radius:50%; background:var(--green);
  animation:dot-pulse 2s infinite;
}
@keyframes dot-pulse {
  0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.8)}
}

.hero-title {
  font-family:var(--font-display); font-size:clamp(2.4rem,5.5vw,4.8rem);
  font-weight:800; line-height:1.08; margin-bottom:clamp(14px,2vh,24px);
  letter-spacing:-.03em;
}
.hero-title span { display:block; }

.hero-subtitle {
  font-size:clamp(.95rem,1.8vw,1.15rem); color:var(--gray-1);
  max-width:600px; margin:0 auto clamp(20px,3vh,36px); line-height:1.6;
}
.hero-cta {
  display:flex; gap:14px; justify-content:center; flex-wrap:wrap;
  margin-bottom:clamp(24px,4vh,48px);
}

.hero-metrics {
  display:flex; justify-content:center; gap:clamp(20px,3vw,48px);
  flex-wrap:wrap; align-items:center;
}
.metric { text-align:center; }
.metric-value {
  font-family:var(--font-display); font-size:clamp(1.4rem,2.5vw,2rem); font-weight:800;
}
.metric-value small { font-size:clamp(.9rem,1.5vw,1.2rem); color:var(--accent-2); }
.metric-label { font-size:clamp(.72rem,1vw,.82rem); color:var(--gray-2); margin-top:2px; }
.metric-divider { width:1px; height:40px; background:var(--border-2); align-self:center; }

.hero-scroll-indicator {
  position:absolute; bottom:clamp(16px,3vh,30px); left:50%; transform:translateX(-50%); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:8px;
}
.scroll-line {
  width:1px; height:40px; background:linear-gradient(to bottom,var(--accent),transparent);
  animation:scroll-line 2s infinite;
}
@keyframes scroll-line {
  0%{opacity:1;transform:scaleY(1)} 50%{opacity:.3;transform:scaleY(.5)} 100%{opacity:1;transform:scaleY(1)}
}
.hero-scroll-indicator span { font-size:.7rem; color:var(--gray-3); text-transform:uppercase; letter-spacing:2px; }

/* ===== REVEAL ANIMATIONS ===== */
.reveal-up { opacity:0; transform:translateY(30px); animation:revealUp .8s var(--ease) forwards; }
.reveal-up[data-delay="100"]{ animation-delay:.1s }
.reveal-up[data-delay="200"]{ animation-delay:.2s }
.reveal-up[data-delay="300"]{ animation-delay:.3s }
.reveal-up[data-delay="400"]{ animation-delay:.4s }
.reveal-up[data-delay="500"]{ animation-delay:.5s }
.reveal-up[data-delay="600"]{ animation-delay:.6s }
@keyframes revealUp { to{opacity:1;transform:translateY(0)} }

.reveal-text {
  display:block; overflow:hidden;
}

.scroll-reveal {
  opacity:0; transform:translateY(40px);
  transition: opacity .7s var(--ease), transform .7s var(--ease);
}
.scroll-reveal.visible { opacity:1; transform:translateY(0); }

/* ===== MARQUEE ===== */
.marquee-section {
  padding:48px 0;
  background:var(--bg-2); border-top:1px solid var(--border); border-bottom:1px solid var(--border);
}
.marquee-label {
  text-align:center; font-size:.78rem; color:var(--gray-3);
  text-transform:uppercase; letter-spacing:3px; font-weight:700; margin-bottom:28px;
}
.marquee {
  overflow:hidden; width:100%;
  mask-image:linear-gradient(to right,transparent,black 10%,black 90%,transparent);
  -webkit-mask-image:linear-gradient(to right,transparent,black 10%,black 90%,transparent);
}
.marquee-track {
  display:flex; gap:52px; width:max-content;
  animation:marquee 35s linear infinite;
}
.marquee-reverse .marquee-track { animation-direction:reverse; }
.marquee-item {
  display:flex; align-items:center; gap:10px; white-space:nowrap;
  font-weight:600; color:var(--gray-3); font-size:.95rem;
}
.marquee-item i { font-size:1.5rem; color:var(--accent); }
.marquee-item:hover { color:var(--white); }
.media-item { font-size:.9rem; }
@keyframes marquee { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ===== SECTION HEADER ===== */
.section-header { text-align:center; margin-bottom:64px; }
.section-tag {
  display:inline-block; padding:6px 18px;
  background:rgba(55,175,225,.08); border:1px solid rgba(55,175,225,.15);
  border-radius:var(--radius-full); font-size:.78rem; font-weight:700;
  color:var(--accent-2); text-transform:uppercase; letter-spacing:2px; margin-bottom:18px;
}
.section-title {
  font-family:var(--font-display); font-size:clamp(2rem,4.5vw,3.2rem);
  font-weight:800; line-height:1.15; margin-bottom:16px; letter-spacing:-.02em;
}
.section-desc { font-size:1.05rem; color:var(--gray-1); max-width:560px; margin:0 auto; }
.section-cta { text-align:center; margin-top:48px; }

/* ===== SERVICE SHOWCASE CARDS (Home) ===== */
.services-showcase { display:flex; flex-direction:column; gap:20px; }
.service-showcase-card {
  display:grid; grid-template-columns:auto 1fr 200px auto;
  align-items:center; gap:24px; padding:28px 32px;
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius); transition:.4s var(--ease);
  text-decoration:none !important; cursor:pointer;
}
.service-showcase-card:hover {
  border-color:var(--accent); background:var(--surface-2);
  transform:translateX(8px);
  box-shadow:var(--shadow-glow);
}
.ssc-icon {
  width:56px; height:56px; display:flex; align-items:center; justify-content:center;
  background:rgba(55,175,225,.1); border-radius:var(--radius-sm);
  font-size:1.4rem; color:var(--accent-2);
  transition:.3s var(--ease);
}
.service-showcase-card:hover .ssc-icon { background:var(--gradient); color:#fff; }
.ssc-content h3 { font-family:var(--font-display); font-size:1.2rem; font-weight:700; margin-bottom:4px; }
.ssc-content p { font-size:.9rem; color:var(--gray-2); }
.ssc-image {
  width:clamp(120px,15vw,200px); height:80px; border-radius:var(--radius-sm);
  background-size:cover; background-position:center;
  opacity:.4; transition:.4s var(--ease); flex-shrink:0;
}
.service-showcase-card:hover .ssc-image { opacity:.8; }
.ssc-arrow {
  width:44px; height:44px; display:flex; align-items:center; justify-content:center;
  border:1px solid var(--border); border-radius:50%;
  color:var(--gray-3); font-size:.9rem; transition:.3s var(--ease);
}
.service-showcase-card:hover .ssc-arrow {
  background:var(--gradient); color:#fff; border-color:transparent;
  transform:rotate(-45deg);
}

/* ===== WHY SECTION (Home) ===== */
.why-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center;
}
.why-content p { color:var(--gray-1); margin-bottom:32px; }
.why-features { display:flex; flex-direction:column; gap:20px; margin-bottom:36px; }
.why-feature {
  display:flex; align-items:center; gap:16px;
  padding:16px 20px; background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-sm); transition:.3s var(--ease);
}
.why-feature:hover { border-color:var(--accent); transform:translateX(4px); }
.wf-icon {
  width:44px; height:44px; min-width:44px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(55,175,225,.1); border-radius:var(--radius-xs);
  color:var(--accent-2); font-size:1rem;
}
.why-feature strong { display:block; font-size:.95rem; }
.why-feature span { font-size:.82rem; color:var(--gray-2); }

.why-visual { position:relative; }
.why-image-stack { position:relative; }
.stack-img {
  border-radius:var(--radius); box-shadow:var(--shadow-lg);
}
.stack-img-1 { width:100%; position:relative; z-index:1; }
.stack-img-2 {
  width:55%; position:absolute; bottom:-40px; right:-20px; z-index:2;
  border:4px solid var(--bg);
}
.stack-stats {
  position:absolute; top:20px; left:-20px; z-index:3;
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-sm); padding:16px 24px;
  backdrop-filter:blur(10px); text-align:center;
}
.ss-number { display:block; font-family:var(--font-display); font-size:1.6rem; font-weight:800; color:var(--neon); }
.ss-label { font-size:.75rem; color:var(--gray-2); }

/* ===== STATS BANNER ===== */
.stats-banner {
  padding:60px 0; background:var(--bg-2);
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
}
.stats-row { display:grid; grid-template-columns:repeat(4,1fr); gap:32px; }
.stat-item { text-align:center; }
.stat-number {
  font-family:var(--font-display); font-size:clamp(2rem,4vw,3rem);
  font-weight:800; background:var(--gradient);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.stat-label { font-size:.85rem; color:var(--gray-2); margin-top:4px; }

/* ===== FEATURED CARDS (Home) ===== */
.featured-grid {
  display:grid; grid-template-columns:1.2fr 1fr; gap:24px;
}
.featured-grid .featured-card:first-child { grid-row:1/3; }
.featured-card {
  position:relative; border-radius:var(--radius); overflow:hidden;
  min-height:300px; transition:.5s var(--ease); cursor:pointer;
}
.featured-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.fc-image {
  position:absolute; inset:0; background-size:cover; background-position:center;
  transition:.6s var(--ease);
}
.featured-card:hover .fc-image { transform:scale(1.05); }
.fc-overlay {
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(to top, rgba(0,0,0,.95) 0%, rgba(0,0,0,.3) 60%, transparent);
  padding:32px; display:flex; flex-direction:column; justify-content:flex-end;
}
.fc-tag {
  display:inline-block; padding:4px 14px;
  background:rgba(55,175,225,.2); border-radius:var(--radius-full);
  font-size:.72rem; font-weight:700; color:var(--accent-2);
  text-transform:uppercase; letter-spacing:1px; margin-bottom:10px; width:fit-content;
}
.fc-overlay h3 { font-family:var(--font-display); font-size:1.3rem; font-weight:700; margin-bottom:8px; }
.fc-overlay p { font-size:.88rem; color:var(--gray-1); margin-bottom:12px; }
.fc-tech { display:flex; gap:8px; flex-wrap:wrap; }
.fc-tech span {
  padding:4px 12px; background:rgba(255,255,255,.06); border:1px solid var(--border);
  border-radius:var(--radius-full); font-size:.72rem; color:var(--gray-2);
}

/* ===== TESTIMONIAL PREVIEW (Home) ===== */
.testimonial-preview { padding:80px 0; }
.tp-card {
  max-width:800px; margin:0 auto; text-align:center;
  padding:60px 48px; background:var(--surface);
  border:1px solid var(--border); border-radius:var(--radius);
  position:relative;
}
.tp-quote { font-size:3rem; color:var(--accent); opacity:.3; margin-bottom:16px; }
.tp-text { font-size:1.2rem; color:var(--gray-1); font-style:italic; line-height:1.8; margin-bottom:28px; }
.tp-author { display:flex; align-items:center; justify-content:center; gap:16px; margin-bottom:20px; }
.tp-avatar { width:52px; height:52px; border-radius:50%; object-fit:cover; border:2px solid var(--accent); }
.tp-author strong { display:block; font-size:.95rem; }
.tp-author > div span { font-size:.82rem; color:var(--gray-2); }
.tp-stars { display:flex; gap:3px; color:var(--gold); font-size:.85rem; }
.tp-link { color:var(--accent-2); font-weight:600; font-size:.9rem; display:inline-flex; align-items:center; gap:6px; }
.tp-link:hover { gap:10px; color:var(--neon); }

/* ===== PAGE HERO (Inner pages) ===== */
.page-hero {
  position:relative; padding:180px 0 100px;
  text-align:center; overflow:hidden;
}
.page-hero-short { padding:160px 0 80px; }
.page-hero-bg {
  position:absolute; inset:0; background-size:cover; background-position:center;
  opacity:.2;
}
.page-hero::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to bottom,rgba(0,0,0,.5),var(--bg));
}
.page-hero .container { position:relative; z-index:1; }
.page-hero-title {
  font-family:var(--font-display); font-size:clamp(2.4rem,5vw,4rem);
  font-weight:800; line-height:1.1; margin-bottom:18px; letter-spacing:-.02em;
}
.page-hero-desc { font-size:1.1rem; color:var(--gray-1); max-width:600px; margin:0 auto; }

/* ===== SERVICE FULL CARDS (Services page) ===== */
.services-full-grid { display:flex; flex-direction:column; gap:48px; }
.service-full-card {
  display:grid; grid-template-columns:1fr 1fr; gap:0;
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius); overflow:hidden;
  transition:.4s var(--ease);
}
.service-full-card:hover { border-color:var(--accent); box-shadow:var(--shadow-glow); }
.sfc-reverse { direction:rtl; }
.sfc-reverse > * { direction:ltr; }
.sfc-visual {
  position:relative; min-height:360px;
  background-size:cover; background-position:center;
}
.sfc-number {
  position:absolute; top:20px; left:20px;
  font-family:var(--font-display); font-size:4rem; font-weight:900;
  color:rgba(255,255,255,.08); line-height:1;
}
.sfc-body { padding:48px; }
.sfc-icon {
  width:52px; height:52px; display:flex; align-items:center; justify-content:center;
  background:rgba(55,175,225,.1); border-radius:var(--radius-sm);
  font-size:1.2rem; color:var(--accent-2); margin-bottom:20px;
}
.sfc-body h3 { font-family:var(--font-display); font-size:1.5rem; font-weight:700; margin-bottom:14px; }
.sfc-body p { color:var(--gray-1); margin-bottom:20px; line-height:1.7; }
.sfc-features { margin-bottom:24px; }
.sfc-features li {
  display:flex; align-items:center; gap:10px; padding:6px 0;
  font-size:.9rem; color:var(--gray-1);
}
.sfc-features i { color:var(--green); font-size:.8rem; }

/* ===== SOLUTIONS GRID (Services page catalog) ===== */
.solutions-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
}
.solution-card {
  padding:28px 24px; background:var(--surface);
  border:1px solid var(--border); border-radius:var(--radius);
  transition:.4s var(--ease); position:relative; overflow:hidden;
}
.solution-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:var(--gradient); opacity:0; transition:.3s var(--ease);
}
.solution-card:hover {
  border-color:var(--accent); transform:translateY(-4px);
  box-shadow:var(--shadow-glow);
}
.solution-card:hover::before { opacity:1; }
.sol-icon {
  width:48px; height:48px; display:flex; align-items:center; justify-content:center;
  background:rgba(55,175,225,.1); border-radius:var(--radius-xs);
  font-size:1.15rem; color:var(--accent-2); margin-bottom:16px;
  transition:.3s var(--ease);
}
.solution-card:hover .sol-icon { background:var(--gradient); color:#fff; }
.solution-card h4 {
  font-family:var(--font-display); font-size:1.05rem; font-weight:700; margin-bottom:8px;
}
.solution-card p { font-size:.85rem; color:var(--gray-2); line-height:1.6; }

/* ===== PRIVACY POLICY PAGE ===== */
.privacy-content {
  max-width:800px; margin:0 auto;
  font-size:1rem; line-height:1.75; color:var(--gray-1);
}
.privacy-content .privacy-intro { font-size:1.1rem; color:var(--gray-1); margin-bottom:24px; }
.privacy-content h2 {
  font-family:var(--font-display); font-size:1.6rem; font-weight:700;
  margin-top:48px; margin-bottom:16px; color:#fff;
}
.privacy-content h3 { font-size:1.2rem; margin-top:28px; margin-bottom:10px; color:var(--gray-1); }
.privacy-content h4 { font-size:1.05rem; margin-top:20px; margin-bottom:8px; color:var(--gray-1); }
.privacy-content p { margin-bottom:16px; }
.privacy-content ul { margin:12px 0 24px 24px; }
.privacy-content li { margin-bottom:8px; }
.privacy-content a { color:var(--accent-2); text-decoration:none; transition:color .2s; }
.privacy-content a:hover { color:var(--accent); text-decoration:underline; }
.privacy-contact { list-style:none; margin-left:0; }
.privacy-contact li { margin-bottom:12px; }
.privacy-contact a { display:inline-flex; align-items:center; gap:10px; }
.privacy-credit { font-size:.85rem; color:var(--gray-3); margin-top:48px; }

/* ===== STORY (About page) ===== */
.story-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.story-content p { color:var(--gray-1); margin-bottom:20px; }
.story-values { display:flex; flex-direction:column; gap:16px; margin-top:32px; }
.value-item {
  display:flex; align-items:center; gap:16px; padding:14px 18px;
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-sm); transition:.3s var(--ease);
}
.value-item:hover { border-color:var(--accent); }
.vi-icon {
  width:44px; height:44px; min-width:44px;
  display:flex; align-items:center; justify-content:center;
  background:var(--gradient); border-radius:var(--radius-xs);
  color:#fff; font-size:1rem;
}
.value-item strong { display:block; font-size:.95rem; }
.value-item span { font-size:.82rem; color:var(--gray-2); }

.story-visual { position:relative; }
.story-image-wrapper { position:relative; }
.story-image-wrapper img {
  width:100%; border-radius:var(--radius); box-shadow:var(--shadow-lg);
}
.story-badge-card {
  position:absolute; bottom:-24px; right:-16px;
  background:var(--gradient); padding:20px 28px;
  border-radius:var(--radius-sm); text-align:center; box-shadow:var(--shadow);
}
.sbc-number { display:block; font-family:var(--font-display); font-size:2rem; font-weight:800; color:#fff; }
.sbc-text { font-size:.75rem; color:rgba(255,255,255,.8); line-height:1.4; }

/* ===== TEAM (About page) ===== */
.team-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.team-card {
  text-align:center; background:var(--surface);
  border:1px solid var(--border); border-radius:var(--radius);
  padding:24px; transition:.4s var(--ease); overflow:hidden;
}
.team-card:hover { border-color:var(--accent); transform:translateY(-6px); box-shadow:var(--shadow-glow); }
.tc-image { position:relative; margin-bottom:16px; overflow:hidden; border-radius:var(--radius-sm); }
.tc-image img { width:100%; aspect-ratio:1; object-fit:cover; transition:.5s var(--ease); }
.team-card:hover .tc-image img { transform:scale(1.05); }
.tc-socials {
  position:absolute; bottom:0; left:0; right:0;
  display:flex; justify-content:center; gap:10px;
  padding:12px; background:linear-gradient(to top,rgba(0,0,0,.9),transparent);
  transform:translateY(100%); transition:.4s var(--ease);
}
.team-card:hover .tc-socials { transform:translateY(0); }
.tc-socials a {
  width:36px; height:36px; display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.1); border-radius:50%;
  color:var(--white); font-size:.85rem; backdrop-filter:blur(6px);
}
.tc-socials a:hover { background:var(--accent); }
.team-card h4 { font-family:var(--font-display); font-size:1.05rem; font-weight:700; margin-bottom:2px; }
.team-card span { font-size:.82rem; color:var(--gray-2); }

/* ===== TIMELINE (About page) ===== */
.timeline { position:relative; max-width:700px; margin:0 auto; }
.timeline-line {
  position:absolute; left:50%; top:0; bottom:0; width:2px;
  background:linear-gradient(to bottom,var(--accent),var(--neon),transparent);
  transform:translateX(-50%);
}
.timeline-item { display:flex; gap:32px; margin-bottom:48px; position:relative; }
.timeline-right { flex-direction:row-reverse; text-align:right; }
.ti-dot {
  width:16px; height:16px; min-width:16px;
  background:var(--gradient); border-radius:50%;
  position:absolute; left:50%; transform:translateX(-50%);
  box-shadow:0 0 20px var(--glow);
  z-index:1;
}
.ti-content {
  width:calc(50% - 40px); padding:24px;
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-sm);
}
.timeline-item:not(.timeline-right) .ti-content { margin-right:auto; }
.timeline-right .ti-content { margin-left:auto; }
.ti-year {
  font-family:var(--font-mono); font-size:.8rem; font-weight:600;
  color:var(--neon); margin-bottom:8px; display:block;
}
.ti-content h4 { font-family:var(--font-display); font-weight:700; margin-bottom:6px; }
.ti-content p { font-size:.88rem; color:var(--gray-2); }

/* ===== PROJECT COUNTERS (Projects page) ===== */
.project-counters { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.pc-item {
  text-align:center; padding:40px 24px;
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius); transition:.3s var(--ease);
}
.pc-item:hover { border-color:var(--accent); transform:translateY(-4px); }
.pc-status { width:12px; height:12px; border-radius:50%; margin:0 auto 14px; }
.completed-dot { background:var(--green); box-shadow:0 0 12px rgba(16,185,129,.4); }
.progress-dot { background:var(--gold); box-shadow:0 0 12px rgba(251,191,36,.4); }
.upcoming-dot { background:var(--accent-2); box-shadow:0 0 12px var(--glow); }
.pc-number { font-family:var(--font-display); font-size:3rem; font-weight:800; }
.pc-label { font-size:.9rem; color:var(--gray-2); margin-bottom:18px; }
.pc-bar { width:100%; height:5px; background:rgba(255,255,255,.05); border-radius:3px; overflow:hidden; }
.pc-bar-fill {
  height:100%; background:var(--gradient); border-radius:3px;
  width:0; transition:width 1.5s var(--ease);
}

/* ===== FILTER TABS ===== */
.filter-tabs {
  display:flex; gap:8px; justify-content:center; flex-wrap:wrap;
  margin-bottom:40px;
}
.filter-tab {
  padding:10px 22px; background:var(--surface);
  border:1px solid var(--border); border-radius:var(--radius-full);
  color:var(--gray-2); font-size:.85rem; font-weight:600;
  cursor:pointer; transition:.3s var(--ease);
}
.filter-tab:hover { border-color:var(--accent); color:var(--white); }
.filter-tab.active { background:var(--gradient); color:#fff; border-color:transparent; }

/* ===== PROJECT CARDS (Projects page) ===== */
.projects-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.project-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius); overflow:hidden;
  transition:.4s var(--ease);
}
.project-card:hover { border-color:var(--accent); transform:translateY(-6px); box-shadow:var(--shadow-glow); }
.project-card.hidden { display:none; }
.proj-image {
  height:200px; background-size:cover; background-position:center;
  transition:.5s var(--ease);
}
.project-card:hover .proj-image { transform:scale(1.03); }
.proj-body { padding:24px; }
.proj-tag {
  display:inline-block; padding:4px 12px;
  background:rgba(55,175,225,.1); border-radius:var(--radius-full);
  font-size:.72rem; font-weight:700; color:var(--accent-2);
  text-transform:uppercase; letter-spacing:1px; margin-bottom:10px;
}
.proj-body h3 { font-family:var(--font-display); font-size:1.1rem; font-weight:700; margin-bottom:8px; }
.proj-body p { font-size:.88rem; color:var(--gray-2); margin-bottom:14px; line-height:1.6; }
.proj-tech { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:12px; }
.proj-tech span {
  padding:3px 10px; background:rgba(255,255,255,.04); border:1px solid var(--border);
  border-radius:var(--radius-full); font-size:.7rem; color:var(--gray-3);
}
.proj-result {
  display:flex; align-items:center; gap:8px;
  font-size:.82rem; font-weight:600; color:var(--green);
}

/* ===== RATING OVERVIEW (Testimonials page) ===== */
.rating-overview {
  display:grid; grid-template-columns:1fr 2fr; gap:48px;
  padding:48px; background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius); align-items:center;
}
.ro-score { text-align:center; }
.ro-number { font-family:var(--font-display); font-size:4rem; font-weight:800; line-height:1; }
.ro-stars { display:flex; gap:4px; justify-content:center; color:var(--gold); font-size:1.2rem; margin:8px 0; }
.ro-count { font-size:.85rem; color:var(--gray-2); }
.ro-bar-row { display:flex; align-items:center; gap:12px; margin-bottom:10px; font-size:.82rem; color:var(--gray-2); }
.ro-bar { flex:1; height:6px; background:rgba(255,255,255,.05); border-radius:3px; overflow:hidden; }
.ro-bar-fill { height:100%; background:var(--gradient); border-radius:3px; }

/* ===== TESTIMONIAL MASONRY ===== */
.testimonials-masonry { columns:2; column-gap:24px; }
.testi-card {
  break-inside:avoid; margin-bottom:24px;
  padding:32px; background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius); transition:.4s var(--ease);
}
.testi-card:hover { border-color:var(--accent); transform:translateY(-4px); box-shadow:var(--shadow-glow); }
.tc-featured {
  background:linear-gradient(135deg,rgba(55,175,225,.08),rgba(55,175,225,.04));
  border-color:rgba(55,175,225,.2);
}
.tc-stars { display:flex; gap:3px; color:var(--gold); font-size:.85rem; margin-bottom:14px; }
.testi-card p { color:var(--gray-1); font-size:.95rem; line-height:1.7; font-style:italic; margin-bottom:20px; }
.tc-author { display:flex; align-items:center; gap:12px; }
.tc-author img { width:44px; height:44px; border-radius:50%; object-fit:cover; }
.tc-author strong { display:block; font-size:.9rem; }
.tc-author span { font-size:.78rem; color:var(--gray-2); }

/* ===== CONTACT (Contact page) ===== */
.contact-grid { display:grid; grid-template-columns:1fr 1.3fr; gap:60px; align-items:start; }
.contact-info-col h2 { font-family:var(--font-display); font-size:2rem; font-weight:800; margin-bottom:16px; line-height:1.2; }
.contact-info-col > p { color:var(--gray-1); margin-bottom:32px; }
.contact-cards { display:flex; flex-direction:column; gap:14px; margin-bottom:32px; }
.contact-card {
  display:flex; align-items:center; gap:16px;
  padding:18px 22px; background:var(--surface);
  border:1px solid var(--border); border-radius:var(--radius-sm);
  transition:.3s var(--ease);
}
.contact-card:hover { border-color:var(--accent); transform:translateX(4px); }
.cc-icon {
  width:44px; height:44px; min-width:44px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(55,175,225,.1); border-radius:var(--radius-xs);
  color:var(--accent-2); font-size:1rem;
}
.contact-card strong { display:block; font-size:.9rem; }
.contact-card a, .contact-card span { font-size:.85rem; color:var(--gray-2); }
.contact-card a:hover { color:var(--neon); }
.contact-map { border-radius:var(--radius); overflow:hidden; border:1px solid var(--border); }

.contact-form {
  padding:40px; background:var(--surface);
  border:1px solid var(--border); border-radius:var(--radius);
}
.contact-form h3 {
  font-family:var(--font-display); font-size:1.4rem; font-weight:700;
  margin-bottom:28px; text-align:center;
}
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { margin-bottom:18px; }
.form-group label { display:block; font-size:.82rem; font-weight:600; color:var(--gray-2); margin-bottom:7px; }
.form-group input, .form-group select, .form-group textarea {
  width:100%; padding:13px 16px; background:var(--bg-2);
  border:1px solid var(--border); border-radius:var(--radius-sm);
  color:var(--white); font-family:var(--font); font-size:.9rem;
  transition:.3s var(--ease); outline:none;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  border-color:var(--accent); box-shadow:0 0 0 3px var(--glow);
}
.form-group input::placeholder, .form-group textarea::placeholder { color:var(--gray-3); }
.form-error { display:block; font-size:.8rem; color:#ef4444; margin-top:4px; }
.contact-messages { margin-bottom:28px; }
.alert {
  padding:16px 20px; border-radius:var(--radius-sm); display:flex; align-items:center; gap:12px;
  font-size:.95rem;
}
.alert-success { background:rgba(16,185,129,.15); border:1px solid rgba(16,185,129,.4); color:#10b981; }
.alert-error { background:rgba(239,68,68,.15); border:1px solid rgba(239,68,68,.4); color:#ef4444; }
.form-group select {
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23555570' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center; padding-right:36px;
}
.form-group textarea { resize:vertical; min-height:100px; }

/* ===== COMPARISON TABLE (Why Us page) ===== */
.compare-table {
  max-width:900px; margin:0 auto;
  border:1px solid var(--border); border-radius:var(--radius); overflow:hidden;
}
.compare-row { display:grid; grid-template-columns:1.2fr 1.5fr 1.5fr; border-bottom:1px solid var(--border); }
.compare-row:last-child { border-bottom:none; }
.compare-header { background:var(--surface); }
.compare-header > div { padding:20px 24px; font-weight:700; font-size:.95rem; }
.compare-metric, .compare-us, .compare-them {
  padding:16px 24px; font-size:.9rem; display:flex; align-items:center; gap:10px;
}
.compare-metric { font-weight:600; background:rgba(255,255,255,.01); }
.compare-us { background:rgba(55,175,225,.04); }
.compare-us i { color:var(--green); }
.compare-them { color:var(--gray-2); }
.compare-them i { color:var(--orange); opacity:.6; }
.compare-badge {
  display:inline-flex; padding:5px 16px; background:var(--gradient);
  border-radius:var(--radius-full); font-size:.8rem; font-weight:700; color:#fff;
}

/* ===== PROCESS CARDS (Why Us page) ===== */
.process-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.process-card {
  text-align:center; padding:40px 24px;
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius); transition:.4s var(--ease);
  position:relative;
}
.process-card:hover { border-color:var(--accent); transform:translateY(-6px); box-shadow:var(--shadow-glow); }
.proc-number {
  font-family:var(--font-display); font-size:3.5rem; font-weight:900;
  background:var(--gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text; opacity:.15; line-height:1; margin-bottom:12px;
}
.proc-icon {
  width:60px; height:60px; display:flex; align-items:center; justify-content:center;
  background:rgba(55,175,225,.1); border:1px solid rgba(55,175,225,.2);
  border-radius:50%; margin:0 auto 18px; font-size:1.3rem; color:var(--accent-2);
  transition:.3s var(--ease);
}
.process-card:hover .proc-icon { background:var(--gradient); color:#fff; border-color:transparent; }
.process-card h3 { font-family:var(--font-display); font-size:1.1rem; font-weight:700; margin-bottom:10px; }
.process-card p { font-size:.88rem; color:var(--gray-2); }

/* ===== BIG CTA ===== */
.big-cta {
  text-align:center; padding:80px 48px;
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius); position:relative; overflow:hidden;
}
.big-cta::before {
  content:''; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:400px; height:400px; background:var(--accent);
  border-radius:50%; filter:blur(150px); opacity:.08;
}
.big-cta h2 { font-family:var(--font-display); font-size:clamp(1.8rem,4vw,2.8rem); font-weight:800; margin-bottom:16px; position:relative; }
.big-cta p { font-size:1.1rem; color:var(--gray-1); margin-bottom:32px; position:relative; }
.big-cta .btn { position:relative; }

/* ===== FOOTER ===== */
.footer {
  position:relative; padding:100px 0 0;
  background:var(--bg-2); border-top:1px solid var(--border); overflow:hidden;
}
.footer-glow {
  position:absolute; top:-200px; left:50%; transform:translateX(-50%);
  width:600px; height:600px; background:var(--accent);
  border-radius:50%; filter:blur(200px); opacity:.04;
}
.footer-cta { text-align:center; margin-bottom:60px; }
.footer-cta h2 { font-family:var(--font-display); font-size:clamp(1.8rem,4vw,2.8rem); font-weight:800; margin-bottom:14px; }
.footer-cta p { font-size:1.05rem; color:var(--gray-1); margin-bottom:28px; }
.footer-divider { width:100%; height:1px; background:var(--border); margin-bottom:48px; }

.footer-grid { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px; }
.footer-brand p { color:var(--gray-2); font-size:.88rem; margin:14px 0 20px; line-height:1.7; }
.footer-socials { display:flex; gap:10px; }
.footer-socials a {
  width:40px; height:40px; display:flex; align-items:center; justify-content:center;
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-xs); color:var(--gray-2); font-size:.95rem;
  transition:.3s var(--ease);
}
.footer-socials a:hover { background:var(--accent); color:#fff; border-color:var(--accent); transform:translateY(-2px); }
.footer-links h4 { font-family:var(--font-display); font-weight:700; margin-bottom:18px; }
.footer-links li { margin-bottom:10px; }
.footer-links a { font-size:.88rem; color:var(--gray-2); display:flex; align-items:center; gap:8px; }
.footer-links a:hover { color:var(--accent-2); }
.footer-links a i { font-size:.8rem; }
.footer-bottom {
  display:flex; justify-content:space-between; align-items:center;
  padding:24px 0; border-top:1px solid var(--border);
  font-size:.82rem; color:var(--gray-3);
}
.footer-bottom-links { display:flex; gap:24px; }
.footer-bottom-links a { color:var(--gray-3); }
.footer-bottom-links a:hover { color:var(--accent-2); }

/* ===== WHATSAPP FLOAT ===== */
.whatsapp-float {
  position:fixed; bottom:28px; right:28px;
  width:60px; height:60px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:#25D366; color:#fff; font-size:1.8rem;
  z-index:999; box-shadow:0 4px 24px rgba(37,211,102,.4);
  transition:.3s var(--ease);
}
.whatsapp-float:hover { transform:scale(1.1); box-shadow:0 6px 32px rgba(37,211,102,.6); }
.wa-pulse {
  position:absolute; inset:-4px; border-radius:50%;
  border:2px solid #25D366; animation:wa-pulse 2s infinite;
}
@keyframes wa-pulse {
  0%{transform:scale(1);opacity:.5} 100%{transform:scale(1.4);opacity:0}
}

/* ===== BACK TO TOP ===== */
.back-to-top {
  position:fixed; bottom:100px; right:28px;
  width:44px; height:44px; background:var(--surface);
  border:1px solid var(--border); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:var(--gray-2); cursor:pointer; z-index:998;
  opacity:0; visibility:hidden; transform:translateY(10px);
  transition:.3s var(--ease);
}
.back-to-top svg { width:18px; height:18px; }
.back-to-top.visible { opacity:1; visibility:visible; transform:translateY(0); }
.back-to-top:hover { background:var(--accent); color:#fff; border-color:var(--accent); }

/* ==========================================================
   RESPONSIVE — full coverage for all devices
   ========================================================== */

/* ---------- TABLET LANDSCAPE / SMALL DESKTOP (≤1024px) ---------- */
@media(max-width:1024px) {
  .why-grid, .story-grid, .contact-grid { grid-template-columns:1fr; gap:48px; }
  .featured-grid { grid-template-columns:1fr; }
  .featured-grid .featured-card:first-child { grid-row:auto; }
  .featured-card { min-height:260px; }
  .stats-row { grid-template-columns:repeat(2,1fr); }
  .team-grid { grid-template-columns:repeat(2,1fr); }
  .process-grid { grid-template-columns:repeat(2,1fr); }
  .projects-grid { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:repeat(2,1fr); }
  .service-full-card { grid-template-columns:1fr; }
  .sfc-reverse { direction:ltr; }
  .sfc-visual { min-height:260px; }
  .solutions-grid { grid-template-columns:repeat(2,1fr); }
  .service-showcase-card { grid-template-columns:auto 1fr auto; }
  .ssc-image { display:none; }
  .rating-overview { grid-template-columns:1fr; }
  .testimonials-masonry { columns:1; }
  .big-cta { padding:60px 36px; }
  .tp-card { padding:48px 36px; }
  .page-hero { padding:160px 0 80px; }
  .page-hero-short { padding:140px 0 60px; }
  /* keep stacked image from overflowing */
  .stack-img-2 { right:0; bottom:-20px; }
  .stack-stats { left:0; }
}

/* ---------- TABLET PORTRAIT / LARGE PHONE (≤768px) ---------- */
@media(max-width:768px) {
  /* cursor off on touch devices */
  body { cursor:auto; }
  .cursor-dot, .cursor-ring { display:none; }

  .container { padding:0 18px; }
  .section { padding:64px 0; }

  /* ---- NAV ---- */
  .nav-links {
    display:none; position:fixed; inset:0;
    background:rgba(0,0,0,.98); backdrop-filter:blur(24px);
    flex-direction:column; align-items:center; justify-content:center;
    gap:8px; z-index:999;
  }
  .nav-links.active { display:flex; }
  .nav-link { font-size:1.2rem; padding:14px 28px; min-height:48px; }
  .nav-actions .nav-cta { display:none; }
  .mobile-toggle { display:block; z-index:1001; }

  /* ---- HERO ---- */
  .hero { padding:100px 0 48px; min-height:100vh; min-height:100dvh; }
  .hero-title { font-size:clamp(1.8rem,6vw,2.8rem); margin-bottom:14px; }
  .hero-subtitle { font-size:.92rem; margin-bottom:20px; }
  .hero-badge { font-size:.8rem; padding:7px 18px; margin-bottom:14px; }
  .hero-cta { gap:10px; margin-bottom:24px; }
  .hero-cta .btn-lg { padding:13px 24px; font-size:.88rem; width:100%; justify-content:center; }
  .hero-metrics { gap:16px; flex-wrap:wrap; }
  .metric-value { font-size:1.3rem; }
  .metric-label { font-size:.7rem; }
  .metric-divider { display:none; }
  .hero-scroll-indicator { display:none; }

  /* ---- PAGE HERO (inner pages) ---- */
  .page-hero { padding:130px 0 60px; }
  .page-hero-short { padding:120px 0 48px; }
  .page-hero-title { font-size:clamp(1.7rem,6vw,2.4rem); }
  .page-hero-desc { font-size:.95rem; }

  /* ---- MARQUEE ---- */
  .marquee-section { padding:32px 0; }
  .marquee-label { font-size:.7rem; margin-bottom:18px; }
  .marquee-item { font-size:.85rem; gap:8px; }
  .marquee-item i { font-size:1.2rem; }

  /* ---- SERVICE SHOWCASE (home) ---- */
  .service-showcase-card { grid-template-columns:1fr; gap:12px; padding:20px; }
  .ssc-icon { width:48px; height:48px; font-size:1.2rem; }
  .ssc-content h3 { font-size:1.05rem; }
  .ssc-arrow { display:none; }

  /* ---- SERVICE FULL CARDS (services page) ---- */
  .sfc-visual { min-height:200px; }
  .sfc-body { padding:28px 20px; }
  .sfc-body h3 { font-size:1.25rem; }
  .sfc-number { font-size:3rem; }
  .solutions-grid { grid-template-columns:1fr; }

  /* ---- STATS ---- */
  .stats-banner { padding:40px 0; }
  .stats-row { grid-template-columns:1fr 1fr; gap:16px; }
  .stat-number { font-size:clamp(1.6rem,5vw,2.4rem); }
  .stat-label { font-size:.78rem; }

  /* ---- WHY SECTION (home) ---- */
  .why-content .section-title { font-size:clamp(1.6rem,5vw,2.2rem); }
  .why-feature { padding:14px 16px; }
  .wf-icon { width:40px; height:40px; min-width:40px; font-size:.9rem; }
  .why-feature strong { font-size:.88rem; }
  .why-feature span { font-size:.78rem; }

  /* stacked images: prevent overflow */
  .why-image-stack { position:relative; }
  .stack-img-2 { width:50%; right:0; bottom:-16px; }
  .stack-stats { position:relative; left:0; top:0; display:inline-block; margin-top:12px; }

  /* ---- FEATURED PROJECTS (home) ---- */
  .featured-card { min-height:240px; }
  .fc-overlay { padding:20px; }
  .fc-overlay h3 { font-size:1.1rem; }
  .fc-overlay p { font-size:.82rem; }

  /* ---- PROJECT COUNTERS (projects page) ---- */
  .project-counters { grid-template-columns:1fr; gap:16px; }
  .pc-item { padding:28px 20px; }
  .pc-number { font-size:2.4rem; }

  /* ---- PROJECT CARDS ---- */
  .projects-grid { grid-template-columns:1fr; }
  .proj-image { height:180px; }

  /* ---- FILTER TABS ---- */
  .filter-tabs { gap:6px; overflow-x:auto; flex-wrap:nowrap; justify-content:flex-start;
    -webkit-overflow-scrolling:touch; scrollbar-width:none; padding-bottom:4px; }
  .filter-tabs::-webkit-scrollbar { display:none; }
  .filter-tab { flex-shrink:0; padding:9px 18px; font-size:.82rem; }

  /* ---- TEAM ---- */
  .team-grid { grid-template-columns:1fr 1fr; gap:16px; }
  .team-card { padding:16px; }
  .team-card h4 { font-size:.95rem; }

  /* ---- TIMELINE ---- */
  .timeline-line { left:16px; }
  .timeline-item, .timeline-right { flex-direction:row; text-align:left; }
  .ti-dot { left:16px; width:12px; height:12px; min-width:12px; }
  .ti-content { width:calc(100% - 52px); margin-left:auto !important; margin-right:0 !important; padding:18px; }
  .ti-content h4 { font-size:1rem; }
  .ti-content p { font-size:.82rem; }

  /* ---- PROCESS CARDS (why-us) ---- */
  .process-grid { grid-template-columns:1fr; }
  .process-card { padding:28px 20px; }
  .proc-number { font-size:2.8rem; }
  .proc-icon { width:52px; height:52px; font-size:1.1rem; }

  /* ---- COMPARISON TABLE ---- */
  .compare-table { border:none; border-radius:0; }
  .compare-row { grid-template-columns:1fr; }
  .compare-header { display:none; }
  .compare-row:not(.compare-header) {
    background:var(--surface); border:1px solid var(--border);
    border-radius:var(--radius-sm); margin-bottom:12px; overflow:hidden;
  }
  .compare-row:last-child { border-bottom:1px solid var(--border); }
  .compare-metric { padding:12px 18px; font-size:.82rem; background:rgba(255,255,255,.03); }
  .compare-us, .compare-them { padding:10px 18px; font-size:.85rem; }
  .compare-us::before { content:'Elias Tech: '; font-weight:700; color:var(--accent-2); }
  .compare-them::before { content:'Traditional: '; font-weight:700; color:var(--gray-3); }

  /* ---- TESTIMONIALS ---- */
  .testimonials-masonry { columns:1; }
  .testi-card { padding:24px; }
  .testi-card p { font-size:.88rem; }
  .tp-card { padding:36px 20px; }
  .tp-text { font-size:1rem; }
  .tp-author { flex-wrap:wrap; gap:12px; }
  .tp-avatar { width:44px; height:44px; }

  /* ---- RATING OVERVIEW ---- */
  .rating-overview { grid-template-columns:1fr; padding:28px; gap:28px; }
  .ro-number { font-size:3rem; }

  /* ---- CONTACT ---- */
  .contact-grid { grid-template-columns:1fr; gap:36px; }
  .contact-info-col h2 { font-size:1.6rem; }
  .contact-form { padding:24px 18px; }
  .contact-form h3 { font-size:1.2rem; }
  .form-row { grid-template-columns:1fr; }
  .form-group input, .form-group select, .form-group textarea { padding:12px 14px; font-size:.88rem; }
  .contact-map iframe { height:200px; }

  /* ---- BIG CTA ---- */
  .big-cta { padding:48px 20px; }
  .big-cta h2 { font-size:clamp(1.4rem,5vw,2rem); }
  .big-cta p { font-size:.95rem; }

  /* ---- STORY (about page) ---- */
  .story-badge-card { position:relative; right:auto; bottom:auto; display:inline-block; margin-top:16px; }
  .story-image-wrapper img { border-radius:var(--radius-sm); }

  /* ---- FOOTER ---- */
  .footer { padding:60px 0 0; }
  .footer-cta { margin-bottom:36px; }
  .footer-cta h2 { font-size:clamp(1.4rem,5vw,1.8rem); }
  .footer-cta p { font-size:.92rem; }
  .footer-grid { grid-template-columns:1fr; gap:24px; }
  .footer-bottom { flex-direction:column; gap:10px; text-align:center; }
  .footer-bottom-links { justify-content:center; }

  /* ---- FLOATING BUTTONS ---- */
  .whatsapp-float { width:52px; height:52px; font-size:1.5rem; bottom:20px; right:16px; }
  .back-to-top { width:40px; height:40px; bottom:84px; right:16px; }

  /* ---- SECTION HEADERS ---- */
  .section-header { margin-bottom:40px; }
  .section-title { font-size:clamp(1.6rem,5vw,2.2rem); }
  .section-desc { font-size:.92rem; }
  .section-tag { font-size:.72rem; padding:5px 14px; letter-spacing:1.5px; }
  .section-cta { margin-top:32px; }

  /* ---- BUTTONS (touch targets) ---- */
  .btn-sm { padding:12px 22px; min-height:44px; }
  .btn-lg { padding:16px 28px; min-height:48px; font-size:.9rem; }
}

/* ---------- SMALL PHONE (≤480px) ---------- */
@media(max-width:480px) {
  .container { padding:0 14px; }

  .hero { padding:90px 0 36px; }
  .hero-title { font-size:clamp(1.5rem,7.5vw,2rem); margin-bottom:10px; }
  .hero-badge { font-size:.75rem; padding:6px 14px; margin-bottom:10px; }
  .hero-subtitle { font-size:.85rem; margin-bottom:16px; }
  .hero-cta { gap:8px; margin-bottom:20px; }
  .hero-cta .btn-lg { padding:12px 20px; font-size:.84rem; }
  .hero-metrics { gap:12px; }
  .metric { min-width:calc(50% - 8px); }
  .metric-value { font-size:1.15rem; }
  .metric-label { font-size:.68rem; }

  .page-hero { padding:110px 0 48px; }
  .page-hero-title { font-size:clamp(1.5rem,7vw,2rem); }

  .stats-row { grid-template-columns:1fr; gap:12px; }
  .stat-item { padding:16px; }

  .team-grid { grid-template-columns:1fr; }

  .filter-tabs { gap:4px; }
  .filter-tab { padding:8px 14px; font-size:.78rem; }

  .sfc-body { padding:22px 16px; }
  .sfc-body h3 { font-size:1.1rem; }

  .solution-card { padding:22px 18px; }
  .solution-card h4 { font-size:.95rem; }
  .solution-card p { font-size:.8rem; }
  .sol-icon { width:42px; height:42px; font-size:1rem; }

  .why-feature { gap:12px; }

  .contact-form { padding:20px 14px; }
  .contact-card { padding:14px 16px; }

  .testi-card { padding:20px 16px; }
  .tc-author img { width:36px; height:36px; }

  .process-card { padding:24px 16px; }

  .footer-cta h2 { font-size:1.3rem; }
  .footer-links h4 { font-size:.92rem; }
  .privacy-content h2 { font-size:1.35rem; margin-top:36px; }
  .privacy-content h3 { font-size:1.1rem; }
}

/* ---------- VERY SMALL PHONE (≤360px) ---------- */
@media(max-width:360px) {
  .container { padding:0 12px; }
  .hero { padding:80px 0 28px; }
  .hero-title { font-size:1.4rem; margin-bottom:8px; }
  .hero-subtitle { font-size:.82rem; margin-bottom:14px; }
  .hero-badge { font-size:.72rem; padding:5px 12px; margin-bottom:8px; }
  .hero-cta .btn-lg { padding:11px 18px; font-size:.8rem; }
  .hero-cta { gap:6px; margin-bottom:16px; }
  .hero-metrics { gap:10px; }
  .metric-value { font-size:1rem; }
  .metric-label { font-size:.65rem; }
  .page-hero-title { font-size:1.4rem; }
  .section-title { font-size:1.4rem; }
  .nav-link { font-size:1.1rem; }
  .stat-number { font-size:1.6rem; }
  .pc-number { font-size:2rem; }
  .contact-info-col h2 { font-size:1.3rem; }
  .big-cta h2 { font-size:1.3rem; }
}

/* ---------- LANDSCAPE PHONE ---------- */
@media(max-height:500px) and (orientation:landscape) {
  .hero { min-height:auto; padding:80px 0 24px; }
  .hero-title { font-size:clamp(1.4rem,4vw,2rem); margin-bottom:8px; }
  .hero-subtitle { font-size:.85rem; margin-bottom:12px; }
  .hero-badge { margin-bottom:8px; }
  .hero-cta { margin-bottom:12px; gap:10px; }
  .hero-metrics { display:none; }
  .hero-scroll-indicator { display:none; }
  .page-hero { padding:90px 0 32px; }
}

/* ---------- SHORT VIEWPORTS (laptop screens ≤700px height) ---------- */
@media(max-height:700px) and (min-width:769px) {
  .hero { padding:100px 0 40px; }
  .hero-title { font-size:clamp(2rem,4.5vw,3.2rem); margin-bottom:12px; }
  .hero-badge { margin-bottom:12px; padding:7px 18px; font-size:.8rem; }
  .hero-subtitle { margin-bottom:20px; }
  .hero-cta { margin-bottom:24px; }
  .hero-metrics { gap:28px; }
  .metric-value { font-size:1.6rem; }
  .metric-divider { height:32px; }
  .hero-scroll-indicator { bottom:12px; }
  .scroll-line { height:28px; }
}

/* ---------- LARGE SCREENS (≥1400px) ---------- */
@media(min-width:1400px) {
  .container { max-width:1320px; }
  .hero-title { font-size:5rem; }
  .section-title { font-size:3.4rem; }
}

/* ===== ACCESSIBILITY ===== */
@media(prefers-reduced-motion:reduce) {
  *,*::before,*::after {
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
  }
  .scroll-reveal { opacity:1; transform:none; }
  .reveal-up { opacity:1; transform:none; }
  .marquee-track { animation:none !important; }
}

        .logo img {
            max-width: 100px;
            height: auto;
            transition: transform 0.3s ease;
        }
        .logo img:hover {
            transform: scale(1.05);
