/* ================================================================
   DESIGN TOKENS
================================================================ */
:root {
  --bg:        #030710;
  --bg2:       #05101f;
  --surface:   rgba(255,255,255,0.038);
  --surface-h: rgba(255,255,255,0.065);
  --border:    rgba(255,255,255,0.08);
  --border-a:  rgba(56,189,248,0.32);
  --ink:       #ddeeff;
  --dim:       #748aab;
  --faint:     #3c4f6a;
  --accent:    #38bdf8;
  --indigo:    #818cf8;
  --gold:      #fbbf24;
  --emerald:   #34d399;
  --R:         14px;
  --ease:      cubic-bezier(.4,0,.2,1);
  --T:         .3s;
  --font:      'Roboto', sans-serif;
  --mono:      'Roboto Mono', monospace;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html, body { overflow-x:hidden; max-width:100%; }
html { font-size:16px; scroll-behavior:smooth; }

body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--ink);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

::selection { background:rgba(56,189,248,.22); color:#fff; }
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:var(--bg2); }
::-webkit-scrollbar-thumb { background:var(--indigo); border-radius:4px; }
a { color:inherit; text-decoration:none; }
img { display:block; max-width:100%; }

/* ================================================================
   PARTICLE CANVAS
================================================================ */
#pc {
  position:fixed; inset:0; z-index:0; pointer-events:none;
}
body::before {
  content:''; position:fixed; inset:0; z-index:1; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
  opacity:.38;
}

/* ================================================================
   FULLPAGE OVERRIDES
================================================================ */
#fullpage { position:relative; z-index:2; }
.fp-overflow { display:flex !important; align-items:center !important; min-height:100%; }
.section { overflow:hidden; }

/* Side dots */
#fp-nav { z-index:9998 !important; }
#fp-nav.fp-right { right:16px !important; }
#fp-nav ul li a span { background:var(--faint) !important; width:6px !important; height:6px !important; margin:-3px 0 0 -3px !important; }
#fp-nav ul li a.active span { background:var(--accent) !important; box-shadow:0 0 8px var(--accent) !important; width:8px !important; height:8px !important; margin:-4px 0 0 -4px !important; }

/* ================================================================
   SECTION WRAPPER (inside container)
================================================================ */
.sec-pad { padding-top:84px; padding-bottom:24px; width:100%; }

/* ================================================================
   NAVBAR
================================================================ */
#navbar {
  position:fixed; top:0; left:0; right:0; z-index:9999;
  padding:.9rem 0;
  transition: background var(--T) var(--ease), padding var(--T) var(--ease);
}
#navbar.stuck {
  background:rgba(3,7,16,.93);
  backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);
  padding:.55rem 0;
}

.brand-link { display:flex; align-items:center; gap:.6rem; }
.brand-avatar {
  width:34px; height:34px; border-radius:50%; overflow:hidden;
  border:2px solid rgba(56,189,248,.38); flex-shrink:0;
}
.brand-avatar img { width:100%; height:100%; object-fit:cover; }
.brand-text { font-family:var(--font); font-weight:700; font-size:1.05rem; }
.brand-text .mr  { color:var(--dim); font-weight:300; font-size:.72em; }
.brand-text .dot { color:var(--accent); }
.brand-text .jn  { color:var(--accent); font-style:italic; font-weight:900; }

.navbar-nav .nav-link {
  font-size:.79rem; font-weight:500; letter-spacing:.07em; text-transform:uppercase;
  color:var(--dim) !important; padding:.4rem .65rem !important;
  position:relative; transition:color var(--T);
}
.navbar-nav .nav-link::after {
  content:''; position:absolute; bottom:-1px; left:.65rem; right:.65rem;
  height:1px; background:var(--accent);
  transform:scaleX(0); transform-origin:center; transition:transform var(--T) var(--ease);
}
.navbar-nav .nav-link:hover,
.navbar-nav .nav-link.active { color:var(--ink) !important; }
.navbar-nav .nav-link:hover::after,
.navbar-nav .nav-link.active::after { transform:scaleX(1); }

.btn-hire {
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.42rem 1.15rem; border-radius:50px; border:none; cursor:pointer;
  background:linear-gradient(115deg, var(--accent), var(--indigo));
  color:#000; font-family:var(--font); font-size:.79rem; font-weight:700;
  transition:all var(--T); box-shadow:0 4px 18px rgba(56,189,248,.28);
}
.btn-hire:hover { transform:translateY(-1px); box-shadow:0 8px 28px rgba(56,189,248,.44); }

/* ================================================================
   GLOBAL BUTTONS
================================================================ */
.btn-p {
  display:inline-flex; align-items:center; gap:.44rem;
  padding:.68rem 1.65rem; border-radius:50px; border:none; cursor:pointer;
  background:linear-gradient(115deg, var(--accent), var(--indigo));
  color:#000; font-family:var(--font); font-size:.86rem; font-weight:700;
  transition:all var(--T); box-shadow:0 5px 22px rgba(56,189,248,.25);
}
.btn-p:hover { transform:translateY(-2px); box-shadow:0 10px 30px rgba(56,189,248,.42); color:#000; }

.btn-o {
  display:inline-flex; align-items:center; gap:.44rem;
  padding:.68rem 1.65rem; border-radius:50px; cursor:pointer;
  background:transparent; border:1px solid var(--border);
  color:var(--ink); font-family:var(--font); font-size:.86rem; font-weight:500;
  transition:all var(--T);
}
.btn-o:hover { border-color:var(--accent); color:var(--accent); box-shadow:0 0 18px rgba(56,189,248,.1); transform:translateY(-1px); }

/* ================================================================
   GLASS CARD
================================================================ */
.gc {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--R);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  transition:all var(--T) var(--ease);
}
.gc:hover {
  background:var(--surface-h);
  border-color:var(--border-a);
  transform:translateY(-3px);
  box-shadow:0 18px 44px rgba(0,0,0,.32), 0 0 28px rgba(56,189,248,.07);
}

/* ================================================================
   SECTION LABELS & HEADINGS
================================================================ */
.stag {
  display:inline-flex; align-items:center; gap:.48rem;
  font-family:var(--mono); font-size:.67rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--accent); margin-bottom:.65rem;
}
.stag::before { content:''; width:20px; height:1px; background:var(--accent); flex-shrink:0; }

.shd {
  font-family:var(--font); font-weight:900;
  font-size:clamp(2rem,4vw,3.6rem);
  line-height:1; letter-spacing:-.03em; color:var(--ink);
}
.shd .g {
  background:linear-gradient(110deg, var(--accent), var(--indigo));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

/* ================================================================
   HERO SECTION — SCI-FI HUD (SVG textures + particles + terminal)
================================================================ */
#s1 { position:relative; background:#01080d; overflow:hidden; }

/* ── Layer 1: Animated square grid ── */
.hud-grid {
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(0,200,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,200,255,.035) 1px, transparent 1px);
  background-size:44px 44px;
  animation:gridMove 20s linear infinite;
}
@keyframes gridMove{ 0%{background-position:0 0;} 100%{background-position:44px 44px;} }

/* ── Layer 2: Circuit SVG pattern ── */
.hud-circuit {
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cpath d='M0 80 L40 80 L40 40 L80 40' fill='none' stroke='rgba(0,200,255,0.055)' stroke-width='0.8'/%3E%3Cpath d='M160 80 L120 80 L120 120 L80 120' fill='none' stroke='rgba(0,200,255,0.055)' stroke-width='0.8'/%3E%3Cpath d='M80 0 L80 40' fill='none' stroke='rgba(0,200,255,0.04)' stroke-width='0.8'/%3E%3Cpath d='M80 120 L80 160' fill='none' stroke='rgba(0,200,255,0.04)' stroke-width='0.8'/%3E%3Ccircle cx='80' cy='40' r='3' fill='none' stroke='rgba(0,200,255,0.12)' stroke-width='0.8'/%3E%3Ccircle cx='80' cy='120' r='3' fill='none' stroke='rgba(0,200,255,0.12)' stroke-width='0.8'/%3E%3Ccircle cx='40' cy='80' r='2' fill='rgba(0,200,255,0.08)'/%3E%3Ccircle cx='120' cy='80' r='2' fill='rgba(0,200,255,0.08)'/%3E%3C/svg%3E");
  background-size:160px 160px;
  animation:circuitDrift 35s linear infinite reverse;
}
@keyframes circuitDrift{ 0%{background-position:0 0;} 100%{background-position:160px 160px;} }

/* ── Layer 3: Diagonal slash lines ── */
.hud-slash {
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80'%3E%3Cline x1='0' y1='80' x2='80' y2='0' stroke='rgba(0,160,200,0.025)' stroke-width='0.6'/%3E%3C/svg%3E");
  background-size:80px 80px;
  animation:slashDrift 28s linear infinite;
}
@keyframes slashDrift{ 0%{background-position:0 0;} 100%{background-position:80px -80px;} }

/* ── Layer 4: Glow orbs ── */
.hud-orbs {
  position:absolute; inset:-20%; z-index:0; pointer-events:none;
  background:
    radial-gradient(ellipse 52% 42% at 75% 48%, rgba(0,200,255,.09) 0%, transparent 65%),
    radial-gradient(ellipse 38% 34% at 12% 55%, rgba(0,150,200,.06) 0%, transparent 60%),
    radial-gradient(ellipse 30% 28% at 50% 90%, rgba(0,255,180,.04) 0%, transparent 58%);
  animation:orbDrift 16s ease-in-out infinite alternate;
}
@keyframes orbDrift{ 0%{transform:scale(1) translate(0,0);} 100%{transform:scale(1.06) translate(-1%,-2%);} }

/* ── Layer 5: Scanlines ── */
.hud-scan {
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.03) 2px,rgba(0,0,0,.03) 4px);
}

/* ── Layer 6: Moving beam ── */
.hud-beam {
  position:absolute; left:0; right:0; z-index:0; pointer-events:none;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(0,200,255,.5), transparent);
  box-shadow:0 0 12px rgba(0,200,255,.3);
  animation:beamSweep 6s linear infinite;
}
@keyframes beamSweep{ 0%{top:-2px;opacity:0;} 4%{opacity:1;} 96%{opacity:.5;} 100%{top:100%;opacity:0;} }

/* ── Layer 7: HUD corner overlays (CSS) ── */
.hud-corners { position:absolute; inset:0; z-index:0; pointer-events:none; }
.hud-corners::before {
  content:''; position:absolute; top:18px; left:18px; width:70px; height:70px;
  border-top:1px solid rgba(0,200,255,.28); border-left:1px solid rgba(0,200,255,.28);
}
.hud-corners::after {
  content:''; position:absolute; bottom:18px; right:18px; width:70px; height:70px;
  border-bottom:1px solid rgba(0,200,255,.18); border-right:1px solid rgba(0,200,255,.18);
}

/* Particle canvas — hero-scoped */
#hpc { position:absolute; inset:0; z-index:1; pointer-events:none; }

/* ── Content above everything ── */
#s1 .sec-pad { position:relative; z-index:2; }
.scroll-arrow { z-index:2; }

/* ── Hero badge — HUD bracket style ── */
.hero-badge {
  display:inline-flex; align-items:center; gap:.5rem;
  background:rgba(0,200,255,.04);
  border:1px solid rgba(0,200,255,.2);
  border-radius:2px;
  padding:.3rem 1rem;
  font-family:var(--mono); font-size:.6rem; letter-spacing:.2em; color:rgba(0,200,255,.8);
  margin-bottom:1.5rem;
  position:relative; overflow:hidden;
}
.hero-badge::before { content:'['; margin-right:.2rem; opacity:.5; }
.hero-badge::after  { content:']'; margin-left:.2rem; opacity:.5; }
.bdot {
  width:6px; height:6px; border-radius:50%;
  background:#00c8ff; box-shadow:0 0 8px #00c8ff;
  animation:bdot 1.4s ease-in-out infinite;
}
@keyframes bdot{0%,100%{opacity:1;}50%{opacity:.15;}}

/* ── Heading — terminal monospace ── */
.hero-h {
  font-family:var(--mono);
  font-weight:700;
  font-size:clamp(2.3rem,4.8vw,5.4rem);
  line-height:.95; letter-spacing:-.025em; margin-bottom:1.1rem;
}
.hero-h .line1 {
  display:block;
  color:rgba(180,220,240,.6);
  font-size:.42em; font-weight:400; letter-spacing:.07em;
  margin-bottom:.5rem; font-family:var(--mono);
}
.hero-h .line2 {
  display:block;
  background:linear-gradient(100deg,#00c8ff,#38bdf8,#00ffcc,#00c8ff);
  background-size:250% auto;
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  animation:hudNameFlow 4s linear infinite;
}
@keyframes hudNameFlow{ 0%{background-position:0% center;} 100%{background-position:250% center;} }

/* Blinking cursor */
.hero-cursor {
  display:inline-block; width:3px; height:.85em;
  background:#00c8ff; margin-left:5px; vertical-align:middle;
  animation:cursorBlink 1s step-end infinite;
}
@keyframes cursorBlink{0%,100%{opacity:1;}50%{opacity:0;}}

/* ── HUD data rows ── */
.hud-rows { margin:.6rem 0 1.4rem; display:flex; flex-direction:column; gap:.42rem; }
.hud-row {
  display:flex; align-items:center; gap:.7rem;
  font-family:var(--mono); font-size:.7rem; color:rgba(0,180,220,.45);
}
.hud-row::before { content:'›'; color:#00c8ff; font-size:.85rem; }
.hud-row span { color:rgba(0,200,255,.75); }

.hero-sub {
  font-family:var(--mono); font-size:.78rem;
  color:rgba(0,150,180,.65); line-height:1.85;
  margin-bottom:2rem;
}

/* ── CTAs ── */
.hero-ctas { display:flex; flex-wrap:wrap; gap:.7rem; margin-bottom:2.2rem; }

.btn-p {
  display:inline-flex; align-items:center; gap:.45rem;
  padding:.65rem 1.55rem; border-radius:2px;
  border:1px solid #00c8ff; cursor:pointer;
  background:rgba(0,200,255,.08);
  color:#00c8ff; font-family:var(--mono); font-size:.78rem; font-weight:700;
  letter-spacing:.06em; transition:all .25s;
  box-shadow:0 0 18px rgba(0,200,255,.12), inset 0 0 18px rgba(0,200,255,.03);
  position:relative; overflow:hidden;
}
.btn-p::before {
  content:''; position:absolute; top:0; left:-80%; width:40%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(0,200,255,.2),transparent);
  animation:btnShine 3s ease-in-out infinite;
}
@keyframes btnShine{0%{left:-80%;}60%{left:140%;}100%{left:140%;}}
.btn-p:hover{ background:rgba(0,200,255,.16); box-shadow:0 0 30px rgba(0,200,255,.28); transform:translateY(-1px); color:#00c8ff; }

.btn-o {
  display:inline-flex; align-items:center; gap:.45rem;
  padding:.65rem 1.4rem; border-radius:2px; cursor:pointer;
  background:transparent; border:1px solid rgba(0,200,255,.18);
  color:rgba(0,200,255,.6); font-family:var(--mono); font-size:.78rem;
  transition:all .25s;
}
.btn-o:hover{ border-color:rgba(0,200,255,.45); color:#00c8ff; box-shadow:0 0 14px rgba(0,200,255,.1); }

/* ── Stats ── */
.hero-stats { display:flex; gap:.7rem; flex-wrap:wrap; }
.hero-stat-card {
  display:flex; flex-direction:column;
  background:rgba(0,200,255,.03);
  border:1px solid rgba(0,200,255,.1);
  border-top:2px solid rgba(0,200,255,.35);
  padding:.6rem 1rem;
  position:relative; overflow:hidden; min-width:82px;
  transition:border-color .3s, transform .3s;
}
.hero-stat-card:hover{ border-color:rgba(0,200,255,.3); transform:translateY(-2px); }
.sv {
  font-family:var(--mono); font-weight:700; font-size:1.9rem; line-height:1;
  color:#00c8ff; text-shadow:0 0 18px rgba(0,200,255,.45);
}
.sk {
  font-family:var(--mono); font-size:.52rem;
  color:rgba(0,200,255,.35); letter-spacing:.14em;
  text-transform:uppercase; margin-top:4px;
}

/* ── RIGHT — HUD initials avatar ── */
.orbit-box { position:relative; width:340px; height:340px; display:flex; align-items:center; justify-content:center; }

/* Rotating scan ring */
.oring {
  position:absolute; inset:0; border-radius:50%;
  border:1px solid rgba(0,200,255,.12);
  animation:ospin 22s linear infinite;
}
.oring.r2{ inset:-36px; border-color:rgba(0,200,255,.07); border-style:dashed; animation-duration:32s; animation-direction:reverse; }
.oring.r3{ inset:-70px; border-color:rgba(0,255,180,.05); border-style:dotted; animation-duration:48s; }
@keyframes ospin{to{transform:rotate(360deg);}}

.onode{ position:absolute; top:0; left:50%; transform:translate(-50%,-50%); border-radius:50%; }
.n1{ width:10px; height:10px; background:#00c8ff; box-shadow:0 0 12px #00c8ff,0 0 28px rgba(0,200,255,.4); }
.n2{ width:8px; height:8px; background:rgba(0,200,255,.7); box-shadow:0 0 10px rgba(0,200,255,.5); }
.n3{ width:6px; height:6px; background:#00ffb4; box-shadow:0 0 10px #00ffb4; }

/* HUD corner brackets on orbit box */
.orbit-corner{ position:absolute; width:22px; height:22px; border-color:rgba(0,200,255,.32); border-style:solid; border-width:0; }
.oc-tl{ top:0; left:0; border-top-width:2px; border-left-width:2px; }
.oc-tr{ top:0; right:0; border-top-width:2px; border-right-width:2px; }
.oc-bl{ bottom:0; left:0; border-bottom-width:2px; border-left-width:2px; }
.oc-br{ bottom:0; right:0; border-bottom-width:2px; border-right-width:2px; }

/* Initials card */
.avatar-circle {
  width:200px; height:200px; border-radius:4px;
  background:linear-gradient(160deg,#010d14,#020c12);
  border:1px solid rgba(0,200,255,.2);
  border-top:2px solid rgba(0,200,255,.5);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.5rem;
  position:relative; overflow:hidden;
  box-shadow:0 0 40px rgba(0,200,255,.12), 0 0 80px rgba(0,200,255,.06), inset 0 0 30px rgba(0,0,0,.4);
  animation:icardBreath 5s ease-in-out infinite;
}
@keyframes icardBreath{
  0%,100%{ box-shadow:0 0 40px rgba(0,200,255,.12),inset 0 0 30px rgba(0,0,0,.4); }
  50%    { box-shadow:0 0 60px rgba(0,200,255,.22),0 0 100px rgba(0,200,255,.08),inset 0 0 30px rgba(0,0,0,.4); }
}
/* Terminal label inside card */
.avatar-circle::before {
  content:'// IDENTITY'; position:absolute; top:8px; left:10px;
  font-family:var(--mono); font-size:.42rem; color:rgba(0,200,255,.28); letter-spacing:.12em;
}
/* Scan beam on card */
.card-scan {
  position:absolute; left:0; right:0; height:2px;
  background:linear-gradient(90deg,transparent,rgba(0,200,255,.5),transparent);
  box-shadow:0 0 8px rgba(0,200,255,.35);
  animation:cardScanMove 2.8s linear infinite;
}
@keyframes cardScanMove{ 0%{top:0;opacity:0;} 5%{opacity:1;} 95%{opacity:.6;} 100%{top:100%;opacity:0;} }

/* Bracket corners inside card */
.card-brk{ position:absolute; width:14px; height:14px; border-color:rgba(0,200,255,.3); border-style:solid; border-width:0; }
.cb-tl{ top:4px; left:4px; border-top-width:1px; border-left-width:1px; }
.cb-tr{ top:4px; right:4px; border-top-width:1px; border-right-width:1px; }
.cb-bl{ bottom:4px; left:4px; border-bottom-width:1px; border-left-width:1px; }
.cb-br{ bottom:4px; right:4px; border-bottom-width:1px; border-right-width:1px; }

.initials-text {
  font-family:var(--mono); font-weight:700; font-size:4rem; line-height:1;
  letter-spacing:-.04em;
  color:#00c8ff; text-shadow:0 0 30px rgba(0,200,255,.55),0 0 60px rgba(0,200,255,.2);
}
.initials-sub {
  font-family:var(--mono); font-size:.46rem; letter-spacing:.2em;
  color:rgba(0,200,255,.28); text-transform:uppercase;
}

/* Floating data chips */
.chips-col {
  position:absolute; right:-72px; top:50%; transform:translateY(-50%);
  display:flex; flex-direction:column; gap:.42rem;
}
.chip {
  background:rgba(0,10,18,.9);
  border:1px solid rgba(0,200,255,.1);
  border-left:2px solid rgba(0,200,255,.3);
  padding:.22rem .72rem;
  font-family:var(--mono); font-size:.57rem; white-space:nowrap;
  color:rgba(0,200,255,.65);
  animation:chipFloat 4s ease-in-out infinite;
  position:relative; overflow:hidden;
}
.chip::after {
  content:''; position:absolute; top:0; left:-60%; width:35%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(0,200,255,.08),transparent);
  animation:chipShine 4.5s ease-in-out infinite;
}
@keyframes chipShine{0%{left:-60%;}60%{left:120%;}100%{left:120%;}}
.chip:nth-child(1){ animation-delay:0s; }
.chip:nth-child(2){ animation-delay:.7s; color:rgba(0,200,255,.55); }
.chip:nth-child(3){ animation-delay:1.4s; color:rgba(255,200,0,.5); }
.chip:nth-child(4){ animation-delay:2.1s; color:rgba(0,255,180,.5); }
@keyframes chipFloat{0%,100%{opacity:.5;transform:translateX(0);}50%{opacity:1;transform:translateX(-7px);}}

/* Online status dot */
.avatar-status {
  position:absolute; bottom:66px; right:58px; z-index:3;
  width:12px; height:12px; border-radius:50%;
  background:#00ffb4; border:2px solid #01080d;
  box-shadow:0 0 10px #00ffb4;
  animation:bdot 2.5s ease-in-out infinite;
}

/* Scroll arrow */
.scroll-arrow {
  position:absolute; bottom:1.8rem; left:50%; transform:translateX(-50%); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:.45rem;
  font-family:var(--mono); font-size:.62rem; letter-spacing:.18em; color:rgba(0,200,255,.6);
  cursor:pointer; user-select:none;
  animation:sarr 1.8s cubic-bezier(.4,0,.2,1) infinite;
  transition:opacity .2s;
}
.scroll-arrow:hover { opacity:.75; }
.scroll-arrow .sarr-icon {
  width:38px; height:38px; border-radius:50%;
  border:1.5px solid rgba(0,200,255,.45);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 14px rgba(0,200,255,.18), inset 0 0 10px rgba(0,200,255,.06);
  background:rgba(0,200,255,.06);
}
.scroll-arrow i { color:rgba(0,200,255,.9); font-size:1rem; }
@keyframes sarr{
  0%  { transform:translateX(-50%) translateY(0);   opacity:.65; }
  50% { transform:translateX(-50%) translateY(11px); opacity:1;  }
  100%{ transform:translateX(-50%) translateY(0);   opacity:.65; }
}

/* ── Hero entrance animations ── */
@keyframes fUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes fIn {from{opacity:0}to{opacity:1}}
.au1{animation:fUp .8s .04s cubic-bezier(.22,1,.36,1) both;}
.au2{animation:fUp .8s .14s cubic-bezier(.22,1,.36,1) both;}
.au3{animation:fUp .8s .24s cubic-bezier(.22,1,.36,1) both;}
.au4{animation:fUp .8s .33s cubic-bezier(.22,1,.36,1) both;}
.au5{animation:fUp .8s .43s cubic-bezier(.22,1,.36,1) both;}
.au6{animation:fUp .8s .53s cubic-bezier(.22,1,.36,1) both;}
.af {animation:fIn 1.1s .5s ease both;}

/* ================================================================
   ABOUT
================================================================ */
#s2 { background:linear-gradient(180deg,var(--bg),var(--bg2),var(--bg)); }

.photo-frame { border-radius:18px; overflow:hidden; border:1px solid var(--border); box-shadow:0 28px 65px rgba(0,0,0,.48); }
.photo-frame img { width:100%; height:370px; object-fit:cover; object-position:top; }
.exp-badge2 {
  position:absolute; bottom:-14px; right:-14px;
  background:linear-gradient(135deg,var(--accent),var(--indigo));
  border-radius:14px; padding:.85rem 1.1rem; text-align:center;
  box-shadow:0 10px 32px rgba(56,189,248,.28);
}
.eb-num { font-weight:900; font-size:1.8rem; color:#000; line-height:1; }
.eb-lbl { font-size:.58rem; color:rgba(0,0,0,.65); text-transform:uppercase; letter-spacing:.06em; }

.atags { display:flex; flex-wrap:wrap; gap:.42rem; margin-bottom:1.1rem; }
.atag {
  display:inline-flex; align-items:center; gap:.3rem;
  background:rgba(56,189,248,.06); border:1px solid rgba(56,189,248,.13);
  border-radius:50px; padding:.22rem .75rem; font-size:.73rem; color:var(--accent);
}
.ap { color:var(--dim); font-size:.9rem; line-height:1.8; margin-bottom:.9rem; font-weight:300; }
.ap strong { color:var(--ink); font-weight:700; }

.info-grid2 { display:grid; grid-template-columns:1fr 1fr; gap:.6rem; margin:1.1rem 0; }
.ipill { padding:.62rem .85rem; border-radius:11px; }
.ipill .lbl { font-size:.6rem; color:var(--faint); text-transform:uppercase; letter-spacing:.08em; }
.ipill .val { font-size:.83rem; color:var(--ink); font-weight:500; margin-top:.12rem; }
.ipill .val a { color:var(--accent); }

/* ================================================================
   SKILLS — COMPACT SCIENTIFIC SPLIT LAYOUT
================================================================ */
#s3 {
  background: var(--bg);
  position: relative;
  overflow: hidden;
}
/* subtle base grid beneath canvas */
#s3::before {
  content:''; position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(56,189,248,.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(56,189,248,.012) 1px, transparent 1px);
  background-size:36px 36px;
}
/* data-flow canvas layer */
#s3bg {
  position:absolute; inset:0; z-index:0; pointer-events:none;
  width:100%; height:100%;
}
#s3 .container { position:relative; z-index:1; }

/* ================================================================
   FP WATERMARK — ALWAYS HIDDEN
================================================================ */
.fp-watermark,
.fp-watermark a,
.fp-watermark img,
.fp-watermark span,
[class*="fp-watermark"],
#fp-license { 
  display:none !important; 
  visibility:hidden !important; 
  opacity:0 !important; 
  pointer-events:none !important;
  width:0 !important; height:0 !important;
  position:absolute !important; 
  top:-9999px !important; left:-9999px !important;
}

/* Section header row */
.skills-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .6rem;
  margin-bottom: 1rem;
}
.skills-header-sub {
  font-family: var(--mono);
  font-size: .62rem;
  color: rgba(56,189,248,.45);
  letter-spacing: .08em;
  white-space: nowrap;
}

/* ── Two-column master layout ── */
.skills-master {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  align-items: start;
}
@media(max-width:767px){ .skills-master{ grid-template-columns:1fr; } }

/* ── LEFT: skill grid ── */
.skills-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: .55rem;
}
@media(max-width:991px){ .skills-grid{ grid-template-columns:repeat(4,1fr); } }

.skill-box {
  padding: .65rem .4rem .55rem;
  text-align: center;
  position: relative;
  background: rgba(0,8,18,.65);
  border: 1px solid rgba(56,189,248,.09);
  border-top: 2px solid rgba(56,189,248,.28);
  border-radius: 4px;
  backdrop-filter: blur(10px);
  transition: all .28s;
  overflow: hidden;
  cursor: default;
}
.skill-box::before {
  content: attr(data-id);
  position: absolute; top: 4px; left: 5px;
  font-family: var(--mono); font-size: .32rem;
  color: rgba(56,189,248,.2); letter-spacing: .08em;
}
.skill-box::after {
  content: '';
  position: absolute; bottom: 0; right: 0;
  width: 8px; height: 8px;
  border-right: 1px solid rgba(56,189,248,.18);
  border-bottom: 1px solid rgba(56,189,248,.18);
}
.skill-box:hover {
  border-top-color: rgba(56,189,248,.7);
  transform: translateY(-3px);
  box-shadow: 0 8px 22px rgba(0,0,0,.35), 0 0 14px rgba(56,189,248,.06);
}

/* SVG ring — smaller */
.skill-ring-wrap {
  position: relative;
  width: 52px; height: 52px;
  margin: 0 auto .38rem;
}
.skill-ring-wrap svg {
  transform: rotate(-90deg);
  width: 52px; height: 52px;
}
.ring-bg  { fill:none; stroke:rgba(56,189,248,.07); stroke-width:2.5; }
.ring-fill {
  fill: none; stroke-width: 2.5; stroke-linecap: round;
  stroke-dasharray: 132.0;   /* 2π × r=21 */
  stroke-dashoffset: 132.0;
  transition: stroke-dashoffset 1.25s cubic-bezier(.22,1,.36,1);
}
.ring-fill.cyan   { stroke: url(#gradCyan); }
.ring-fill.indigo { stroke: url(#gradIndigo); }
.ring-fill.gold   { stroke: url(#gradGold); }
.ring-fill.green  { stroke: url(#gradGreen); }

.ring-icon {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.05rem;
}
.snm {
  font-family: var(--mono); font-size: .52rem; font-weight: 500;
  color: rgba(200,225,255,.75); letter-spacing: .07em;
  text-transform: uppercase; margin-bottom: .18rem; line-height: 1.2;
}
.skill-pct {
  font-family: var(--mono); font-size: .5rem;
  color: rgba(56,189,248,.55); letter-spacing: .04em;
}

/* ── RIGHT: code panel ── */
.skills-right {
  display: flex;
  flex-direction: column;
  gap: .7rem;
  height: 100%;
}

/* Terminal window */
.skills-terminal {
  background: rgba(0,6,14,.82);
  border: 1px solid rgba(56,189,248,.12);
  border-radius: 6px;
  overflow: hidden;
  flex: 1;
}
.skills-terminal-bar {
  display: flex;
  align-items: center;
  gap: .4rem;
  padding: .42rem .75rem;
  background: rgba(56,189,248,.05);
  border-bottom: 1px solid rgba(56,189,248,.1);
}
.tbar-dot {
  width: 8px; height: 8px; border-radius: 50%;
}
.tbar-dot.r { background: #ff5f57; }
.tbar-dot.y { background: #febc2e; }
.tbar-dot.g { background: #28c840; }
.tbar-title {
  margin-left: .4rem;
  font-family: var(--mono); font-size: .52rem;
  color: rgba(56,189,248,.35); letter-spacing: .1em;
}
.skills-code {
  padding: .7rem .9rem;
  font-family: var(--mono); font-size: .6rem;
  line-height: 1.9; color: rgba(180,220,240,.55);
  overflow-x: auto;
}
.sc-key   { color: rgba(56,189,248,.8); }
.sc-val   { color: rgba(52,211,153,.8); }
.sc-num   { color: rgba(251,191,36,.75); }
.sc-brace { color: rgba(180,220,240,.3); }
.sc-comment { color: rgba(100,140,180,.4); font-style: italic; }

/* Mini stat pills below terminal */
.skills-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .5rem;
}
.sk-stat {
  background: rgba(56,189,248,.04);
  border: 1px solid rgba(56,189,248,.1);
  border-radius: 4px;
  padding: .5rem .4rem;
  text-align: center;
}
.sk-stat-n {
  font-family: var(--mono); font-weight: 700; font-size: 1.1rem;
  background: linear-gradient(110deg, var(--accent), var(--indigo));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  line-height: 1;
}
.sk-stat-l {
  font-family: var(--mono); font-size: .48rem;
  color: rgba(56,189,248,.35); letter-spacing: .08em;
  text-transform: uppercase; margin-top: 3px;
}

/* legacy */
.bwrap { display:none; }
.bfill { display:none; }
.sico  { display:none; }

/* ================================================================
   EXPERIENCE
================================================================ */
#s4 { background:linear-gradient(180deg,var(--bg),var(--bg2),var(--bg)); }
.tl { position:relative; }
.tl::before {
  content:''; position:absolute; left:0; top:8px; bottom:8px;
  width:1px; background:linear-gradient(180deg,transparent,var(--border) 20%,var(--border) 80%,transparent);
}
.tlrow { padding-left:1.7rem; margin-bottom:1.1rem; position:relative; }
.tlrow:last-child { margin-bottom:0; }
.tldot {
  position:absolute; left:0; top:.32rem;
  width:9px; height:9px; border-radius:50%;
  background:var(--accent); transform:translateX(-4.5px);
  box-shadow:0 0 0 3px rgba(56,189,248,.13),0 0 9px rgba(56,189,248,.28);
}
.ecard { padding:1.1rem 1.3rem; }
.ehead { display:flex; align-items:flex-start; justify-content:space-between; flex-wrap:wrap; gap:.44rem; margin-bottom:.48rem; }
.erole { font-weight:700; font-size:.94rem; color:var(--ink); }
.eco { color:var(--accent); font-size:.78rem; margin-top:.08rem; }
.eperiod {
  font-family:var(--mono); font-size:.6rem; color:var(--dim);
  background:var(--surface); border:1px solid var(--border); border-radius:50px;
  padding:.18rem .65rem; white-space:nowrap;
}
.edesc { font-size:.82rem; color:var(--dim); line-height:1.72; margin-bottom:.65rem; font-weight:300; }
.etags { display:flex; flex-wrap:wrap; gap:.32rem; }
.etag {
  font-size:.64rem; background:rgba(129,140,248,.08); border:1px solid rgba(129,140,248,.15);
  border-radius:50px; padding:.16rem .6rem; color:var(--indigo);
}
/* Fiverr card — rich */
.fv-banner {
  position:relative;
  display:flex; flex-direction:column;
  height:100%; padding:1.4rem 1.3rem 1.2rem;
  border-radius:var(--R);
  background:linear-gradient(145deg,rgba(20,184,166,.07),rgba(56,189,248,.05),rgba(129,140,248,.06));
  border:1px solid rgba(52,211,153,.15);
  overflow:hidden;
}
/* animated top border */
.fv-banner::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,var(--emerald),var(--accent),var(--indigo));
  background-size:200% auto;
  animation:fvTopLine 3s linear infinite;
}
@keyframes fvTopLine{ 0%{background-position:0% center;} 100%{background-position:200% center;} }
/* corner glow */
.fv-banner::after {
  content:''; position:absolute; top:-40px; right:-40px;
  width:120px; height:120px; border-radius:50%;
  background:radial-gradient(circle, rgba(52,211,153,.12), transparent 70%);
  pointer-events:none;
}

/* big icon badge */
.fv-ico-wrap {
  display:flex; align-items:center; gap:.75rem; margin-bottom:1rem;
}
.fv-ico {
  width:42px; height:42px; border-radius:10px;
  background:linear-gradient(135deg,rgba(52,211,153,.15),rgba(56,189,248,.1));
  border:1px solid rgba(52,211,153,.25);
  display:flex; align-items:center; justify-content:center;
  font-size:1.25rem; color:var(--emerald); flex-shrink:0;
}
.fv-badge {
  font-family:var(--mono); font-size:.55rem; letter-spacing:.12em;
  color:var(--emerald); background:rgba(52,211,153,.08);
  border:1px solid rgba(52,211,153,.2); border-radius:50px;
  padding:.18rem .65rem;
}

.fv-title {
  font-weight:800; font-size:1.05rem; margin-bottom:.4rem;
  color:var(--ink); line-height:1.2;
}

/* stat chips row */
.fv-stats {
  display:flex; flex-wrap:wrap; gap:.4rem; margin-bottom:.9rem;
}
.fv-stat {
  font-family:var(--mono); font-size:.58rem; letter-spacing:.06em;
  color:rgba(200,240,255,.55);
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06);
  border-radius:4px; padding:.18rem .55rem;
  display:flex; align-items:center; gap:.3rem;
}
.fv-stat i { color:var(--emerald); font-size:.5rem; }

.fv-desc { font-size:.78rem; color:var(--dim); font-weight:300; line-height:1.65; margin-bottom:1rem; flex:1; }

/* rating row */
.fv-rating {
  display:flex; align-items:center; gap:.4rem; margin-bottom:1rem;
}
.fv-stars { color:#fbbf24; font-size:.72rem; letter-spacing:.04em; }
.fv-rating-txt { font-family:var(--mono); font-size:.6rem; color:rgba(251,191,36,.7); }

/* markets */
.fv-markets {
  display:flex; gap:.35rem; flex-wrap:wrap; margin-bottom:1.1rem;
}
.fv-market {
  font-family:var(--mono); font-size:.55rem;
  color:rgba(56,189,248,.6); background:rgba(56,189,248,.06);
  border:1px solid rgba(56,189,248,.12); border-radius:3px;
  padding:.12rem .5rem;
}

.fv-info { flex:1; min-width:0; display:flex; flex-direction:column; }

/* ================================================================
   SERVICES
================================================================ */
#s5 {
  background: var(--bg);
  position: relative; overflow: hidden;
}
#s5::before {
  content:''; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(ellipse 55% 50% at 15% 50%, rgba(56,189,248,.05) 0%,transparent 65%),
    radial-gradient(ellipse 45% 45% at 85% 50%, rgba(129,140,248,.04) 0%,transparent 65%);
}
#s5 .container { position:relative; z-index:1; }

/* ── Section header ── */
.svc-header {
  display:flex; align-items:flex-end; justify-content:space-between;
  flex-wrap:wrap; gap:.8rem; margin-bottom:1.4rem;
}
.svc-header-left { text-align:left; }
.svc-count {
  font-family:var(--mono); font-size:.6rem; letter-spacing:.14em;
  color:rgba(56,189,248,.4);
}

/* ── Service card ── */
.svc {
  padding: 1.4rem 1.25rem 1.2rem;
  height: 100%;
  position: relative;
  overflow: hidden;
  background: rgba(4,10,24,.7);
  border-radius: var(--R);
  transition: all .3s var(--ease);
  border: 1px solid rgba(255,255,255,.06);
  display: flex; flex-direction: column;
}
/* top accent line — hidden by default, shows on hover */
.svc::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, var(--accent), var(--indigo));
  transform:scaleX(0); transform-origin:left;
  transition:transform .35s var(--ease);
}
/* subtle corner glow on hover */
.svc::after {
  content:''; position:absolute; top:-60px; right:-60px;
  width:140px; height:140px; border-radius:50%;
  background:radial-gradient(circle, rgba(56,189,248,.09), transparent 70%);
  opacity:0; transition:opacity .35s;
  pointer-events:none;
}
.svc:hover {
  border-color: rgba(56,189,248,.2);
  transform: translateY(-5px);
  box-shadow: 0 18px 44px rgba(0,0,0,.35), 0 0 30px rgba(56,189,248,.06);
}
.svc:hover::before { transform:scaleX(1); }
.svc:hover::after  { opacity:1; }

/* Icon wrap */
.svc-ico-wrap {
  width:46px; height:46px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:1rem; flex-shrink:0;
  position:relative; transition:transform .3s;
}
.svc:hover .svc-ico-wrap { transform:scale(1.08); }
.svc-ico-wrap i {
  font-size:1.2rem;
}

/* card number */
.svc-num {
  position:absolute; top:.85rem; right:1rem;
  font-family:var(--mono); font-size:.55rem; letter-spacing:.1em;
  color:rgba(255,255,255,.1); font-weight:700;
}

.svc-nm {
  font-weight:700; font-size:.92rem; margin-bottom:.42rem;
  color:var(--ink); line-height:1.3;
}
.svc-ds {
  font-size:.78rem; color:var(--dim); line-height:1.75;
  font-weight:300; flex:1; margin-bottom:.9rem;
}

/* tags row */
.svc-tags {
  display:flex; flex-wrap:wrap; gap:.3rem; margin-top:auto;
}
.svc-tag {
  font-family:var(--mono); font-size:.52rem; letter-spacing:.06em;
  color:rgba(56,189,248,.55); background:rgba(56,189,248,.06);
  border:1px solid rgba(56,189,248,.1); border-radius:3px;
  padding:.12rem .48rem;
}

/* ================================================================
   PORTFOLIO
================================================================ */
#s6 {
  background: var(--bg);
  position: relative; overflow: hidden;
}
#s6::before {
  content:''; position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='56' height='100'%3E%3Cpath d='M28 0L56 16L56 50L28 66L0 50L0 16Z' fill='none' stroke='rgba(56,189,248,0.04)' stroke-width='0.7'/%3E%3Cpath d='M28 34L56 50L56 84L28 100L0 84L0 50Z' fill='none' stroke='rgba(56,189,248,0.04)' stroke-width='0.7'/%3E%3C/svg%3E");
  background-size: 56px 100px;
  animation: hexDriftP 30s linear infinite;
}
@keyframes hexDriftP{ 0%{background-position:0 0;} 100%{background-position:56px 100px;} }
#s6 .container { position:relative; z-index:1; }

/* portfolio header */
.port-header {
  display:flex; align-items:flex-end; justify-content:space-between;
  flex-wrap:wrap; gap:.8rem; margin-bottom:1.4rem;
}
.port-count {
  font-family:var(--mono); font-size:.6rem; letter-spacing:.14em;
  color:rgba(56,189,248,.4);
}

/* card */
.pcrd {
  border-radius:10px; overflow:hidden; height:100%;
  display:flex; flex-direction:column; text-decoration:none; color:inherit;
  background: rgba(3,8,20,.8);
  border: 1px solid rgba(255,255,255,.06);
  transition: all .3s var(--ease);
  position: relative;
}
.pcrd::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background: linear-gradient(90deg, var(--accent), var(--indigo));
  transform: scaleX(0); transform-origin:left;
  transition: transform .35s var(--ease); z-index:2;
}
.pcrd:hover {
  border-color: rgba(56,189,248,.22);
  transform: translateY(-6px);
  box-shadow: 0 20px 48px rgba(0,0,0,.4), 0 0 28px rgba(56,189,248,.07);
}
.pcrd:hover::before { transform:scaleX(1); }

/* thumbnail */
.pthumb {
  height:130px; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:.45rem;
  position:relative; overflow:hidden;
  background: radial-gradient(ellipse at center, rgba(56,189,248,.07) 0%, rgba(3,8,20,1) 70%);
}
/* animated scan beam */
.pthumb::after {
  content:''; position:absolute; left:0; right:0; height:1px;
  background: linear-gradient(90deg, transparent, rgba(56,189,248,.35), transparent);
  animation: pscan 4s linear infinite;
  opacity:0; transition:opacity .3s;
}
.pcrd:hover .pthumb::after { opacity:1; }
@keyframes pscan{ 0%{top:0;} 100%{top:100%;} }

/* icon circle */
.pico-wrap {
  width:52px; height:52px; border-radius:50%;
  background: rgba(56,189,248,.08);
  border: 1px solid rgba(56,189,248,.15);
  display:flex; align-items:center; justify-content:center;
  transition: transform .3s, box-shadow .3s;
}
.pcrd:hover .pico-wrap {
  transform:scale(1.1);
  box-shadow: 0 0 20px rgba(56,189,248,.2);
}
.pico { font-size:1.35rem; }

/* HUD corner brackets on thumb */
.pthumb-br { position:absolute; width:14px; height:14px; border-color:rgba(56,189,248,.25); border-style:solid; border-width:0; }
.ptb-tl { top:6px; left:6px; border-top-width:1px; border-left-width:1px; }
.ptb-tr { top:6px; right:6px; border-top-width:1px; border-right-width:1px; }
.ptb-bl { bottom:6px; left:6px; border-bottom-width:1px; border-left-width:1px; }
.ptb-br { bottom:6px; right:6px; border-bottom-width:1px; border-right-width:1px; }

.purl {
  font-family:var(--mono); font-size:.52rem;
  color:rgba(56,189,248,.3); letter-spacing:.06em;
}

/* overlay */
.p-over {
  position:absolute; inset:0; opacity:0;
  background: linear-gradient(135deg,rgba(56,189,248,.1),rgba(129,140,248,.08));
  transition:opacity .3s; display:flex; align-items:center; justify-content:center;
}
.pcrd:hover .p-over { opacity:1; }
.pvisit {
  width:38px; height:38px; border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--indigo)); color:#000;
  display:flex; align-items:center; justify-content:center; font-size:.82rem;
  box-shadow: 0 0 20px rgba(56,189,248,.4);
  transform:scale(.7); transition:transform .3s;
}
.pcrd:hover .pvisit { transform:scale(1); }

/* body */
.pbody {
  padding:.75rem .9rem .8rem;
  border-top: 1px solid rgba(255,255,255,.05);
  position:relative;
}
.pbody::before {
  content:''; position:absolute; top:0; left:.9rem; right:.9rem; height:1px;
  background: linear-gradient(90deg, rgba(56,189,248,.2), transparent);
}
.pdom {
  font-family:var(--mono); font-size:.55rem;
  color:rgba(56,189,248,.55); margin-bottom:.25rem; letter-spacing:.04em;
}
.ptitle {
  font-size:.82rem; font-weight:700; color:var(--ink); line-height:1.3;
}
/* category tag */
.ptag {
  display:inline-block; margin-top:.35rem;
  font-family:var(--mono); font-size:.48rem; letter-spacing:.08em;
  color:rgba(56,189,248,.4); background:rgba(56,189,248,.06);
  border:1px solid rgba(56,189,248,.1); border-radius:3px; padding:.1rem .4rem;
}

/* live indicator dot */
.plive {
  position:absolute; top:.75rem; right:.9rem;
  width:6px; height:6px; border-radius:50%;
  background:var(--emerald); box-shadow:0 0 6px var(--emerald);
  animation:bdot 2s ease-in-out infinite;
}

/* ================================================================
   CONTACT
================================================================ */
#s7 {
  background: var(--bg);
  position: relative; overflow: hidden;
}
#s7 .sec-pad { padding-top:64px; padding-bottom:64px; }
#s7::before {
  content:''; position:absolute; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(ellipse at 10% 80%, rgba(56,189,248,.07) 0%, transparent 50%),
    radial-gradient(ellipse at 90% 10%, rgba(129,140,248,.06) 0%, transparent 50%);
}
#s7 .container { position:relative; z-index:1; }

/* ── CONTACT HUD LAYOUT ── */
/* ct-hud replaced by Bootstrap row */

/* ── LEFT PANEL ── */
.ct-left {
  position: relative;
}
/* Top HUD label bar */
.ct-panel-tag {
  display: flex; align-items: center; gap: .6rem;
  margin-bottom: 1.4rem;
}
.ct-panel-tag::before {
  content:''; width: 3px; height: 18px;
  background: linear-gradient(180deg, var(--accent), var(--indigo));
  border-radius: 2px; flex-shrink:0;
}
.ct-panel-tag span {
  font-family: var(--mono); font-size: .6rem; letter-spacing: .15em;
  color: rgba(56,189,248,.6); text-transform: uppercase;
}

/* avail badge */
.avail-badge {
  display: inline-flex; align-items: center; gap: .45rem;
  background: rgba(52,211,153,.07); border: 1px solid rgba(52,211,153,.28);
  border-radius: 50px; padding: .28rem .85rem;
  font-size: .7rem; color: var(--emerald); font-weight: 700;
  letter-spacing: .04em; margin-bottom: 1rem;
}
.avail-dot { width:7px; height:7px; border-radius:50%; background:var(--emerald); animation:bdot 2s ease-in-out infinite; }

/* intro text */
.ct-intro {
  font-size: .82rem; color: var(--dim); font-weight: 300;
  line-height: 1.75; margin-bottom: 1.6rem;
}

/* stats row */
.ct-stats {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: .5rem; margin-bottom: 1.8rem;
}
.ct-stat {
  text-align: center; padding: .7rem .3rem;
  border: 1px solid rgba(56,189,248,.12);
  border-radius: 8px;
  background: rgba(56,189,248,.03);
  position: relative; overflow: hidden;
}
.ct-stat::before {
  content:''; position:absolute; top:0; left:15%; right:15%; height:1px;
  background: linear-gradient(90deg, transparent, rgba(56,189,248,.4), transparent);
}
.ct-stat-n {
  font-weight: 900; font-size: 1.35rem; line-height: 1;
  background: linear-gradient(110deg, var(--accent), var(--indigo));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.ct-stat-l { font-size: .54rem; color: var(--faint); text-transform: uppercase; letter-spacing: .06em; margin-top: 4px; }

/* contact info list */
.ct-info-list { display: flex; flex-direction: column; gap: .5rem; margin-bottom: 1.6rem; }
.ct-info-item {
  display: flex; align-items: center; gap: .9rem;
  padding: .6rem .75rem; border-radius: 8px;
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.06);
  text-decoration: none; color: inherit;
  transition: all .22s var(--ease); position: relative;
}
.ct-info-item::before {
  content:''; position:absolute; left:0; top:15%; bottom:15%; width:2px;
  background: linear-gradient(180deg, var(--accent), var(--indigo));
  border-radius: 2px; opacity:0; transition: opacity .22s;
}
.ct-info-item:hover { background: rgba(56,189,248,.06); border-color: rgba(56,189,248,.22); transform: translateX(4px); color: inherit; }
.ct-info-item:hover::before { opacity: 1; }
.ct-ico {
  width: 34px; height: 34px; border-radius: 8px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; font-size: .85rem;
}
.ct-ico.c-email  { background: rgba(56,189,248,.1);  color: var(--accent); }
.ct-ico.c-phone  { background: rgba(52,211,153,.1);  color: var(--emerald); }
.ct-ico.c-fiverr { background: rgba(29,191,115,.1);  color: #1dbf73; }
.ct-info-txt .ct-lbl { font-family: var(--mono); font-size: .54rem; color: rgba(56,189,248,.45); text-transform: uppercase; letter-spacing: .1em; }
.ct-info-txt .ct-val { font-size: .82rem; color: var(--ink); font-weight: 600; margin-top: .05rem; }

/* social icons */
.ct-social { display: flex; gap: .45rem; flex-wrap: wrap; }
.ct-sb {
  width: 34px; height: 34px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid rgba(255,255,255,.1); color: var(--dim); font-size: .8rem;
  transition: all .2s;
}
.ct-sb:hover { border-color: var(--accent); color: var(--accent); box-shadow: 0 0 14px rgba(56,189,248,.2); transform: translateY(-2px); }

/* ── RIGHT: FORM HUD ── */
.ct-form-panel {
  position: relative;
}
.ct-form-hud {
  position: relative;
  padding: 2rem 1.8rem;
  background: rgba(2,8,20,.7);
  border: 1px solid rgba(56,189,248,.12);
  border-radius: 4px;
}
/* animated top gradient bar */
.ct-form-hud::before {
  content: ''; position: absolute;
  top: -1px; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--accent), var(--indigo), var(--emerald), var(--accent));
  background-size: 300% 100%;
  animation: gradRun 4s linear infinite;
}
@keyframes gradRun { 0%{background-position:0%} 100%{background-position:300%} }

/* ── 4 HUD corner brackets ── */
/* top-left */
.ct-form-hud .hud-tl,
.ct-form-hud .hud-tr,
.ct-form-hud .hud-bl,
.ct-form-hud .hud-br {
  position: absolute; width: 14px; height: 14px;
  border-color: rgba(56,189,248,.5); border-style: solid;
}
.ct-form-hud .hud-tl { top:-1px; left:-1px; border-width:2px 0 0 2px; }
.ct-form-hud .hud-tr { top:-1px; right:-1px; border-width:2px 2px 0 0; }
.ct-form-hud .hud-bl { bottom:-1px; left:-1px; border-width:0 0 2px 2px; }
.ct-form-hud .hud-br { bottom:-1px; right:-1px; border-width:0 2px 2px 0; }

/* section divider lines */
.ct-divider {
  display: flex; align-items: center; gap: 1rem;
  margin-bottom: 1.4rem;
}
.ct-divider-line {
  flex: 1; height: 1px;
  background: linear-gradient(90deg, rgba(56,189,248,.3), transparent);
}
.ct-divider-label {
  font-family: var(--mono); font-size: .9rem; letter-spacing: .18em;
  color: var(--accent); white-space: nowrap; font-weight: 700;
  text-shadow: 0 0 12px rgba(56,189,248,.4);
}

/* form grid */
.ct-form-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: .9rem; margin-bottom: .9rem;
}
@media(max-width:576px){ .ct-form-grid{grid-template-columns:1fr;} }
.ct-form-full { margin-bottom: .9rem; }

/* label */
.ct-label {
  display: block; font-family: var(--mono); font-size: .56rem;
  font-weight: 700; text-transform: uppercase; letter-spacing: .12em;
  color: rgba(56,189,248,.55); margin-bottom: .3rem;
}

/* input base */
.ct-input {
  width: 100%; padding: .7rem .95rem;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 8px; color: var(--ink);
  font-family: var(--font); font-size: .86rem; outline: none;
  transition: all .2s var(--ease);
}
.ct-input::placeholder { color: rgba(109,130,165,.45); }
.ct-input:focus { border-color: rgba(56,189,248,.45); background: rgba(56,189,248,.04); box-shadow: 0 0 0 3px rgba(56,189,248,.08); }
textarea.ct-input { resize: vertical; min-height: 105px; }

/* phone field custom — see .ph-wrap */
/* ── Custom Phone Field ── */
.ph-wrap {
  display: flex; align-items: stretch;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 8px; overflow: visible;
  background: rgba(255,255,255,.03);
  transition: all .2s var(--ease);
  position: relative;
}
.ph-wrap:focus-within {
  border-color: rgba(56,189,248,.45);
  background: rgba(56,189,248,.04);
  box-shadow: 0 0 0 3px rgba(56,189,248,.08);
}
.ph-select {
  border: none; outline: none;
  background: rgba(56,189,248,.08);
  border-right: 1px solid rgba(56,189,248,.2);
  border-radius: 8px 0 0 8px;
  color: var(--accent); font-family: var(--mono);
  font-size: .78rem; font-weight: 700;
  padding: 0 .5rem 0 .7rem;
  cursor: pointer; min-width: 90px;
  appearance: none; -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(56,189,248,0.6)'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 6px center;
  padding-right: 22px;
}
.ph-select:focus { outline: none; }
.ph-select option { background: #030c1e; color: var(--ink); font-family: var(--font); }
.ph-number {
  flex: 1; border: none; outline: none;
  background: transparent; color: var(--ink);
  font-family: var(--font); font-size: .86rem;
  padding: .7rem .95rem;
}
.ph-number::placeholder { color: rgba(109,130,165,.45); }


/* send button */
.ct-send {
  width: 100%; padding: .82rem; border-radius: 8px; border: none; cursor: pointer;
  background: linear-gradient(115deg, var(--accent), var(--indigo));
  color: #000; font-family: var(--mono); font-size: .8rem; font-weight: 800;
  display: flex; align-items: center; justify-content: center; gap: .5rem;
  transition: all .25s; box-shadow: 0 6px 24px rgba(56,189,248,.25);
  letter-spacing: .12em; text-transform: uppercase;
}
.ct-send:hover { transform: translateY(-2px); box-shadow: 0 14px 40px rgba(56,189,248,.5); }
.ct-send:disabled { opacity: .6; cursor: not-allowed; }

/* form messages */
.fmsg { display:none; padding:.6rem .9rem; border-radius:8px; font-size:.8rem; margin-top:.6rem; }
.fmsg.ok  { background:rgba(52,211,153,.08); border:1px solid rgba(52,211,153,.22); color:var(--emerald); }
.fmsg.err { background:rgba(248,113,113,.08); border:1px solid rgba(248,113,113,.22); color:#f87171; }
/* ================================================================
   FOOTER
================================================================ */
#s8 { background:var(--bg2); }
.ft {
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem;
  padding:1.4rem 0; border-top:1px solid var(--border);
}
.ft-brand { font-weight:900; font-size:1.05rem; }
.ft-brand .dot { color:var(--accent); }
.ft-brand .jn { color:var(--accent); font-style:italic; }
.ft-copy { font-size:.75rem; color:var(--faint); }
.ft-nav { display:flex; gap:1.2rem; }
.ft-nav a { font-size:.75rem; color:var(--faint); transition:color .2s; }
.ft-nav a:hover { color:var(--accent); }

/* ================================================================
   FAB — FLOATING ACTION BUTTON (always visible, fixed)
================================================================ */
.fab-wrap {
  position:fixed !important;
  bottom:1.8rem; right:1.6rem;
  z-index:999999;
  display:flex; flex-direction:column; align-items:flex-end; gap:.48rem;
}
.fab-main {
  width:50px; height:50px; border-radius:50%; cursor:pointer; border:none;
  background:linear-gradient(135deg,var(--accent),var(--indigo));
  display:flex; align-items:center; justify-content:center;
  font-size:1.1rem; color:#000;
  box-shadow:0 5px 25px rgba(56,189,248,.38);
  transition:all var(--T);
  flex-shrink:0; position:relative; z-index:2;
}
.fab-main:hover { transform:scale(1.1) rotate(10deg); }
.fab-items {
  display:flex; flex-direction:column; gap:.4rem;
  opacity:0; pointer-events:none;
  transform:translateY(10px) scale(.92);
  transition:opacity .22s var(--ease), transform .22s var(--ease);
}
.fab-items.open { opacity:1; pointer-events:all; transform:translateY(0) scale(1); }
.fab-item {
  display:flex; align-items:center; gap:.58rem; cursor:pointer;
  background:rgba(5,14,30,.96); border:1px solid var(--border); backdrop-filter:blur(16px);
  border-radius:50px; padding:.45rem .88rem .45rem .48rem;
  transition:all .2s; text-decoration:none; color:var(--ink);
}
.fab-item:hover { border-color:var(--accent); transform:translateX(-4px); color:var(--ink); }
.fab-ico { width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.9rem; flex-shrink:0; }
.iwa{background:#25D366;} .icall{background:var(--accent);color:#000;} .imail{background:var(--indigo);}
.fab-lbl { font-size:.76rem; font-weight:500; }

/* ================================================================
   BACK TO TOP
================================================================ */
#btt {
  position:fixed !important;
  bottom:1.8rem; left:1.6rem;
  z-index:999999;
  width:42px; height:42px; border-radius:50%;
  background:var(--surface); border:1px solid var(--border); backdrop-filter:blur(12px);
  display:flex; align-items:center; justify-content:center;
  color:var(--accent); font-size:.85rem; cursor:pointer;
  opacity:0; pointer-events:none;
  transition:all var(--T);
}
#btt.show { opacity:1; pointer-events:all; }
#btt:hover { border-color:var(--accent); box-shadow:0 0 16px rgba(56,189,248,.18); transform:translateY(-2px); }

/* ================================================================
   RESPONSIVE — no horizontal overflow
================================================================ */

/* Global overflow lock */
html, body {
  overflow-x: hidden;
  max-width: 100%;
}
* { box-sizing: border-box; }


/* ── 1100px ── */
@media(max-width:1100px){
  .chips-col { display:none; }
}

/* ── 991px — Tablet ── */
@media(max-width:991px){
  .orbit-box  { width:220px; height:220px; }
  .oring.r2   { inset:-22px; }
  .photo-frame img { height:280px; }
  .exp-badge2 { bottom:-10px; right:-10px; }

  /* Skills 2-col → 1-col */
  .skills-master { grid-template-columns:1fr; }



  /* Services 3-col → 2-col */
  .svc-tags { flex-wrap:wrap; }

  /* Portfolio cards equal width */
  .pcrd { min-width:0; }

  /* Timeline */
  .tlrow { padding-left:1.2rem; }
}

/* ── 767px — Mobile large ── */
@media(max-width:767px){
  .hero-avatar-col { display:none !important; }

  /* Hero text center */
  .hero-h, .hero-tag, .hero-sub { text-align:center; }
  .hero-badge, .hero-ctas, .hero-stats { justify-content:center; display:flex; }
  .hud-rows { align-items:center; }
  .hero-ctas { flex-wrap:wrap; justify-content:center; }

  /* About — stack vertically */
  .photo-frame { margin:0 auto; max-width:280px; }
  .exp-badge2  { display:none; }
  .atags       { justify-content:center; flex-wrap:wrap; }
  .info-grid2  { grid-template-columns:1fr 1fr; }

  /* Skills grid 5→3 cols */
  .skills-grid { grid-template-columns:repeat(3,1fr); }

  /* Experience timeline */
  .tl::before { display:none; }
  .tlrow      { padding-left:0; }
  .tldot      { display:none; }

  /* Services 3→1 col */
  #s5 .col-lg-4 { width:100%; }

  /* Portfolio 2→1 col */
  #s6 .col-6   { width:100%; }

  /* Contact 2-col → 1-col */
  .cinfo-card  { margin-bottom:1.5rem; }

  /* Footer */
  .ft { flex-direction:column; align-items:center; text-align:center; }
  .ft-nav { flex-wrap:wrap; justify-content:center; gap:.75rem; }

  /* Fiverr banner */
  .fv-banner { height:auto; }

  /* Scroll arrow always centered */
  .scroll-arrow { left:50%; }

  /* Section heading scale */
  .shd { font-size:clamp(1.6rem,6vw,2.8rem); }
}

/* ── 575px — Mobile small ── */
@media(max-width:575px){
  .info-grid2 { grid-template-columns:1fr; }
  .hero-ctas .btn-p, .hero-ctas .btn-o { justify-content:center; width:100%; }
  .hero-stats { gap:.5rem; }
  .hero-stat-card { min-width:70px; }

  /* Skills grid 5→2 cols */
  .skills-grid { grid-template-columns:repeat(2,1fr); }

  /* Contact stats row */
  .ct-stats-row { grid-template-columns:1fr 1fr; }

  /* Portfolio full width */
  #s6 .col-6, #s6 .col-md-4 { width:100%; }

  /* Services full width */
  #s5 .col-md-6, #s5 .col-lg-4 { width:100%; }

  /* FAB items stay in viewport */
  .fab-wrap { right:1rem; bottom:1.2rem; }
  #btt { left:1rem; bottom:1.2rem; }

  /* Section padding reduce */
  .sec-pad { padding-top:76px; padding-bottom:16px; }
}

/* ================================================================
   DRAWER — MOBILE / TABLET SLIDE-IN MENU
================================================================ */

/* Hamburger button — visible only on mobile/tablet */
.hamburger-btn {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 40px; height: 40px;
  background: rgba(56,189,248,.08);
  border: 1px solid rgba(56,189,248,.22);
  border-radius: 8px;
  cursor: pointer;
  padding: 0;
  transition: background .25s;
}
.hamburger-btn:hover { background: rgba(56,189,248,.18); }
.hamburger-btn span {
  display: block;
  width: 20px; height: 2px;
  background: var(--accent);
  border-radius: 2px;
  transition: transform .3s, opacity .3s;
}

/* Desktop nav hidden on mobile */
.desktop-nav {
  display: flex;
  align-items: center;
}

@media (max-width: 991px) {
  .hamburger-btn { display: flex; }
  .desktop-nav   { display: none; }
}

/* ── Overlay ── */
#drawerOverlay {
  position: fixed; inset: 0; z-index: 19998;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(3px);
  opacity: 0; pointer-events: none;
  transition: opacity .35s ease;
}
#drawerOverlay.open { opacity: 1; pointer-events: all; }

/* ── Drawer panel ── */
#drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  z-index: 19999;
  width: min(320px, 85vw);
  background: var(--bg2);
  border-left: 1px solid rgba(56,189,248,.15);
  display: flex; flex-direction: column;
  transform: translateX(100%);
  transition: transform .38s cubic-bezier(.4,0,.2,1);
  box-shadow: -8px 0 40px rgba(0,0,0,.5);
}
#drawer.open { transform: translateX(0); }

/* Drawer header */
.drawer-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.2rem 1.4rem;
  border-bottom: 1px solid rgba(56,189,248,.1);
}
.drawer-close {
  width: 34px; height: 34px; border-radius: 8px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  color: var(--dim); font-size: 1rem;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all .2s;
}
.drawer-close:hover { background: rgba(56,189,248,.12); border-color: var(--accent); color: var(--accent); }

/* Drawer nav links */
.drawer-nav {
  flex: 1;
  display: flex; flex-direction: column;
  padding: 1rem 0;
  overflow-y: auto;
}
.drawer-link {
  display: flex; align-items: center; gap: .75rem;
  padding: .95rem 1.6rem;
  font-family: var(--font); font-size: .95rem; font-weight: 500;
  color: var(--dim);
  cursor: pointer;
  text-decoration: none;
  border-left: 2px solid transparent;
  transition: all .2s;
  position: relative;
}
.drawer-link::after {
  content: ''; position: absolute; right: 1.4rem; top: 50%;
  transform: translateY(-50%);
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent); opacity: 0;
  transition: opacity .2s;
}
.drawer-link:hover,
.drawer-link.active {
  color: var(--ink);
  border-left-color: var(--accent);
  background: rgba(56,189,248,.05);
}
.drawer-link:hover::after,
.drawer-link.active::after { opacity: 1; }

.dl-num {
  font-family: var(--mono); font-size: .62rem;
  color: rgba(56,189,248,.4); letter-spacing: .08em;
  min-width: 22px;
}

/* Drawer footer */
.drawer-foot {
  padding: 1.2rem 1.4rem;
  border-top: 1px solid rgba(56,189,248,.1);
}
.drawer-foot .btn-hire { width: 100%; justify-content: center; border-radius: 10px; padding: .75rem; }

/* Only show drawer on mobile/tablet */
@media (min-width: 992px) {
  #drawer, #drawerOverlay { display: none !important; }
}

