/* =============================================
   RESET & ROOT
============================================= */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

@property --hue   { syntax:"<angle>"; initial-value:270deg; inherits:false; }
@property --shimmer { syntax:"<number>"; initial-value:0; inherits:false; }

:root {
  --bg:       #050507;
  --bg2:      #0d0d12;
  --bg3:      #111118;
  --bg4:      #181820;
  --border:   #ffffff0d;
  --border2:  #ffffff1a;
  --border3:  #ffffff26;
   --text:     #f5f6fb;
   --muted:    #b7bdd0;
   --muted2:   #9098b2;
  --accent:   #7c6ef0;
  --accent2:  #a89cf7;
  --accent3:  #c4b8ff;
  --green:    #22c55e;
  --green2:   #16a34a;
  --spring:   linear(0,0.009,0.035 2.1%,0.141,0.281 6.7%,0.723 12.9%,0.938,1.008,1.014 18%,1.007,0.999,1.001 28.5%,1);
}

html { scroll-behavior:smooth; }
body { background:var(--bg); color:var(--text); font-family:'Plus Jakarta Sans',sans-serif; line-height:1.6; overflow-x:hidden; cursor:none; }

/* =============================================
   CUSTOM CURSOR
============================================= */
#cursor      { position:fixed; width:10px; height:10px; background:var(--accent2); border-radius:50%; pointer-events:none; z-index:9999; transform:translate(-50%,-50%); transition:width .2s,height .2s,background .2s,opacity .2s; mix-blend-mode:screen; }
#cursor-ring { position:fixed; width:36px; height:36px; border:1.5px solid #a89cf760; border-radius:50%; pointer-events:none; z-index:9998; transform:translate(-50%,-50%); transition:width .35s var(--spring),height .35s var(--spring),border-color .2s,opacity .3s; }
body:has(a:hover) #cursor-ring, body:has(button:hover) #cursor-ring { width:56px; height:56px; border-color:var(--accent2); }
body:has(a:hover) #cursor, body:has(button:hover) #cursor { width:6px; height:6px; background:#fff; }

/* =============================================
   NOISE TEXTURE
============================================= */
body::before { content:""; position:fixed; inset:0; background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E"); pointer-events:none; z-index:1000; opacity:.35; }

/* =============================================
   AMBIENT GRID
============================================= */
.bg-grid { position:fixed; inset:0; z-index:0; pointer-events:none; background-image:linear-gradient(rgba(124,110,240,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(124,110,240,.03) 1px,transparent 1px); background-size:60px 60px; mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,black 20%,transparent 80%); }

/* =============================================
   AMBIENT ORBS
============================================= */
.hero-orb { position:fixed; top:0; left:0; width:100vw; height:100vh; pointer-events:none; z-index:0; background:radial-gradient(ellipse 900px 600px at 10% 40%,#7c6ef012,transparent 60%),radial-gradient(ellipse 500px 400px at 80% 85%,#22c55e08,transparent 70%),radial-gradient(ellipse 400px 300px at 60% 20%,#a89cf708,transparent 70%); will-change:transform; animation:orbDrift 20s ease-in-out infinite alternate; }
@keyframes orbDrift { from{transform:translateX(0) translateY(0)} to{transform:translateX(30px) translateY(-20px)} }

/* =============================================
   SCROLL REVEAL
============================================= */
.is-hidden { opacity:0; transform:translateY(32px); transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1); }
.is-hidden.visible { opacity:1; transform:translateY(0); }

/* =============================================
   MAGNETIC
============================================= */
.magnetic { display:inline-block; transition:transform .3s var(--spring); }

/* =============================================
   NAV
============================================= */
nav { position:fixed; top:0; left:0; right:0; z-index:100; padding:0 2.5rem; height:60px; display:flex; justify-content:space-between; align-items:center; background:rgba(5,5,7,.75); backdrop-filter:blur(20px) saturate(1.5); -webkit-backdrop-filter:blur(20px) saturate(1.5); border-bottom:1px solid var(--border); transition:border-color .3s,background .3s; }
nav.scrolled { background:rgba(5,5,7,.95); border-color:var(--border2); }
.nav-name { font-family:'Syne',sans-serif; font-weight:700; font-size:.95rem; letter-spacing:.02em; background:linear-gradient(135deg,var(--text) 40%,var(--accent2)); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.nav-links { display:flex; gap:2rem; align-items:center; }
.nav-links a { color:var(--muted); text-decoration:none; font-size:.8rem; letter-spacing:.06em; font-weight:400; transition:color .2s; position:relative; padding-bottom:2px; }
.nav-links a::after { content:""; position:absolute; bottom:-1px; left:0; width:0; height:1px; background:var(--accent2); transition:width .3s var(--spring); }
.nav-links a:hover { color:var(--text); }
.nav-links a:hover::after, .nav-links a.nav-active::after { width:100%; }
.nav-links a.nav-active { color:var(--text); }
.nav-links a.nav-wa { background:var(--green) !important; color:#fff !important; padding:.85rem 1rem; border-radius:999px; font-size:.75rem !important; font-weight:500; display:inline-flex; align-items:center; justify-content:center; gap:.42rem; line-height:1; letter-spacing:.02em; white-space:nowrap; transition:transform .3s var(--spring),box-shadow .3s !important; }
.nav-links a.nav-wa::after { display:none !important; }
.nav-links a.nav-wa .nav-wa-icon { display:inline-flex; align-items:center; justify-content:center; line-height:0; }
.nav-links a.nav-wa .nav-wa-icon svg { display:block; width:12px; height:12px; flex:0 0 auto; }
.nav-links a.nav-wa .nav-wa-text { display:inline-block; line-height:1; transform:translateY(-.02em); }
.nav-links a.nav-wa:hover { transform:scale(1.07) !important; box-shadow:0 4px 20px #22c55e30 !important; color:#fff !important; }

/* =============================================
   HERO
============================================= */
.hero { min-height:100vh; display:flex; flex-direction:column; justify-content:center; padding:6rem 2.5rem 4rem; max-width:960px; margin:0 auto; position:relative; }
.hero > * { position:relative; z-index:1; }
.hero-badge { display:inline-flex; align-items:center; gap:.6rem; background:var(--bg3); border:1px solid var(--border2); border-radius:999px; padding:.4rem 1.1rem; font-size:.72rem; color:var(--muted); letter-spacing:.1em; margin-bottom:2.2rem; width:fit-content; position:relative; overflow:hidden; }
.hero-badge::after { content:""; position:absolute; top:0; left:-100%; width:60%; height:100%; background:linear-gradient(90deg,transparent,rgba(255,255,255,.07),transparent); animation:badgeShimmer 3.5s ease-in-out infinite; }
@keyframes badgeShimmer { 0%{left:-100%} 50%,100%{left:160%} }
.badge-dot { width:6px; height:6px; background:var(--accent); border-radius:50%; animation:pulse 2s infinite; position:relative; }
.badge-dot::after { content:""; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:6px; height:6px; border-radius:50%; border:1px solid var(--accent); animation:sonar 2s ease-out infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.3} }
@keyframes sonar { 0%{transform:translate(-50%,-50%) scale(1);opacity:.8} 100%{transform:translate(-50%,-50%) scale(4);opacity:0} }
.hero h1 { font-family:'Plus Jakarta Sans',sans-serif; font-size:clamp(3.5rem,9vw,6.5rem); font-weight:700; letter-spacing:-.02em; line-height:1.06; margin-bottom:1.8rem; max-width:100%; overflow:visible; }
.name-line { display:block; }
.name-line1,.name-line2 { white-space:nowrap; }
.name-line2 { line-height:1.12; padding-bottom:.18em; }
.char { display:inline-block; opacity:0; transform:translateY(24px); animation:charIn .6s cubic-bezier(.16,1,.3,1) forwards; }
@keyframes charIn { to{opacity:1;transform:translateY(0)} }
.accent-name { display:inline-block; line-height:1.12; padding-bottom:.06em; background:linear-gradient(var(--hue),#7c6ef0,#a89cf7,#e0d9ff,#a89cf7); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; animation:hueShift 10s linear infinite,charIn .6s cubic-bezier(.16,1,.3,1) forwards; opacity:0; transform:translateY(24px); }
@keyframes hueShift { to{--hue:990deg} }
.hero-sub { font-size:1.05rem; color:var(--muted); max-width:520px; line-height:1.8; margin-bottom:2.8rem; font-weight:400; }
.hero-cta { display:flex; gap:.9rem; flex-wrap:wrap; align-items:center; }
.btn-primary { background:var(--accent); color:#fff; padding:.8rem 1.6rem; border-radius:10px; text-decoration:none; font-size:.86rem; font-weight:500; border:none; cursor:none; position:relative; overflow:hidden; transition:transform .35s var(--spring),box-shadow .3s; letter-spacing:.02em; }
.btn-primary::before { content:""; position:absolute; inset:0; background:linear-gradient(135deg,rgba(255,255,255,.15),transparent); opacity:0; transition:opacity .2s; }
.btn-primary:hover::before { opacity:1; }
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 12px 40px #7c6ef040; }
.btn-ghost { border:1px solid var(--border2); color:var(--text); padding:.8rem 1.6rem; border-radius:10px; text-decoration:none; font-size:.86rem; transition:border-color .25s,transform .35s var(--spring),background .2s; }
.btn-ghost:hover { border-color:var(--accent2); transform:translateY(-3px); background:var(--bg2); }
.btn-wa { background:var(--green); color:#fff; padding:.8rem 1.6rem; border-radius:10px; text-decoration:none; font-size:.86rem; font-weight:500; display:flex; align-items:center; gap:.5rem; position:relative; overflow:hidden; transition:transform .35s var(--spring),box-shadow .3s; }
.btn-wa:hover { transform:translateY(-3px); box-shadow:0 12px 40px #22c55e35; }
.ripple { position:absolute; border-radius:50%; transform:scale(0); animation:rippleAnim .6s linear; background:rgba(255,255,255,.2); pointer-events:none; }
@keyframes rippleAnim { to{transform:scale(5);opacity:0} }
.hero-links { display:flex; gap:1.6rem; margin-top:3.2rem; flex-wrap:wrap; }
.hero-links a { color:var(--muted); text-decoration:none; font-size:.8rem; transition:color .2s,transform .3s var(--spring); display:flex; align-items:center; gap:.4rem; }
.hero-links a:hover { color:var(--text); transform:translateY(-2px); }

/* =============================================
   MARQUEE
============================================= */
.marquee-strip { overflow:hidden; padding:1.2rem 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); background:var(--bg2); position:relative; z-index:1; }
.marquee-track { display:flex; gap:0; width:max-content; animation:marqueeScroll 25s linear infinite; }
.marquee-strip:hover .marquee-track { animation-play-state:paused; }
@keyframes marqueeScroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.marquee-item { display:flex; align-items:center; gap:.6rem; padding:0 2.5rem; font-size:.75rem; letter-spacing:.12em; color:var(--muted2); font-family:'Syne',sans-serif; font-weight:500; white-space:nowrap; text-transform:uppercase; }
.marquee-item .dot { width:3px; height:3px; background:var(--accent); border-radius:50%; flex-shrink:0; }

/* =============================================
   SECTIONS
============================================= */
section { padding:6rem 2.5rem; max-width:1120px; margin:0 auto; }
.section-label { font-size:.68rem; letter-spacing:.2em; color:var(--accent); margin-bottom:.7rem; text-transform:uppercase; font-family:'Syne',sans-serif; font-weight:600; display:flex; align-items:center; gap:.6rem; }
.section-label::before { content:""; display:block; width:20px; height:1px; background:var(--accent); }
.section-title { font-family:'Syne',sans-serif; font-size:clamp(1.8rem,4vw,2.6rem); font-weight:700; letter-spacing:-.03em; margin-bottom:.8rem; line-height:1.1; }
.section-sub { font-size:.9rem; color:var(--muted); margin-bottom:3rem; max-width:540px; line-height:1.75; font-weight:400; }
.divider { height:1px; background:linear-gradient(90deg,transparent 5%,#7c6ef030 30%,#7c6ef018 70%,transparent 95%); max-width:1120px; margin:0 auto; }

/* =============================================
   SOLUTIONS
============================================= */
.solutions-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:14px; }
.sol-card { background:var(--bg2); border:1px solid var(--border); border-radius:14px; padding:1.7rem; transition:border-color .35s,transform .45s var(--spring),box-shadow .35s; cursor:default; position:relative; overflow:hidden; }
.sol-card::before { content:""; position:absolute; inset:0; opacity:0; background:radial-gradient(circle at var(--mx,50%) var(--my,50%),#7c6ef015,transparent 60%); transition:opacity .3s; }
.sol-card:hover::before { opacity:1; }
.sol-card:hover { border-color:#7c6ef040; transform:translateY(-5px); box-shadow:0 16px 50px rgba(124,110,240,.1); }
.sol-icon { width:42px; height:42px; border-radius:11px; background:linear-gradient(135deg,var(--bg3),var(--bg4)); border:1px solid var(--border2); display:flex; align-items:center; justify-content:center; font-size:1.1rem; margin-bottom:1.1rem; transition:transform .4s var(--spring),box-shadow .3s; }
.sol-card:hover .sol-icon { transform:scale(1.15) rotate(-5deg); box-shadow:0 6px 20px rgba(124,110,240,.2); }
.sol-tag { font-size:.62rem; letter-spacing:.12em; color:var(--accent2); text-transform:uppercase; margin-bottom:.55rem; font-family:'Syne',sans-serif; }
.sol-card h3 { font-size:.95rem; font-weight:600; margin-bottom:.55rem; font-family:'Syne',sans-serif; letter-spacing:-.01em; }
.sol-card p { font-size:.79rem; color:var(--muted); line-height:1.7; }
.sol-features { list-style:none; margin-top:1rem; display:flex; flex-direction:column; gap:.4rem; }
.sol-features li { font-size:.76rem; color:var(--muted); display:flex; align-items:center; gap:.55rem; }
.sol-features li::before { content:""; width:5px; height:5px; border-radius:50%; background:var(--accent); flex-shrink:0; }

/* =============================================
   AI CHAT WIDGET
============================================= */
.ai-widget-wrap { background:var(--bg2); border:1px solid var(--border2); border-radius:20px; padding:2.2rem; position:relative; overflow:hidden; }
.ai-widget-wrap::before { content:""; position:absolute; top:0; right:0; width:300px; height:300px; background:radial-gradient(circle,#7c6ef015,transparent 70%); pointer-events:none; }
.ai-widget-header { display:flex; align-items:center; gap:.85rem; margin-bottom:1.6rem; }
.ai-avatar { width:38px; height:38px; border-radius:50%; background:linear-gradient(135deg,var(--accent),#4f46e5); display:flex; align-items:center; justify-content:center; font-size:.8rem; font-weight:700; color:#fff; flex-shrink:0; font-family:'Syne',sans-serif; box-shadow:0 4px 16px #7c6ef040; }
.ai-widget-header h3 { font-size:.95rem; font-weight:600; font-family:'Syne',sans-serif; }
.ai-widget-header p { font-size:.74rem; color:var(--muted); }
.ai-status-dot { display:inline-block; width:7px; height:7px; background:var(--green); border-radius:50%; margin-right:4px; animation:pulse 2s infinite; }
.ai-chat-window { background:var(--bg3); border-radius:12px; padding:1.1rem; height:280px; overflow-y:auto; display:flex; flex-direction:column; gap:.85rem; margin-bottom:1.1rem; scrollbar-width:thin; scrollbar-color:var(--border2) transparent; }
.ai-msg { max-width:82%; padding:.7rem 1rem; border-radius:12px; font-size:.83rem; line-height:1.65; animation:msgIn .4s cubic-bezier(.16,1,.3,1) forwards; white-space:pre-line; }
@keyframes msgIn { from{opacity:0;transform:translateY(10px) scale(.97)} to{opacity:1;transform:none} }
.ai-msg.bot { background:var(--bg4); border:1px solid var(--border); color:var(--text); align-self:flex-start; border-radius:4px 12px 12px 12px; }
.ai-msg.user { background:linear-gradient(135deg,var(--accent),#6055c4); color:#fff; align-self:flex-end; border-radius:12px 4px 12px 12px; box-shadow:0 4px 16px #7c6ef030; }
.ai-msg.typing { color:var(--muted); font-style:italic; }
.ai-suggestions { display:flex; flex-wrap:wrap; gap:.5rem; margin-bottom:1.1rem; }
.ai-chip { background:var(--bg3); border:1px solid var(--border2); border-radius:999px; padding:.33rem .9rem; font-size:.73rem; color:var(--muted); cursor:none; transition:all .25s,transform .3s var(--spring); white-space:nowrap; font-family:'Plus Jakarta Sans',sans-serif; }
.ai-chip:hover { border-color:var(--accent); color:var(--accent2); transform:translateY(-2px); background:#7c6ef010; }
.ai-input-row { display:flex; gap:.55rem; }
.ai-input { flex:1; background:var(--bg3); border:1px solid var(--border2); border-radius:10px; padding:.7rem 1.1rem; font-size:.83rem; color:var(--text); font-family:'Plus Jakarta Sans',sans-serif; outline:none; transition:border-color .2s,box-shadow .2s; }
.ai-input:focus { border-color:var(--accent); box-shadow:0 0 0 3px #7c6ef012; }
.ai-send { background:linear-gradient(135deg,var(--accent),#5f52d4); border:none; border-radius:10px; padding:.7rem 1.2rem; color:#fff; cursor:none; font-size:.83rem; font-weight:500; transition:transform .3s var(--spring),box-shadow .25s; white-space:nowrap; position:relative; overflow:hidden; font-family:'Plus Jakarta Sans',sans-serif; }
.ai-send:hover { transform:translateY(-2px); box-shadow:0 6px 20px #7c6ef040; }

/* =============================================
   BENTO PROJECTS
============================================= */
.bento { display:grid; grid-template-columns:repeat(12,1fr); gap:14px; }
.bento-card { background:var(--bg2); border:1px solid var(--border); border-radius:16px; padding:1.7rem; position:relative; overflow:hidden; transition:border-color .35s,box-shadow .4s; cursor:none; will-change:transform; }
.bento-card::after { content:""; position:absolute; inset:0; opacity:0; background:radial-gradient(circle at var(--mx,50%) var(--my,50%),#7c6ef00e,transparent 60%); transition:opacity .35s; border-radius:inherit; }
.bento-card:hover::after { opacity:1; }
.bento-card.large  { grid-column:span 7; }
.bento-card.large:hover { border-color:#7c6ef055; box-shadow:0 0 60px #7c6ef018,0 20px 60px #7c6ef010; }
.bento-card.medium { grid-column:span 5; }
.bento-card.small  { grid-column:span 4; }
.bento-card:hover  { border-color:var(--border2); box-shadow:0 16px 50px rgba(0,0,0,.4); }
.bento-accent { position:absolute; top:0; right:0; width:120px; height:120px; background:linear-gradient(135deg,#7c6ef030,transparent); border-radius:0 16px 0 120px; pointer-events:none; transition:opacity .4s; opacity:.06; }
.bento-card:hover .bento-accent { opacity:.18; }
.card-number { position:absolute; top:1.5rem; right:1.7rem; font-family:'Syne',sans-serif; font-size:3rem; font-weight:800; color:var(--muted2); opacity:.15; line-height:1; transition:opacity .3s,transform .4s var(--spring); pointer-events:none; user-select:none; }
.bento-card:hover .card-number { opacity:.28; transform:scale(1.1); }
.card-tag { display:inline-block; font-size:.66rem; letter-spacing:.1em; color:var(--accent2); background:#7c6ef012; border:1px solid #7c6ef025; border-radius:5px; padding:.2rem .6rem; margin-bottom:1rem; font-family:'Syne',sans-serif; }
.bento-card h3 { font-family:'Syne',sans-serif; font-size:1.1rem; font-weight:700; margin-bottom:.45rem; letter-spacing:-.02em; }
.bento-card p { font-size:.82rem; color:var(--muted); line-height:1.7; font-weight:400; }
.card-stack { display:flex; flex-wrap:wrap; gap:.38rem; margin-top:1rem; }
.tech-pill { font-size:.67rem; background:var(--bg3); border:1px solid var(--border); border-radius:999px; padding:.2rem .65rem; color:var(--muted); transition:color .2s,border-color .2s,background .2s; }
.bento-card:hover .tech-pill { border-color:var(--border2); color:var(--text); background:var(--bg4); }
.card-link { display:inline-flex; align-items:center; gap:.35rem; margin-top:1rem; font-size:.75rem; color:var(--accent2); text-decoration:none; opacity:.7; transition:opacity .2s,transform .3s var(--spring); }
.card-link:hover { opacity:1; transform:translateX(4px); }
.bento-card.dimmed { opacity:.25; transform:scale(.97); transition:opacity .35s,transform .35s; }
.bento-card.highlighted { border-color:var(--accent) !important; box-shadow:0 0 30px #7c6ef025 !important; }

/* =============================================
   DEMO CAROUSEL
============================================= */
.carousel { display:flex; gap:16px; overflow-x:auto; scroll-snap-type:x mandatory; padding-bottom:1rem; scrollbar-width:none; cursor:grab; }
.carousel:active { cursor:grabbing; }
.carousel::-webkit-scrollbar { display:none; }
.demo-card { flex:0 0 285px; scroll-snap-align:start; background:var(--bg2); border:1px solid var(--border); border-radius:14px; overflow:hidden; transition:border-color .35s,transform .4s var(--spring),box-shadow .3s; cursor:none; }
.demo-card:hover { border-color:var(--border2); transform:translateY(-5px); box-shadow:0 16px 45px rgba(0,0,0,.4); }
.demo-thumb { height:170px; display:flex; align-items:flex-end; padding:1.1rem; position:relative; }
.demo-thumb.t1{background:linear-gradient(135deg,#1a1060,#0a0a12)} .demo-thumb.t2{background:linear-gradient(135deg,#0a2a1a,#050a07)} .demo-thumb.t3{background:linear-gradient(135deg,#2a0a0a,#0a0505)} .demo-thumb.t4{background:linear-gradient(135deg,#1a100a,#0a0705)} .demo-thumb.t5{background:linear-gradient(135deg,#0a1a2a,#050a10)} .demo-thumb.t6{background:linear-gradient(135deg,#0a2a24,#050a08)}
.demo-thumb::before { content:""; position:absolute; inset:0; background:linear-gradient(to bottom,transparent 40%,rgba(0,0,0,.5)); }
.demo-thumb h4 { font-family:'Syne',sans-serif; font-size:.92rem; font-weight:700; position:relative; z-index:1; }
.demo-thumb p { font-size:.7rem; color:rgba(255,255,255,.5); position:relative; z-index:1; }
.demo-info { padding:1rem 1.2rem; display:flex; justify-content:space-between; align-items:center; }
.demo-type { font-size:.68rem; color:var(--muted); background:var(--bg3); border:1px solid var(--border); border-radius:5px; padding:.15rem .55rem; }
.demo-cta { font-size:.72rem; color:var(--accent2); text-decoration:none; opacity:.8; transition:opacity .2s,transform .3s var(--spring); }
.demo-cta:hover { opacity:1; transform:translateX(4px); }
.carousel-hint { font-size:.72rem; color:var(--muted2); margin-top:.7rem; text-align:right; }

/* =============================================
   SKILLS
============================================= */
.skills-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:1.2rem; }
.skill-group { background:var(--bg2); border:1px solid var(--border); border-radius:14px; padding:1.5rem; transition:border-color .3s,transform .4s var(--spring); }
.skill-group:hover { border-color:var(--border2); transform:translateY(-2px); }
.skill-group h4 { font-size:.66rem; letter-spacing:.14em; color:var(--muted2); text-transform:uppercase; margin-bottom:1rem; font-family:'Syne',sans-serif; }
.skill-tags { display:flex; flex-wrap:wrap; gap:.45rem; }
.skill-tag { font-size:.75rem; color:var(--muted); background:var(--bg3); border:1px solid var(--border); border-radius:8px; padding:.3rem .7rem; cursor:none; transition:color .2s,border-color .2s,background .2s,transform .3s var(--spring); }
.skill-tag:hover { color:var(--accent2); border-color:var(--accent); background:#7c6ef010; transform:translateY(-2px); }
.skill-tag.active { color:var(--accent2); border-color:var(--accent); background:#7c6ef018; }

/* =============================================
   SERVICES
============================================= */
.services-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(290px,1fr)); gap:16px; }
.service-card { background:var(--bg2); border:1px solid var(--border); border-radius:16px; padding:2.1rem; position:relative; overflow:hidden; transition:border-color .35s,transform .45s var(--spring),box-shadow .35s; }
.service-card:hover { border-color:var(--border2); transform:translateY(-5px); box-shadow:0 16px 50px rgba(0,0,0,.3); }
.service-card.featured { border-color:#7c6ef044; }
.service-card.featured:hover { box-shadow:0 16px 50px #7c6ef018; border-color:#7c6ef066; }
.service-card.featured::before { content:"Most Popular"; position:absolute; top:1.1rem; right:1.1rem; font-size:.63rem; letter-spacing:.1em; color:var(--accent2); background:#7c6ef018; border:1px solid #7c6ef030; border-radius:999px; padding:.2rem .65rem; font-family:'Syne',sans-serif; }
.service-icon { width:44px; height:44px; border-radius:12px; background:linear-gradient(135deg,var(--bg3),var(--bg4)); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; margin-bottom:1.3rem; font-size:1.15rem; transition:transform .4s var(--spring),box-shadow .3s; }
.service-card:hover .service-icon { transform:scale(1.12) rotate(-4deg); box-shadow:0 8px 24px rgba(124,110,240,.2); }
.service-card h3 { font-family:'Syne',sans-serif; font-size:1.1rem; font-weight:700; margin-bottom:.55rem; letter-spacing:-.02em; }
.service-card .desc { font-size:.83rem; color:var(--muted); line-height:1.7; margin-bottom:1.3rem; font-weight:400; }
.service-price { display:flex; align-items:baseline; gap:.55rem; margin-bottom:1.3rem; }
.price-inr { font-family:'Syne',sans-serif; font-size:1.6rem; font-weight:700; }
.price-usd { font-size:.8rem; color:var(--muted); }
.service-features { list-style:none; display:flex; flex-direction:column; gap:.55rem; }
.service-features li { font-size:.8rem; color:var(--muted); display:flex; align-items:center; gap:.65rem; }
.service-features li::before { content:""; width:5px; height:5px; border-radius:50%; background:var(--accent); flex-shrink:0; }
.service-cta { display:block; margin-top:1.6rem; text-align:center; background:var(--bg3); border:1px solid var(--border2); border-radius:10px; padding:.7rem; font-size:.83rem; color:var(--text); text-decoration:none; position:relative; overflow:hidden; transition:background .2s,border-color .2s,transform .3s var(--spring); cursor:none; }
.service-cta:hover { background:var(--bg4); border-color:var(--accent); transform:translateY(-1px); }
.service-card.featured .service-cta { background:linear-gradient(135deg,var(--accent),#5f52d4); border-color:var(--accent); color:#fff; }
.service-card.featured .service-cta:hover { opacity:.88; }

/* =============================================
   TESTIMONIALS
============================================= */
.testi-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:16px; }
.testi-card { background:var(--bg2); border:1px solid var(--border); border-radius:14px; padding:1.6rem; transition:border-color .3s,transform .4s var(--spring); position:relative; overflow:hidden; }
.testi-card::before { content:'"'; position:absolute; top:-.5rem; left:1.2rem; font-family:'Syne',sans-serif; font-size:6rem; font-weight:800; color:var(--accent); opacity:.06; line-height:1; pointer-events:none; }
.testi-card:hover { border-color:var(--border2); transform:translateY(-4px); }
.stars { display:flex; gap:2px; margin-bottom:1.1rem; }
.star { color:#f59e0b; font-size:.85rem; }
.testi-card blockquote { font-size:.86rem; color:var(--muted); line-height:1.8; margin-bottom:1.3rem; font-style:italic; font-weight:400; }
.testi-author { display:flex; align-items:center; gap:.8rem; }
.testi-avatar { width:38px; height:38px; border-radius:50%; background:linear-gradient(135deg,var(--bg3),var(--bg4)); border:1px solid var(--border2); display:flex; align-items:center; justify-content:center; font-size:.72rem; font-weight:600; flex-shrink:0; font-family:'Syne',sans-serif; }
.testi-name { font-size:.83rem; font-weight:500; font-family:'Syne',sans-serif; }
.testi-role { font-size:.71rem; color:var(--muted); }

/* =============================================
   EXPERIENCE TIMELINE
============================================= */
.exp-list { display:flex; flex-direction:column; gap:0; position:relative; padding-left:2rem; }
.exp-list::before { content:""; position:absolute; left:0; top:.7rem; bottom:0; width:1px; background:linear-gradient(to bottom,var(--accent) 0%,var(--border) 100%); }
.exp-item { display:grid; grid-template-columns:150px 1fr; gap:2rem; padding:2rem 0; border-bottom:1px solid var(--border); transition:transform .3s var(--spring); position:relative; }
.exp-item::before { content:""; position:absolute; left:-2.4rem; top:2.4rem; width:10px; height:10px; border-radius:50%; background:var(--accent); border:2px solid var(--bg); box-shadow:0 0 0 3px var(--bg),0 0 12px var(--accent); transition:transform .3s var(--spring); }
.exp-item:hover { transform:translateX(6px); }
.exp-item:hover::before { transform:scale(1.4); }
.exp-item:last-child { border-bottom:none; }
.exp-meta { font-size:.77rem; color:var(--muted); padding-top:.2rem; }
.exp-meta .company { font-family:'Syne',sans-serif; font-weight:600; color:var(--text); margin-bottom:.3rem; font-size:.85rem; }
.exp-title { font-family:'Syne',sans-serif; font-size:1rem; font-weight:600; margin-bottom:.5rem; letter-spacing:-.01em; }
.exp-desc { font-size:.83rem; color:var(--muted); line-height:1.75; font-weight:400; }

/* =============================================
   CERTS
============================================= */
.cert-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(215px,1fr)); gap:12px; }
.cert-card { background:var(--bg2); border:1px solid var(--border); border-radius:12px; padding:1.3rem; transition:border-color .3s,transform .4s var(--spring); position:relative; overflow:hidden; }
.cert-card::after { content:""; position:absolute; inset:0; background:linear-gradient(135deg,#7c6ef008,transparent); opacity:0; transition:opacity .3s; }
.cert-card:hover::after { opacity:1; }
.cert-card:hover { border-color:var(--border2); transform:translateY(-3px); }
.cert-card .issuer { font-size:.66rem; color:var(--accent2); letter-spacing:.1em; margin-bottom:.4rem; text-transform:uppercase; font-family:'Syne',sans-serif; }
.cert-card p { font-size:.8rem; color:var(--muted); line-height:1.55; font-weight:400; }

/* =============================================
   ABOUT
============================================= */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:start; }
.about-text p { font-size:.97rem; color:var(--muted); line-height:1.85; margin-bottom:1.1rem; font-weight:400; }
.about-text p strong { color:var(--text); font-weight:500; }
.about-stats { display:grid; gap:12px; }
.stat-card { background:var(--bg2); border:1px solid var(--border); border-radius:12px; padding:1.3rem; transition:border-color .3s,transform .4s var(--spring); position:relative; overflow:hidden; }
.stat-card::before { content:""; position:absolute; left:0; top:0; bottom:0; width:2px; background:linear-gradient(to bottom,var(--accent),transparent); opacity:0; transition:opacity .3s; }
.stat-card:hover::before { opacity:1; }
.stat-card:hover { border-color:var(--border2); transform:translateX(6px); }
.stat-num { font-family:'Syne',sans-serif; font-size:2rem; font-weight:800; color:var(--accent2); }
.stat-label { font-size:.75rem; color:var(--muted); margin-top:.2rem; font-weight:400; }

/* =============================================
   CONTACT FORM
============================================= */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:start; }
.contact-info h2 { font-family:'Syne',sans-serif; font-size:2rem; font-weight:700; letter-spacing:-.03em; margin-bottom:.8rem; line-height:1.1; }
.contact-info p { color:var(--muted); font-size:.9rem; line-height:1.8; margin-bottom:2.2rem; font-weight:400; }
.contact-detail { display:flex; align-items:center; gap:.8rem; margin-bottom:1.1rem; font-size:.85rem; color:var(--muted); }
.contact-detail a { color:var(--muted); text-decoration:none; transition:color .2s; }
.contact-detail a:hover { color:var(--text); }
.contact-icon { width:34px; height:34px; border-radius:9px; background:var(--bg2); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:border-color .2s,background .2s; }
.contact-detail:hover .contact-icon { border-color:var(--border2); background:var(--bg3); }
.form-wrap { background:var(--bg2); border:1px solid var(--border); border-radius:18px; padding:2.2rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-bottom:1rem; }
.form-group { display:flex; flex-direction:column; gap:.45rem; margin-bottom:1.1rem; }
.form-group label { font-size:.73rem; color:var(--muted); letter-spacing:.06em; font-family:'Syne',sans-serif; }
.form-group input, .form-group select, .form-group textarea { background:var(--bg3); border:1px solid var(--border2); border-radius:10px; padding:.75rem 1.1rem; font-size:.85rem; color:var(--text); font-family:'Plus Jakarta Sans',sans-serif; outline:none; transition:border-color .2s,box-shadow .2s; width:100%; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--accent); box-shadow:0 0 0 3px #7c6ef012; }
.form-group select option { background:var(--bg3); }
.form-group textarea { resize:vertical; min-height:120px; }
.form-submit { width:100%; background:linear-gradient(135deg,var(--accent),#5f52d4); color:#fff; border:none; border-radius:10px; padding:.9rem; font-size:.9rem; font-weight:500; cursor:none; font-family:'Plus Jakarta Sans',sans-serif; position:relative; overflow:hidden; transition:transform .35s var(--spring),box-shadow .3s; display:flex; align-items:center; justify-content:center; gap:.55rem; }
.form-submit:hover { transform:translateY(-2px); box-shadow:0 10px 35px #7c6ef035; }
.form-submit:active { transform:scale(.98); }

/* =============================================
   TOAST NOTIFICATIONS
============================================= */
#toast-container { position:fixed; bottom:2rem; left:50%; transform:translateX(-50%); z-index:9000; display:flex; flex-direction:column; gap:.6rem; align-items:center; pointer-events:none; }
.toast { display:flex; align-items:center; gap:.7rem; background:var(--bg3); border:1px solid var(--border2); border-radius:12px; padding:.8rem 1.4rem; font-size:.85rem; color:var(--text); box-shadow:0 8px 32px rgba(0,0,0,.5); animation:toastIn .4s cubic-bezier(.16,1,.3,1) forwards; backdrop-filter:blur(12px); min-width:280px; max-width:480px; pointer-events:auto; }
.toast.success { border-color:#22c55e40; }
.toast.success .toast-icon { color:#22c55e; }
.toast.error { border-color:#ef444440; }
.toast.error .toast-icon { color:#ef4444; }
.toast.info { border-color:#7c6ef040; }
.toast.info .toast-icon { color:var(--accent2); }
.toast-icon { font-size:1.1rem; flex-shrink:0; }
.toast-msg { flex:1; line-height:1.4; }
.toast-link { color:#c4b8ff; text-decoration:underline; text-underline-offset:2px; font-weight:600; white-space:nowrap; }
.toast-link:hover { color:#ffffff; }
.toast-close { background:none; border:none; color:var(--muted); cursor:pointer; font-size:1rem; padding:0; line-height:1; flex-shrink:0; }
.toast-close:hover { color:var(--text); }
@keyframes toastIn { from{opacity:0;transform:translateY(16px) scale(.95)} to{opacity:1;transform:none} }
.toast.removing { animation:toastOut .3s ease forwards; }
@keyframes toastOut { to{opacity:0;transform:translateY(10px) scale(.95)} }

/* =============================================
   PAYMENT MODAL
============================================= */
.payment-modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.75); backdrop-filter:blur(8px); z-index:5000; display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity .3s; }
.payment-modal-overlay.open { opacity:1; pointer-events:all; }
.payment-modal { background:var(--bg2); border:1px solid var(--border2); border-radius:20px; padding:2.4rem; max-width:440px; width:90%; position:relative; transform:translateY(20px) scale(.97); transition:transform .35s cubic-bezier(.16,1,.3,1); }
.payment-modal-overlay.open .payment-modal { transform:none; }
.payment-modal h3 { font-family:'Syne',sans-serif; font-size:1.3rem; font-weight:700; margin-bottom:.4rem; }
.payment-modal .modal-sub { font-size:.83rem; color:var(--muted); margin-bottom:1.8rem; }
.payment-modal .form-group { margin-bottom:1rem; }
.payment-modal .modal-price { font-family:'Syne',sans-serif; font-size:1.8rem; font-weight:800; color:var(--accent2); margin:.8rem 0 1.6rem; }
.modal-actions { display:flex; gap:.7rem; }
.btn-modal-pay { flex:1; background:linear-gradient(135deg,var(--accent),#5f52d4); color:#fff; border:none; border-radius:10px; padding:.85rem; font-size:.9rem; font-weight:600; cursor:pointer; font-family:'Plus Jakarta Sans',sans-serif; transition:transform .3s var(--spring),box-shadow .25s; }
.btn-modal-pay:hover { transform:translateY(-2px); box-shadow:0 8px 28px #7c6ef040; }
.btn-modal-cancel { padding:.85rem 1.2rem; background:var(--bg3); border:1px solid var(--border2); color:var(--muted); border-radius:10px; font-size:.85rem; cursor:pointer; font-family:'Plus Jakarta Sans',sans-serif; transition:border-color .2s,color .2s; }
.btn-modal-cancel:hover { border-color:var(--border2); color:var(--text); }
.modal-close-x { position:absolute; top:1.2rem; right:1.4rem; background:none; border:none; color:var(--muted); font-size:1.3rem; cursor:pointer; transition:color .2s; line-height:1; }
.modal-close-x:hover { color:var(--text); }

/* =============================================
   WA FLOAT
============================================= */
.wa-float { position:fixed; bottom:2.2rem; right:2.2rem; z-index:200; background:var(--green); color:#fff; width:56px; height:56px; border-radius:50%; display:flex; align-items:center; justify-content:center; text-decoration:none; box-shadow:0 4px 24px rgba(34,197,94,.35),0 0 0 0 rgba(34,197,94,.3); transition:transform .35s var(--spring),box-shadow .3s; animation:waFloat 3.5s ease-in-out infinite,waPulse 3.5s ease-in-out infinite; }
.wa-float:hover { transform:scale(1.14) !important; box-shadow:0 8px 36px rgba(34,197,94,.5) !important; animation:none; }
@keyframes waFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }
@keyframes waPulse { 0%,100%{box-shadow:0 4px 24px rgba(34,197,94,.35),0 0 0 0 rgba(34,197,94,.3)} 50%{box-shadow:0 4px 24px rgba(34,197,94,.35),0 0 0 14px rgba(34,197,94,0)} }

/* =============================================
   FOOTER
============================================= */
.site-footer { margin-top:4rem; padding:4rem 2.5rem 2rem; border-top:1px solid var(--border); background:radial-gradient(circle at 8% 8%,#7c6ef015 0%,transparent 45%),var(--bg); }
.footer-container { max-width:1120px; margin:auto; display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:2.5rem; }
.footer-col h4 { font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted2); margin-bottom:1.1rem; font-family:'Syne',sans-serif; }
.footer-col ul { list-style:none; padding:0; display:flex; flex-direction:column; gap:.75rem; }
.footer-col a { text-decoration:none; font-size:.85rem; color:var(--muted); transition:all .2s; }
.footer-col a:hover { color:white; transform:translateX(4px); display:inline-block; }
.footer-brand p { font-size:.85rem; color:var(--muted); line-height:1.75; max-width:360px; margin:1rem 0; font-weight:400; }
.footer-tag { font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); background:#7c6ef012; border:1px solid #7c6ef025; padding:.28rem .75rem; border-radius:999px; font-family:'Syne',sans-serif; }
.brand-name { font-family:'Syne',sans-serif; font-size:1.25rem; font-weight:700; margin-top:.7rem; letter-spacing:-.02em; }
.footer-location { display:block; margin-top:.9rem; font-size:.74rem; color:var(--muted2); }
.footer-cta { display:inline-block; margin-top:.7rem; padding:.55rem 1rem; font-size:.82rem; color:#fff !important; text-decoration:none; background:linear-gradient(135deg,var(--accent),#6a5df0); border-radius:10px; border:1px solid #8b7eff; transition:transform .35s var(--spring),box-shadow .3s; }
.footer-cta:hover { transform:translateY(-2px); box-shadow:0 8px 24px #7c6ef040; }
.footer-bottom { max-width:1120px; margin:2.5rem auto 0; padding-top:1.2rem; border-top:1px solid var(--border); display:flex; justify-content:space-between; flex-wrap:wrap; font-size:.74rem; color:var(--muted2); }
.footer-mini-links { display:flex; gap:.7rem; }
.footer-mini-links a { text-decoration:none; color:var(--muted); transition:color .2s; }
.footer-mini-links a:hover { color:white; }

/* =============================================
   SPOTLIGHT
============================================= */
.spotlight-header { position:relative; display:inline-block; }
.spotlight-header::after { content:attr(data-text); position:absolute; left:0; top:0; background:linear-gradient(90deg,var(--accent2),var(--accent3),var(--accent2)); background-size:200%; -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; opacity:0; transition:opacity .4s; animation:gradMove 4s linear infinite paused; }
.spotlight-header:hover::after { opacity:1; animation-play-state:running; }
@keyframes gradMove { from{background-position:0% 50%} to{background-position:200% 50%} }

/* =============================================
   SCROLLBAR
============================================= */
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--muted2); border-radius:2px; }
::-webkit-scrollbar-thumb:hover { background:var(--accent); }

/* =============================================
   PAGE FLASH
============================================= */
#page-flash { position:fixed; inset:0; background:var(--accent); z-index:99999; pointer-events:none; opacity:0; animation:flashIn .6s cubic-bezier(.16,1,.3,1) forwards; }
@keyframes flashIn { 0%{opacity:.25;clip-path:inset(0 100% 0 0)} 100%{opacity:0;clip-path:inset(0 0% 0 0)} }

/* =============================================
   RESPONSIVE
============================================= */
@media (max-width:768px) {
   .hero { padding:5.5rem 1.2rem 3rem; }
   .hero h1 { font-size:clamp(2.55rem,14vw,4.2rem); letter-spacing:-.01em; line-height:1.08; margin-bottom:1.3rem; }
   .hero-badge { max-width:100%; letter-spacing:.07em; margin-bottom:1.6rem; }
  .footer-container { grid-template-columns:1fr; gap:1.6rem; }
  .footer-bottom { flex-direction:column; align-items:flex-start; gap:.7rem; }
  .bento-card.large,.bento-card.medium,.bento-card.small { grid-column:span 12; }
  .about-grid,.contact-grid { grid-template-columns:1fr; }
  .exp-item { grid-template-columns:1fr; gap:.5rem; }
  .nav-links { display:none; }
  body { cursor:auto; }
  #cursor,#cursor-ring { display:none; }
  .form-row { grid-template-columns:1fr; }
  .modal-actions { flex-direction:column; }
}
@media (prefers-reduced-motion:reduce) {
  *,*::before,*::after { animation-duration:.001ms !important; transition-duration:.001ms !important; }
}
