/* ── NIMMY — Modern Purple Redesign ─────────── */
:root {
  --bg:        #07060B;
  --bg2:       #0B0A12;
  --bg3:       #11101A;
  --bgc:       #0E0D17;
  --t1:        #FFFFFF;
  --t2:        #DCD9EA;
  --tm:        #8A86A6;
  --td:        #524F6B;
  --acc:       #8B5CFF;
  --acc2:      #B493FF;
  --acch:      #A37BFF;
  --bd:        #1B1827;
  --bdh:       #2A2541;
  --glow:      rgba(139,92,255,.18);
  --glow2:     rgba(139,92,255,.35);
  --fd:        'Geist', 'Inter', system-ui, sans-serif;
  --fb:        'Geist', 'Inter', system-ui, sans-serif;
  --fm:        'JetBrains Mono', monospace;
  --fs:        'Instrument Serif', serif;
  --eout:      cubic-bezier(0,0,.2,1);
  --eio:       cubic-bezier(.4,0,.2,1);
  --esp:       cubic-bezier(.34,1.56,.64,1);
  --r1:8px; --r2:12px; --r3:16px; --r4:24px; --rf:9999px;
}
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
body {
  background:var(--bg); color:var(--t1);
  font-family:var(--fb), "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", emoji;
  font-size:1rem; line-height:1.6;
  overflow-x:hidden;
}
.emoji, .ai-msg, .fsuc {
  font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", var(--fb), sans-serif;
}
a { color:inherit; text-decoration:none; }
::-webkit-scrollbar { width:8px; }
::-webkit-scrollbar-track { background:#000; }
::-webkit-scrollbar-thumb { background:#2a2541; border-radius:99px; }
::-webkit-scrollbar-thumb:hover { background:var(--acc); }
::selection { background:rgba(139,92,255,.45); color:#fff; }

/* ── Liquid glass utility ──────────────────── */
.glass {
  background: rgba(255,255,255,0.02);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid rgba(255,255,255,.06);
  position: relative;
  overflow: hidden;
}
.glass::before {
  content:""; position:absolute; inset:0;
  border-radius:inherit; padding:1px;
  background: linear-gradient(180deg,
    rgba(255,255,255,.18) 0%,
    rgba(255,255,255,.04) 30%,
    rgba(255,255,255,0) 60%,
    rgba(139,92,255,.12) 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  pointer-events:none;
}

/* ── NAV ───────────────────────────────────── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  padding:1.1rem 0; transition:all .3s var(--eout);
}
nav.stuck {
  background:rgba(7,6,11,.75);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--bd); padding:.7rem 0;
}
.nw {
  max-width:1380px; margin:0 auto; padding:0 2.25rem;
  display:flex; align-items:center; justify-content:space-between; gap:2rem;
}
.logo { display:flex; align-items:center; }
.logo-img { height:78px; width:auto; display:block; transition:transform .35s var(--esp), filter .35s, height .3s; filter:drop-shadow(0 0 0 transparent); }
.logo:hover .logo-img { transform:scale(1.05) rotate(-2deg); filter:drop-shadow(0 4px 18px rgba(139,92,255,.5)); }
nav.stuck .logo-img { height:60px; }
.nlinks-wrap {
  display:flex; gap:.25rem; list-style:none;
  padding:.4rem; border-radius:var(--rf);
  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.06);
  backdrop-filter:blur(10px);
}
.nlinks-wrap li { list-style:none; }
.nlinks-wrap a {
  display:block; font-size:1rem; font-weight:500; color:var(--t2);
  padding:.7rem 1.25rem; border-radius:var(--rf);
  transition:background .2s, color .2s;
  white-space:nowrap;
}
.nlinks-wrap a:hover { background:rgba(255,255,255,.05); color:#fff; }
.nbtn {
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:var(--fd); font-size:1rem; font-weight:600;
  padding:.85rem 1.55rem; border-radius:var(--rf); border:none;
  background:#fff; color:#0A0810; cursor:pointer;
  transition:transform .2s var(--esp), box-shadow .25s;
  white-space:nowrap;
}
.nham {
  display:none; width:44px; height:44px; border-radius:50%;
  border:1px solid rgba(255,255,255,.1); background:rgba(255,255,255,.03);
  align-items:center; justify-content:center; cursor:pointer; color:#fff;
}
.nmob {
  display:none; position:fixed; inset:0; z-index:300;
  background:rgba(7,6,11,.96); backdrop-filter:blur(20px);
  flex-direction:column; align-items:center; justify-content:center;
  gap:1.4rem; padding:2rem;
  opacity:0; pointer-events:none; transition:opacity .3s;
}
.nmob.open { opacity:1; pointer-events:auto; }
.nmob a {
  font-family:var(--fd); font-size:1.6rem; font-weight:500;
  color:#fff; padding:.6rem 1rem;
}
.nmob a:hover { color:var(--acc2); }
.nmob .nbtn { font-size:1.05rem; padding:.95rem 1.8rem; margin-top:1rem; }
.nmob-close {
  position:absolute; top:1.5rem; right:1.5rem;
  width:48px; height:48px; border-radius:50%;
  border:1px solid rgba(255,255,255,.1); background:rgba(255,255,255,.03);
  display:flex; align-items:center; justify-content:center; cursor:pointer; color:#fff;
}
.nbtn:hover { transform:translateY(-1px); box-shadow:0 8px 24px rgba(255,255,255,.1); }

/* ── BUTTONS ───────────────────────────────── */
.btn-p {
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--fd); font-size:1.12rem; font-weight:600;
  padding:1.2rem 2.3rem; border-radius:var(--rf); border:none;
  background:linear-gradient(180deg,#fff,#ECE8FF);
  color:#0A0810; cursor:pointer;
  box-shadow: 0 0 0 1px rgba(255,255,255,.2), 0 8px 32px rgba(139,92,255,.2);
  transition:transform .2s var(--esp), box-shadow .25s;
}
.btn-p:hover { transform:translateY(-2px); box-shadow:0 0 0 1px rgba(255,255,255,.3), 0 16px 40px rgba(139,92,255,.35); }
.btn-o {
  display:inline-flex; align-items:center; gap:.55rem;
  font-family:var(--fd); font-size:1.12rem; font-weight:500;
  padding:1.2rem 2.1rem; border-radius:var(--rf);
  border:1px solid rgba(255,255,255,.12); color:#fff;
  background:rgba(255,255,255,.02); cursor:pointer;
  transition:all .25s var(--eout);
}
.btn-o:hover { border-color:rgba(255,255,255,.22); background:rgba(255,255,255,.05); }

/* ── HERO ──────────────────────────────────── */
.hero {
  min-height:100vh; position:relative;
  display:flex; align-items:center; padding:10rem 2rem 6rem; overflow:hidden;
  background:#07060B;
}
.hero-bg {
  position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(139,92,255,.22) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 20% 100%, rgba(91,55,200,.12) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 85% 80%, rgba(180,147,255,.08) 0%, transparent 60%),
    #07060B;
}
/* Subtle grid */
.hgrid {
  position:absolute; inset:0; z-index:1;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 80% 70% at 50% 40%, #000 0%, transparent 75%);
}
/* Glowing orb behind hero */
.hero-orb {
  position:absolute; top:-10%; left:50%; transform:translateX(-50%);
  width:1100px; height:700px; border-radius:50%;
  background:radial-gradient(circle, rgba(139,92,255,.30) 0%, transparent 60%);
  filter:blur(80px); z-index:1; pointer-events:none;
  animation:orbFloat 14s ease-in-out infinite;
}
@keyframes orbFloat {
  0%,100% { transform:translate(-50%,0) scale(1); opacity:.9; }
  50%     { transform:translate(-48%,3%) scale(1.06); opacity:1; }
}

/* Headline shimmer */
.hgrad, .hh1 .it, .sh2 .it {
  background-size:200% auto;
  animation:shimmer 6s linear infinite;
}
@keyframes shimmer {
  0% { background-position:-200% center; }
  100% { background-position:200% center; }
}

/* Phone float */
.ai-phone { animation:phoneFloat 7s ease-in-out infinite; }
@keyframes phoneFloat {
  0%,100% { transform:rotateY(-12deg) rotateX(4deg) translateY(0); }
  50%     { transform:rotateY(-10deg) rotateX(3deg) translateY(-12px); }
}

/* Hero preview cards stagger float */
.hp-card { animation:cardFloat 6s ease-in-out infinite; }
.hp-card:nth-child(2) { animation-delay:.8s; }
.hp-card:nth-child(3) { animation-delay:1.6s; }
@keyframes cardFloat {
  0%,100% { transform:translateY(0); }
  50%     { transform:translateY(-6px); }
}

/* Glowing border on srv card hover */
.srv-card::after, .cf-card::after, .numc::after {
  content:''; position:absolute; inset:-1px; border-radius:inherit;
  pointer-events:none; opacity:0; transition:opacity .4s;
  background: radial-gradient(400px circle at var(--mx,50%) var(--my,50%), rgba(139,92,255,.18), transparent 40%);
}
.srv-card:hover::after, .cf-card:hover::after, .numc:hover::after { opacity:1; }

/* Pulse on AI feat icons */
.ai-feat-icon { animation:iconPulse 3s ease-in-out infinite; }
.ai-feat:nth-child(2) .ai-feat-icon { animation-delay:.6s; }
.ai-feat:nth-child(3) .ai-feat-icon { animation-delay:1.2s; }
@keyframes iconPulse {
  0%,100% { box-shadow:0 0 0 0 rgba(139,92,255,.0); }
  50%     { box-shadow:0 0 0 6px rgba(139,92,255,.08); }
}

/* Pulse online dot */
.ai-phone-online { animation:onlinePulse 1.6s ease-in-out infinite; }
@keyframes onlinePulse {
  0%,100% { box-shadow:0 0 0 0 rgba(16,185,129,.6); }
  50%     { box-shadow:0 0 0 6px rgba(16,185,129,0); }
}

/* Btn primary breathing glow */
.btn-p { animation:breathe 4s ease-in-out infinite; }
@keyframes breathe {
  0%,100% { box-shadow:0 0 0 1px rgba(255,255,255,.2), 0 8px 32px rgba(139,92,255,.2); }
  50%     { box-shadow:0 0 0 1px rgba(255,255,255,.3), 0 12px 40px rgba(139,92,255,.45); }
}

/* Tag pulse */
.htag-pill { animation:tagGlow 2.5s ease-in-out infinite; }
@keyframes tagGlow {
  0%,100% { box-shadow:0 0 0 0 rgba(139,92,255,.5); }
  50%     { box-shadow:0 0 14px 2px rgba(139,92,255,.5); }
}

/* Marquee dot pulse */
.mqs { animation:dotPulse 2s ease-in-out infinite; }
@keyframes dotPulse {
  0%,100% { opacity:.3; transform:scale(.85); }
  50%     { opacity:1; transform:scale(1.1); }
}

/* Hero h1 italic word slide-shimmer underline */
.hh1 .it { position:relative; display:inline-block; }
.hwrap { max-width:1380px; margin:0 auto; width:100%; position:relative; z-index:10; text-align:center; display:flex; flex-direction:column; align-items:center; }

.htag {
  display:inline-flex; align-items:center; gap:.6rem;
  padding:.45rem .45rem .45rem 1.15rem;
  border-radius:var(--rf);
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(10px);
  margin-bottom:2.4rem;
  font-size:.88rem; color:var(--t2); font-weight:500;
  opacity:0; transform:translateY(15px);
  animation:fadeUp .8s .1s var(--eout) forwards;
}
.htag-pill {
  background:linear-gradient(135deg, var(--acc), var(--acch));
  color:#fff; font-size:.78rem; font-weight:600;
  padding:.25rem .7rem; border-radius:var(--rf);
  letter-spacing:.02em;
}
.hh1 {
  font-family:var(--fd); font-size:clamp(2.4rem, 7.5vw, 7rem);
  font-weight:500; line-height:1.02; letter-spacing:-.045em;
  margin-bottom:1.8rem; max-width:1180px;
  opacity:0; transform:translateY(25px);
  animation:fadeUp 1s .25s var(--eout) forwards;
}
.hh1 .it {
  font-family:var(--fs); font-style:italic; font-weight:400;
  background:linear-gradient(120deg, #fff 30%, var(--acc2) 70%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  letter-spacing:-.02em;
}
.hgrad {
  background:linear-gradient(120deg, #fff 0%, var(--acc2) 50%, var(--acc) 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.hsub {
  font-family:var(--fb); font-size:1.28rem; color:var(--tm); line-height:1.65;
  max-width:680px; margin:0 auto 2.8rem;
  opacity:0; transform:translateY(20px);
  animation:fadeUp .9s .4s var(--eout) forwards;
}
.hbtns {
  display:flex; gap:.85rem; flex-wrap:wrap; justify-content:center;
  opacity:0; transform:translateY(20px);
  animation:fadeUp .8s .55s var(--eout) forwards;
}
@keyframes fadeUp { to { opacity:1; transform:translateY(0); } }

/* Hero "preview" — abstract product mock */
.hpreview {
  margin-top:5.5rem; width:min(1200px, 100%);
  border-radius:var(--r4);
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(139,92,255,.08), rgba(0,0,0,.5));
  padding:1px; position:relative;
  opacity:0; transform:translateY(40px);
  animation:fadeUp 1.1s .7s var(--eout) forwards;
  overflow:hidden;
}
.hpreview-inner {
  border-radius:calc(var(--r4) - 1px);
  background:#0A0815;
  padding:1.5rem;
  min-height:280px;
  display:grid; grid-template-columns:1fr 1fr 1fr; gap:1rem;
}
.hp-card {
  border-radius:var(--r3);
  border:1px solid rgba(255,255,255,.05);
  background:rgba(255,255,255,.015);
  padding:1.25rem;
  display:flex; flex-direction:column; gap:.6rem;
  text-align:left;
}
.hp-card-icon {
  width:42px; height:42px; border-radius:11px;
  background:rgba(139,92,255,.12); border:1px solid rgba(139,92,255,.25);
  display:flex; align-items:center; justify-content:center;
  color:var(--acc);
}
.hp-card-title { font-family:var(--fd); font-size:1.08rem; font-weight:600; color:#fff; }
.hp-card-desc  { font-family:var(--fb); font-size:.88rem; color:var(--tm); line-height:1.6; }
.hp-card-bar {
  margin-top:auto; height:6px; border-radius:99px;
  background:linear-gradient(90deg, var(--acc), var(--acc2) 60%, transparent);
}

/* ── MARQUEE ───────────────────────────────── */
.mq {
  overflow:hidden; padding:1.5rem 0;
  border-top:1px solid var(--bd); border-bottom:1px solid var(--bd);
  background:#08070E; position:relative;
}
.mq::before,.mq::after { content:''; position:absolute; top:0; bottom:0; width:140px; z-index:2; }
.mq::before { left:0; background:linear-gradient(to right,#08070E,transparent); }
.mq::after  { right:0; background:linear-gradient(to left,#08070E,transparent); }
.mqt { display:flex; gap:3rem; animation:slide 35s linear infinite; width:max-content; }
.mqi {
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--fd); font-size:.78rem; font-weight:500;
  text-transform:uppercase; letter-spacing:.13em; color:var(--td); white-space:nowrap;
}
.mqs { color:var(--acc); opacity:.5; font-size:.55rem; }
@keyframes slide { from {transform:translateX(0)} to {transform:translateX(-50%)} }

/* ── SECTIONS ──────────────────────────────── */
.sec { padding:8rem 0; position:relative; }
.seca { background:#0A0814; }
.w { max-width:1380px; margin:0 auto; padding:0 2.25rem; }
.ey {
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--fm); font-size:.78rem; font-weight:500;
  text-transform:uppercase; letter-spacing:.18em; color:var(--acc); margin-bottom:1.2rem;
}
.ey::before { content:''; width:8px; height:8px; border-radius:50%; background:var(--acc); box-shadow:0 0 12px var(--acc); }
.sh2 {
  font-family:var(--fd); font-size:clamp(2rem, 4.5vw, 4.6rem);
  font-weight:500; line-height:1.05; letter-spacing:-.035em; margin-bottom:1.2rem;
}
.sh2 .it {
  font-family:var(--fs); font-style:italic; font-weight:400;
  color:var(--acc2); letter-spacing:-.015em;
}
.sp { font-family:var(--fb); font-size:1.18rem; color:var(--tm); line-height:1.7; max-width:640px; }

/* Reveal */
.rv { opacity:0; transform:translateY(28px); transition:opacity .8s var(--eout), transform .8s var(--eout); }
.rv.in { opacity:1; transform:translateY(0); }
.d1{transition-delay:.08s} .d2{transition-delay:.16s} .d3{transition-delay:.24s}
.d4{transition-delay:.32s} .d5{transition-delay:.40s}

/* ── SERVICES — bento grid ─────────────────── */
.srv-intro { display:grid; grid-template-columns:1.2fr .8fr; gap:3.5rem; align-items:end; margin-bottom:3.5rem; }
.srv-grid {
  display:grid; grid-template-columns:repeat(6,1fr);
  gap:1rem;
}
.srv-card {
  position:relative;
  border-radius:var(--r3);
  border:1px solid rgba(255,255,255,.06);
  background:linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.005));
  overflow:hidden;
  display:flex; flex-direction:column;
  min-height:380px;
  transition:border-color .35s, transform .35s var(--eout), box-shadow .35s;
}
.srv-card:hover {
  border-color:rgba(139,92,255,.35);
  transform:translateY(-3px);
  box-shadow:0 24px 60px rgba(139,92,255,.12);
}
.srv-card.span-3 { grid-column:span 3; }
.srv-card.span-2 { grid-column:span 2; }
.srv-card.span-4 { grid-column:span 4; min-height:420px; }
.srv-media {
  position:relative; flex:1; overflow:hidden;
  background:linear-gradient(135deg, #100D1C 0%, #1A1330 100%);
  border-bottom:1px solid rgba(255,255,255,.04);
  min-height:160px;
}
.srv-asset, .srv-media img, .srv-media video {
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover; display:block;
  z-index:2; opacity:0; transition:opacity .5s var(--eout), transform .8s var(--eout);
  background:#0A0815;
}
.srv-asset.loaded { opacity:1; }
.srv-card:hover .srv-asset.loaded { transform:scale(1.05); }
.srv-media-ph { z-index:1; }
.srv-media-ph {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  color:rgba(139,92,255,.35);
}
.srv-media-ph svg { width:64px; height:64px; }
.srv-body { padding:1.4rem 1.5rem 1.5rem; display:flex; flex-direction:column; gap:.55rem; }
.srv-num {
  font-family:var(--fm); font-size:.62rem; color:var(--acc);
  letter-spacing:.16em; text-transform:uppercase; margin-bottom:.15rem;
}
.srv-title {
  font-family:var(--fd); font-size:1.5rem;
  font-weight:600; letter-spacing:-.02em; color:#fff;
}
.srv-desc { font-family:var(--fb); font-size:1.02rem; color:var(--tm); line-height:1.6; }
.srv-tags { display:flex; flex-wrap:wrap; gap:.35rem; margin-top:.5rem; }
.srv-tag {
  font-family:var(--fb); font-size:.7rem; font-weight:500;
  padding:.25rem .65rem; border-radius:var(--rf);
  border:1px solid rgba(255,255,255,.08);
  color:var(--t2); background:rgba(255,255,255,.02);
}

/* ── HOW IT WORKS ──────────────────────────── */
.cf-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; margin-top:4rem;
}
.cf-card {
  position:relative;
  border-radius:var(--r3);
  border:1px solid rgba(255,255,255,.06);
  background:linear-gradient(180deg, rgba(139,92,255,.04), rgba(255,255,255,.005));
  padding:2rem 1.75rem;
  display:flex; flex-direction:column; gap:.9rem;
  min-height:280px;
  transition:border-color .35s, transform .35s var(--eout);
}
.cf-card:hover { border-color:rgba(139,92,255,.3); transform:translateY(-3px); }
.cf-num {
  font-family:var(--fs); font-style:italic; font-weight:400;
  font-size:3rem; line-height:1;
  background:linear-gradient(135deg, var(--acc2), var(--acc));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.cf-title { font-family:var(--fd); font-size:1.4rem; font-weight:600; letter-spacing:-.015em; color:#fff; }
.cf-desc { font-family:var(--fb); font-size:1.02rem; color:var(--tm); line-height:1.65; flex:1; }
.cf-tag {
  align-self:flex-start;
  font-family:var(--fm); font-size:.6rem; letter-spacing:.13em; text-transform:uppercase;
  color:var(--acc); border:1px solid rgba(139,92,255,.25);
  border-radius:var(--rf); padding:.18rem .55rem;
  background:rgba(139,92,255,.06);
}

/* ── AI AGENT ──────────────────────────────── */
.ai-grid {
  display:grid; grid-template-columns:1.05fr .95fr; gap:5rem; align-items:center;
}
.ai-feats { display:flex; flex-direction:column; gap:1.25rem; margin-top:2.5rem; }
.ai-feat { display:flex; gap:1rem; align-items:flex-start; }
.ai-feat-icon {
  width:48px; height:48px; flex-shrink:0;
  border-radius:13px;
  background:rgba(139,92,255,.1); border:1px solid rgba(139,92,255,.25);
  display:flex; align-items:center; justify-content:center; color:var(--acc);
}
.ai-feat-title { font-family:var(--fd); font-size:1.2rem; font-weight:600; color:#fff; margin-bottom:.3rem; }
.ai-feat-desc  { font-family:var(--fb); font-size:1.02rem; color:var(--tm); line-height:1.6; }

.ai-phone-scene {
  position:relative; perspective:1400px;
  display:flex; align-items:center; justify-content:center;
  min-height:580px;
}
.ai-phone {
  width:300px; height:600px;
  border-radius:38px;
  background:linear-gradient(160deg, #1A1330, #0A0815);
  border:1px solid rgba(139,92,255,.25);
  padding:14px;
  box-shadow: 0 0 0 1px rgba(139,92,255,.15), 0 40px 100px rgba(139,92,255,.25), 0 60px 120px rgba(0,0,0,.6);
  transform: rotateY(-12deg) rotateX(4deg);
  transform-style:preserve-3d;
  position:relative;
}
.ai-phone-screen {
  width:100%; height:100%; border-radius:26px;
  background:#0A0815;
  overflow:hidden;
  display:flex; flex-direction:column;
  position:relative;
}
.ai-phone-notch {
  position:absolute; top:8px; left:50%; transform:translateX(-50%);
  width:80px; height:18px; border-radius:99px; background:#000; z-index:5;
}
.ai-phone-header {
  padding:38px 16px 14px;
  border-bottom:1px solid rgba(255,255,255,.06);
  display:flex; align-items:center; gap:10px;
}
.ai-phone-avatar {
  width:34px; height:34px; border-radius:50%;
  background:linear-gradient(135deg, var(--acc), var(--acc2));
  display:flex; align-items:center; justify-content:center;
  font-family:var(--fd); font-weight:700; font-size:.8rem; color:#fff;
}
.ai-phone-agent { font-family:var(--fd); font-size:.8rem; font-weight:600; color:#fff; }
.ai-phone-status {
  font-family:var(--fb); font-size:.65rem; color:var(--tm);
  display:flex; align-items:center; gap:5px;
}
.ai-phone-online { width:6px; height:6px; border-radius:50%; background:#10B981; box-shadow:0 0 6px #10B981; }
.ai-chat {
  flex:1; padding:14px 12px; display:flex; flex-direction:column; gap:8px;
  overflow:hidden;
}
.ai-msg { max-width:80%; padding:.55rem .8rem; border-radius:14px; font-family:var(--fb); font-size:.74rem; line-height:1.45; }
.ai-msg-in { align-self:flex-start; background:rgba(255,255,255,.06); color:var(--t2); border-bottom-left-radius:4px; }
.ai-msg-out { align-self:flex-end; background:linear-gradient(135deg, var(--acc), #6B45D9); color:#fff; border-bottom-right-radius:4px; }
.ai-typing {
  align-self:flex-start; display:flex; gap:3px;
  background:rgba(255,255,255,.06); padding:.6rem .7rem; border-radius:14px;
}
.ai-typing span {
  width:5px; height:5px; border-radius:50%; background:var(--tm);
  animation:typing 1.2s infinite ease-in-out;
}
.ai-typing span:nth-child(2){animation-delay:.15s}
.ai-typing span:nth-child(3){animation-delay:.3s}
@keyframes typing { 0%,60%,100%{opacity:.3;transform:translateY(0)} 30%{opacity:1;transform:translateY(-2px)} }
.ai-input {
  margin:0 10px 12px; padding:.55rem .8rem; border-radius:99px;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.06);
  font-family:var(--fb); font-size:.7rem; color:var(--td);
  display:flex; align-items:center; justify-content:space-between;
}

/* ── PORTFOLIO ─────────────────────────────── */
.port-grid { display:grid; grid-template-columns:1.2fr .8fr; gap:1.5rem; margin-top:3.5rem; }
.port-card {
  position:relative;
  border-radius:var(--r4);
  border:1px solid rgba(255,255,255,.07);
  background:#0A0815;
  overflow:hidden;
  min-height:480px;
  display:flex; flex-direction:column;
  transition:border-color .35s, transform .35s var(--eout);
}
.port-card:hover { border-color:rgba(139,92,255,.3); transform:translateY(-3px); }
.port-media {
  position:relative; flex:1; overflow:hidden;
  background:linear-gradient(135deg, #15102A 0%, #1A1335 100%);
  min-height:280px;
}
.port-asset, .port-media img, .port-media video {
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover; display:block;
  z-index:2; opacity:0; transition:opacity .5s var(--eout);
  background:#0A0815;
}
.port-asset.loaded { opacity:1; }
.port-media-ph { z-index:1; }
.port-media-ph {
  position:absolute; inset:0; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:.8rem; color:rgba(139,92,255,.3);
}
.port-badge {
  position:absolute; top:14px; left:14px;
  display:inline-flex; align-items:center; gap:.4rem;
  font-family:var(--fm); font-size:.62rem; font-weight:500;
  padding:.3rem .65rem; border-radius:var(--rf);
  background:rgba(7,6,11,.6); backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.08); color:var(--t2);
}
.port-badge .dot { width:6px; height:6px; border-radius:50%; background:var(--acc); box-shadow:0 0 6px var(--acc); }
.port-info { padding:1.6rem 1.75rem; border-top:1px solid rgba(255,255,255,.05); }
.port-name { font-family:var(--fd); font-size:1.85rem; font-weight:600; letter-spacing:-.025em; margin-bottom:.55rem; }
.port-desc { font-family:var(--fb); font-size:1.02rem; color:var(--tm); line-height:1.6; margin-bottom:1.2rem; }
.port-link {
  display:inline-flex; align-items:center; gap:.4rem;
  font-family:var(--fd); font-size:.85rem; font-weight:600; color:var(--acc);
}
.port-link svg { transition:transform .25s; }
.port-link:hover svg { transform:translateX(4px); }

.port-cta {
  border-radius:var(--r4);
  border:1px dashed rgba(139,92,255,.3);
  background:linear-gradient(180deg, rgba(139,92,255,.06), rgba(255,255,255,.005));
  padding:2.5rem 2rem; text-align:center;
  display:flex; flex-direction:column; justify-content:center; align-items:center;
}
.port-cta-icon {
  width:54px; height:54px; border-radius:14px;
  background:rgba(139,92,255,.12); border:1px solid rgba(139,92,255,.3);
  display:flex; align-items:center; justify-content:center; color:var(--acc);
  margin-bottom:1.2rem;
}
.port-cta h3 { font-family:var(--fd); font-size:1.65rem; font-weight:600; letter-spacing:-.025em; margin-bottom:.7rem; }
.port-cta p { font-family:var(--fb); font-size:.95rem; color:var(--tm); line-height:1.65; margin-bottom:1.6rem; max-width:360px; }

/* ── DIFFERENTIALS ─────────────────────────── */
.numg { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; margin-top:4rem; }
.numc {
  border-radius:var(--r3);
  border:1px solid rgba(255,255,255,.06);
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.005));
  padding:2.25rem 1.75rem;
  text-align:left;
  transition:border-color .3s, transform .3s var(--eout);
}
.numc:hover { border-color:rgba(139,92,255,.3); transform:translateY(-3px); }
.numc-icon {
  width:50px; height:50px; border-radius:13px;
  background:rgba(139,92,255,.1); border:1px solid rgba(139,92,255,.25);
  display:flex; align-items:center; justify-content:center; color:var(--acc);
  margin-bottom:1.25rem;
}
.numv { font-family:var(--fd); font-size:1.42rem; font-weight:600; letter-spacing:-.02em; line-height:1.25; color:#fff; margin-bottom:.6rem; }
.numl { font-family:var(--fb); font-size:1.02rem; color:var(--tm); line-height:1.65; }

/* ── CONTACT ───────────────────────────────── */
.ctasec { padding:7rem 0 5rem; position:relative; overflow:hidden; }
.ctabg {
  position:absolute; top:0; left:50%; transform:translateX(-50%);
  width:1100px; height:600px; pointer-events:none;
  background:radial-gradient(ellipse, rgba(139,92,255,.18) 0%, transparent 65%);
  filter:blur(80px); z-index:0;
}
.cta-head { text-align:center; margin-bottom:3rem; position:relative; z-index:2; }
.ctah2 {
  font-family:var(--fd); font-size:clamp(2rem, 4.5vw, 3.6rem);
  font-weight:500; line-height:1.05; letter-spacing:-.04em;
}
.ctap { font-family:var(--fb); font-size:1rem; color:var(--tm); line-height:1.65; margin-top:.9rem; }
.fcard {
  position:relative; z-index:2;
  max-width:720px; margin:0 auto;
  border-radius:var(--r4);
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(20,15,35,.95), rgba(10,8,20,.95));
  padding:2.5rem;
  backdrop-filter:blur(20px);
  box-shadow:0 30px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(139,92,255,.1);
}
.ftit { font-family:var(--fd); font-size:1.4rem; font-weight:600; letter-spacing:-.02em; margin-bottom:.5rem; }
.fsub { font-family:var(--fb); font-size:.9rem; color:var(--tm); margin-bottom:1.8rem; }
.frow { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field { display:flex; flex-direction:column; gap:.4rem; margin-bottom:1rem; }
.flbl { font-family:var(--fb); font-size:.78rem; font-weight:500; color:var(--t2); }
.field input, .field select, .field textarea {
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r2);
  padding:.85rem 1rem; font-family:var(--fb); font-size:.88rem; color:#fff;
  outline:none; width:100%;
  transition:border-color .25s, box-shadow .25s, background .25s;
}
.field input::placeholder, .field textarea::placeholder { color:var(--td); }
.field input:focus, .field select:focus, .field textarea:focus {
  border-color:rgba(139,92,255,.5);
  background:rgba(139,92,255,.04);
  box-shadow:0 0 0 3px rgba(139,92,255,.12);
}
.field select { color:var(--tm); }
.field select option { background:#0A0815; color:#fff; }
.field textarea { resize:none; min-height:100px; }
.fchk { display:flex; align-items:flex-start; gap:.6rem; font-family:var(--fb); font-size:.82rem; color:var(--tm); margin-bottom:1.4rem; }
.fchk input[type=checkbox] { width:16px; height:16px; flex-shrink:0; margin-top:2px; accent-color:var(--acc); }
.fsub2 {
  width:100%; padding:1rem;
  font-family:var(--fd); font-size:.95rem; font-weight:600;
  border:none; border-radius:var(--rf); cursor:pointer;
  background:linear-gradient(180deg, var(--acc), #6B45D9);
  color:#fff;
  box-shadow:0 0 0 1px rgba(139,92,255,.4), 0 12px 32px rgba(139,92,255,.35);
  transition:transform .2s var(--esp), box-shadow .25s;
}
.fsub2:hover { transform:translateY(-2px); box-shadow:0 0 0 1px rgba(139,92,255,.5), 0 16px 40px rgba(139,92,255,.45); }
.fsuc { display:none; text-align:center; padding:2rem 0; }
.fsuc-t { font-family:var(--fd); font-size:1.3rem; font-weight:600; margin-bottom:.5rem; }
.fsuc-s { font-family:var(--fb); font-size:.88rem; color:var(--tm); line-height:1.6; }

.cta-bar { max-width:720px; margin:1.5rem auto 0; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; padding:0 .5rem; position:relative; z-index:2; }
.cta-bar-item { display:inline-flex; align-items:center; gap:.5rem; font-family:var(--fb); font-size:.82rem; color:var(--tm); }
.cta-bar-item:hover { color:#fff; }
.cta-bar-soc-row { display:flex; gap:.5rem; }
.cta-bar-soc {
  width:34px; height:34px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  border:1px solid rgba(255,255,255,.08);
  color:var(--t2); transition:all .2s;
}
.cta-bar-soc:hover { border-color:var(--acc); color:var(--acc); background:rgba(139,92,255,.06); }

/* ── FOOTER ────────────────────────────────── */
footer { padding:4rem 0 2rem; border-top:1px solid var(--bd); background:#06050A; }
.ftg { max-width:1280px; margin:0 auto; padding:0 2rem; display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:3rem; margin-bottom:3rem; }
.ftag { font-family:var(--fb); font-size:.85rem; color:var(--tm); line-height:1.65; margin-top:1rem; max-width:280px; }
.fct { font-family:var(--fd); font-size:.78rem; font-weight:600; color:#fff; text-transform:uppercase; letter-spacing:.1em; margin-bottom:1rem; }
.flinks { list-style:none; display:flex; flex-direction:column; gap:.65rem; }
.flinks a { font-family:var(--fb); font-size:.85rem; color:var(--tm); transition:color .2s; }
.flinks a:hover { color:#fff; }
.fbot { max-width:1280px; margin:0 auto; padding:1.5rem 2rem 0; border-top:1px solid var(--bd); display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; }
.fcopy { font-family:var(--fb); font-size:.78rem; color:var(--td); }
.fsoc { display:flex; gap:.5rem; }
.fsocs { width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center; border:1px solid var(--bd); color:var(--tm); transition:all .2s; }
.fsocs:hover { border-color:var(--acc); color:var(--acc); }

/* ── RESPONSIVE ────────────────────────────── */
@media (min-width: 1280px) {
  .nw { padding:0 2.5rem; }
  .sec { padding:9rem 0; }
  .seca { padding:9rem 0; }
  .hero { padding:11rem 2rem 7rem; }
}
@media (max-width: 1100px) {
  .srv-grid { grid-template-columns:repeat(2,1fr); }
  .srv-card.span-3, .srv-card.span-2, .srv-card.span-4 { grid-column:span 1; }
  .cf-grid { grid-template-columns:repeat(2,1fr); }
  .numg { grid-template-columns:repeat(2,1fr); }
  .ai-grid { grid-template-columns:1fr; gap:3rem; }
  .port-grid { grid-template-columns:1fr; }
  .srv-intro { grid-template-columns:1fr; gap:1.25rem; }
  .ftg { grid-template-columns:1.2fr 1fr 1fr; }
}
@media (max-width: 880px) {
  .nlinks-wrap { display:none; }
  nav .nbtn { display:none; }
  .nham { display:flex; }
  .hpreview-inner { grid-template-columns:1fr; gap:.85rem; padding:1rem; }
  .ai-feats { gap:1.1rem; }
  .ftg { grid-template-columns:1fr 1fr; gap:2rem; }
  .fbot { flex-direction:column; gap:.75rem; align-items:flex-start; }
}
@media (max-width: 640px) {
  html, body { overflow-x:hidden; max-width:100vw; }
  body { font-size:1rem; line-height:1.55; }
  img, video { max-width:100%; height:auto; }
  .nw { padding:0 1.1rem; gap:.75rem; }
  nav { padding:.75rem 0; }
  nav.stuck { padding:.55rem 0; }
  .logo-img { height:50px !important; }
  nav.stuck .logo-img { height:42px !important; }
  .nham { width:42px; height:42px; }
  .nmob a { font-size:1.4rem; }
  .hero { padding:6rem 1.1rem 3rem; min-height:auto; }
  .hero-orb { width:100%; height:500px; filter:blur(60px); }
  .htag { font-size:.78rem; padding:.4rem .4rem .4rem .9rem; margin-bottom:1.4rem; max-width:calc(100vw - 2.2rem); flex-wrap:wrap; }
  .htag-pill { font-size:.68rem; padding:.2rem .55rem; }
  .hh1 { font-size:2.5rem; line-height:1.05; margin-bottom:1.1rem; letter-spacing:-.035em; }
  .hsub { font-size:1.02rem; max-width:100%; margin-bottom:1.8rem; }
  .hbtns { width:100%; flex-direction:column; gap:.7rem; }
  .hbtns .btn-p, .hbtns .btn-o { width:100%; justify-content:center; padding:1.05rem 1.4rem; font-size:1.02rem; }
  .hpreview { margin-top:3rem; border-radius:18px; }
  .hpreview-inner { padding:.85rem; gap:.7rem; min-height:auto; }
  .hp-card { padding:1.1rem; }
  .hp-card-title { font-size:1rem; }
  .hp-card-desc { font-size:.85rem; }
  .mq { padding:1rem 0; }
  .mqi { font-size:.68rem; letter-spacing:.1em; }
  .mqt { gap:1.75rem; }
  .sec { padding:4rem 0; }
  .seca { padding:4rem 0; }
  .w { padding:0 1.1rem; }
  .ey { font-size:.7rem; margin-bottom:.8rem; letter-spacing:.15em; }
  .sh2 { font-size:2.05rem; line-height:1.1; margin-bottom:.85rem; letter-spacing:-.025em; }
  .sp { font-size:1rem; line-height:1.6; }
  .srv-grid { grid-template-columns:1fr; gap:.85rem; }
  .srv-card { min-height:auto; }
  .srv-media { min-height:160px; height:200px; }
  .srv-body { padding:1.2rem 1.2rem 1.35rem; gap:.45rem; }
  .srv-title { font-size:1.22rem; }
  .srv-desc { font-size:.95rem; }
  .srv-tag { font-size:.7rem; padding:.22rem .6rem; }
  .cf-grid { grid-template-columns:1fr; gap:.85rem; margin-top:2.25rem; }
  .cf-card { min-height:auto; padding:1.5rem 1.3rem; }
  .cf-num { font-size:2.4rem; }
  .cf-title { font-size:1.18rem; }
  .cf-desc { font-size:.95rem; }
  .numg { grid-template-columns:1fr; gap:.85rem; margin-top:2.25rem; }
  .numc { padding:1.6rem 1.3rem; }
  .numv { font-size:1.18rem; }
  .numl { font-size:.95rem; }
  .ai-grid { gap:2.25rem; }
  .ai-feats { margin-top:1.6rem; gap:1rem; }
  .ai-feat-title { font-size:1.05rem; }
  .ai-feat-desc { font-size:.95rem; }
  .ai-phone-scene { min-height:500px; perspective:none; }
  .ai-phone { width:260px; height:500px; transform:none !important; animation:phoneFloat 6s ease-in-out infinite !important; }
  @keyframes phoneFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
  .port-grid { grid-template-columns:1fr; gap:1rem; margin-top:2.25rem; }
  .port-card { min-height:auto; }
  .port-media { min-height:220px; height:240px; }
  .port-name { font-size:1.5rem; }
  .port-desc { font-size:.95rem; }
  .port-info { padding:1.4rem 1.3rem; }
  .port-cta { padding:2.2rem 1.4rem; min-height:280px; }
  .port-cta h3 { font-size:1.5rem; }
  .port-cta p { font-size:.92rem; }
  .ctasec { padding:4.5rem 0 3.5rem; }
  .ctah2 { font-size:2.1rem; }
  .ctap { font-size:.98rem; }
  .fcard { padding:1.5rem 1.2rem; border-radius:18px; }
  .frow { grid-template-columns:1fr; gap:0; }
  .ftit { font-size:1.2rem; }
  .field input, .field select, .field textarea { font-size:1rem; padding:.9rem 1rem; }
  .fsub2 { font-size:1rem; padding:1rem; }
  .cta-bar { flex-direction:column; align-items:flex-start; gap:.85rem; padding:0 .25rem; margin-top:1.25rem; }
  .cta-bar-item { font-size:.88rem; }
  .ftg { grid-template-columns:1fr; gap:1.75rem; padding:0 1.1rem; }
  .fbot { padding:1.25rem 1.1rem 0; }
  footer { padding:3rem 0 1.5rem; }
  footer img { height:54px !important; }
}
@media (max-width: 380px) {
  .hh1 { font-size:2.1rem; }
  .sh2 { font-size:1.78rem; }
  .ctah2 { font-size:1.85rem; }
  .ai-phone { width:240px; height:460px; }
  .ai-phone-scene { min-height:460px; }
  .port-name { font-size:1.35rem; }
}
@media (hover: none) and (pointer: coarse) {
  .srv-card:hover, .cf-card:hover, .numc:hover, .port-card:hover { transform:none; }
  .srv-card:hover .srv-asset.loaded { transform:none; }
}
