@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;600;700;800&family=Spline+Sans+Mono:wght@500;600&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --green:#0A2514;
  --lime:#86E11F;
  --bg:#0a0a0a;
  --card:#141414;
  --z4:#a1a1aa;
  --z5:#71717a;
  --bdr:rgba(10,37,20,.5);
}

html{scroll-behavior:smooth}
body{font-family:'Poppins',sans-serif;background:var(--bg);color:#fff;overflow-x:hidden;-webkit-font-smoothing:antialiased}
::selection{background:var(--lime);color:#000}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;font-family:inherit}
input,textarea{font-family:inherit}
.mono{font-family:'Spline Sans Mono',monospace}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.scrollbar-hide::-webkit-scrollbar{display:none}
.scrollbar-hide{-ms-overflow-style:none;scrollbar-width:none}

/* ── Navbar ── */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:clamp(1rem,2vw,1.5rem) clamp(1rem,4vw,3rem);
  background:rgba(10,10,10,.7);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.navbar-logo img{height:clamp(1.8rem,3vw,2.5rem);object-fit:contain}
.navbar-links{display:flex;align-items:center;gap:clamp(1rem,2vw,2rem);font-size:clamp(.7rem,1vw,.875rem);font-weight:500}
.navbar-links a{color:var(--z4);transition:color .2s}
.navbar-links a:hover{color:#fff}
.navbar-links a.active{background:var(--lime);color:#000;padding:.375rem 1rem;border-radius:9999px}
.lang-toggle{background:none;color:var(--z4);font-size:.75rem;padding:.25rem .5rem;border:1px solid var(--z5);border-radius:.25rem;transition:color .2s,border-color .2s;margin-left:.5rem}
.lang-toggle:hover{color:var(--lime);border-color:var(--lime)}
.lang-toggle .active-lang{color:#fff;font-weight:700}
.lang-toggle-mobile{background:none;color:var(--z4);font-size:1rem;padding:.5rem 1rem;border:1px solid var(--z5);border-radius:.25rem;margin-top:1rem}
.lang-toggle-mobile:hover{color:var(--lime);border-color:var(--lime)}
.lang-toggle-mobile .active-lang{color:#fff;font-weight:700}

/* Hamburger button — hidden on desktop */
.nav-burger{display:none;background:none;padding:.5rem;position:relative;width:2rem;height:1.5rem;flex-direction:column;justify-content:space-between}
.nav-burger span{display:block;width:100%;height:2px;background:var(--lime);border-radius:2px;transition:transform .3s,opacity .3s}
.nav-burger.open span:nth-child(1){transform:translateY(.55rem) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-.55rem) rotate(-45deg)}

/* Mobile nav overlay */
.mobile-nav{display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:99;background:rgba(10,10,10,.95);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;opacity:0;pointer-events:none;transition:opacity .3s}
.mobile-nav.open{opacity:1;pointer-events:auto}
.mobile-nav a{color:#fff;font-size:1.25rem;font-weight:600;letter-spacing:.05em;transition:color .2s}
.mobile-nav a:hover{color:var(--lime)}

/* ── Hero ── full viewport, h1 dead center ── */
.hero{
  position:relative;width:100%;height:100vh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:0 clamp(1rem,4vw,3rem);
  overflow:hidden;
}
.hero-radial{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse 80% 60% at 70% 20%,rgba(10,37,20,.7),transparent 70%);
}

.hero-greeting{
  display:flex;align-items:center;justify-content:center;gap:.75rem;
  margin-top:auto;margin-bottom:clamp(1.5rem,3vh,2.5rem);z-index:2;position:relative;
}
.hero-greeting p{color:var(--lime);font-weight:500;letter-spacing:.05em;font-size:clamp(.875rem,1.2vw,1rem)}

.hero-inner{position:relative;width:100%;max-width:min(72rem,95vw);z-index:1}

.hero h1{
  font-size:clamp(2.5rem,8vw,7rem);font-weight:800;
  line-height:.88;letter-spacing:-.03em;text-transform:uppercase;position:relative;z-index:1;
}

/* Floating images — positioned on .hero (full viewport) with vw/vh */
.hero-float{
  position:absolute;z-index:3;border-radius:clamp(.75rem,1.5vw,1rem);overflow:hidden;
  border:3px solid var(--green);background:var(--card);
  box-shadow:0 20px 40px rgba(0,0,0,.4);
  cursor:grab;user-select:none;touch-action:none;will-change:transform;
}
.hero-float:active{cursor:grabbing}
.hero-float img{width:100%;height:100%;object-fit:cover;pointer-events:none}

/* float-1: left side, vertically centered */
.hero-float-1{
  width:clamp(6.5rem,12vw,13rem);height:clamp(9rem,17vw,18rem);
  left:clamp(1rem,2.5vw,6vw);top:clamp(30vh,38vh,42vh);
  animation:fl1 6s ease-in-out infinite alternate;
}
/* float-2: lower right corner area */
.hero-float-2{
  width:clamp(5rem,9vw,9rem);height:clamp(7rem,13vw,12rem);
  right:clamp(1rem,3vw,6vw);bottom:clamp(8vh,12vh,16vh);
  animation:fl2 7.5s ease-in-out infinite alternate;
}
/* float-3: upper right area */
.hero-float-3{
  width:clamp(4rem,7vw,7rem);height:clamp(5.5rem,10vw,9.5rem);
  right:clamp(10rem,22vw,30vw);top:clamp(10vh,14vh,18vh);
  animation:fl3 6.5s ease-in-out infinite alternate;
}

@keyframes fl1{from{transform:translateY(-1.5vh) rotate(-12deg)}to{transform:translateY(1.5vh) rotate(-3deg)}}
@keyframes fl2{from{transform:translateY(-1.2vh) rotate(8deg)}to{transform:translateY(1.2vh) rotate(18deg)}}
@keyframes fl3{from{transform:translateY(-1.2vh) rotate(0)}to{transform:translateY(1.2vh) rotate(10deg)}}

/* Role pills — positioned on .hero with vw/vh, always in view */
.hero-role{
  position:absolute;z-index:4;cursor:grab;user-select:none;touch-action:none;will-change:transform;
}
.hero-role:active{cursor:grabbing}
.hero-role span{
  display:block;background:var(--lime);color:#000;padding:.4em 1.1em;border-radius:9999px;
  font-weight:700;font-size:clamp(.8rem,1.1vw,1.05rem);white-space:nowrap;
  box-shadow:0 6px 20px rgba(134,225,31,.15);
}

/* r0=AI Consultant: lower right (swapped with Philosopher) */
.r0{right:clamp(4rem,12vw,20vw);bottom:clamp(18vh,24vh,30vh);animation:bob0 5.5s ease-in-out infinite alternate}
/* r1=Father: upper right */
.r1{right:clamp(3rem,10vw,16vw);top:clamp(18vh,24vh,30vh);animation:bob1 6.2s ease-in-out infinite alternate}
/* r2=Educator: upper center */
.r2{left:clamp(8rem,28vw,34vw);top:clamp(16vh,22vh,26vh);animation:bob2 5.8s ease-in-out infinite alternate}
/* r3=Transhuman: upper left */
.r3{left:clamp(2rem,6vw,10vw);top:clamp(12vh,16vh,20vh);animation:bob3 6.5s ease-in-out infinite alternate}
/* r4=Philosopher: lower left-center (swapped with AI Consultant) */
.r4{left:clamp(4rem,18vw,26vw);bottom:clamp(16vh,22vh,28vh);animation:bob4 6s ease-in-out infinite alternate}

/* r-mike: next to "Hi, I'm" greeting */
.r-mike{position:absolute;left:calc(100% + .75rem);top:50%;transform:translateY(-50%);animation:bobMike 5s ease-in-out infinite alternate}
@keyframes bobMike{from{transform:translateY(calc(-50% - .8vh)) rotate(-2deg)}to{transform:translateY(calc(-50% + .8vh)) rotate(2deg)}}

@keyframes bob0{from{transform:translateY(-1vh) rotate(-3deg)}to{transform:translateY(1vh) rotate(3deg)}}
@keyframes bob1{from{transform:translateY(-1.2vh) rotate(2deg)}to{transform:translateY(1.2vh) rotate(-2deg)}}
@keyframes bob2{from{transform:translateY(-1vh) rotate(-4deg)}to{transform:translateY(1vh) rotate(4deg)}}
@keyframes bob3{from{transform:translateY(-1.3vh) rotate(3deg)}to{transform:translateY(1.3vh) rotate(-3deg)}}
@keyframes bob4{from{transform:translateY(-.8vh) rotate(-2deg)}to{transform:translateY(.8vh) rotate(2deg)}}

/* Mobile hero tags — hidden on desktop */
.hero-tags-mobile{display:none}

/* Sparkles */
.sparkle{position:absolute;color:var(--green);pointer-events:none}
.sparkle-tr{top:38vh;right:22vw;width:clamp(2rem,3vw,3rem);height:clamp(2rem,3vw,3rem)}
.sparkle-bl{bottom:35vh;left:28vw;width:clamp(1.5rem,2vw,2rem);height:clamp(1.5rem,2vw,2rem)}

/* ── Ambient background glows ── */
.ambient-glow{position:absolute;border-radius:50%;pointer-events:none;z-index:0;filter:blur(80px);opacity:.35}
.about{position:relative}
.about::before{content:'';position:absolute;top:-10%;right:-5%;width:50vw;height:50vw;background:radial-gradient(circle,rgba(10,37,20,.7),transparent 65%);pointer-events:none;z-index:-1}
.services{position:relative}
.services::after{content:'';position:absolute;bottom:-20%;left:-5%;width:45vw;height:45vw;background:radial-gradient(circle,rgba(10,37,20,.6),transparent 65%);pointer-events:none;z-index:-1}
.portfolio{position:relative}
.portfolio::before{content:'';position:absolute;top:10%;left:50%;transform:translateX(-50%);width:60vw;height:30vw;background:radial-gradient(ellipse,rgba(10,37,20,.4),transparent 70%);pointer-events:none;z-index:-1}
.experience{position:relative}
.experience::after{content:'';position:absolute;top:20%;right:-5%;width:50vw;height:60vw;background:radial-gradient(circle,rgba(10,37,20,.6),transparent 65%);pointer-events:none;z-index:-1}
.faq{position:relative}
.faq::before{content:'';position:absolute;bottom:0;left:-5%;width:45vw;height:45vw;background:radial-gradient(circle,rgba(10,37,20,.6),transparent 65%);pointer-events:none;z-index:-1}

/* Scattered page sparkles */
.page-sparkle{position:absolute;pointer-events:none;z-index:1;opacity:.15;animation:sparkle-pulse 4s ease-in-out infinite}
.page-sparkle svg{width:100%;height:100%;stroke:var(--lime);fill:none;stroke-width:1.5}
@keyframes sparkle-pulse{0%,100%{opacity:.1;transform:scale(.8)}50%{opacity:.25;transform:scale(1)}}

/* Scroll arrow */
.hero-arrow{
  position:absolute;bottom:clamp(1.5rem,3vh,2.5rem);left:50%;transform:translateX(-50%);
  z-index:5;cursor:pointer;animation:arrBounce 2s ease-in-out infinite;
}
.hero-arrow img{width:clamp(1.5rem,2.5vw,2rem);height:clamp(1.5rem,2.5vw,2rem);transform:rotate(90deg);opacity:.7;transition:opacity .2s}
.hero-arrow:hover img{opacity:1}
@keyframes arrBounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* CTA — pushed toward bottom of hero */
.hero-cta-wrap{margin-top:auto;padding-bottom:clamp(4rem,8vh,7rem);z-index:5;transform:rotate(8deg) translateX(10%);transition:transform .3s;position:relative}
.hero-cta-wrap:hover{transform:rotate(0) translateX(10%)}
.hero-cta{
  display:inline-flex;align-items:center;gap:.75rem;
  background:var(--lime);color:#000;padding:clamp(.75rem,1.5vw,1rem) clamp(1.5rem,3vw,2.5rem);
  border-radius:9999px;font-weight:700;font-size:clamp(.9rem,1.2vw,1.125rem);transition:all .3s;
  box-shadow:0 0 30px rgba(134,225,31,.25);
}
.hero-cta:hover{background:#6bc416;box-shadow:0 0 40px rgba(134,225,31,.4)}
.hero-cta img{width:1.25rem;height:1.25rem;filter:brightness(0);transform:rotate(-45deg)}

/* ── About ── */
.about{padding:clamp(3rem,8vw,6rem) clamp(1rem,4vw,3rem);max-width:80rem;margin:0 auto}
.about-top{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,4rem);margin-bottom:clamp(3rem,5vw,5rem);align-items:center}
.about-top h2{font-size:clamp(1.5rem,3.5vw,3rem);font-weight:700;line-height:1.2}
.about-top h2 .sparkle-inline{display:inline;color:var(--lime);width:clamp(1.5rem,2.5vw,2rem);height:clamp(1.5rem,2.5vw,2rem);vertical-align:middle}
.about-paragraphs{display:flex;flex-direction:column;gap:1.5rem;color:var(--z4);font-size:clamp(.9rem,1.1vw,1.125rem)}

.about-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,1.5vw,1.5rem)}

.about-card{
  background:var(--card);border-radius:clamp(1rem,2vw,1.5rem);padding:clamp(1.25rem,2vw,2rem);
  display:flex;flex-direction:column;justify-content:space-between;
  border:1px solid var(--bdr);position:relative;overflow:hidden;transition:border-color .3s;
}
.about-card:hover{border-color:var(--lime)}
.about-card-label{font-size:.75rem;color:var(--z5);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem;display:flex;align-items:center;justify-content:space-between}

.reading-card{cursor:pointer}
.reading-card .book-icon{opacity:0;transition:opacity .3s;color:var(--lime)}
.reading-card:hover .book-icon{opacity:1}
.reading-card h3{font-size:clamp(1rem,1.5vw,1.25rem);font-weight:700;margin-bottom:.25rem;white-space:pre-line}
.reading-card .author{color:var(--z5);font-size:.875rem}
.book-cover-wrap{margin-top:1.5rem;display:flex;justify-content:center}
.book-cover{
  width:clamp(7rem,12vw,10rem);height:clamp(10rem,17vw,14rem);background:var(--green);border-radius:.5rem;overflow:hidden;
  position:relative;box-shadow:0 20px 40px rgba(0,0,0,.4);transform:rotate(12deg);transition:transform .5s;
}
.reading-card:hover .book-cover{transform:rotate(6deg)}
.book-cover img{width:100%;height:100%;object-fit:cover}
.book-cover .spine{display:none}
.book-genre{font-size:.875rem;color:var(--z5);letter-spacing:.05em}
.reading-card .overlay-gradient{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.6),transparent);opacity:0;transition:opacity .3s;z-index:0}
.reading-card:hover .overlay-gradient{opacity:1}

.work-step-content{min-height:clamp(8rem,12vw,10rem)}
.work-step-content h3{font-size:clamp(1.2rem,1.8vw,1.5rem);font-weight:700;margin-bottom:1rem}
.work-step-content p{color:var(--z4);font-size:clamp(.8rem,1vw,.875rem);line-height:1.6}
.work-steps-nav{display:flex;align-items:center;justify-content:space-between;margin-top:1.5rem;overflow:hidden;padding-bottom:0;gap:0;flex-wrap:wrap}
.work-steps-nav button{background:none;color:var(--z5);padding:.3rem .5rem;border-radius:9999px;font-size:clamp(.55rem,.75vw,.75rem);white-space:nowrap;transition:all .2s}
.work-steps-nav button.active{background:var(--lime);color:#000}

/* Library modal */
.modal-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:1rem;background:rgba(0,0,0,.8);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .3s}
.modal-overlay.open{opacity:1;pointer-events:auto}
.modal-content{background:var(--card);border:1px solid var(--green);border-radius:1.5rem;padding:clamp(1.5rem,3vw,2rem);max-width:56rem;width:100%;max-height:80vh;overflow-y:auto;position:relative;transform:scale(.95) translateY(20px);transition:transform .3s}
.modal-overlay.open .modal-content{transform:scale(1) translateY(0)}
.modal-close{position:absolute;top:1.5rem;right:1.5rem;padding:.5rem;border-radius:9999px;background:rgba(10,37,20,.5);color:var(--z4);transition:all .2s;line-height:0}
.modal-close:hover{background:var(--green);color:#fff}
.modal-content h2{font-size:clamp(1.5rem,2.5vw,1.875rem);font-weight:700;margin-bottom:.5rem}
.modal-content .subtitle{color:var(--z4);margin-bottom:2rem}
.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(8rem,1fr));gap:1.5rem}
.library-item{cursor:pointer}
.library-item .lib-cover{width:100%;aspect-ratio:2/3;background:var(--green);border-radius:.5rem;overflow:hidden;margin-bottom:.75rem;position:relative;box-shadow:0 10px 30px rgba(0,0,0,.3);transition:transform .3s}
.library-item:hover .lib-cover{transform:translateY(-.5rem)}
.library-item .lib-cover img{width:100%;height:100%;object-fit:cover}
.library-item .lib-cover .spine{position:absolute;left:0;top:0;bottom:0;width:.5rem;background:rgba(255,255,255,.2)}
.library-item .lib-cover .hover-overlay{position:absolute;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.library-item:hover .lib-cover .hover-overlay{opacity:1}
.library-item h4{font-weight:700;font-size:.875rem;margin-bottom:.25rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color .3s}
.library-item:hover h4{color:var(--lime)}
.library-item .lib-author{font-size:.75rem;color:var(--z5)}

/* ── Tidal Player ── */
.player{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%}
.player-carousel{position:relative;display:flex;align-items:center;justify-content:center;height:6rem;width:100%;max-width:230px;margin-bottom:2rem;margin-top:1rem}
.player-carousel img{position:absolute;width:74px;height:74px;border-radius:50%;object-fit:cover;border:3px solid var(--green);background:var(--green);transition:all .4s cubic-bezier(.4,0,.2,1)}
.player-carousel .art-prev{left:0;z-index:10;transform:scale(.8);opacity:.4;filter:brightness(.75);cursor:pointer}
.player-carousel .art-current{left:50%;transform:translateX(-50%) scale(1.15);z-index:30;opacity:1;box-shadow:0 8px 24px rgba(0,0,0,.5);cursor:pointer}
.player-carousel .art-current.spinning{animation:albumSpin 4s linear infinite}
.player-carousel .art-next{right:0;z-index:10;transform:scale(.8);opacity:.4;filter:brightness(.75);cursor:pointer}
.player-tidal-badge{position:absolute;top:-1rem;left:50%;transform:translateX(-50%);z-index:40;background:#000;color:#fff;font-size:8px;font-weight:700;padding:2px 8px;border-radius:.5rem;letter-spacing:.1em;display:flex;align-items:center;gap:4px;white-space:nowrap}
.player-title{color:#fff;font-size:15px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;margin-bottom:.25rem}
.player-artist{color:#777;font-size:.75rem;margin-bottom:1.5rem}
.player-progress{width:100%;display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem}
.player-progress .time{font-size:10px;color:#555;min-width:28px;text-align:center;font-variant-numeric:tabular-nums}
.player-progress .bar{flex:1;height:3px;background:#333;border-radius:2px;cursor:pointer;overflow:hidden;position:relative}
.player-progress .bar-fill{height:100%;background:var(--lime);border-radius:2px;will-change:width}
.player-controls{display:flex;align-items:center;gap:1.5rem}
.player-controls button{background:none;color:#888;padding:.25rem;transition:color .2s;display:flex;align-items:center;justify-content:center}
.player-controls button:hover{color:#fff}
.player-controls .play-btn{width:3rem;height:3rem;border-radius:50%;background:#fff;color:#000;display:flex;align-items:center;justify-content:center;transition:transform .2s}
.player-controls .play-btn:hover{transform:scale(1.05)}
.player-controls .play-btn svg{width:1.25rem;height:1.25rem}
.player-loading{display:flex;align-items:center;justify-content:center;flex:1}
.player-spinner{width:2rem;height:2rem;border:3px solid var(--green);border-top-color:var(--lime);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes albumSpin{from{transform:translateX(-50%) scale(1.15) rotate(0)}to{transform:translateX(-50%) scale(1.15) rotate(360deg)}}

/* ── Experience ── */
.experience{padding:clamp(3rem,8vw,6rem) clamp(1rem,4vw,3rem);max-width:80rem;margin:0 auto}
.experience-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:clamp(2rem,4vw,4rem);gap:2rem}
.experience-header p{color:var(--z4);max-width:24rem;font-size:clamp(.85rem,1vw,1rem)}
.experience-header h2{font-size:clamp(1.5rem,3.5vw,3rem);font-weight:700;text-align:right;max-width:36rem}
.exp-item{border-bottom:1px solid var(--green);padding-bottom:1rem;margin-bottom:1rem}
.exp-row{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;cursor:pointer;gap:1rem}
.exp-row:hover .exp-id{color:#fff}
.exp-left{display:flex;align-items:center;gap:clamp(1rem,2vw,2rem);flex:1}
.exp-id{font-size:clamp(1.5rem,2.5vw,2rem);font-weight:700;color:var(--z5);transition:color .2s;min-width:2.5rem}
.exp-year{font-size:.75rem;color:var(--z5);margin-bottom:.25rem}
.exp-role{font-weight:700;font-size:clamp(.9rem,1.2vw,1.125rem)}
.exp-location-wrap{flex:0 0 auto;width:clamp(8rem,14vw,14rem)}
.exp-location-label{font-size:.75rem;color:var(--z5);margin-bottom:.25rem}
.exp-location{display:flex;align-items:center;gap:.5rem;font-weight:500;font-size:clamp(.8rem,1vw,.9rem)}
.exp-location .flag{font-size:1.5rem}
.exp-position-wrap{flex:0 0 auto;width:clamp(8rem,14vw,14rem)}
.exp-position-label{font-size:.75rem;color:var(--z5);margin-bottom:.25rem}
.exp-position{font-weight:500;font-size:clamp(.8rem,1vw,.9rem)}
.exp-toggle{padding:.4rem 1.2rem;border-radius:9999px;display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem;font-weight:500;transition:all .2s;flex-shrink:0}
.exp-toggle.collapsed{background:var(--green);color:#fff}
.exp-toggle.collapsed:hover{background:var(--lime);color:#000}
.exp-toggle.expanded{background:var(--lime);color:#000}
.exp-detail{overflow:hidden;max-height:0;opacity:0;transition:max-height .4s ease,opacity .3s ease}
.exp-detail.open{max-height:500px;opacity:1}
.exp-detail-inner{padding:2rem 0 1rem clamp(0rem,4vw,6rem);display:flex;gap:3rem}
.exp-stats{flex:0 0 33%}
.exp-stats-label{font-size:.75rem;color:var(--z5);margin-bottom:1rem}
.stat-bar{margin-bottom:1rem}
.stat-bar .track{width:100%;background:var(--green);height:.5rem;border-radius:9999px;overflow:hidden;margin-bottom:.5rem}
.stat-bar .fill-lime{width:92%;height:100%;background:var(--lime)}
.stat-bar .fill-green{width:92%;height:100%;background:#22c55e}
.stat-bar .stat-label{display:flex;justify-content:flex-end;font-size:.75rem;color:var(--z4)}
.stat-bar .stat-label .pct-lime{color:var(--lime);font-weight:700;margin-right:.5rem}
.stat-bar .stat-label .pct-green{color:#22c55e;font-weight:700;margin-right:.5rem}
.exp-desc-wrap{flex:1}
.exp-desc-wrap .explain-label{font-size:.75rem;color:var(--z5);margin-bottom:.5rem}
.exp-desc-wrap p{color:var(--z4);font-size:clamp(.8rem,1vw,.875rem);line-height:1.6}

/* ── Portfolio ── */
.portfolio{padding:clamp(3rem,8vw,6rem) clamp(1rem,4vw,3rem);max-width:80rem;margin:0 auto;text-align:center}
.portfolio h2{font-size:clamp(1.5rem,3.5vw,3rem);font-weight:700;margin-bottom:1.5rem;white-space:pre-line}
.portfolio .subtitle{color:var(--z4);margin-bottom:3rem;max-width:28rem;margin-left:auto;margin-right:auto;font-size:clamp(.85rem,1vw,1rem)}
.portfolio-cats{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem;margin-bottom:clamp(2rem,4vw,4rem)}
.portfolio-cats button{padding:.4rem 1.2rem;border-radius:9999px;font-size:clamp(.75rem,.9vw,.875rem);transition:all .2s}
.portfolio-cats button.active{background:var(--lime);color:#000;font-weight:500}
.portfolio-cats button:not(.active){background:var(--green);color:#fff}
.portfolio-cats button:not(.active):hover{background:#6bc416;color:#000}

.portfolio-carousel{display:flex;align-items:center;gap:1.5rem;position:relative}
.carousel-arrow{background:none;border:none;cursor:pointer;flex-shrink:0;padding:.5rem}
.carousel-arrow img{width:clamp(1.5rem,2.5vw,2rem);height:clamp(1.5rem,2.5vw,2rem);opacity:.7;transition:opacity .2s}
.carousel-arrow:hover img{opacity:1}
.carousel-left{animation:arrBounceLeft 2s ease-in-out infinite}
.carousel-left img{transform:rotate(180deg)}
.carousel-right{animation:arrBounceRight 2s ease-in-out infinite}
@keyframes arrBounceLeft{0%,100%{transform:translateX(0)}50%{transform:translateX(-6px)}}
@keyframes arrBounceRight{0%,100%{transform:translateX(0)}50%{transform:translateX(6px)}}
.portfolio-carousel{display:flex;align-items:center;gap:1rem}
.portfolio-track{flex:1;overflow:hidden;mask-image:linear-gradient(to right,transparent,black 8%,black 92%,transparent);-webkit-mask-image:linear-gradient(to right,transparent,black 8%,black 92%,transparent);padding:1rem 0 2rem}
.portfolio-cards{display:flex;align-items:center;gap:1.5rem;width:max-content}
.project-card{min-width:280px;width:clamp(300px,28vw,380px);height:520px;background:var(--card);border-radius:1.5rem;padding:1.5rem;flex-shrink:0;opacity:.5;cursor:pointer;transition:opacity .3s, box-shadow .3s, background .3s, border-color .3s;display:flex;flex-direction:column;overflow:hidden}
.project-card.active{background:var(--green);border:1px solid var(--green);box-shadow:0 20px 40px rgba(0,0,0,.5);z-index:10;opacity:1;cursor:default;height:auto;min-height:520px;overflow:visible}
.project-card:not(.active):hover{opacity:.8}
.project-img{background:var(--green);border-radius:1rem;height:clamp(10rem,16vw,12rem);overflow:hidden;margin-bottom:1.5rem;position:relative}
.project-card.active .project-img{height:clamp(11rem,18vw,14rem)}
.project-img img{width:100%;height:100%;object-fit:cover}
.project-card:not(.active) .project-img img{opacity:.5}
.project-badge{position:absolute;top:1rem;right:1rem;background:#fff;color:#000;font-size:.75rem;font-weight:700;padding:.25rem .75rem;border-radius:9999px;display:flex;align-items:center;gap:.25rem}
.project-badge img{width:10px;height:10px;transform:rotate(-45deg);filter:brightness(0)}
.project-body{text-align:left;flex:1;display:flex;flex-direction:column;overflow:hidden}
.project-card.active .project-body{overflow:visible}
.project-body .project-desc{flex:1;overflow:hidden}
.project-card.active .project-body .project-desc{overflow:visible}
.project-body .project-btns{margin-top:auto}
.project-body h3{font-weight:700;font-size:clamp(1rem,1.3vw,1.125rem);margin-bottom:.5rem}
.project-card.active .project-body h3{font-size:clamp(1.1rem,1.5vw,1.25rem);margin-bottom:.75rem}
.project-tags{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}
.tag{font-size:10px;padding:.25rem .5rem;border-radius:.25rem}
.tag-zinc{background:var(--green);color:var(--z4)}
.tag-green{background:rgba(20,83,45,.5);color:#4ade80;border:1px solid #166534}
.tag-blue{background:rgba(30,58,138,.5);color:#60a5fa;border:1px solid #1e3a8a}
.tag-orange{background:rgba(124,45,18,.5);color:#fb923c;border:1px solid #9a3412}
.project-detail-label{font-size:.75rem;color:var(--z5);margin-bottom:.5rem}
.project-desc{font-size:clamp(.8rem,1vw,.875rem);color:var(--z4);line-height:1.6;margin-bottom:2rem}
.project-card:not(.active) .project-desc{font-size:.75rem;color:var(--z5);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:1.5rem}
.project-btns{display:flex;gap:.5rem}
.project-btns button,.project-btns a{flex:1;padding:clamp(.5rem,1vw,.75rem);border-radius:9999px;font-size:clamp(.75rem,.9vw,.875rem);font-weight:600;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s;text-decoration:none}
.btn-learn{background:var(--lime);color:#000}
.btn-learn:hover{background:#6bc416}
.btn-learn img{width:.75rem;height:.75rem;filter:brightness(0)}
.btn-play{background:#000;color:#fff}
.btn-play:hover{background:var(--card)}
.btn-play img{width:.75rem;height:.75rem;filter:brightness(0) invert(1);opacity:.5;transition:opacity .2s}
.btn-play:hover img{opacity:1}

/* ── Services ── */
.services{padding:clamp(3rem,8vw,6rem) clamp(1rem,4vw,3rem);max-width:80rem;margin:0 auto}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:1fr;gap:1rem}
.services-title-card{padding:1.5rem;border-radius:1.5rem;display:flex;flex-direction:column;justify-content:space-between}
.services-title-card h2{font-size:clamp(1.5rem,3vw,2.5rem);font-weight:700;line-height:1.2;margin-bottom:1.5rem}
.services-title-card p{color:var(--z4);font-size:clamp(.8rem,.9vw,.9rem)}

/* Flip cards */
.flip-card{perspective:800px;cursor:pointer;min-height:220px}
.flip-card-inner{position:relative;width:100%;height:100%;min-height:220px;transition:transform .6s;transform-style:preserve-3d}
.flip-card.flipped .flip-card-inner{transform:rotateY(180deg)}
.flip-card-front,.flip-card-back{position:absolute;inset:0;backface-visibility:hidden;border-radius:1.5rem;padding:1.5rem;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.flip-card-front{background:var(--card);border:1px solid var(--bdr);transition:border-color .3s}
.flip-card:hover .flip-card-front{border-color:var(--lime)}
.flip-card-front h3{font-size:clamp(1.1rem,1.5vw,1.4rem);font-weight:700}
.flip-card-front .svc-arrow{position:absolute;bottom:1.5rem;right:1.5rem}
.flip-card-front .svc-arrow img{width:1.25rem;height:1.25rem;opacity:.5;transition:all .3s}
.flip-card:hover .flip-card-front .svc-arrow img{opacity:1;transform:rotate(-45deg)}
.flip-card-back{background:var(--lime);color:#000;transform:rotateY(180deg)}
.flip-card-back h3{font-size:clamp(1rem,1.3vw,1.2rem);font-weight:700;margin-bottom:.75rem}
.flip-card-back .svc-desc{font-size:clamp(.75rem,.85vw,.85rem);color:rgba(0,0,0,.7);line-height:1.5}
.flip-card-back .svc-arrow-back{position:absolute;bottom:1.5rem;right:1.5rem}
.flip-card-back .svc-arrow-back img{width:1.25rem;height:1.25rem;opacity:.7;transition:all .3s;filter:brightness(0)}
.flip-card.flipped:hover .svc-arrow-back img{opacity:1;transform:rotate(-45deg)}

/* ── FAQ ── */
.faq{padding:clamp(3rem,8vw,6rem) clamp(1rem,4vw,3rem);max-width:56rem;margin:0 auto}
.faq-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:clamp(2rem,4vw,4rem);gap:2rem}
.faq-header h2{font-size:clamp(1.5rem,3.5vw,3rem);font-weight:700;max-width:28rem;white-space:pre-line}
.faq-header p{color:var(--z4);max-width:20rem;text-align:right;font-size:clamp(.85rem,1vw,1rem)}
.faq-item{border-bottom:1px solid var(--green);padding-bottom:1rem;margin-bottom:1rem}
.faq-question{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;cursor:pointer;gap:1rem}
.faq-question h3{font-size:clamp(1rem,1.5vw,1.25rem);font-weight:500;color:var(--z4);transition:color .2s}
.faq-question h3.open{color:#fff}
.faq-toggle{padding:.4rem 1.2rem;border-radius:9999px;display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem;font-weight:500;transition:all .2s;flex-shrink:0}
.faq-toggle.collapsed{background:var(--green);color:#fff}
.faq-toggle.collapsed:hover{background:var(--lime);color:#000}
.faq-toggle.expanded{background:var(--lime);color:#000}
.faq-answer{overflow:hidden;max-height:0;opacity:0;transition:max-height .4s ease,opacity .3s ease}
.faq-answer.open{max-height:200px;opacity:1}
.faq-answer p{color:var(--z4);padding-bottom:1rem;max-width:40rem;font-size:clamp(.85rem,1vw,1rem)}
.faq-answer.open{max-height:500px}
.media-links{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--bdr)}
.media-links h3{font-size:clamp(1.1rem,1.5vw,1.3rem);font-weight:700;margin-bottom:1.5rem;color:var(--lime)}
.media-grid{display:flex;flex-wrap:wrap;gap:.75rem}
.media-grid a{display:inline-block;padding:.5rem 1rem;border:1px solid var(--bdr);border-radius:9999px;color:var(--z4);font-size:clamp(.75rem,.85vw,.85rem);text-decoration:none;transition:all .3s}
.media-grid a:hover{border-color:var(--lime);color:var(--lime)}

/* ── Contact ── */
.contact{position:relative;width:100%;padding:clamp(3rem,8vw,6rem) clamp(1rem,4vw,3rem);margin:0;overflow:hidden}
.contact-radial{position:absolute;inset:-80% 0 0 0;z-index:-1;background:radial-gradient(ellipse 90% 70% at 20% 85%,rgba(10,37,20,.95),transparent 60%)}
.contact .contact-stats,.contact .contact-bottom{max-width:80rem;margin-left:auto;margin-right:auto}
.contact-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.5rem,3vw,3rem);margin-bottom:clamp(3rem,6vw,6rem)}
.contact-stats .stat-value{font-size:clamp(2rem,5vw,3.75rem);font-weight:700;margin-bottom:.5rem}
.contact-stats .stat-value s{color:var(--z5);text-decoration:line-through;margin-right:.25em;opacity:.5}
.contact-stats .stat-label{color:var(--z4);font-size:clamp(.75rem,1vw,.875rem);white-space:pre-line}
.contact-bottom{display:flex;gap:clamp(2rem,4vw,4rem);justify-content:space-between;align-items:flex-start}
.contact-bottom h2{font-size:clamp(1.5rem,3.5vw,3rem);font-weight:700;line-height:1.2;margin-bottom:1.5rem;white-space:pre-line}
.contact-bottom>div:first-child{flex:1}
.contact-bottom>div:first-child p{color:var(--z4);max-width:24rem;font-size:clamp(.85rem,1vw,1rem)}
.contact-form{width:100%;max-width:28rem;flex-shrink:0}
.contact-form .form-row{display:flex;gap:1rem;margin-bottom:1rem}
.contact-form input,.contact-form textarea{width:100%;background:var(--card);border:1px solid var(--green);border-radius:.75rem;padding:.75rem 1rem;color:#fff;outline:none;transition:border-color .2s;font-size:.875rem}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--lime)}
.contact-form textarea{resize:none;margin-bottom:1rem}
.contact-form .submit-btn{width:100%;background:var(--lime);color:#000;font-weight:700;padding:clamp(.75rem,1.2vw,1rem);border-radius:.75rem;font-size:1rem;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .3s}
.contact-form .submit-btn:hover{background:#6bc416}
.contact-form .submit-btn img{width:1.25rem;height:1.25rem;filter:brightness(0)}

/* ── Footer ── */
.footer{border-top:1px solid var(--green);overflow:hidden}
.footer-top{padding:clamp(2rem,4vw,3rem) clamp(1rem,4vw,3rem) .5rem;max-width:80rem;margin:0 auto;display:flex;justify-content:center;align-items:center}
.footer-socials{display:flex;gap:2rem;flex-wrap:wrap;justify-content:center}
.footer-socials a{color:var(--z4);transition:color .2s;display:flex;align-items:center;gap:.5rem;font-size:clamp(.8rem,1vw,.9rem);text-decoration:none}
.footer-socials a:hover{color:var(--lime)}
.footer-socials svg{width:1.25rem;height:1.25rem;flex-shrink:0}
.footer-ticker{padding:1rem 0;border-top:1px solid var(--green);white-space:nowrap;overflow:hidden;max-height:0;opacity:0;transition:max-height .6s ease,opacity .4s ease}
.footer-ticker.visible{max-height:4rem;opacity:1}
.footer-wtf{text-align:right;padding:0 clamp(1rem,4vw,3rem) .25rem;cursor:pointer;margin:0;line-height:1}
.footer-wtf span{font-size:.55rem;color:var(--z5);transition:color .2s}
.footer-wtf span:hover{color:var(--lime)}
.ticker-track{display:inline-flex;gap:2rem;animation:ticker 40s linear infinite}
.ticker-track span{color:var(--z5);font-size:.8rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}
.ticker-track span::after{content:" \2022";color:var(--lime);margin-left:2rem}
.ticker-track span.ticker-highlight{color:var(--lime);font-weight:700}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* Toast popup */
.toast{position:absolute;left:0;right:0;text-align:center;
  background:var(--lime);color:#000;padding:.75rem 1.5rem;border-radius:.75rem;
  font-weight:700;font-size:clamp(.9rem,1.2vw,1.1rem);z-index:9999;
  box-shadow:0 8px 30px rgba(134,225,31,.3);
  opacity:0;transform:translateY(20px);pointer-events:none;
  transition:opacity .3s,transform .5s cubic-bezier(.34,1.56,.64,1)}
.toast.show{opacity:1;transform:translateY(8px);pointer-events:auto}
.toast.hide{opacity:0;transform:translateY(20px);transition:opacity .3s,transform .3s ease-in}

/* ── Responsive ── */
@media(max-width:1024px){
  .about-top{grid-template-columns:1fr}
  .about-cards{grid-template-columns:1fr}
  .services-layout{flex-direction:column}
  .services-left{flex:none}
  .services-grid{grid-template-columns:1fr 1fr}
  .contact-bottom{flex-direction:column}
  .contact-form{max-width:100%}
  .experience-header{flex-direction:column;align-items:flex-start}
  .experience-header h2{text-align:left}
  .exp-row{flex-wrap:wrap}
  .exp-location-wrap,.exp-position-wrap{width:auto;flex:1 1 40%}
  .exp-detail-inner{flex-direction:column;padding-left:0}
  .exp-stats{flex:none}
  .faq-header{flex-direction:column;align-items:flex-start}
  .faq-header p{text-align:left}
}

@media(max-width:768px){
  .navbar{justify-content:space-between}
  .navbar-links{display:none}
  .nav-burger{display:flex}
  .mobile-nav{display:flex}
  .about-cards{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr}
  .contact-stats{grid-template-columns:repeat(3,1fr);gap:1rem;text-align:center}
  .footer-socials{flex-direction:column;align-items:center;gap:1rem}
  .portfolio-carousel{gap:.5rem}
  .portfolio-track{mask-image:none;-webkit-mask-image:none;overflow:visible}
  .portfolio-cards{justify-content:center;width:100%!important;transform:none!important}
  .project-card:not(.active){display:none!important}
  .project-card{min-width:0;width:100%!important;height:auto;max-height:none}
  .project-img,.project-card.active .project-img{height:clamp(8rem,35vw,12rem)}
  .contact-form .form-row{flex-direction:column}
  .hero-float-1{left:2vw;top:14vh}
  .hero-float-2,.hero-float-3{display:none}
  .hero-role{display:none}
  .hero-tags-mobile{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;z-index:4;margin-top:1.5rem}
  .hero-tags-mobile span{background:var(--lime);color:#000;padding:.35em .9em;border-radius:9999px;font-weight:700;font-size:.75rem;white-space:nowrap}
  .r-mike{display:block;left:calc(100% + 1rem);top:calc(50% - .5rem)}
  .sparkle,.page-sparkle{display:none}
  .hero-cta-wrap{padding-bottom:clamp(2.5rem,5vh,4rem)}
  .hero-arrow{bottom:clamp(.75rem,2vh,1.5rem)}
  .exp-row{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;gap:.25rem .5rem;padding:.75rem 0;align-items:center}
  .exp-left{grid-column:1/-1}
  .exp-id{display:none}
  .exp-year{font-size:.7rem}
  .exp-role{font-size:.85rem}
  .exp-location-label,.exp-position-label{display:none}
  .exp-location-wrap,.exp-position-wrap{width:auto}
  .exp-location{font-size:.7rem;gap:.3rem}
  .exp-location .flag{font-size:.9rem}
  .exp-position{font-size:.7rem;color:var(--z4)}
  .exp-toggle{grid-column:2;grid-row:2;justify-self:end}
}

@media(max-width:480px){
  .hero-float-1{transform:scale(.6)}
}
