/* =============================================
   SOUL PORTFOLIO — Blue Theme
   ============================================= */
:root{
  --a:#00c3ff;
  --a2:#0077ff;
  --bg:#00020c;
  --c1:#000818;
  --b0:rgba(0,195,255,.1);
  --bh:rgba(0,195,255,.35);
  --t0:#fff;
  --t1:rgba(255,255,255,.45);
  --t2:rgba(255,255,255,.2);
  --r:16px;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;overflow-x:hidden;}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg);color:var(--t0);overflow-x:hidden;overflow-y:auto;position:relative;}

/* ---- BG & TRAIL CANVAS ---- */
#bg-canvas{position:fixed;inset:0;z-index:0;pointer-events:none;width:100vw;height:100vh;}
#trail-canvas{position:fixed;inset:0;z-index:1;pointer-events:none;width:100vw;height:100vh;}

/* ---- SPLASH ---- */
#splash{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:var(--bg);transition:opacity 1.1s cubic-bezier(.4,0,.2,1);}
#splash-canvas{position:absolute;inset:0;pointer-events:none;}
.splash-inner{position:relative;z-index:2;text-align:center;}
.splash-enter{
  font-size:clamp(2rem,4vw,3.5rem);font-weight:300;letter-spacing:.25em;
  color:rgba(255,255,255,.6);text-transform:lowercase;
  animation:splashPulse 3s ease-in-out infinite;
}
@keyframes splashPulse{0%,100%{opacity:.5;}50%{opacity:1;}}

/* ---- NAV ---- */
#nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:.9rem 2rem;transition:background .3s,box-shadow .3s;}
#nav.scrolled{background:rgba(0,4,15,.85);backdrop-filter:blur(20px);box-shadow:0 1px 0 rgba(0,195,255,.08);}
.nav-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:2rem;}
.nav-logo{font-size:1.2rem;font-weight:800;color:#fff;text-decoration:none;letter-spacing:-.02em;}
.nav-links{list-style:none;display:flex;gap:1.8rem;margin-left:auto;}
.nl{color:var(--t1);text-decoration:none;font-size:.88rem;font-weight:500;transition:color .2s;letter-spacing:.01em;}
.nl:hover,.nl.active{color:#fff;}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;}
.burger span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:.3s;}
.mobile-menu{display:none;flex-direction:column;gap:1rem;padding:1rem 2rem 1.5rem;background:rgba(0,4,15,.95);}
.mobile-menu.open{display:flex;}
.ml{color:var(--t1);text-decoration:none;font-size:1rem;font-weight:500;}
@media(max-width:640px){.nav-links{display:none;}.burger{display:flex;}}

/* ---- SECTIONS ---- */
/* Tighter vertical rhythm to reduce overall scroll length */
.sec{position:relative;z-index:2;padding:4rem 2rem;}
.sec-head{text-align:center;margin-bottom:3rem;}
.sec-label{font-size:.75rem;font-weight:600;color:var(--a);letter-spacing:.18em;text-transform:uppercase;margin-bottom:.7rem;opacity:.8;}
.sec-head h2{font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.04em;margin-bottom:.8rem;}
.sec-sub{font-size:.95rem;color:var(--t1);max-width:480px;margin:0 auto;line-height:1.7;}
.accent{color:var(--a);}

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

/* ---- 3D HERO SHAPE ---- */
.hero-shape{position:absolute;right:8%;top:50%;transform:translateY(-50%);width:260px;height:260px;pointer-events:none;perspective:600px;opacity:.18;}
.hero-cube{width:100%;height:100%;position:relative;transform-style:preserve-3d;animation:rotateCube 14s linear infinite;}
.cube-face{position:absolute;width:100%;height:100%;border:1px solid rgba(0,195,255,.7);border-radius:4px;}
.cube-face.front {transform:rotateY(  0deg) translateZ(130px);}
.cube-face.back  {transform:rotateY(180deg) translateZ(130px);}
.cube-face.left  {transform:rotateY(-90deg) translateZ(130px);}
.cube-face.right {transform:rotateY( 90deg) translateZ(130px);}
.cube-face.top   {transform:rotateX( 90deg) translateZ(130px);}
.cube-face.bottom{transform:rotateX(-90deg) translateZ(130px);}
@keyframes rotateCube{from{transform:rotateX(20deg) rotateY(0deg);}to{transform:rotateX(20deg) rotateY(360deg);}}

/* ---- CLICK RIPPLE ---- */
@keyframes rippleOut{0%{width:0;height:0;opacity:.8;}100%{width:80px;height:80px;opacity:0;}}

/* ---- NAV PFP ---- */
.nav-logo{display:flex;align-items:center;gap:.6rem;}
.nav-pfp{width:30px;height:30px;border-radius:50%;object-fit:cover;object-position:center top;border:1.5px solid rgba(0,195,255,.4);}

/* ---- TYPING ---- */
.hero-typing{font-size:1rem;font-weight:400;color:rgba(255,255,255,.45);margin-bottom:1.4rem;letter-spacing:.01em;animation:fadeUp .52s .06s ease both;}
#typed{color:#fff;font-weight:600;}
.typed-cursor{color:#00c3ff;font-weight:300;animation:blink .75s step-end infinite;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:0;}}

/* ---- HERO ---- */
.hero-sec{min-height:100vh;display:flex;align-items:center;padding-top:5rem;position:relative;overflow:hidden;}
.hero-content{max-width:750px;margin:0 auto;text-align:center;}
.hero-eye{font-size:.78rem;font-weight:600;color:var(--a);letter-spacing:.2em;text-transform:uppercase;margin-bottom:1.2rem;animation:fadeUp .5s ease both;}
.hero-title{font-size:clamp(3rem,9vw,6.5rem);font-weight:800;line-height:1;letter-spacing:-.04em;margin-bottom:1.4rem;animation:fadeUp .55s .05s ease both;}
.hero-name{
  font-style:normal;
  background:linear-gradient(90deg,#00c3ff,#60aaff,#00c3ff,#0077ff,#00c3ff);
  background-size:300% 100%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:fadeUp .55s .05s ease both, gradientShift 4s ease-in-out infinite;
}
@keyframes gradientShift{0%,100%{background-position:0% 50%;}50%{background-position:100% 50%;}}
.hero-quote{font-size:1.05rem;color:var(--t1);line-height:1.75;margin-bottom:2.5rem;max-width:520px;margin-left:auto;margin-right:auto;animation:fadeUp .6s .1s ease both;}
.hero-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:3.5rem;animation:fadeUp .65s .15s ease both;}
.hero-stats{display:flex;align-items:center;justify-content:center;gap:2.5rem;animation:fadeUp .7s .2s ease both;}
.stat{text-align:center;}
.hn{display:block;font-size:2rem;font-weight:800;color:var(--a);line-height:1;}
.stat span:last-child{font-size:.75rem;color:var(--t2);font-weight:500;letter-spacing:.05em;margin-top:.25rem;display:block;}
.stat-div{width:1px;height:36px;background:rgba(0,195,255,.2);}

/* ---- BUTTONS ---- */
.btn-main{display:inline-flex;align-items:center;gap:.45rem;padding:.82rem 2.1rem;border-radius:50px;background:linear-gradient(135deg,#00c3ff,#0077ff);color:#fff;font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:.92rem;text-decoration:none;border:none;cursor:pointer;box-shadow:0 4px 24px rgba(0,195,255,.4);transition:transform .22s,box-shadow .22s,opacity .22s;}
.btn-main:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,195,255,.55);opacity:.9;}
.btn-ghost{display:inline-flex;align-items:center;padding:.82rem 2.1rem;border-radius:50px;border:1px solid rgba(0,195,255,.35);color:rgba(255,255,255,.75);font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.92rem;text-decoration:none;transition:border-color .22s,color .22s,background .22s;}
.btn-ghost:hover{border-color:var(--a);color:#fff;background:rgba(0,195,255,.08);}

/* ---- CARDS ---- */
.cards{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:0;max-width:1100px;margin:0 auto;
  border:1px solid rgba(255,255,255,.06);border-radius:20px;overflow:hidden;
  background:rgba(255,255,255,.02);
}
.card{background:transparent;display:flex;flex-direction:column;padding:2.2rem 2rem 1.8rem;border-right:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06);position:relative;overflow:hidden;transition:background .3s ease;}
.card:nth-child(3n){border-right:none;}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(0,195,255,.5),transparent);transform:scaleX(0);transform-origin:center;transition:transform .4s ease;}
.card:hover::before{transform:scaleX(1);}
.card:hover{background:rgba(0,195,255,.025);}
.card::after{content:'';position:absolute;inset:0;background:radial-gradient(600px circle at var(--mx,50%) var(--my,50%),rgba(0,195,255,.05),transparent 40%);opacity:0;transition:opacity .4s;pointer-events:none;}
.card:hover::after{opacity:1;}
.card-dim{opacity:.4;}.card-dim:hover{opacity:.55;}
.card-inner{flex:1;}
.card-meta{display:flex;align-items:center;gap:.6rem;margin-bottom:1.3rem;}
.card-type{font-size:.7rem;font-weight:500;color:rgba(255,255,255,.25);letter-spacing:.1em;text-transform:uppercase;margin-left:auto;}
.card h3{font-size:1.1rem;font-weight:700;letter-spacing:-.025em;line-height:1.3;margin-bottom:.7rem;color:#fff;transition:color .25s;}
.card:hover h3{color:var(--a);}
.card-inner>p{font-size:.84rem;color:rgba(255,255,255,.38);line-height:1.75;margin-bottom:1.4rem;}
.card-tags{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:1.8rem;}
.card-tags span{font-size:.67rem;font-weight:500;padding:.2rem .65rem;border-radius:4px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);color:rgba(255,255,255,.3);letter-spacing:.04em;}
.card-footer{border-top:1px solid rgba(255,255,255,.05);padding-top:1.1rem;margin-top:auto;}
.card-link{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;font-weight:600;color:rgba(0,195,255,.8);text-decoration:none;transition:color .2s,gap .2s;}
.card-link:hover{color:var(--a);gap:.65rem;}
.card-link.muted{color:rgba(255,255,255,.15);cursor:default;pointer-events:none;}
.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.18rem .65rem;border-radius:4px;font-size:.65rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;}
.badge::before{content:'';width:5px;height:5px;border-radius:50%;}
.green{background:rgba(0,195,80,.08);color:#00b85a;border:1px solid rgba(0,195,80,.18);}.green::before{background:#00b85a;}
.amber{background:rgba(255,155,0,.08);color:#e09000;border:1px solid rgba(255,155,0,.18);}.amber::before{background:#e09000;}
@media(max-width:900px){.cards{grid-template-columns:1fr 1fr;}.card:nth-child(3n){border-right:1px solid rgba(255,255,255,.06);}.card:nth-child(2n){border-right:none;}}
@media(max-width:560px){.cards{grid-template-columns:1fr;}.card{border-right:none!important;}}

/* ---- SOUL PROJECT CARDS ---- */
.soul-cards{display:flex;flex-direction:column;gap:1px;max-width:900px;margin:0 auto;border:1px solid rgba(0,195,255,.08);border-radius:20px;overflow:hidden;}
.soul-card{
  background:rgba(0,195,255,.02);
  padding:2.2rem 2.5rem;
  display:flex;align-items:center;gap:2.5rem;
  position:relative;overflow:hidden;
  border-bottom:1px solid rgba(0,195,255,.07);
  transition:background .3s;
}
.soul-card:last-child{border-bottom:none;}
.soul-card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:2px;
  background:linear-gradient(180deg,transparent,#00c3ff,transparent);
  transform:scaleY(0);transform-origin:center;transition:transform .5s ease;
}
.soul-card:hover::before{transform:scaleY(1);}
.soul-card:hover{background:rgba(0,195,255,.045);}
.soul-card-soon{opacity:.45;}.soul-card-soon:hover{opacity:.6;}
.soul-card-num{font-size:3rem;font-weight:800;color:rgba(0,195,255,.1);min-width:60px;text-align:center;line-height:1;transition:color .3s;flex-shrink:0;}
.soul-card:hover .soul-card-num{color:rgba(0,195,255,.25);}
.soul-card-body{flex:1;}
.soul-card-top{display:flex;align-items:center;gap:.7rem;margin-bottom:.7rem;}
.soul-card-type{font-size:.68rem;font-weight:500;color:rgba(255,255,255,.2);letter-spacing:.1em;text-transform:uppercase;margin-left:auto;}
.soul-card-body h3{font-size:1.15rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.5rem;color:#fff;transition:color .25s;}
.soul-card:hover .soul-card-body h3{color:#00c3ff;}
.soul-card-body p{font-size:.84rem;color:rgba(255,255,255,.35);line-height:1.75;margin-bottom:1rem;}
.soul-card-tags{display:flex;flex-wrap:wrap;gap:.3rem;}
.soul-card-tags span{font-size:.65rem;font-weight:500;padding:.18rem .6rem;border-radius:4px;background:rgba(0,195,255,.05);border:1px solid rgba(0,195,255,.12);color:rgba(0,195,255,.5);}
.soul-visit{font-size:.8rem;font-weight:700;color:#00c3ff;text-decoration:none;padding:.5rem 1.2rem;border-radius:8px;border:1px solid rgba(0,195,255,.2);background:rgba(0,195,255,.06);transition:background .2s,border-color .2s;white-space:nowrap;flex-shrink:0;}
.soul-visit:hover{background:rgba(0,195,255,.14);border-color:rgba(0,195,255,.4);}
@media(max-width:640px){.soul-card{flex-direction:column;align-items:flex-start;gap:1rem;padding:1.8rem;}.soul-card-num{display:none;}}

/* ---- SKILLS ---- */
.skills-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1rem;max-width:1000px;margin:0 auto;}
.skill-card{background:var(--c1);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:2rem 1rem 1.4rem;display:flex;flex-direction:column;align-items:center;gap:.85rem;cursor:default;transition:border-color .7s ease,transform .7s cubic-bezier(.25,.46,.45,.94),box-shadow .7s ease;transform-style:preserve-3d;}
/* Make the skill cards "pop" more on hover */
.skill-card:hover{border-color:rgba(0,195,255,.3);transform:translateY(-12px) scale(1.06);box-shadow:0 20px 40px rgba(0,0,0,.5);}
.skill-card img{width:42px;height:42px;object-fit:contain;}
.skill-card span{font-size:.8rem;font-weight:600;color:var(--t1);letter-spacing:.02em;}
@media(max-width:900px){.skills-grid{grid-template-columns:repeat(4,1fr);}}
@media(max-width:480px){.skills-grid{grid-template-columns:repeat(3,1fr);}}

/* ---- CONTACT ---- */
.contact-sec{background:var(--bg);padding-bottom:3rem;}
.contact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:700px;margin:0 auto;}
.cblock{
  background:rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.07);
  border-radius:20px;padding:2.5rem 2rem;
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:.9rem;
  transition:border-color .35s,transform .35s;
  position:relative;overflow:hidden;
}
.cblock:hover{border-color:rgba(0,195,255,.25);transform:translateY(-3px);}
.cblock-ico{
  width:58px;height:58px;border-radius:50%;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:.3rem;
}
.cblock h4{font-size:1.1rem;font-weight:700;color:#fff;letter-spacing:-.01em;}
.cblock p{font-size:.84rem;color:rgba(255,255,255,.35);margin-bottom:.4rem;}
.cblock-btn{
  margin-top:.4rem;
  display:inline-flex;align-items:center;justify-content:center;
  padding:.6rem 1.8rem;border-radius:50px;
  background:rgba(0,195,255,.1);
  border:1px solid rgba(0,195,255,.2);
  color:#00c3ff;font-size:.82rem;font-weight:700;
  cursor:pointer;text-decoration:none;
  transition:background .2s,border-color .2s;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.cblock-btn:hover{background:rgba(0,195,255,.18);border-color:rgba(0,195,255,.4);}
@media(max-width:500px){.contact-grid{grid-template-columns:1fr;}}

/* ---- PROGRESS BAR ---- */
#progress-bar{position:fixed;top:0;left:0;height:2px;width:0%;background:linear-gradient(90deg,#00c3ff,#7fe8ff);z-index:9999;transition:width .1s linear;pointer-events:none;}

html,body{overflow-x:hidden;overflow-y:auto;}
/* ---- FOOTER ---- */
.footer{position:relative;z-index:2;padding:1.6rem 2rem 1.6rem;border-top:1px solid rgba(0,195,255,.08);}
.footer-inner{max-width:700px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:.6rem;text-align:center;}
.footer-name{
  font-size:clamp(2.5rem,7vw,4.5rem);font-weight:800;letter-spacing:.18em;
  background:linear-gradient(90deg,#00c3ff,#7fe8ff,#00c3ff,#0077ff,#00c3ff);
  background-size:300% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:gradientShift 4s ease-in-out infinite;line-height:1;
}
.footer-handle{font-size:.82rem;color:rgba(255,255,255,.3);letter-spacing:.05em;}
.footer-desc{font-size:.85rem;color:rgba(255,255,255,.22);margin-bottom:.3rem;}
.footer-links{display:flex;gap:2rem;margin:.4rem 0;}
.footer-links a{color:rgba(255,255,255,.28);text-decoration:none;font-size:.83rem;transition:color .2s;}
.footer-links a:hover{color:#fff;}
.footer-copy{font-size:.7rem;color:rgba(255,255,255,.13);margin-top:.2rem;}

/* NOTE: Footer styles are intentionally centered/stacked. */

/* ---- MUSIC BTN ---- */
.music-btn{position:fixed;bottom:1.8rem;right:1.8rem;z-index:200;width:48px;height:48px;border-radius:50%;background:rgba(0,195,255,.15);border:1px solid rgba(0,195,255,.3);color:var(--a);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s;backdrop-filter:blur(10px);}
.music-btn:hover{background:rgba(0,195,255,.25);transform:scale(1.08);}

/* ---- SCROLL REVEAL ---- */
.r{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease;transition-delay:var(--sd,0ms);}
.r.vis{opacity:1;transform:translateY(0);}

/* ---- ANIMATIONS ---- */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}

/* Footer name resized and spaced */

.footer-name {
    font-size: clamp(1.2rem, 3vw, 2rem) !important;
    letter-spacing: 0.6em !important;
    font-weight: 600;
}
