*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0C0E0A;
  --bg2:#14170F;
  --card:#17190F;
  --card-hover:#1C1F14;
  --accent:#D3E512;
  --accent2:#B8C910;
  --accent-soft:rgba(211,229,18,0.1);
  --accent-glow:rgba(211,229,18,0.35);
  --accent-ink:#0C0E0A;
  --text:#EDEFE5;
  --text2:#9B9D8D;
  --text3:#5A5C50;
  --border:rgba(211,229,18,0.08);
  --border-strong:rgba(211,229,18,0.16);
  --font:'Inter',system-ui,sans-serif;
  --mono:'JetBrains Mono',monospace;
}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{
  background:var(--bg);color:var(--text);font-family:var(--font);
  font-size:15px;line-height:1.6;font-weight:400;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;outline:none;background:none;color:inherit}
img{display:block;max-width:100%}
::selection{background:var(--accent);color:var(--accent-ink)}

/* CURSOR */
.cursor-dot{position:fixed;top:0;left:0;width:6px;height:6px;background:var(--accent);border-radius:50%;pointer-events:none;z-index:10000;transform:translate(-50%,-50%);transition:opacity .2s}
.cursor-ring{position:fixed;top:0;left:0;width:32px;height:32px;border:1px solid rgba(211,229,18,0.3);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .3s ease,height .3s ease,opacity .3s ease;opacity:0.6}
.cursor-ring.hover{width:48px;height:48px;opacity:1}
@media(hover:none),(pointer:coarse),(max-width:900px){
  .cursor-dot,.cursor-ring{display:none !important}
  body,a,button,input,select,textarea{cursor:auto !important}
}

/* HEADER */
header{position:fixed;top:0;left:0;right:0;z-index:100;padding:16px 0;background:rgba(12,14,10,0.7);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid transparent;transition:all .3s ease}
header.scrolled{background:rgba(12,14,10,0.96);border-bottom-color:var(--border)}
.header-inner{max-width:1200px;margin:0 auto;padding:0 32px;display:flex;justify-content:space-between;align-items:center;gap:24px}
.brand{
  display:flex;align-items:center;gap:10px;
  font-family:'Space Grotesk',sans-serif;
  font-size:17px;font-weight:700;letter-spacing:0.06em;
  text-transform:uppercase;
}
.brand-mark{width:28px;height:28px;background:var(--accent);color:var(--accent-ink);border-radius:6px;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:15px;display:inline-flex;align-items:center;justify-content:center;letter-spacing:0}
.nav-center{display:flex;gap:2px;padding:4px;background:var(--card);border:1px solid var(--border);border-radius:10px}
.nav-center a{padding:8px 16px;font-size:13px;font-weight:500;color:var(--text2);border-radius:6px;transition:all .25s ease}
.nav-center a:hover{color:var(--text);background:var(--bg2)}
.nav-center a.active{background:var(--accent);color:var(--accent-ink);font-weight:600}
.header-right{display:flex;align-items:center;gap:14px}
.header-avail{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11.5px;color:var(--text2)}
.header-avail-dot{width:6px;height:6px;background:var(--accent);border-radius:50%;box-shadow:0 0 0 3px var(--accent-soft)}
.btn-header{padding:9px 18px;background:var(--accent);color:var(--accent-ink);border-radius:8px;font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:8px;transition:all .25s ease}
.btn-header:hover{background:var(--accent2);transform:translateY(-1px)}
.mobile-btn{display:none;width:36px;height:36px;background:var(--card);border:1px solid var(--border);border-radius:8px;align-items:center;justify-content:center;flex-direction:column;gap:3px}
.mobile-btn span{width:13px;height:1.5px;background:var(--text);display:block}

/* SECTIONS BASE */
section{padding:100px 0;position:relative}
.container{max-width:1200px;margin:0 auto;padding:0 32px}
.label{display:inline-flex;align-items:center;gap:8px;padding:5px 11px;background:var(--accent-soft);border:1px solid var(--border-strong);border-radius:100px;font-family:var(--mono);font-size:10.5px;letter-spacing:0.14em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:18px}
.label::before{content:'';width:5px;height:5px;background:var(--accent);border-radius:50%}
.heading{font-size:42px;font-weight:700;letter-spacing:-0.025em;line-height:1.1;margin-bottom:14px;max-width:720px}
.heading .accent{color:var(--accent)}
.intro{font-size:16px;color:var(--text2);line-height:1.65;max-width:580px}
.section-header-center{text-align:center;margin:0 auto 56px;max-width:720px}
.section-header-center .intro{margin:0 auto}

/* HERO */
.hero{padding:140px 0 80px;position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 800px 400px at 50% 0%,var(--accent-soft),transparent 60%);pointer-events:none}
.hero-inner{max-width:1200px;margin:0 auto;padding:0 32px;position:relative;z-index:1;text-align:center}
.hero-badge{display:inline-flex;align-items:center;gap:10px;padding:7px 14px;background:var(--card);border:1px solid var(--border);border-radius:100px;font-size:12.5px;color:var(--text2);margin-bottom:28px}
.hero-badge-dot{width:6px;height:6px;background:var(--accent);border-radius:50%;box-shadow:0 0 0 3px var(--accent-soft)}
.hero-badge strong{color:var(--accent);font-weight:700;font-family:'Space Grotesk',sans-serif;letter-spacing:0.12em}
h1{font-size:64px;font-weight:700;line-height:1.05;letter-spacing:-0.035em;margin-bottom:22px;max-width:860px;margin-left:auto;margin-right:auto}
h1 .accent{color:var(--accent)}
.hero-desc{font-size:17px;color:var(--text2);line-height:1.65;max-width:600px;margin:0 auto 36px}
.hero-desc strong{color:var(--text);font-weight:700;font-family:'Space Grotesk',sans-serif;letter-spacing:0.04em}
.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:48px}
.btn-primary{padding:14px 26px;background:var(--accent);color:var(--accent-ink);border-radius:10px;font-size:14px;font-weight:700;display:inline-flex;align-items:center;gap:8px;transition:all .25s ease}
.btn-primary:hover{background:var(--accent2);transform:translateY(-2px);box-shadow:0 10px 28px rgba(211,229,18,0.2)}
.btn-secondary{padding:14px 26px;background:transparent;color:var(--text);border:1px solid var(--border-strong);border-radius:10px;font-size:14px;font-weight:600;transition:all .25s ease}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}
.hero-trust{display:flex;align-items:center;justify-content:center;gap:16px;padding-top:36px;border-top:1px solid var(--border);max-width:560px;margin:0 auto}
.hero-trust-avatars{display:flex}
.hero-trust-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));border:2px solid var(--bg);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--accent-ink);margin-left:-8px}
.hero-trust-avatar:first-child{margin-left:0}
.hero-trust-avatar:nth-child(2){background:linear-gradient(135deg,#8b9a0e,#D3E512)}
.hero-trust-avatar:nth-child(3){background:linear-gradient(135deg,#4a5f08,#a8b80f)}
.hero-trust-avatar:nth-child(4){background:var(--bg2);color:var(--text);border-color:var(--border-strong)}
.hero-trust-text{text-align:left}
.hero-trust-text strong{color:var(--text);font-weight:700;font-size:13.5px}
.hero-trust-text .stars{color:var(--accent);margin-left:4px;letter-spacing:1px;font-size:11px}
.hero-trust-text span{display:block;font-size:12.5px;color:var(--text2);margin-top:2px}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;max-width:900px;margin:60px auto 0;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px 0}
.hero-stat{text-align:center;border-right:1px solid var(--border);padding:0 20px;transition:transform .3s ease}
.hero-stat:last-child{border-right:none}
.hero-stat:hover{transform:translateY(-2px)}
.hero-stat-v{font-size:28px;font-weight:800;color:var(--accent);letter-spacing:-0.02em;line-height:1}
.hero-stat-v sup{font-size:0.55em;vertical-align:super;margin-left:1px;font-weight:500}
.hero-stat-l{font-family:var(--mono);font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--text3);margin-top:6px}

/* MARQUEE */
.marquee{padding:18px 0;background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden;position:relative}
.marquee::before,.marquee::after{content:'';position:absolute;top:0;bottom:0;width:100px;z-index:2;pointer-events:none}
.marquee::before{left:0;background:linear-gradient(90deg,var(--bg2),transparent)}
.marquee::after{right:0;background:linear-gradient(-90deg,var(--bg2),transparent)}
.marquee-track{display:flex;gap:40px;white-space:nowrap;width:fit-content;animation:marquee 35s linear infinite}
.marquee-item{display:inline-flex;align-items:center;gap:12px;font-size:15px;font-weight:500;color:var(--text2);letter-spacing:-0.01em}
.marquee-item::after{content:'';width:5px;height:5px;background:var(--accent);border-radius:50%;margin-left:12px}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ============ SERVICES - BENTO GRID LIKE SS 6 ============ */
.services-bento{
  display:grid;
  grid-template-columns:1fr 1.4fr 1fr;
  grid-template-rows:auto auto;
  gap:14px;
}
/* Center big card - Web Development */
.svc-main{
  grid-column:2;grid-row:1/3;
  min-height:560px;
}
/* Left column */
.svc-tl{grid-column:1;grid-row:1}
.svc-bl{grid-column:1;grid-row:2}
/* Right column */
.svc-tr{grid-column:3;grid-row:1}
.svc-br{grid-column:3;grid-row:2}

.svc{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:16px;padding:28px;
  display:flex;flex-direction:column;gap:16px;
  position:relative;overflow:hidden;
  transition:all .4s ease;
  cursor:pointer;min-height:260px;
  color:inherit;text-decoration:none;
}

/* Radial glow hover effect (like SS 5) */
.svc::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%),var(--accent-glow) 0%,transparent 50%);
  opacity:0;transition:opacity .4s ease;pointer-events:none;
  z-index:0;
}
.svc:hover{
  border-color:var(--accent);transform:translateY(-4px);
  background:var(--card-hover);
}
.svc:hover::before{opacity:1}

.svc > *{position:relative;z-index:1}

.svc-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.svc-badge{
  padding:4px 9px;background:var(--accent);color:var(--accent-ink);
  border-radius:5px;font-family:var(--mono);font-size:10px;
  font-weight:700;letter-spacing:0.12em;text-transform:uppercase;
  display:inline-block;
}
.svc-num{
  font-family:var(--mono);font-size:10.5px;letter-spacing:0.14em;
  color:var(--text3);display:block;margin-top:6px;
}
.svc-icon{
  width:42px;height:42px;border-radius:10px;background:var(--accent);
  color:var(--accent-ink);
  display:flex;align-items:center;justify-content:center;
  transition:all .3s ease;flex-shrink:0;
}
.svc-icon-ghost{background:var(--bg2);border:1px solid var(--border-strong);color:var(--accent)}
.svc:hover .svc-icon-ghost{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.svc-icon svg{width:20px;height:20px}

.svc-title{font-size:22px;font-weight:700;letter-spacing:-0.015em;line-height:1.15}
.svc-main .svc-title{font-size:38px;font-weight:700;letter-spacing:-0.025em;line-height:1.05}
.svc-desc{font-size:14px;color:var(--text2);line-height:1.6}
.svc-main .svc-desc{font-size:16px;line-height:1.65;max-width:480px}

.svc-tags{display:flex;flex-wrap:wrap;gap:5px}
.svc-tag{
  padding:3px 9px;background:var(--bg2);border:1px solid var(--border);
  border-radius:100px;font-family:var(--mono);font-size:10px;
  color:var(--text2);transition:all .25s ease;
}
.svc:hover .svc-tag{border-color:var(--border-strong);color:var(--text)}

.svc-foot{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:14px;margin-top:auto;border-top:1px solid var(--border);
  font-size:13px;font-weight:600;color:var(--text);
}
.svc-main .svc-foot{font-size:14px}
.svc-foot-arr{
  width:28px;height:28px;border-radius:50%;
  border:1px solid var(--border-strong);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:11px;transition:all .3s ease;
}
.svc-main .svc-foot-arr{width:32px;height:32px;font-size:13px}
.svc:hover .svc-foot{color:var(--accent)}
.svc:hover .svc-foot-arr{background:var(--accent);color:var(--accent-ink);border-color:var(--accent);transform:rotate(-45deg)}

/* Featured - pre-highlighted */
.svc.featured{
  background:linear-gradient(160deg,var(--card) 0%,rgba(211,229,18,0.04) 100%);
  border-color:var(--border-strong);
}

/* Main center card - special bg (like SS 5 crypto card) */
.svc-main{
  background:radial-gradient(ellipse at center,rgba(211,229,18,0.08) 0%,var(--card) 50%);
  border-color:var(--border-strong);
  align-items:flex-start;
}
.svc-main::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at center,var(--accent-glow) 0%,transparent 60%);
  opacity:0.4;transition:opacity .5s ease;pointer-events:none;
}
.svc-main:hover::after{opacity:0.8}
.svc-main-center{
  margin:auto 0;display:flex;flex-direction:column;align-items:center;
  text-align:center;width:100%;gap:18px;padding:20px 0;
}
.svc-main-icon-big{
  width:80px;height:80px;border-radius:20px;background:var(--accent);
  color:var(--accent-ink);display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 40px rgba(211,229,18,0.3);
  transition:all .4s ease;
}
.svc-main:hover .svc-main-icon-big{
  transform:scale(1.08);
  box-shadow:0 0 60px rgba(211,229,18,0.5);
}
.svc-main-icon-big svg{width:36px;height:36px}

/* ============ STATS ============ */
.stats-banner{padding:64px 0;background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.stats-grid{max-width:1000px;margin:0 auto;padding:0 32px;display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.stat{text-align:center;padding:0 16px;border-left:1px solid var(--border)}
.stat:first-child{border-left:none}
.stat-v{font-size:44px;font-weight:800;letter-spacing:-0.035em;line-height:1;color:var(--text)}
.stat-v sup{color:var(--accent);font-size:0.45em;vertical-align:super;margin-left:2px;font-weight:600}
.stat-l{font-family:var(--mono);font-size:10.5px;letter-spacing:0.14em;text-transform:uppercase;color:var(--text3);margin-top:8px}

/* ============ PROCESS - VERTICAL SNAKE ROADMAP ============ */
.process-flow{
  position:relative;max-width:900px;margin:0 auto;
  padding:40px 0;
}

/* SVG snake path - stretches to full container */
.process-snake{
  position:absolute;inset:0;width:100%;height:100%;
  pointer-events:none;z-index:0;
}
.process-snake path{
  stroke:var(--accent);stroke-width:2.5;fill:none;
  stroke-linecap:round;stroke-linejoin:round;
  filter:drop-shadow(0 0 6px rgba(211,229,18,0.5)) drop-shadow(0 0 14px rgba(211,229,18,0.25));
  stroke-dasharray:3000;stroke-dashoffset:3000;
  vector-effect:non-scaling-stroke;
}
.process-snake.animate path{
  animation:drawSnake 3.5s cubic-bezier(0.65,0,0.35,1) forwards;
}
@keyframes drawSnake{to{stroke-dashoffset:0}}

/* Vertical stack of cards, alternating sides */
.process-steps{
  display:flex;flex-direction:column;
  position:relative;z-index:1;
  gap:80px;
}
.p-flow-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:18px;padding:28px 30px;
  display:flex;flex-direction:column;gap:14px;
  transition:all .4s ease;position:relative;
  width:42%;
}
.p-flow-card::before{
  content:'';position:absolute;inset:0;border-radius:18px;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%),var(--accent-glow) 0%,transparent 50%);
  opacity:0;transition:opacity .4s ease;pointer-events:none;
}
.p-flow-card:hover::before{opacity:1}
.p-flow-card > *{position:relative;z-index:1}

/* Alternate: 1 left, 2 right, 3 left, 4 right */
.p-flow-card:nth-child(1){align-self:flex-start}
.p-flow-card:nth-child(2){align-self:flex-end}
.p-flow-card:nth-child(3){align-self:flex-start}
.p-flow-card:nth-child(4){align-self:flex-end}

.p-flow-card:hover{
  background:var(--card-hover);border-color:var(--accent);
  transform:translateY(-4px);
  box-shadow:0 12px 40px rgba(211,229,18,0.12);
}
.p-flow-num{
  width:44px;height:44px;border-radius:10px;
  background:var(--bg2);border:1px solid var(--border-strong);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;font-weight:700;color:var(--accent);
  transition:all .3s ease;
}
.p-flow-card:hover .p-flow-num{
  background:var(--accent);color:var(--accent-ink);border-color:var(--accent);
  transform:rotate(-5deg) scale(1.05);
}
.p-flow-phase{
  font-family:var(--mono);font-size:10.5px;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--text3);font-weight:600;
}
.p-flow-title{font-size:22px;font-weight:700;letter-spacing:-0.015em}
.p-flow-desc{font-size:14px;color:var(--text2);line-height:1.6}

/* ============ WORK ============ */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.work-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:0;overflow:hidden;transition:all .3s ease;cursor:pointer;position:relative}
.work-card::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at var(--mx,50%) var(--my,50%),var(--accent-glow) 0%,transparent 50%);opacity:0;transition:opacity .4s ease;pointer-events:none;z-index:0}
.work-card:hover{border-color:var(--accent);transform:translateY(-4px)}
.work-card:hover::before{opacity:1}
.work-card > *{position:relative;z-index:1}
.work-visual{aspect-ratio:16/10;background:var(--bg2);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;border-bottom:1px solid var(--border)}
.work-visual::before{content:'';position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:28px 28px;mask-image:radial-gradient(ellipse,black,transparent 70%)}
.work-num{font-size:64px;font-weight:800;letter-spacing:-0.03em;line-height:1;color:transparent;-webkit-text-stroke:1.5px rgba(211,229,18,0.3);position:relative;z-index:1;transition:all .3s ease}
.work-card:hover .work-num{-webkit-text-stroke:1.5px var(--accent);color:var(--accent);transform:scale(1.05)}
.work-content{padding:20px}
.work-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.work-tag{padding:3px 9px;background:var(--accent-soft);border:1px solid var(--border-strong);border-radius:5px;font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--accent)}
.work-year{font-family:var(--mono);font-size:11px;color:var(--text3);letter-spacing:0.08em}
.work-title{font-size:17px;font-weight:700;letter-spacing:-0.01em;margin-bottom:6px;transition:color .25s ease}
.work-card:hover .work-title{color:var(--accent)}
.work-line{font-size:13px;color:var(--text2);line-height:1.55;margin-bottom:14px}
.work-metrics{display:flex;gap:20px;padding-top:12px;border-top:1px solid var(--border)}
.work-m{display:flex;flex-direction:column;gap:1px}
.work-m-v{font-size:15px;font-weight:700;color:var(--accent);letter-spacing:-0.015em}
.work-m-l{font-family:var(--mono);font-size:9.5px;letter-spacing:0.12em;text-transform:uppercase;color:var(--text3)}

/* REVIEWS - AUTO CAROUSEL */
.reviews-carousel{
  position:relative;overflow:hidden;
  margin:0 -32px;padding:4px 0;
  mask-image:linear-gradient(90deg,transparent 0%,black 8%,black 92%,transparent 100%);
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,black 8%,black 92%,transparent 100%);
}
.reviews-track{
  display:flex;gap:16px;width:max-content;
  animation:reviewsScroll 40s linear infinite;
  will-change:transform;
}
.reviews-carousel:hover .reviews-track{animation-play-state:paused}
@keyframes reviewsScroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

.review{
  background:var(--card);border:1px solid var(--border);border-radius:14px;
  padding:24px;display:flex;flex-direction:column;gap:18px;
  width:380px;flex-shrink:0;min-height:220px;
  transition:border-color .3s ease,background-color .3s ease,transform .3s ease;
  position:relative;overflow:hidden;
}
.review::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at var(--mx,50%) var(--my,50%),var(--accent-glow) 0%,transparent 50%);opacity:0;transition:opacity .4s ease;pointer-events:none;z-index:0}
.review:hover{background:var(--card-hover);border-color:var(--border-strong);transform:translateY(-3px)}
.review:hover::before{opacity:1}
.review > *{position:relative;z-index:1}
.review-head{display:flex;align-items:center;gap:12px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.review-ava{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--accent-ink);font-size:13px;flex-shrink:0}
.review-who{flex:1;min-width:0}
.review-name{font-size:13.5px;font-weight:700;color:var(--text);margin-bottom:1px}
.review-role{font-family:var(--mono);font-size:10.5px;color:var(--text3);letter-spacing:0.04em}
.review-stars{color:var(--accent);font-size:11px;letter-spacing:0.5px;flex-shrink:0}
.review-quote{font-size:14px;line-height:1.6;color:var(--text)}
.review-quote em{color:var(--accent);font-style:normal;font-weight:600}

/* FAQ */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;max-width:1000px;margin:0 auto}
.faq{background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:all .25s ease}
.faq:hover{border-color:var(--border-strong)}
.faq.open{border-color:var(--accent)}
.faq-head{padding:18px 22px;display:flex;justify-content:space-between;align-items:center;gap:14px;cursor:pointer}
.faq-q{font-size:14.5px;font-weight:600;color:var(--text);transition:color .25s ease}
.faq.open .faq-q{color:var(--accent)}
.faq-plus{width:24px;height:24px;border-radius:50%;background:var(--bg2);border:1px solid var(--border-strong);position:relative;transition:all .3s ease;flex-shrink:0}
.faq-plus::before,.faq-plus::after{content:'';position:absolute;top:50%;left:50%;background:var(--text);transition:all .3s ease}
.faq-plus::before{width:9px;height:1.5px;transform:translate(-50%,-50%)}
.faq-plus::after{width:1.5px;height:9px;transform:translate(-50%,-50%)}
.faq.open .faq-plus{background:var(--accent);border-color:var(--accent)}
.faq.open .faq-plus::before,.faq.open .faq-plus::after{background:var(--accent-ink)}
.faq.open .faq-plus::after{transform:translate(-50%,-50%) rotate(90deg)}
.faq-body{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-body-inner{padding:0 22px 20px;font-size:13.5px;color:var(--text2);line-height:1.65}

/* CTA */
.cta{padding:100px 0;background:var(--bg2);border-top:1px solid var(--border);position:relative;overflow:hidden}
.cta-inner{max-width:1200px;margin:0 auto;padding:0 32px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;position:relative;z-index:1}
.cta-left h2{font-size:48px;font-weight:700;letter-spacing:-0.035em;line-height:1.05;margin:14px 0 22px}
.cta-left h2 .accent{color:var(--accent)}
.cta-desc{font-size:16px;color:var(--text2);line-height:1.6;margin-bottom:32px;max-width:440px}
.cta-points{display:flex;flex-direction:column;gap:12px;padding-top:24px;border-top:1px solid var(--border)}
.cta-point{display:flex;align-items:center;gap:12px}
.cta-check{width:22px;height:22px;background:var(--accent);color:var(--accent-ink);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.cta-point-text{font-size:13.5px;color:var(--text)}
.cta-point-text strong{color:var(--accent);font-weight:700}
.cta-form{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:28px;display:flex;flex-direction:column;gap:16px}
.cta-form-top{display:flex;justify-content:space-between;align-items:center;padding-bottom:14px;border-bottom:1px solid var(--border)}
.cta-form-title{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:700}
.cta-form-title::before{content:'';width:7px;height:7px;background:var(--accent);border-radius:50%}
.cta-form-progress{font-family:var(--mono);font-size:10.5px;letter-spacing:0.12em;text-transform:uppercase;color:var(--text3)}
.fld{display:flex;flex-direction:column;gap:6px}
.fld label{font-family:var(--mono);font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--text3);font-weight:600}
.fld label .r{color:var(--accent);margin-left:2px}
.fld input,.fld select,.fld textarea{width:100%;padding:10px 12px;background:var(--bg2);border:1px solid var(--border);border-radius:7px;color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:all .25s ease}
.fld input:focus,.fld select:focus,.fld textarea:focus{border-color:var(--accent)}
.fld input::placeholder,.fld textarea::placeholder{color:var(--text3)}
.fld select{cursor:pointer;appearance:none;padding-right:28px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23D3E512' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.fld textarea{resize:vertical;min-height:72px}
.fld-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cta-submit{margin-top:4px;padding:13px;background:var(--accent);color:var(--accent-ink);border-radius:8px;font-size:13.5px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:all .25s ease}
.cta-submit:hover{background:var(--accent2);transform:translateY(-1px)}

/* FOOTER */
footer{padding:60px 0 24px;background:var(--bg);border-top:1px solid var(--border)}
.foot-inner{max-width:1200px;margin:0 auto;padding:0 32px}
.foot-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:32px;padding-bottom:40px;margin-bottom:32px;border-bottom:1px solid var(--border)}
.foot-brand{max-width:300px;display:flex;flex-direction:column;gap:14px}
.foot-brand p{font-size:13.5px;color:var(--text2);line-height:1.6}
.foot-socials{display:flex;gap:8px;flex-wrap:wrap}
.foot-social{
  width:40px;height:40px;min-width:40px;min-height:40px;
  border:1px solid var(--border-strong);border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  color:var(--text2);transition:all .25s ease;
  background:var(--card);flex-shrink:0;
  padding:0;overflow:hidden;
}
.foot-social svg{
  width:20px;height:20px;min-width:20px;min-height:20px;
  display:block;flex-shrink:0;
  transition:transform .25s ease;
}
.foot-social:hover{
  background:var(--card-hover);
  border-color:var(--accent);
  transform:translateY(-2px);
}
.foot-social:hover svg{transform:scale(1.08)}
.foot-col h5{font-family:var(--mono);font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--accent);margin-bottom:16px;font-weight:700}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.foot-col a{font-size:13.5px;color:var(--text2);transition:color .25s ease}
.foot-col a:hover{color:var(--accent)}
.foot-bot{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:10.5px;letter-spacing:0.08em;text-transform:uppercase;color:var(--text3);flex-wrap:wrap;gap:10px}
.foot-bot-links{display:flex;gap:18px}
.foot-bot a:hover{color:var(--text)}

/* Reveal */
.reveal{opacity:0;transform:translateY(20px);transition:all .7s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* RESPONSIVE */
@media(max-width:1000px){
  .services-bento{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .svc-main{grid-column:1/3;grid-row:1;min-height:auto}
  .svc-tl,.svc-bl,.svc-tr,.svc-br{grid-column:auto;grid-row:auto}
  /* Mobile process: narrower alternating cards + visible snake */
  .process-flow{padding:10px 0}
  .process-steps{gap:50px}
  .p-flow-card{width:80% !important}
  .process-snake{display:block}
  .process-snake path{stroke-width:2}
  .work-grid{grid-template-columns:1fr 1fr}
  .review{width:320px}
  .faq-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr;gap:32px 0}
  .stat{border-left:none;padding:16px 0;border-top:1px solid var(--border)}
  .stat:nth-child(-n+2){border-top:none}
  .stat:nth-child(2),.stat:nth-child(4){border-left:1px solid var(--border)}
  .cta-inner{grid-template-columns:1fr;gap:40px}
  .foot-top{grid-template-columns:1fr 1fr;gap:24px}
  .foot-brand{grid-column:1/3;max-width:none}
  .hero-stats{grid-template-columns:1fr 1fr;padding:0}
  .hero-stat{padding:16px;border-right:none;border-bottom:1px solid var(--border)}
  .hero-stat:nth-child(2n-1){border-right:1px solid var(--border)}
  .hero-stat:nth-last-child(-n+2){border-bottom:none}
}
@media(max-width:720px){
  header{padding:12px 0}
  .header-inner{padding:0 20px;gap:12px}
  .nav-center,.header-avail{display:none}
  .mobile-btn{display:flex}
  .btn-header{padding:8px 14px;font-size:12.5px}
  .hero{padding:110px 0 60px}
  .hero-inner{padding:0 20px}
  h1{font-size:36px}
  .heading{font-size:30px}
  section,.cta,.stats-banner{padding:60px 0}
  .container,.foot-inner,.cta-inner{padding:0 20px}
  .services-bento{grid-template-columns:1fr}
  .svc-main{grid-column:1;grid-row:auto}
  /* Mobile process - still alternating, narrower cards */
  .p-flow-card{width:78% !important;padding:22px 20px}
  .p-flow-title{font-size:19px}
  .process-steps{gap:44px}
  .process-snake path{stroke-width:1.8}
  .work-grid{grid-template-columns:1fr}
  .review{width:280px;padding:20px}
  .reviews-carousel{margin:0 -20px}
  .reviews-track{animation-duration:50s}
  .stats-grid{grid-template-columns:1fr 1fr;padding:0 20px;gap:24px 12px}
  .stat{padding:12px 0;border-top:none;border-left:none !important}
  .stat:nth-child(2),.stat:nth-child(4){border-left:1px solid var(--border) !important}
  .stat-v{font-size:32px}
  .cta-left h2{font-size:36px}
  .fld-row{grid-template-columns:1fr}
  .cta-form{padding:22px}
  footer{padding:44px 0 24px}
  .foot-inner{padding:0 20px}
  .foot-top{
    grid-template-columns:1fr 1fr;gap:28px 20px;
    padding-bottom:32px;margin-bottom:24px;
  }
  .foot-brand{grid-column:1/3;max-width:none;margin-bottom:8px}
  .foot-brand p{font-size:13px}
  .foot-socials{gap:8px}
  .foot-col h5{font-size:9.5px;margin-bottom:12px}
  .foot-col ul{gap:8px}
  .foot-col a{font-size:13px}
  .foot-bot{flex-direction:column;align-items:flex-start;gap:12px;padding:0}
  .foot-bot-links{gap:16px}
  body,a,button,input,select,textarea,.service,.work-card,.review,.faq,.p-flow-card{cursor:auto !important}
  .cursor-dot,.cursor-ring{display:none !important}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}

/* ============ PRELOADER ============ */
body.loading{overflow:hidden}
.preloader{
  position:fixed;inset:0;z-index:99999;
  background:var(--bg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:48px;
  transition:opacity 0.6s ease 0.3s,visibility 0.6s ease 0.3s;
}
.preloader.done{opacity:0;visibility:hidden;pointer-events:none}

/* Animated background grid */
.preloader::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(var(--border) 1px,transparent 1px),
    linear-gradient(90deg,var(--border) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse at center,black 20%,transparent 70%);
  opacity:0.3;
}

/* Logo with pulse glow */
.preloader-logo{
  position:relative;z-index:1;
  display:flex;align-items:center;gap:14px;
  font-family:'Space Grotesk',sans-serif;
  font-size:30px;font-weight:700;letter-spacing:0.08em;color:var(--text);
  text-transform:uppercase;
  opacity:0;animation:preloaderLogoIn 0.8s cubic-bezier(0.22,1,0.36,1) 0.1s forwards;
}
@keyframes preloaderLogoIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

.preloader-mark{
  width:52px;height:52px;background:var(--accent);color:var(--accent-ink);
  border-radius:12px;font-weight:800;font-size:28px;
  display:inline-flex;align-items:center;justify-content:center;
  position:relative;
  box-shadow:0 0 40px rgba(211,229,18,0.5);
  animation:preloaderMarkPulse 1.6s ease infinite;
}
@keyframes preloaderMarkPulse{
  0%,100%{box-shadow:0 0 40px rgba(211,229,18,0.5),0 0 0 0 rgba(211,229,18,0.3)}
  50%{box-shadow:0 0 60px rgba(211,229,18,0.7),0 0 0 12px rgba(211,229,18,0)}
}

/* Progress bar */
.preloader-bar-wrap{
  position:relative;z-index:1;
  width:280px;height:3px;
  background:var(--border);border-radius:100px;overflow:hidden;
  opacity:0;animation:preloaderLogoIn 0.6s ease 0.3s forwards;
}
.preloader-bar{
  height:100%;width:0%;
  background:var(--accent);
  border-radius:100px;
  box-shadow:0 0 10px rgba(211,229,18,0.6);
  animation:preloaderProgress 2.2s cubic-bezier(0.22,1,0.36,1) 0.3s forwards;
}
@keyframes preloaderProgress{
  0%{width:0%}
  30%{width:45%}
  60%{width:70%}
  100%{width:100%}
}

/* Status text */
.preloader-status{
  position:relative;z-index:1;
  font-family:var(--mono);font-size:11px;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--text3);
  opacity:0;animation:preloaderLogoIn 0.6s ease 0.5s forwards;
  display:flex;align-items:center;gap:8px;
}
.preloader-status::before{
  content:'';width:6px;height:6px;background:var(--accent);border-radius:50%;
  animation:preloaderDot 1s ease infinite;
}
@keyframes preloaderDot{0%,100%{opacity:1}50%{opacity:0.3}}

/* Counter */
.preloader-counter{
  position:absolute;bottom:40px;right:40px;z-index:1;
  font-family:var(--mono);font-size:120px;font-weight:800;
  color:var(--accent);letter-spacing:-0.04em;line-height:1;
  opacity:0.15;
  animation:preloaderLogoIn 0.6s ease 0.2s forwards;
}

/* Corner labels */
.preloader-corner{
  position:absolute;z-index:1;
  font-family:var(--mono);font-size:10px;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--text3);
  opacity:0;animation:preloaderLogoIn 0.6s ease 0.4s forwards;
}
.preloader-corner-tl{top:32px;left:32px}
.preloader-corner-tr{top:32px;right:32px}
.preloader-corner-bl{bottom:32px;left:32px}

@media(max-width:720px){
  .preloader-counter{font-size:60px;bottom:24px;right:24px}
  .preloader-corner{font-size:9px}
  .preloader-corner-tl,.preloader-corner-tr{top:20px}
  .preloader-corner-tl,.preloader-corner-bl{left:20px}
  .preloader-corner-tr{right:20px}
  .preloader-corner-bl{bottom:24px}
  .preloader-bar-wrap{width:220px}
  .preloader-logo{font-size:24px}
  .preloader-mark{width:44px;height:44px;font-size:22px}
}
/* ==================================================
   REV THEME - WordPress specific additions
   ================================================== */

/* Custom logo image */
.brand-custom-logo{
  max-height:40px;width:auto;display:block;
}

/* Nav menu items (from wp_nav_menu) */
.nav-center .menu-item a,
.nav-center > a{
  padding:8px 16px;font-size:13px;font-weight:500;color:var(--text2);
  border-radius:6px;transition:all .25s ease;text-decoration:none;display:inline-block;
}
.nav-center .menu-item a:hover,
.nav-center > a:hover{color:var(--text);background:var(--bg2)}
.nav-center .menu-item.current-menu-item > a,
.nav-center > a.active{background:var(--accent);color:var(--accent-ink);font-weight:600}
.nav-center .menu-item{list-style:none;display:inline-block}
.nav-center .menu,
.nav-center ul{
  display:flex;gap:2px;padding:0;margin:0;list-style:none;
}

/* Footer menu items */
.foot-col ul,
.foot-col .menu{
  list-style:none;display:flex;flex-direction:column;gap:10px;padding:0;margin:0;
}
.foot-col li{list-style:none}
.foot-col a{font-size:13.5px;color:var(--text2);transition:color .25s ease;text-decoration:none}
.foot-col a:hover{color:var(--accent)}

/* Footer bottom menu items */
.foot-bot-links .menu-item{display:inline-block;list-style:none}
.foot-bot-links .menu-item a,
.foot-bot-links > a{
  font-size:10.5px;letter-spacing:0.08em;color:var(--text3);
  text-transform:uppercase;text-decoration:none;
}
.foot-bot-links .menu-item a:hover,
.foot-bot-links > a:hover{color:var(--text)}

/* Project card with real image */
.work-visual-has-image{
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  transition:transform .5s ease;
}
.work-card:hover .work-visual-has-image{transform:scale(1.04)}
.work-visual-has-image::before{display:none}

/* Testimonial avatar with image */
.review-ava[style*="background-image"]{
  background-size:cover !important;
  background-position:center !important;
}

/* WP admin bar fix */
.admin-bar .site-header{top:32px}
.admin-bar .preloader{top:32px}
@media(max-width:782px){
  .admin-bar .site-header{top:46px}
}

/* WP content styling for single project */
.single-rev_project main h1,
.single-rev_project main h2,
.single-rev_project main h3{color:var(--text);margin:32px 0 16px;letter-spacing:-0.02em;line-height:1.2}
.single-rev_project main p{margin-bottom:20px}
.single-rev_project main a{color:var(--accent);text-decoration:underline}
.single-rev_project main ul,
.single-rev_project main ol{margin:0 0 20px 24px}
.single-rev_project main img{border-radius:12px;margin:20px 0}
