/* === RESET & TOKENS === */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#050508;--bg-2:#0c0c12;--bg-3:#13131b;--bg-card:#161620;--bg-card-h:#1c1c2a;
  --text:#f0f0f3;--text-2:#a1a1aa;--text-3:#63637a;
  --accent:#22d3ee;--accent-2:#a78bfa;--accent-dim:rgba(34,211,238,.08);--accent-glow:rgba(34,211,238,.25);
  --border:rgba(255,255,255,.06);--border-h:rgba(255,255,255,.12);
  --radius:14px;--radius-sm:8px;
  --font:'Inter',system-ui,sans-serif;--mono:'JetBrains Mono',monospace;
  --ease:cubic-bezier(.4,0,.2,1);--max-w:1180px;
}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden;cursor:none}
a{color:var(--accent);text-decoration:none;cursor:none;transition:.3s var(--ease)}
a:hover{color:#67e8f9}
img{max-width:100%;display:block}
::selection{background:var(--accent);color:var(--bg)}
.container{max-width:var(--max-w);margin:0 auto;padding:0 1.5rem;width:100%}
.gradient-text{background:linear-gradient(135deg,var(--accent),var(--accent-2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

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

/* === CURSOR === */
.cursor{width:8px;height:8px;background:var(--accent);border-radius:50%;position:fixed;pointer-events:none;z-index:9999;transition:transform .1s ease;mix-blend-mode:difference}
.cursor-follower{width:40px;height:40px;border:1.5px solid var(--accent);border-radius:50%;position:fixed;pointer-events:none;z-index:9998;transition:transform .12s ease,width .3s,height .3s,border-color .3s,background .3s;transform:translate(-50%,-50%)}
.cursor-follower.hover{width:64px;height:64px;border-color:var(--accent-2);background:rgba(167,139,250,.06)}
@media(max-width:768px){.cursor,.cursor-follower{display:none}body{cursor:auto}a,.btn{cursor:pointer}}

/* === NAV === */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.25rem 0;transition:.3s var(--ease)}
.nav.scrolled{background:rgba(5,5,8,.88);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:.85rem 0}
.nav__inner{display:flex;align-items:center;justify-content:space-between}
.nav__logo{font-family:var(--mono);font-size:1.2rem;font-weight:700;color:var(--text)}
.nav__logo span{color:var(--accent)}
.nav__links{display:flex;gap:2.25rem}
.nav__link{color:var(--text-2);font-size:.88rem;font-weight:500;position:relative}
.nav__link::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--accent);transition:width .3s ease}
.nav__link:hover{color:var(--text)}.nav__link:hover::after{width:100%}
.nav__cta{display:inline-flex}
.nav__burger{display:none;background:none;border:none;width:28px;height:20px;position:relative;cursor:none}
.nav__burger span{display:block;width:100%;height:2px;background:var(--text);position:absolute;left:0;transition:.3s var(--ease)}
.nav__burger span:nth-child(1){top:0}.nav__burger span:nth-child(2){top:50%;transform:translateY(-50%)}.nav__burger span:nth-child(3){bottom:0}
.nav__burger.active span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}
.nav__burger.active span:nth-child(2){opacity:0}
.nav__burger.active span:nth-child(3){bottom:50%;transform:translateY(50%) rotate(-45deg)}
.mobile-menu{position:fixed;inset:0;background:var(--bg);z-index:99;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;opacity:0;pointer-events:none;transition:.3s var(--ease)}
.mobile-menu.active{opacity:1;pointer-events:all}
.mobile-menu__link{font-size:1.75rem;font-weight:600;color:var(--text-2)}.mobile-menu__link:hover{color:var(--accent)}
@media(max-width:768px){.nav__links,.nav__cta{display:none}.nav__burger{display:block}}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.6rem;border-radius:50px;font-weight:600;font-size:.88rem;transition:.3s var(--ease);border:none;cursor:none;white-space:nowrap}
.btn--sm{padding:.55rem 1.2rem;font-size:.82rem}
.btn--lg{padding:1rem 2rem;font-size:.95rem}
.btn--xl{padding:1.1rem 2.5rem;font-size:1rem}
.btn--primary{background:var(--accent);color:var(--bg)}
.btn--primary:hover{background:#67e8f9;color:var(--bg);transform:translateY(-2px);box-shadow:0 12px 35px var(--accent-glow)}
.btn--outline{background:transparent;border:1.5px solid var(--border-h);color:var(--text)}
.btn--outline:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}

/* === HERO === */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;padding:7rem 0 4rem;overflow:hidden}
.hero__bg{position:absolute;inset:0}
.hero__grid-lines{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,black 20%,transparent 70%)}
.hero__orb{position:absolute;border-radius:50%;filter:blur(100px);animation:float 10s ease-in-out infinite}
.hero__orb--1{width:500px;height:500px;top:-15%;right:-5%;background:radial-gradient(circle,rgba(34,211,238,.15),transparent 70%)}
.hero__orb--2{width:400px;height:400px;bottom:-10%;left:-10%;background:radial-gradient(circle,rgba(167,139,250,.1),transparent 70%);animation-delay:-5s}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(20px,-20px) scale(1.05)}}
.hero__inner{display:grid;grid-template-columns:1.1fr 1fr;gap:4rem;align-items:center;position:relative;z-index:1}
.hero__badge{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--mono);font-size:.8rem;color:var(--accent);margin-bottom:1.5rem;background:var(--accent-dim);padding:.4rem .9rem;border-radius:20px;border:1px solid rgba(34,211,238,.15)}
.pulse-dot{width:8px;height:8px;background:#22c55e;border-radius:50%;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
.hero__title{font-size:clamp(2.5rem,5.5vw,4.2rem);font-weight:800;line-height:1.08;margin-bottom:1.5rem;letter-spacing:-.02em}
.hero__desc{font-size:1.05rem;color:var(--text-2);line-height:1.7;margin-bottom:2rem;max-width:520px}
.hero__desc strong{color:var(--text);font-weight:600}
.hero__actions{display:flex;gap:1rem;margin-bottom:3rem;flex-wrap:wrap}
.hero__stats{display:flex;gap:2.5rem}
.stat__number{font-size:2.2rem;font-weight:800;font-family:var(--mono);color:var(--text)}
.stat__plus{color:var(--accent);font-weight:700;font-size:1.5rem}
.stat__label{display:block;font-size:.75rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;margin-top:.2rem}

/* === TERMINAL === */
.terminal{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:0 30px 60px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.03)}
.terminal__bar{display:flex;align-items:center;gap:.75rem;padding:.7rem 1rem;background:rgba(255,255,255,.02);border-bottom:1px solid var(--border)}
.terminal__dots{display:flex;gap:6px}
.terminal__dots i{width:11px;height:11px;border-radius:50%;display:block}
.terminal__dots i:nth-child(1){background:#ef4444}.terminal__dots i:nth-child(2){background:#eab308}.terminal__dots i:nth-child(3){background:#22c55e}
.terminal__title{font-family:var(--mono);font-size:.72rem;color:var(--text-3)}
.terminal__body{padding:1.25rem;min-height:240px;font-family:var(--mono);font-size:.82rem}
.term-line{margin-bottom:.4rem;display:flex;align-items:center;gap:.5rem;opacity:0;transition:opacity .3s ease}
.term-line.show{opacity:1}
.term-prompt{color:var(--accent);font-weight:700}
.term-cmd{color:var(--text)}
.term-output{padding-left:1.2rem;color:var(--text-2);font-size:.78rem}
.term-success span{color:#22c55e}
.term-cursor::after{content:'▋';animation:blink 1s step-end infinite;color:var(--accent)}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

.scroll-indicator{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;font-size:.7rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.12em}
.scroll-indicator__line{width:1px;height:36px;background:linear-gradient(to bottom,var(--accent),transparent);animation:scrollAnim 2s ease-in-out infinite}
@keyframes scrollAnim{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

@media(max-width:768px){
  .hero__inner{grid-template-columns:1fr;gap:2.5rem}
  .hero__visual{order:-1}
  .hero__stats{gap:1.5rem}
  .hero{padding:8rem 0 3rem}
}

/* === SECTIONS === */
.section{padding:6rem 0}
.section--dark{background:var(--bg-2)}
.section__header{margin-bottom:3.5rem}
.section__label{display:inline-block;font-family:var(--mono);font-size:.78rem;color:var(--accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.6rem}
.section__title{font-size:clamp(2rem,4vw,2.8rem);font-weight:700;letter-spacing:-.01em}
.section__desc{color:var(--text-2);font-size:1rem;margin-top:.75rem;max-width:500px}

/* === SERVICE CARDS === */
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}
.card--service{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;transition:.35s var(--ease);position:relative;overflow:hidden}
.card--service::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-2));transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.card--service:hover{border-color:var(--border-h);background:var(--bg-card-h);transform:translateY(-4px)}.card--service:hover::before{transform:scaleX(1)}
.card__icon{color:var(--accent);margin-bottom:1.25rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--accent-dim);border-radius:10px}
.card__title{font-size:1.15rem;font-weight:600;margin-bottom:.6rem}
.card__desc{color:var(--text-2);font-size:.88rem;line-height:1.65;margin-bottom:1.25rem}
.card__tags{display:flex;flex-wrap:wrap;gap:.4rem}
.card__tags span{font-size:.7rem;font-family:var(--mono);padding:.2rem .6rem;background:var(--accent-dim);color:var(--accent);border-radius:20px}
@media(max-width:768px){.services-grid{grid-template-columns:1fr}}

/* === PROJECTS === */
.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}
.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;transition:.35s var(--ease)}
.project-card:hover{border-color:var(--border-h);transform:translateY(-4px);box-shadow:0 20px 40px rgba(0,0,0,.3)}
.project-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.project-card__company{font-family:var(--mono);font-size:.78rem;color:var(--accent);background:var(--accent-dim);padding:.2rem .6rem;border-radius:4px}
.project-card__year{font-size:.75rem;color:var(--text-3);font-family:var(--mono)}
.project-card__title{font-size:1.15rem;font-weight:600;margin-bottom:.75rem}
.project-card__desc{color:var(--text-2);font-size:.88rem;line-height:1.65;margin-bottom:1.25rem}
.project-card__tech{display:flex;flex-wrap:wrap;gap:.4rem}
.project-card__tech span{font-size:.7rem;font-family:var(--mono);padding:.2rem .6rem;background:rgba(167,139,250,.08);color:var(--accent-2);border-radius:20px}
@media(max-width:768px){.projects-grid{grid-template-columns:1fr}}

/* === TIMELINE === */
.timeline{position:relative;padding-left:2.5rem}
.timeline::before{content:'';position:absolute;left:8px;top:8px;bottom:8px;width:1px;background:linear-gradient(to bottom,var(--accent),var(--border),transparent)}
.timeline__item{position:relative;padding-bottom:2rem}
.timeline__item:last-child{padding-bottom:0}
.timeline__dot{position:absolute;left:-2.5rem;top:.75rem;width:16px;height:16px;border-radius:50%;background:var(--bg);border:2px solid var(--accent);z-index:1}
.timeline__card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem 1.75rem;transition:.3s var(--ease)}
.timeline__card:hover{border-color:var(--border-h);transform:translateX(6px)}
.timeline__top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;flex-wrap:wrap;gap:.5rem}
.timeline__role{font-size:1.05rem;font-weight:600}
.timeline__company{font-family:var(--mono);font-size:.82rem;color:var(--accent);display:block;margin-top:.2rem}
.timeline__date{font-size:.75rem;color:var(--text-3);font-family:var(--mono);white-space:nowrap}
.timeline__desc{color:var(--text-2);font-size:.88rem;line-height:1.65}

/* === CERTS === */
.certs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.cert{display:flex;align-items:center;gap:1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem;transition:.3s var(--ease)}
.cert:hover{border-color:var(--accent);transform:translateY(-2px)}
.cert__badge{font-family:var(--mono);font-size:.82rem;font-weight:700;color:var(--bg);background:var(--accent);width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:10px;flex-shrink:0}
.cert__badge--purple{background:var(--accent-2)}
.cert__badge--orange{background:#f97316}
.cert__badge--blue{background:#3b82f6}
.cert__info h4{font-size:.92rem;font-weight:600;margin-bottom:.15rem}
.cert__info span{font-size:.78rem;color:var(--text-3)}
@media(max-width:768px){.certs-grid{grid-template-columns:1fr}}

/* === CONTACT === */
.contact-wrapper{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:4rem;display:grid;grid-template-columns:1.2fr auto;gap:3rem;align-items:center}
.contact__title{font-size:clamp(1.8rem,3.5vw,2.5rem);font-weight:700;margin:.75rem 0 1rem;line-height:1.2}
.contact__desc{color:var(--text-2);font-size:.95rem;line-height:1.7;margin-bottom:2rem;max-width:500px}
.contact__links{display:flex;flex-direction:column;gap:.75rem}
.contact__link{display:inline-flex;align-items:center;gap:.75rem;color:var(--text-2);font-size:.9rem;transition:.3s var(--ease)}
.contact__link:hover{color:var(--accent)}
.contact__link svg{flex-shrink:0}
.contact__cta{text-align:center}
@media(max-width:768px){.contact-wrapper{grid-template-columns:1fr;padding:2.5rem 1.5rem;gap:2rem}}

/* === FOOTER === */
.footer{padding:2rem 0;border-top:1px solid var(--border)}
.footer__inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer__left{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}
.footer__copy{font-size:.82rem;color:var(--text-3)}
.footer__location{font-size:.78rem;color:var(--text-3)}
.footer__links{display:flex;gap:1.5rem}
.footer__links a{font-size:.82rem;color:var(--text-2)}.footer__links a:hover{color:var(--accent)}

/* === ANIMATIONS === */
.anim{opacity:0;transform:translateY(32px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.anim.visible{opacity:1;transform:translateY(0)}

/* === DEVOPS LIFECYCLE === */
.lifecycle{display:flex;flex-direction:column;align-items:center;gap:2.5rem}
@media(min-width:900px){.lifecycle{flex-direction:row;justify-content:center;gap:4rem}}
.lifecycle__ring{position:relative;width:420px;height:420px;flex-shrink:0}
@media(max-width:560px){.lifecycle__ring{width:300px;height:300px}}
.lifecycle__svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.lifecycle__dash{animation:lcSpin 28s linear infinite;transform-origin:center}
@keyframes lcSpin{to{transform:rotate(360deg)}}
.lifecycle__center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}
.lifecycle__inf{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,var(--accent),var(--accent-2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1;animation:lcPulse 3s ease-in-out infinite}
.lifecycle__center span{font-family:var(--mono);font-size:.65rem;color:var(--text-3);letter-spacing:.1em;display:block;margin-top:.2rem}
@keyframes lcPulse{0%,100%{opacity:1}50%{opacity:.5}}
.lc-node{position:absolute;top:50%;left:50%;width:60px;height:60px;margin:-30px 0 0 -30px;transform:rotate(var(--a)) translateY(-140px) rotate(calc(-1 * var(--a)));background:var(--bg-2);border:2px solid rgba(34,211,238,.3);border-radius:50%;cursor:none;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:1.2rem;transition:.3s var(--ease);z-index:2;color:var(--text)}
.lc-node i{font-style:normal;font-size:.55rem;font-weight:600;color:var(--text-3);font-family:var(--mono);margin-top:.1rem}
@media(max-width:560px){.lc-node{width:46px;height:46px;margin:-23px 0 0 -23px;transform:rotate(var(--a)) translateY(-100px) rotate(calc(-1 * var(--a)));font-size:1rem}.lc-node i{font-size:.5rem}}
.lc-node:hover,.lc-node.active{border-color:var(--accent);background:rgba(34,211,238,.1);transform:rotate(var(--a)) translateY(-140px) rotate(calc(-1 * var(--a))) scale(1.18);box-shadow:0 0 25px rgba(34,211,238,.2)}
@media(max-width:560px){.lc-node:hover,.lc-node.active{transform:rotate(var(--a)) translateY(-100px) rotate(calc(-1 * var(--a))) scale(1.18)}}
.lifecycle__detail{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;max-width:380px;width:100%;opacity:0;transform:translateY(10px);transition:.4s var(--ease)}
.lifecycle__detail.visible{opacity:1;transform:translateY(0)}
.lifecycle__detail h3{font-size:1.15rem;font-weight:700;margin-bottom:.75rem}
.lifecycle__detail p{color:var(--text-2);font-size:.85rem;line-height:1.65;margin-bottom:1.25rem}
.lifecycle__tags{display:flex;flex-wrap:wrap;gap:.4rem}
.lc-tag{font-family:var(--mono);font-size:.7rem;font-weight:500;padding:.3rem .7rem;border-radius:20px;background:var(--accent-dim);color:var(--accent);border:1px solid rgba(34,211,238,.12);opacity:0;animation:lcFade .3s ease forwards}
.lc-tag:nth-child(2){animation-delay:.05s}.lc-tag:nth-child(3){animation-delay:.1s}.lc-tag:nth-child(4){animation-delay:.15s}.lc-tag:nth-child(5){animation-delay:.2s}.lc-tag:nth-child(6){animation-delay:.25s}
.lc-tag--purple{background:rgba(167,139,250,.08);color:var(--accent-2);border-color:rgba(167,139,250,.12)}
.lc-tag--green{background:rgba(34,197,94,.08);color:#22c55e;border-color:rgba(34,197,94,.12)}
.lc-tag--orange{background:rgba(249,115,22,.08);color:#f97316;border-color:rgba(249,115,22,.12)}
@keyframes lcFade{to{opacity:1}}
