/* ============================================================
   NazDoublei — Staging portfolio
   Dark · neon green · cinematic · premium
============================================================ */

:root{
  --bg:        #050505;
  --bg-2:      #0a0a09;
  --panel:     rgba(255,255,255,0.025);
  --panel-2:   rgba(255,255,255,0.04);
  --ink:       #ececec;
  --ink-soft:  #b7b7b7;
  --muted:     #6c6c6c;
  --line:      rgba(255,255,255,0.07);
  --line-2:    rgba(255,255,255,0.14);
  --line-3:    rgba(255,255,255,0.24);
  --accent:    #00ff9c;
  --accent-2:  #00d97d;
  --accent-soft:rgba(0,255,156,0.14);
  --glow-sm:   0 0 18px rgba(0,255,156,0.35);
  --glow-md:   0 0 38px rgba(0,255,156,0.40);
  --glow-lg:   0 0 80px rgba(0,255,156,0.45);
  --display:   "Space Grotesk", -apple-system, BlinkMacSystemFont, sans-serif;
  --sans:      "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
  --mono:      "JetBrains Mono", ui-monospace, Menlo, monospace;
  --ease:      cubic-bezier(.7,0,.2,1);
  --ease-out:  cubic-bezier(.16,1,.3,1);
  --pad:       clamp(20px, 4.5vw, 80px);
}

*{box-sizing:border-box;margin:0;padding:0;}
html,body{background:var(--bg);color:var(--ink);}
html{scroll-behavior:auto;}
body{
  font-family:var(--sans);
  font-weight:400;font-size:15px;line-height:1.55;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  position:relative;
  cursor:none;
}
img{display:block;max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;}
button{font:inherit;color:inherit;border:0;background:none;cursor:none;}
ul{list-style:none;}
em{font-style:italic;color:var(--accent);text-shadow:0 0 24px rgba(0,255,156,.35);font-weight:inherit;}
strong{font-weight:500;color:#fff;}
::selection{background:var(--accent);color:var(--bg);}

/* hide scrollbar visually but keep it functional */
::-webkit-scrollbar{width:0;height:0;}

/* ============================================================
   GLOBAL OVERLAYS
============================================================ */

/* Custom cursor — solid neon (no blend mode so it never disappears) */
.cursor{position:fixed;top:0;left:0;pointer-events:none;z-index:10000;}
.cursor__dot,.cursor__ring{position:absolute;top:0;left:0;border-radius:50%;transform:translate(-50%,-50%);will-change:transform,width,height;}
.cursor__dot{
  width:6px;height:6px;background:var(--accent);
  box-shadow:0 0 10px rgba(0,255,156,.85),0 0 24px rgba(0,255,156,.5);
}
.cursor__ring{
  width:36px;height:36px;border:1px solid rgba(0,255,156,.65);
  background:rgba(0,255,156,0.04);
  opacity:.95;
  transition:width .3s var(--ease-out),height .3s var(--ease-out),background-color .25s,border-color .25s;
}
.cursor.is-link  .cursor__ring{width:64px;height:64px;background:rgba(0,255,156,0.08);}
.cursor.is-card  .cursor__ring{width:90px;height:90px;background:rgba(0,255,156,0.10);border-color:var(--accent);}
@media (hover:none){
  body,a,button{cursor:auto;}
  .cursor{display:none;}
}

/* Grid backdrop */
.bg-grid{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(ellipse 80% 70% at 50% 40%, #000 30%, transparent 90%);
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 40%, #000 30%, transparent 90%);
  animation:gridDrift 60s linear infinite;
}
@keyframes gridDrift{
  0%{background-position:0 0,0 0}
  100%{background-position:72px 72px,72px 72px}
}

/* Noise */
.bg-noise{
  position:fixed;inset:-50%;z-index:1;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode:overlay;
  animation:noise 1.1s steps(6) infinite;
}
@keyframes noise{
  0%{transform:translate(0,0)}25%{transform:translate(-2%,1%)}
  50%{transform:translate(1%,-2%)}75%{transform:translate(-1%,2%)}
  100%{transform:translate(0,0)}
}

/* Mouse-follow light */
.bg-light{
  position:fixed;top:0;left:0;width:600px;height:600px;
  margin:-300px 0 0 -300px;
  z-index:2;pointer-events:none;
  background:radial-gradient(circle at center, rgba(0,255,156,0.12), transparent 60%);
  filter:blur(20px);
  transform:translate3d(50vw,50vh,0);
  transition:opacity .4s;
  will-change:transform;
}

/* Scroll progress */
.scroll-progress{
  position:fixed;top:0;left:0;right:0;height:2px;z-index:9000;
  background:rgba(255,255,255,.04);
}
.scroll-progress span{
  display:block;height:100%;width:0%;
  background:linear-gradient(90deg, transparent, var(--accent));
  box-shadow:var(--glow-sm);
}

/* ============================================================
   LOADER
============================================================ */
.loader{
  position:fixed;inset:0;z-index:5000;background:var(--bg);
  display:flex;align-items:flex-end;
  padding:var(--pad);
}
.loader__inner{width:100%;}
.loader__brand{
  display:flex;align-items:center;gap:14px;margin-bottom:22px;
}
.loader__mark{
  width:42px;height:42px;border-radius:50%;
  border:1px solid var(--line-2);
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--display);font-weight:600;
  color:var(--accent);font-size:14px;
  box-shadow:inset 0 0 22px rgba(0,255,156,.18),0 0 30px rgba(0,255,156,.18);
}
.loader__name{font-family:var(--display);font-weight:500;letter-spacing:.22em;font-size:13px;}
.loader__bar{height:1px;background:rgba(255,255,255,.1);overflow:hidden;}
.loader__bar i{display:block;width:0%;height:100%;background:linear-gradient(90deg, transparent, var(--accent));box-shadow:var(--glow-sm);transition:width .25s linear;}
.loader__row{
  display:flex;justify-content:space-between;margin-top:14px;
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--muted);
  text-transform:uppercase;
}
.loader__msg{color:var(--accent);}
body.is-loaded .loader{transform:translateY(-100%);transition:transform 1.1s var(--ease-out) .15s;}
body.is-loading{overflow:hidden;}

/* ============================================================
   NAV
============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:20px;
  padding:18px var(--pad);
  background:linear-gradient(to bottom, rgba(5,5,5,.85) 0%, rgba(5,5,5,0) 100%);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  transition:transform .5s var(--ease);
}
.nav.is-hidden{transform:translateY(-110%);}
.nav__brand{display:inline-flex;align-items:center;gap:12px;}
.nav__mark{
  width:32px;height:32px;border-radius:50%;
  border:1px solid var(--line-2);
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--display);font-weight:600;font-size:11px;
  color:var(--accent);
  box-shadow:inset 0 0 18px rgba(0,255,156,.18);
  transition:box-shadow .35s,border-color .35s;
}
.nav__brand:hover .nav__mark{box-shadow:inset 0 0 22px rgba(0,255,156,.30),0 0 22px rgba(0,255,156,.4);border-color:var(--accent);}
.nav__name{font-family:var(--display);font-weight:500;letter-spacing:.18em;font-size:12px;text-transform:uppercase;}

.nav__menu{display:flex;gap:6px;justify-self:center;}
.nav__menu a{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;
  border-radius:99px;
  font-size:12px;letter-spacing:.04em;
  border:1px solid transparent;
  transition:border-color .3s,background .3s,color .3s;
}
.nav__menu a span{font-family:var(--mono);font-size:10px;color:var(--muted);transition:color .3s;}
.nav__menu a:hover{border-color:var(--line-2);background:var(--panel);}
.nav__menu a:hover span{color:var(--accent);}

.nav__cta{
  justify-self:end;display:inline-flex;align-items:center;gap:10px;
  padding:9px 16px;border-radius:99px;
  border:1px solid var(--line-2);
  font-size:12px;letter-spacing:.04em;font-family:var(--mono);text-transform:uppercase;
  transition:border-color .35s,color .35s,box-shadow .35s;
}
.nav__cta-dot{
  width:8px;height:8px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 4px rgba(0,255,156,.14),0 0 16px rgba(0,255,156,.55);
}
.nav__cta:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 30px rgba(0,255,156,.25);}

/* ============================================================
   SHARED TYPE & SECTION HEADS
============================================================ */
.kicker{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--accent);
  text-transform:uppercase;
}
.kicker--right{margin-left:auto;color:var(--muted);}
.kicker--right .dot{display:inline-block;}

.h-section{
  font-family:var(--display);font-weight:500;
  font-size:clamp(34px,4.6vw,68px);
  line-height:1.04;letter-spacing:-0.024em;
}
.section__head{
  display:flex;flex-direction:column;gap:18px;
  margin-bottom:60px;max-width:920px;
}
.section__head--center{align-items:center;text-align:center;margin-left:auto;margin-right:auto;}
.section__sub{
  max-width:60ch;font-size:16px;color:var(--ink-soft);
}

[data-section]{position:relative;padding:140px var(--pad);}
[data-section]+[data-section]{border-top:1px solid var(--line);}

[data-reveal]{opacity:0;transform:translateY(28px);}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:99px;
  font-family:var(--sans);font-weight:500;font-size:13px;letter-spacing:.04em;
  transition:transform .35s var(--ease-out),box-shadow .35s,background .3s,color .3s,border-color .3s;
}
.btn svg{width:14px;height:14px;}
.btn--primary{
  background:var(--accent);color:#001a0e;
  box-shadow:0 0 0 1px rgba(0,255,156,.4),0 0 30px rgba(0,255,156,.32);
}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 0 0 1px rgba(0,255,156,.6),0 0 60px rgba(0,255,156,.55);}
.btn--ghost{border:1px solid var(--line-2);color:var(--ink);}
.btn--ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px);box-shadow:0 0 30px rgba(0,255,156,.2);}

.dot{width:7px;height:7px;border-radius:50%;display:inline-block;}
.dot--green{background:var(--accent);box-shadow:0 0 0 4px rgba(0,255,156,.14),0 0 14px rgba(0,255,156,.55);}

/* ============================================================
   HERO
============================================================ */
.hero{
  position:relative;
  min-height:100vh;
  padding:140px var(--pad) 80px;
  display:flex;flex-direction:column;justify-content:space-between;gap:60px;
  overflow:hidden;
}
.hero__top{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;}
.hero__title{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(54px,9.2vw,156px);
  line-height:.96;
  letter-spacing:-0.035em;
  margin-top:auto;
}
.hero__title .line{display:block;overflow:hidden;}
.hero__title .line > span{display:inline-block;will-change:transform;}
.hero__title em{font-weight:500;color:var(--accent);text-shadow:0 0 40px rgba(0,255,156,.5);}

.hero__bottom{
  display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:end;
  margin-top:20px;
}
.hero__lead{
  max-width:54ch;font-size:clamp(15px,1.2vw,17px);color:var(--ink-soft);
}
.hero__lead em{color:var(--accent);}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:flex-end;}

/* Floating glyphs */
.hero__float{position:absolute;inset:0;pointer-events:none;z-index:0;}
.hero__float span{
  position:absolute;top:var(--y);left:var(--x);
  font-family:var(--mono);font-size:clamp(20px,2.2vw,32px);
  color:var(--accent);opacity:.45;
  text-shadow:0 0 24px rgba(0,255,156,.45);
  transform:translate(-50%,-50%);
  animation:bob 6s ease-in-out infinite;
  animation-delay:calc(var(--y) * -0.05s);
}
.hero__float span:nth-child(even){animation-duration:8s;color:#fff;opacity:.25;text-shadow:none;}
@keyframes bob{
  0%,100%{transform:translate(-50%,-50%) translateY(0)}
  50%{transform:translate(-50%,-50%) translateY(-12px)}
}

/* Orbs */
.hero__orb{
  position:absolute;border-radius:50%;filter:blur(80px);
  pointer-events:none;z-index:0;
}
.hero__orb--1{width:520px;height:520px;left:-160px;top:30%;background:radial-gradient(circle, rgba(0,255,156,.22), transparent 70%);}
.hero__orb--2{width:420px;height:420px;right:-120px;bottom:-80px;background:radial-gradient(circle, rgba(0,255,156,.14), transparent 70%);}

/* Hero portrait — right-bleed cinematic */
.hero__portrait{
  position:absolute;top:0;right:0;bottom:0;
  width:58%;z-index:1;pointer-events:none;
  overflow:hidden;
}
.hero__portrait-inner{
  position:absolute;inset:0;
  will-change:transform;
  transform-origin:65% 50%;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
}
.hero__portrait img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:64% center;
  filter:saturate(.95) contrast(1.06) brightness(.92);
  image-rendering:auto;
  -webkit-backface-visibility:hidden;
          backface-visibility:hidden;
  /* Fade left edge so portrait blends into the dark bg */
  -webkit-mask-image:linear-gradient(to right, transparent 0%, rgba(0,0,0,.4) 25%, #000 46%, #000 100%);
          mask-image:linear-gradient(to right, transparent 0%, rgba(0,0,0,.4) 25%, #000 46%, #000 100%);
}
/* Soft neon glow behind subject */
.hero__portrait::before{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(ellipse 55% 65% at 70% 48%, rgba(0,255,156,.12), transparent 65%),
    linear-gradient(to top, rgba(5,5,5,.6) 0%, transparent 40%);
}
/* Subtle neon edge where image meets bg */
.hero__portrait::after{
  content:"";position:absolute;left:40%;top:8%;bottom:8%;width:1px;z-index:2;
  background:linear-gradient(to bottom, transparent, rgba(0,255,156,.45), transparent);
  filter:blur(.6px);
  opacity:.85;
  animation:edgePulse 4s ease-in-out infinite;
}
@keyframes edgePulse{
  0%,100%{opacity:.7;transform:scaleY(1)}
  50%{opacity:1;transform:scaleY(1.04)}
}
.hero__portrait-label{
  position:absolute;left:44%;bottom:84px;z-index:3;
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 14px;border-radius:99px;
  border:1px solid rgba(0,255,156,.35);
  background:rgba(5,5,5,.55);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;
  color:var(--ink);text-transform:uppercase;
  box-shadow:0 0 30px rgba(0,255,156,.15);
}

/* Constrain hero text to the left half so it doesn't fight the portrait */
.hero__title{
  max-width:56%;
  font-size:clamp(42px,6.2vw,104px);
  position:relative;z-index:2;
}
.hero__title .line{padding-right:.1em;}   /* tiny safety gutter so the last glyph never clips */
.hero__bottom{
  position:relative;z-index:2;
}
.hero__lead{max-width:42ch;}

@media (max-width:1024px){
  .hero__portrait{
    position:relative;width:100%;height:auto;aspect-ratio:16/10;
    margin:24px 0 8px;border-radius:6px;
    border:1px solid var(--line);
  }
  .hero__portrait img{
    object-position:center 30%;
    -webkit-mask-image:linear-gradient(to top, transparent 0%, #000 25%, #000 100%);
            mask-image:linear-gradient(to top, transparent 0%, #000 25%, #000 100%);
  }
  .hero__portrait::after{left:0;top:auto;bottom:0;width:100%;height:1px;
    background:linear-gradient(to right, transparent, rgba(0,255,156,.55), transparent);
    animation:none;
  }
  .hero__portrait-label{left:14px;bottom:14px;}
  .hero__title,.hero__lead{max-width:none;}
}

/* ticker */
.hero__ticker{
  position:absolute;left:0;right:0;bottom:54px;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:14px 0;
  overflow:hidden;
  background:rgba(255,255,255,0.015);
  z-index:1;
}
.ticker__track{
  display:flex;gap:36px;align-items:center;white-space:nowrap;
  font-family:var(--mono);font-size:12px;letter-spacing:.16em;color:var(--muted);text-transform:uppercase;
  animation:scroll 40s linear infinite;
}
.ticker__sep{color:var(--accent);}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.hero__scroll{
  position:absolute;left:var(--pad);bottom:14px;
  display:inline-flex;flex-direction:column;align-items:center;gap:6px;
  font-family:var(--mono);font-size:10px;letter-spacing:.24em;color:var(--muted);text-transform:uppercase;
  z-index:2;
}
.hero__scroll svg{width:12px;height:36px;}
.hero__scroll svg line{stroke:var(--accent);stroke-width:1;stroke-dasharray:36;animation:scrollLine 2.5s ease infinite;}
@keyframes scrollLine{0%{stroke-dashoffset:36}50%{stroke-dashoffset:0}100%{stroke-dashoffset:-36}}

/* ============================================================
   ABOUT
============================================================ */
.about{}
.about__banner{
  position:relative;width:100%;aspect-ratio:21/9;
  margin-bottom:80px;
  border:1px solid var(--line);border-radius:6px;overflow:hidden;
  background:var(--bg-2);
}
.about__banner img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;
  filter:brightness(.55) saturate(.85);
  will-change:transform;
}
.about__banner::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(5,5,5,.45) 0%, rgba(5,5,5,.1) 40%, rgba(5,5,5,.85) 100%),
    radial-gradient(circle at 20% 60%, rgba(0,255,156,.10), transparent 50%);
  pointer-events:none;
}
.about__banner-cap{
  position:absolute;left:24px;bottom:18px;z-index:2;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--accent);
  text-transform:uppercase;
}
.about__grid{
  display:grid;grid-template-columns:1.4fr 1fr;gap:80px;align-items:flex-start;
}
.about__bio p{
  font-size:clamp(16px,1.25vw,19px);color:var(--ink-soft);
  margin-bottom:20px;line-height:1.65;
}
.about__bio p strong{color:#fff;}
.about__tags{
  display:flex;flex-wrap:wrap;gap:8px;margin-top:30px;
}
.about__tags li{
  padding:7px 14px;border:1px solid var(--line-2);border-radius:99px;
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--ink-soft);
  text-transform:uppercase;
  transition:border-color .3s,color .3s,box-shadow .3s;
}
.about__tags li:hover{border-color:var(--accent);color:var(--accent);box-shadow:var(--glow-sm);}

.about__stats{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
  border-left:1px solid var(--line);
  padding-left:50px;
}
.stat{
  display:flex;flex-direction:column;gap:6px;
  padding:18px 0;border-bottom:1px dashed var(--line);
}
.stat strong{
  font-family:var(--display);font-weight:400;
  font-size:clamp(40px,4.4vw,64px);line-height:1;color:#fff;
  letter-spacing:-0.02em;
}
.stat span{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);}

/* ============================================================
   EXPERTISE (cards)
============================================================ */
.cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  perspective:1200px;
}
.card{
  position:relative;
  padding:32px 28px 28px;
  border:1px solid var(--line);
  border-radius:6px;
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  transform-style:preserve-3d;
  transition:border-color .4s,box-shadow .4s,transform .15s;
  overflow:hidden;
  min-height:280px;
  display:flex;flex-direction:column;gap:14px;
  will-change:transform;
}
.card::before{
  content:"";position:absolute;inset:-1px;border-radius:6px;padding:1px;
  background:linear-gradient(140deg, transparent 40%, var(--accent) 60%, transparent 80%);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .5s;
  pointer-events:none;
}
.card:hover{border-color:var(--line-2);box-shadow:0 30px 80px -30px rgba(0,255,156,.25);}
.card:hover::before{opacity:1;}
.card__num{
  position:absolute;top:18px;right:22px;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--muted);
}
.card__ico{
  width:32px;height:32px;color:var(--accent);
  filter:drop-shadow(0 0 12px rgba(0,255,156,.5));
  margin-bottom:8px;
}
.card h3{
  font-family:var(--display);font-weight:500;font-size:22px;color:#fff;
  letter-spacing:-0.01em;
}
.card p{font-size:14px;color:var(--ink-soft);line-height:1.6;}

/* ============================================================
   TECH STACK
============================================================ */
.stack__grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
  margin-bottom:60px;
}
.chip{
  position:relative;
  display:flex;flex-direction:column;gap:6px;
  padding:24px 22px;
  border:1px solid var(--line);border-radius:4px;
  background:var(--panel);
  transition:border-color .4s,background .4s,transform .35s var(--ease-out),box-shadow .4s;
}
.chip:hover{
  border-color:var(--accent);
  background:rgba(0,255,156,0.04);
  transform:translateY(-3px);
  box-shadow:var(--glow-sm);
}
.chip__mark{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:6px;
  background:rgba(0,255,156,.08);
  border:1px solid rgba(0,255,156,.3);
  font-family:var(--display);font-weight:600;font-size:13px;
  color:var(--accent);
  text-shadow:0 0 12px rgba(0,255,156,.6);
  margin-bottom:8px;
}
.chip__name{font-family:var(--display);font-weight:500;font-size:16px;color:#fff;}
.chip__role{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;}

.stack__marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:30px 0;overflow:hidden;
}
.stack__marquee .ticker__track{
  font-family:var(--display);font-size:clamp(28px,4vw,56px);
  font-weight:300;letter-spacing:-0.01em;color:#fff;text-transform:none;
  animation-duration:50s;
}

/* ============================================================
   PROJECTS
============================================================ */
.proj-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:20px;
  perspective:1400px;
}
.proj{
  grid-column:span 3;
  display:flex;flex-direction:column;gap:14px;
  transition:transform .15s;
  will-change:transform;
  transform-style:preserve-3d;
}
.proj--lg{grid-column:span 6;}
.proj__cover{
  position:relative;width:100%;aspect-ratio:5/4;
  background:var(--bg-2);
  border:1px solid var(--line);border-radius:4px;overflow:hidden;
  transition:border-color .4s,box-shadow .4s;
}
.proj--lg .proj__cover{aspect-ratio:5/3;}
.proj__cover img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;
  transition:transform 1s var(--ease-out),filter .5s;
  filter:saturate(.9) brightness(.78);
}
.proj:hover .proj__cover{border-color:var(--accent);box-shadow:0 30px 80px -30px rgba(0,255,156,.4);}
.proj:hover .proj__cover img{transform:scale(1.06);filter:saturate(1) brightness(.92);}
.proj__cover::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 50%, rgba(0,0,0,0.55) 100%);
  pointer-events:none;
}

.corner{
  position:absolute;width:14px;height:14px;border:1px solid var(--accent);
  opacity:0;transition:opacity .35s, transform .35s var(--ease-out);
}
.corner.tl{top:10px;left:10px;border-right:0;border-bottom:0;}
.corner.tr{top:10px;right:10px;border-left:0;border-bottom:0;}
.corner.bl{bottom:10px;left:10px;border-right:0;border-top:0;}
.corner.br{bottom:10px;right:10px;border-left:0;border-top:0;}
.proj:hover .corner{opacity:1;transform:scale(1.4);}

.proj__meta{
  display:flex;justify-content:space-between;align-items:flex-start;gap:18px;
}
.proj__meta h3{font-family:var(--display);font-weight:500;font-size:18px;color:#fff;letter-spacing:-0.01em;}
.proj__meta span{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase;display:block;margin-top:4px;}
.tags{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end;}
.tags li{
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;
  padding:4px 10px;border:1px solid var(--line-2);border-radius:99px;
  color:var(--ink-soft);text-transform:uppercase;
}

/* ============================================================
   TRADING
============================================================ */
.trading{position:relative;overflow:hidden;}
.trading__chart{
  position:absolute;inset:0;width:100%;height:100%;
  opacity:.5;pointer-events:none;z-index:0;
}
.trading__inner{position:relative;z-index:2;}
.trading__panel{
  margin-top:60px;
  display:grid;grid-template-columns:repeat(4,1fr) 1.6fr;gap:20px;
  padding:32px;
  border:1px solid var(--line);border-radius:6px;
  background:rgba(0,0,0,0.55);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  position:relative;
}
.trading__panel::before{
  content:"";position:absolute;inset:-1px;border-radius:6px;padding:1px;
  background:linear-gradient(120deg, transparent 30%, rgba(0,255,156,.4) 50%, transparent 70%);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  pointer-events:none;
}
.metric{display:flex;flex-direction:column;gap:8px;padding:6px 0;}
.metric .lab{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.16em;text-transform:uppercase;}
.metric strong{
  font-family:var(--display);font-weight:400;
  font-size:clamp(28px,3.2vw,48px);line-height:1;color:#fff;letter-spacing:-0.02em;
}
.metric--status{justify-self:end;align-self:center;text-align:right;}
.metric--status .status-line{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:12px;color:var(--accent);letter-spacing:.1em;
}

.trading__quote{
  margin-top:60px;max-width:780px;
  font-family:var(--display);font-weight:300;
  font-size:clamp(22px,2.4vw,34px);line-height:1.35;color:#fff;letter-spacing:-0.01em;
  border-left:1px solid var(--accent);
  padding:14px 0 14px 28px;
}
.trading__quote::after{content:"";display:block;width:30px;height:1px;background:var(--accent);margin-top:24px;box-shadow:var(--glow-sm);}

/* ============================================================
   TESTIMONIALS
============================================================ */
.quotes__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}
.qcard{
  padding:32px 28px;
  border:1px solid var(--line);border-radius:6px;
  background:var(--panel);
  transition:border-color .4s,box-shadow .4s,transform .35s var(--ease-out);
}
.qcard:hover{border-color:var(--accent);box-shadow:var(--glow-sm);transform:translateY(-3px);}
.qcard blockquote{
  font-family:var(--display);font-weight:300;font-size:18px;line-height:1.55;color:#fff;
  letter-spacing:-0.005em;margin-bottom:24px;
}
.qcard figcaption{display:flex;align-items:center;gap:14px;font-size:13px;color:var(--ink-soft);}
.qcard__avatar{
  width:42px;height:42px;border-radius:50%;
  background:rgba(0,255,156,.10);
  border:1px solid rgba(0,255,156,.3);
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--display);font-weight:500;color:var(--accent);font-size:13px;
}
.qcard strong{display:block;font-weight:500;color:#fff;font-size:14px;}
.qcard span{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--muted);text-transform:uppercase;}

/* ============================================================
   CONTACT
============================================================ */
.h-contact{
  font-family:var(--display);font-weight:400;
  font-size:clamp(40px,6vw,96px);line-height:1.02;letter-spacing:-0.03em;color:#fff;
}
.form{
  max-width:880px;margin:60px auto 40px;
  display:grid;grid-template-columns:1fr 1fr;gap:18px 22px;
  padding:36px;
  border:1px solid var(--line);border-radius:8px;
  background:rgba(255,255,255,0.02);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  position:relative;
}
.form::before{
  content:"";position:absolute;inset:-1px;border-radius:8px;padding:1px;
  background:linear-gradient(135deg, transparent 50%, rgba(0,255,156,.35) 80%, transparent 100%);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  pointer-events:none;opacity:.7;
}
.field{display:flex;flex-direction:column;gap:8px;position:relative;}
.field--full{grid-column:1 / -1;}
.field label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;}
.field input,
.field textarea,
.field select{
  width:100%;
  padding:14px 16px;
  background:rgba(0,0,0,0.4);
  border:1px solid var(--line-2);border-radius:4px;
  color:#fff;font:inherit;
  transition:border-color .3s,box-shadow .3s,background .3s;
}
.field textarea{resize:vertical;min-height:120px;font-family:inherit;}
.field input:focus,
.field textarea:focus,
.field select:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 4px rgba(0,255,156,.10),0 0 28px rgba(0,255,156,.25);
}
.select{position:relative;}
.select select{appearance:none;-webkit-appearance:none;padding-right:42px;cursor:none;}
.select svg{position:absolute;right:14px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--accent);pointer-events:none;}
.form__send{display:flex;align-items:center;justify-content:space-between;gap:20px;}
.form__sent{font-family:var(--mono);font-size:12px;color:var(--accent);letter-spacing:.1em;opacity:0;transition:opacity .4s;}
.form__sent.is-on{opacity:1;}

.contact__alt{
  max-width:880px;margin:30px auto 0;
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
  padding:24px 0;border-top:1px solid var(--line);
}
.contact__alt .lab{display:block;font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase;margin-bottom:6px;}
.contact__alt a{color:#fff;border-bottom:1px solid var(--line-2);padding-bottom:1px;transition:color .3s,border-color .3s;}
.contact__alt a:hover{color:var(--accent);border-color:var(--accent);}

/* ============================================================
   FOOTER
============================================================ */
.foot{
  padding:80px var(--pad) 30px;
  border-top:1px solid var(--line);
  position:relative;overflow:hidden;
}
.foot__top{
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;
  padding-bottom:40px;border-bottom:1px solid var(--line);
}
.foot__tag{margin-top:18px;font-size:13px;color:var(--ink-soft);max-width:36ch;}
.foot__nav{display:flex;flex-direction:column;gap:10px;}
.foot__nav a{font-size:13px;color:var(--ink-soft);transition:color .3s;position:relative;width:fit-content;}
.foot__nav a::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--accent);
  transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease-out);
}
.foot__nav a:hover{color:var(--accent);}
.foot__nav a:hover::after{transform:scaleX(1);transform-origin:left;}

.foot__mark{
  font-family:var(--display);font-weight:600;
  font-size:clamp(60px,16vw,260px);
  letter-spacing:-0.04em;
  text-align:center;
  background:linear-gradient(180deg, rgba(255,255,255,0.08), rgba(0,255,156,0.08));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  line-height:.95;margin:40px 0 -28px;
  user-select:none;
}

.foot__base{
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--muted);
  text-transform:uppercase;padding-top:24px;border-top:1px solid var(--line);
}

/* ============================================================
   RESPONSIVE
============================================================ */
@media (max-width:1100px){
  .cards{grid-template-columns:repeat(2,1fr);}
  .stack__grid{grid-template-columns:repeat(3,1fr);}
  .trading__panel{grid-template-columns:repeat(2,1fr);}
  .metric--status{grid-column:1 / -1;text-align:left;justify-self:start;}
  .quotes__grid{grid-template-columns:1fr;}
  .hero__bottom{grid-template-columns:1fr;}
  .hero__actions{justify-content:flex-start;}
  .about__grid{grid-template-columns:1fr;gap:50px;}
  .about__stats{border-left:0;padding-left:0;border-top:1px solid var(--line);padding-top:30px;}
  .proj-grid{grid-template-columns:repeat(2,1fr);}
  .proj,.proj--lg{grid-column:span 2;}
  .foot__top{grid-template-columns:1fr;gap:30px;}
}
@media (max-width:720px){
  .nav{grid-template-columns:1fr auto;}
  .nav__menu{display:none;}
  .nav__name{display:none;}
  .cards{grid-template-columns:1fr;}
  .stack__grid{grid-template-columns:repeat(2,1fr);}
  .form{grid-template-columns:1fr;padding:24px;}
  .contact__alt{grid-template-columns:repeat(2,1fr);}
  .hero__title{font-size:clamp(40px,12vw,80px);}
  .hero__ticker{position:relative;bottom:0;}
  .trading__panel{grid-template-columns:1fr;}
  .proj-grid{grid-template-columns:1fr;}
  .proj,.proj--lg{grid-column:span 1;}
}

@media (prefers-reduced-motion: reduce){
  *{animation:none !important;transition:none !important;}
  [data-reveal]{opacity:1;transform:none;}
}
