/* ============================================================
   JAD PORTFOLIO — style.css  (Light · Gradient · Modern)
   ============================================================ */

:root {
  --grad-1: #a855f7;
  --grad-2: #ec4899;
  --grad-3: #38bdf8;
  --grad-4: #8b5cf6;

  --bg:       #ffffff;
  --bg-2:     #f8f5ff;
  --bg-3:     #f0f4ff;
  --surface:  rgba(255,255,255,.7);
  --glass:    rgba(255,255,255,.55);
  --border:   rgba(168,85,247,.15);
  --border-h: rgba(168,85,247,.4);

  --text:     #0f0520;
  --text-2:   #4b3d6e;
  --text-3:   #8b7aaa;

  --accent:   #a855f7;
  --accent-2: #8b5cf6;
  --accent-g: rgba(168,85,247,.25);

  --font-d: 'Syne', sans-serif;
  --font-b: 'DM Sans', sans-serif;

  --r-sm: 14px;
  --r-md: 20px;
  --r-lg: 28px;
  --r-xl: 36px;

  --shadow:   0 8px 40px rgba(168,85,247,.12);
  --shadow-h: 0 20px 60px rgba(168,85,247,.22);
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--bg);color:var(--text);font-family:var(--font-b);font-weight:400;line-height:1.65;overflow-x:hidden;cursor:none}
a{text-decoration:none;color:inherit}
ul{list-style:none}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:#f8f5ff}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--grad-1),var(--grad-2));border-radius:999px}

/* ── CURSOR ── */
.cursor{position:fixed;width:10px;height:10px;background:var(--accent);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .15s,height .15s;mix-blend-mode:multiply}
.cursor-follower{position:fixed;width:38px;height:38px;border:1.5px solid rgba(168,85,247,.35);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .25s,height .25s,border-color .25s}
body.cursor-hovering .cursor{width:18px;height:18px}
body.cursor-hovering .cursor-follower{width:54px;height:54px;border-color:var(--accent)}
@media(max-width:768px){.cursor,.cursor-follower{display:none}body{cursor:auto}}

/* ── LOADER ── */
.loader{position:fixed;inset:0;background:#fff;display:flex;align-items:center;justify-content:center;z-index:10000;transition:opacity .6s,visibility .6s}
.loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-inner{text-align:center}
.loader-logo{font-family:var(--font-d);font-size:clamp(3rem,10vw,5rem);font-weight:800;background:linear-gradient(135deg,var(--grad-1),var(--grad-2),var(--grad-3));-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:28px;animation:logo-pulse 1.2s ease-in-out infinite}
@keyframes logo-pulse{0%,100%{filter:drop-shadow(0 0 10px rgba(168,85,247,.4))}50%{filter:drop-shadow(0 0 28px rgba(168,85,247,.7))}}
.loader-bar{width:180px;height:3px;background:#ede9fe;border-radius:999px;margin:0 auto 14px;overflow:hidden}
.loader-progress{height:100%;background:linear-gradient(90deg,var(--grad-1),var(--grad-2),var(--grad-3));border-radius:999px;width:0%;transition:width .04s linear}
.loader-text{font-size:.72rem;color:var(--text-3);letter-spacing:.14em;text-transform:uppercase}

/* ── NAVBAR ── */
.navbar{position:fixed;top:0;left:0;right:0;z-index:900;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(16px,5vw,60px);height:68px;background:transparent;transition:background .35s,box-shadow .35s}
.navbar.scrolled{background:rgba(255,255,255,.88);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 0 rgba(168,85,247,.1)}
.nav-logo{font-family:var(--font-d);font-size:1.4rem;font-weight:800;color:var(--text);letter-spacing:-.02em}
.nav-logo .dot{color:var(--accent)}
.nav-links{display:flex;align-items:center;gap:36px}
.nav-link{font-size:.85rem;font-weight:500;color:var(--text-2);letter-spacing:.02em;position:relative;transition:color .25s}
.nav-link::after{content:'';position:absolute;bottom:-3px;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--grad-1),var(--grad-2));transform:scaleX(0);transform-origin:right;transition:transform .3s cubic-bezier(.7,0,.3,1);border-radius:999px}
.nav-link:hover{color:var(--accent)}
.nav-link:hover::after{transform:scaleX(1);transform-origin:left}
.hamburger{display:none;background:none;border:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.hamburger span{display:block;width:24px;height:2px;background:var(--text-2);border-radius:999px;transition:transform .35s,opacity .35s,background .25s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);background:var(--accent)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);background:var(--accent)}

/* ── MOBILE MENU ── */
.mobile-menu{position:fixed;inset:0;background:rgba(255,255,255,.97);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);z-index:800;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:48px;transform:translateX(100%);transition:transform .45s cubic-bezier(.77,0,.18,1)}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu ul{display:flex;flex-direction:column;align-items:center;gap:28px}
.mob-link{font-family:var(--font-d);font-size:clamp(1.6rem,7vw,2.4rem);font-weight:700;color:var(--text-2);transition:color .25s;position:relative}
.mob-link::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--grad-1),var(--grad-2));transition:width .35s;border-radius:999px}
.mob-link:hover{color:var(--accent)}
.mob-link:hover::after{width:100%}
.mob-socials{display:flex;gap:20px}
.mob-socials a{width:46px;height:46px;border:1.5px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--text-3);transition:color .25s,border-color .25s,transform .25s}
.mob-socials a:hover{color:var(--accent);border-color:var(--accent);transform:translateY(-3px)}

/* ── UTILITIES ── */
.container{width:100%;max-width:1160px;margin:0 auto;padding:0 clamp(16px,5vw,48px)}
.section{padding:clamp(80px,12vw,140px) 0;position:relative;overflow:hidden}
.mt-32{margin-top:32px}
.glass{background:var(--glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.8);border-radius:var(--r-lg)}

/* ── SECTION HEADER ── */
.section-header{margin-bottom:clamp(48px,7vw,80px)}
.section-tag{display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.section-title{font-family:var(--font-d);font-size:clamp(2rem,5.5vw,3.6rem);font-weight:800;line-height:1.1;letter-spacing:-.03em;color:var(--text)}
.section-title em{font-style:normal;background:linear-gradient(135deg,var(--grad-1),var(--grad-2));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;border-radius:999px;font-family:var(--font-b);font-size:.9rem;font-weight:600;cursor:pointer;border:none;transition:all .3s ease;white-space:nowrap}
.btn-primary{background:linear-gradient(135deg,var(--grad-1),var(--grad-2));color:#fff;box-shadow:0 4px 20px rgba(168,85,247,.3)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 10px 40px rgba(168,85,247,.45)}
.btn-outline{background:rgba(255,255,255,.7);color:var(--text-2);border:1.5px solid var(--border);backdrop-filter:blur(10px)}
.btn-outline:hover{background:#fff;color:var(--accent);border-color:var(--accent);transform:translateY(-3px);box-shadow:var(--shadow)}
.btn-full{width:100%;justify-content:center}

/* ── REVEAL ── */
.reveal,.reveal-left,.reveal-right{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s cubic-bezier(.25,.8,.25,1)}
.reveal-left{transform:translateX(-40px) translateY(0)}
.reveal-right{transform:translateX(40px) translateY(0)}
.revealed{opacity:1!important;transform:translate(0)!important}

/* ================================================================
   HERO
   ================================================================ */
.hero{min-height:100svh;display:flex;align-items:center;position:relative;overflow:hidden;padding:120px clamp(16px,5vw,48px) 80px}

/* Big gradient background */
.hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,#fdf4ff 0%,#f0e7ff 25%,#e0f2fe 60%,#fce7f3 100%);z-index:0}
.hero-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.55;animation:blob-float 8s ease-in-out infinite}
.blob1{width:600px;height:600px;background:radial-gradient(circle,rgba(168,85,247,.5),rgba(236,72,153,.3));top:-10%;left:-15%;animation-delay:0s}
.blob2{width:500px;height:500px;background:radial-gradient(circle,rgba(56,189,248,.5),rgba(168,85,247,.3));top:20%;right:-10%;animation-delay:3s}
.blob3{width:400px;height:400px;background:radial-gradient(circle,rgba(236,72,153,.4),rgba(251,191,36,.2));bottom:-10%;left:30%;animation-delay:6s}
@keyframes blob-float{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(30px,-20px) scale(1.05)}66%{transform:translate(-20px,15px) scale(.95)}}

.hero-grid-overlay{position:absolute;inset:0;background-image:linear-gradient(rgba(168,85,247,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(168,85,247,.04) 1px,transparent 1px);background-size:50px 50px;z-index:1}

.hero-content{position:relative;z-index:2;width:100%;max-width:1160px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:clamp(40px,6vw,80px)}

.hero-left{flex:1;min-width:0}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.7);border:1.5px solid rgba(168,85,247,.2);border-radius:999px;padding:7px 18px;font-size:.78rem;font-weight:500;color:var(--text-2);margin-bottom:28px;backdrop-filter:blur(10px);box-shadow:0 2px 12px rgba(168,85,247,.1)}
.badge-dot{width:7px;height:7px;background:#22c55e;border-radius:50%;box-shadow:0 0 8px #22c55e;animation:blink 2s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

.hero-title{font-family:var(--font-d);font-size:clamp(2.4rem,7vw,5.2rem);font-weight:800;line-height:1.07;letter-spacing:-.04em;margin-bottom:22px}
.hero-name{display:block;background:linear-gradient(135deg,var(--text) 30%,var(--grad-4));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-dash{color:var(--grad-1);margin:0 4px}
.hero-role{display:block;font-size:clamp(1rem,2.8vw,1.8rem);font-weight:500;background:linear-gradient(90deg,var(--grad-1),var(--grad-2));-webkit-background-clip:text;background-clip:text;color:transparent;margin-top:8px;min-height:1.5em}

.hero-sub{font-size:clamp(.9rem,2vw,1.05rem);color:var(--text-2);max-width:500px;line-height:1.75;margin-bottom:36px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:48px}
.hero-stats{display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.stat-num{display:block;font-family:var(--font-d);font-size:clamp(1.4rem,3vw,2rem);font-weight:800;background:linear-gradient(135deg,var(--grad-1),var(--grad-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.stat-label{font-size:.72rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.1em}
.stat-divider{width:1px;height:36px;background:linear-gradient(to bottom,transparent,var(--border),transparent)}

/* Hero right — profile card */
.hero-right{flex:0 0 auto}
.profile-wrapper{position:relative;width:clamp(260px,36vw,400px);height:clamp(260px,36vw,400px);display:flex;align-items:center;justify-content:center}
.profile-ring{position:absolute;inset:0;border-radius:50%;border:1.5px solid rgba(168,85,247,.2);animation:spin-slow 20s linear infinite}
.profile-ring::before{content:'';position:absolute;top:-5px;left:50%;width:10px;height:10px;background:linear-gradient(135deg,var(--grad-1),var(--grad-2));border-radius:50%;box-shadow:0 0 12px var(--grad-1);transform:translateX(-50%)}
.ring-2{inset:18px;border-color:rgba(236,72,153,.15);animation:spin-slow 14s linear infinite reverse;animation-delay:-7s}
@keyframes spin-slow{to{transform:rotate(360deg)}}

.profile-card{position:relative;width:clamp(170px,27vw,270px);height:clamp(170px,27vw,270px);background:rgba(255,255,255,.75);border:1.5px solid rgba(255,255,255,.9);border-radius:50%;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(20px);box-shadow:0 20px 80px rgba(168,85,247,.2),inset 0 1px 0 rgba(255,255,255,.9)}
.avatar-placeholder{width:clamp(95px,15vw,145px);height:clamp(95px,15vw,145px);background:linear-gradient(135deg,var(--grad-1),var(--grad-2),var(--grad-3));border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-d);font-size:clamp(2.5rem,5vw,4rem);font-weight:800;color:#fff;position:relative;box-shadow:0 8px 40px rgba(168,85,247,.4)}
.avatar-glow{position:absolute;inset:-16px;background:radial-gradient(circle,rgba(168,85,247,.2) 0%,transparent 70%);border-radius:50%;animation:logo-pulse 3s ease-in-out infinite}

.profile-info-card{position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.9);border:1px solid rgba(168,85,247,.15);border-radius:999px;padding:6px 14px;font-size:.7rem;color:var(--text-3);white-space:nowrap;box-shadow:0 4px 16px rgba(168,85,247,.1);backdrop-filter:blur(10px)}
.status-dot{width:6px;height:6px;background:#22c55e;border-radius:50%;box-shadow:0 0 6px #22c55e}

.floating-tag{position:absolute;background:rgba(255,255,255,.88);border:1.5px solid rgba(168,85,247,.15);border-radius:999px;padding:7px 14px;font-size:.72rem;font-weight:600;color:var(--text-2);display:flex;align-items:center;gap:6px;backdrop-filter:blur(10px);box-shadow:0 4px 20px rgba(168,85,247,.12);animation:float-tag 4s ease-in-out infinite}
.floating-tag i{color:var(--accent)}
.tag-1{top:10%;right:-24px;animation-delay:0s}
.tag-2{bottom:20%;left:-32px;animation-delay:1.3s}
.tag-3{top:50%;right:-30px;animation-delay:2.6s}
@keyframes float-tag{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

.scroll-indicator{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;opacity:.45;z-index:2}
.scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,var(--grad-1),transparent);animation:scroll-pulse 2s ease-in-out infinite}
.scroll-indicator span{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-3)}
@keyframes scroll-pulse{0%,100%{opacity:1;transform:scaleY(1)}50%{opacity:.4;transform:scaleY(.6)}}

/* ================================================================
   ABOUT
   ================================================================ */
.about{background:var(--bg-2)}
.about::before{content:'';position:absolute;top:0;right:0;width:500px;height:500px;background:radial-gradient(circle,rgba(168,85,247,.07) 0%,transparent 70%);pointer-events:none}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:start}
.about-lead{font-family:var(--font-d);font-size:clamp(1rem,2vw,1.25rem);font-weight:700;color:var(--text);line-height:1.55;margin-bottom:20px}
.about-body{color:var(--text-2);margin-bottom:16px;font-size:.95rem;line-height:1.75}
.about-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.about-card{padding:24px;border-radius:var(--r-md);background:rgba(255,255,255,.7);border:1.5px solid rgba(168,85,247,.1);backdrop-filter:blur(12px);box-shadow:0 4px 20px rgba(168,85,247,.06);transition:border-color .3s,transform .3s,box-shadow .3s}
.about-card:hover{border-color:rgba(168,85,247,.3);transform:translateY(-5px);box-shadow:var(--shadow)}
.acard-icon{font-size:1.4rem;margin-bottom:12px;background:linear-gradient(135deg,var(--grad-1),var(--grad-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.about-card h3{font-family:var(--font-d);font-size:.95rem;font-weight:700;margin-bottom:8px;color:var(--text)}
.about-card p{font-size:.8rem;color:var(--text-3);line-height:1.6}

/* ================================================================
   SKILLS
   ================================================================ */
.skills{background:var(--bg)}
.skills-bg-glow{position:absolute;top:30%;left:50%;transform:translate(-50%,-50%);width:700px;height:400px;background:radial-gradient(ellipse,rgba(168,85,247,.07) 0%,transparent 70%);pointer-events:none}
.skills-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.skill-card{padding:28px 20px 22px;border-radius:var(--r-md);text-align:center;background:rgba(255,255,255,.8);border:1.5px solid rgba(168,85,247,.1);backdrop-filter:blur(12px);box-shadow:0 4px 20px rgba(168,85,247,.05);transition:border-color .3s,transform .3s,box-shadow .3s}
.skill-card:hover{border-color:rgba(168,85,247,.3);transform:translateY(-6px);box-shadow:var(--shadow)}
.skill-icon{font-size:2rem;margin-bottom:12px;background:linear-gradient(135deg,var(--grad-1),var(--grad-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.skill-card h3{font-family:var(--font-d);font-size:.9rem;font-weight:700;color:var(--text);margin-bottom:14px}
.skill-bar{height:4px;background:#ede9fe;border-radius:999px;overflow:hidden;margin-bottom:8px}
.skill-fill{height:100%;background:linear-gradient(90deg,var(--grad-1),var(--grad-2),var(--grad-3));border-radius:999px;width:0%;transition:width 1.2s cubic-bezier(.25,.8,.25,1)}
.skill-pct{font-size:.68rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.1em}

/* ================================================================
   PROJECTS
   ================================================================ */
.projects{background:var(--bg-2)}
.projects::before{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--grad-1),var(--grad-2),var(--grad-3))}

.project-featured{margin-bottom:clamp(32px,5vw,52px)}
.project-featured-inner{display:grid;grid-template-columns:1fr 1.1fr;gap:0;border-radius:var(--r-xl);overflow:hidden;background:rgba(255,255,255,.75);border:1.5px solid rgba(168,85,247,.15);backdrop-filter:blur(16px);box-shadow:0 8px 40px rgba(168,85,247,.1);transition:border-color .3s,box-shadow .3s,transform .3s}
.project-featured-inner:hover{border-color:rgba(168,85,247,.35);box-shadow:0 24px 80px rgba(168,85,247,.2);transform:translateY(-4px)}

.project-image-placeholder{width:100%;height:100%;min-height:360px;position:relative;overflow:hidden}
.p1{background:linear-gradient(135deg,#f3e8ff 0%,#e9d5ff 40%,#ddd6fe 100%)}
.p2{background:linear-gradient(135deg,#e0f2fe 0%,#bae6fd 40%,#ddd6fe 100%)}

.proj-img-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative}
.proj-logo-big{font-size:clamp(3.5rem,7vw,6rem);background:linear-gradient(135deg,var(--grad-1),var(--grad-2));-webkit-background-clip:text;background-clip:text;color:transparent;position:relative;z-index:2}
.proj-glow-orb{position:absolute;width:200px;height:200px;background:radial-gradient(circle,rgba(168,85,247,.25) 0%,transparent 70%);border-radius:50%;animation:orb-pulse 4s ease-in-out infinite}
.orb2{background:radial-gradient(circle,rgba(56,189,248,.25) 0%,transparent 70%)}
@keyframes orb-pulse{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.3);opacity:1}}
.proj-particles{position:absolute;inset:0;overflow:hidden}
.proj-particles span{position:absolute;width:3px;height:3px;background:var(--grad-1);border-radius:50%;opacity:.35;animation:particle-float 6s ease-in-out infinite}
.proj-particles span:nth-child(1){top:20%;left:15%;animation-delay:0s}
.proj-particles span:nth-child(2){top:70%;left:75%;animation-delay:1.2s}
.proj-particles span:nth-child(3){top:40%;left:85%;animation-delay:2.4s}
.proj-particles span:nth-child(4){top:80%;left:25%;animation-delay:3.6s}
.proj-particles span:nth-child(5){top:15%;left:60%;animation-delay:.8s}
@keyframes particle-float{0%,100%{transform:translate(0,0) scale(1);opacity:.35}33%{transform:translate(12px,-16px) scale(2.5);opacity:.7}66%{transform:translate(-8px,8px) scale(1.5);opacity:.5}}

.project-info{padding:clamp(28px,4vw,48px);display:flex;flex-direction:column;gap:16px}
.proj-badge{display:inline-block;background:linear-gradient(135deg,rgba(168,85,247,.12),rgba(236,72,153,.12));border:1px solid rgba(168,85,247,.25);color:var(--accent);font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:5px 14px;border-radius:999px;width:fit-content}
.badge-pink{background:linear-gradient(135deg,rgba(56,189,248,.12),rgba(168,85,247,.12));border-color:rgba(56,189,248,.3);color:#0284c7}
.proj-title{font-family:var(--font-d);font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;color:var(--text);letter-spacing:-.03em;line-height:1.1}
.proj-desc{font-size:.9rem;color:var(--text-2);line-height:1.75}
.proj-tags{display:flex;flex-wrap:wrap;gap:8px}
.tag{background:rgba(168,85,247,.07);border:1px solid rgba(168,85,247,.15);border-radius:999px;padding:5px 13px;font-size:.72rem;font-weight:500;color:var(--accent)}
.proj-features{display:flex;flex-direction:column;gap:8px}
.feat{display:flex;align-items:center;gap:8px;font-size:.83rem;color:var(--text-2)}
.feat i{background:linear-gradient(135deg,var(--grad-1),var(--grad-2));-webkit-background-clip:text;background-clip:text;color:transparent;font-size:.8rem}
.proj-buttons{display:flex;flex-wrap:wrap;gap:12px;margin-top:4px}

.project-sec-inner{display:grid;grid-template-columns:1fr 1.5fr;gap:0;border-radius:var(--r-xl);overflow:hidden;background:rgba(255,255,255,.75);border:1.5px solid rgba(168,85,247,.12);backdrop-filter:blur(16px);box-shadow:0 8px 40px rgba(168,85,247,.08);transition:border-color .3s,box-shadow .3s,transform .3s}
.project-sec-inner:hover{border-color:rgba(56,189,248,.35);box-shadow:0 24px 80px rgba(56,189,248,.15);transform:translateY(-4px)}
.project-sec-media .project-image-placeholder{min-height:280px}
.project-sec-info{padding:clamp(24px,4vw,44px);display:flex;flex-direction:column;gap:16px}

.tilt-card{transform-style:preserve-3d;will-change:transform}

/* ================================================================
   SERVICES
   ================================================================ */
.services{background:var(--bg)}
.services-bg{position:absolute;top:0;right:0;width:50%;height:100%;background:radial-gradient(ellipse at right center,rgba(236,72,153,.05) 0%,transparent 70%);pointer-events:none}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.service-card{padding:clamp(24px,3.5vw,36px);border-radius:var(--r-lg);background:rgba(255,255,255,.8);border:1.5px solid rgba(168,85,247,.1);backdrop-filter:blur(12px);box-shadow:0 4px 20px rgba(168,85,247,.05);position:relative;overflow:hidden;transition:border-color .3s,transform .35s,box-shadow .35s}
.service-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(168,85,247,.04) 0%,rgba(236,72,153,.04) 100%);opacity:0;transition:opacity .35s}
.service-card:hover{border-color:rgba(168,85,247,.3);transform:translateY(-6px);box-shadow:var(--shadow)}
.service-card:hover::before{opacity:1}
.serv-num{font-family:var(--font-d);font-size:.7rem;font-weight:700;background:linear-gradient(135deg,var(--grad-1),var(--grad-2));-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:.1em;margin-bottom:16px;opacity:.8}
.serv-icon{font-size:1.8rem;margin-bottom:16px;background:linear-gradient(135deg,var(--grad-1),var(--grad-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.service-card h3{font-family:var(--font-d);font-size:1rem;font-weight:700;color:var(--text);margin-bottom:10px}
.service-card p{font-size:.83rem;color:var(--text-3);line-height:1.65}

/* ================================================================
   CONTACT
   ================================================================ */
.contact{background:linear-gradient(135deg,#fdf4ff 0%,#f0e7ff 40%,#e0f2fe 100%)}
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(40px,6vw,80px);align-items:start}
.contact-lead{font-size:clamp(1rem,2vw,1.15rem);color:var(--text-2);line-height:1.75;margin-bottom:36px}
.contact-socials{display:flex;flex-direction:column;gap:12px}
.social-item{display:flex;align-items:center;gap:14px;padding:16px 20px;border-radius:var(--r-sm);background:rgba(255,255,255,.7);border:1.5px solid rgba(168,85,247,.12);backdrop-filter:blur(10px);box-shadow:0 2px 12px rgba(168,85,247,.06);transition:border-color .25s,transform .25s,box-shadow .25s}
.social-item:hover{border-color:rgba(168,85,247,.3);transform:translateX(6px);box-shadow:var(--shadow)}
.social-item i:first-child{font-size:1.1rem;background:linear-gradient(135deg,var(--grad-1),var(--grad-2));-webkit-background-clip:text;background-clip:text;color:transparent;width:22px}
.social-item span{flex:1;font-size:.9rem;color:var(--text-2);font-weight:500}
.social-arrow{font-size:.7rem;color:var(--text-3);transition:transform .25s,color .25s}
.social-item:hover .social-arrow{transform:translateX(4px);color:var(--accent)}

.contact-form{padding:clamp(24px,4vw,44px);border-radius:var(--r-lg);background:rgba(255,255,255,.75);border:1.5px solid rgba(168,85,247,.15);backdrop-filter:blur(20px);box-shadow:0 8px 40px rgba(168,85,247,.1);display:flex;flex-direction:column;gap:24px}
.form-group{position:relative}
.form-group input,.form-group textarea{width:100%;background:transparent;border:none;border-bottom:1.5px solid rgba(168,85,247,.2);color:var(--text);font-family:var(--font-b);font-size:.9rem;padding:16px 0 10px;outline:none;resize:none;transition:border-color .3s}
.form-group input:focus,.form-group textarea:focus{border-color:var(--accent)}
.form-group label{position:absolute;top:16px;left:0;font-size:.85rem;color:var(--text-3);pointer-events:none;transition:transform .25s,font-size .25s,color .25s}
.form-group input:focus~label,.form-group input:not(:placeholder-shown)~label,.form-group textarea:focus~label,.form-group textarea:not(:placeholder-shown)~label{transform:translateY(-22px);font-size:.72rem;color:var(--accent)}
.input-line{position:absolute;bottom:0;left:0;width:0%;height:2px;background:linear-gradient(90deg,var(--grad-1),var(--grad-2));transition:width .4s ease;border-radius:999px}
.form-group input:focus~.input-line,.form-group textarea:focus~.input-line{width:100%}
.form-success{display:none;align-items:center;gap:10px;background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.25);border-radius:var(--r-sm);padding:14px 18px;font-size:.85rem;color:#16a34a}
.form-success i{font-size:1rem}
.form-success.show{display:flex}

/* ── FOOTER ── */
.footer{background:#fff;border-top:1px solid rgba(168,85,247,.1);padding:32px 0}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.footer-logo{font-family:var(--font-d);font-size:1.2rem;font-weight:800;color:var(--text)}
.footer-copy{font-size:.78rem;color:var(--text-3)}
.footer-socials{display:flex;gap:16px}
.footer-socials a{color:var(--text-3);font-size:1rem;transition:color .25s,transform .25s}
.footer-socials a:hover{color:var(--accent);transform:translateY(-2px)}

/* ── BACK TO TOP ── */
.back-to-top{position:fixed;bottom:28px;right:24px;width:46px;height:46px;background:linear-gradient(135deg,var(--grad-1),var(--grad-2));border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.85rem;cursor:pointer;z-index:800;opacity:0;visibility:hidden;transform:translateY(12px);transition:all .35s;box-shadow:0 4px 20px rgba(168,85,247,.35)}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{transform:translateY(-4px);box-shadow:0 10px 30px rgba(168,85,247,.5)}

/* ── RESPONSIVE ── */
@media(max-width:1024px){.skills-grid{grid-template-columns:repeat(4,1fr)}.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){.about-grid{grid-template-columns:1fr}.about-cards{grid-template-columns:repeat(2,1fr)}.project-featured-inner{grid-template-columns:1fr}.project-image-placeholder{min-height:220px!important}.project-sec-inner{grid-template-columns:1fr}.contact-grid{grid-template-columns:1fr}}
@media(max-width:768px){.nav-links{display:none}.hamburger{display:flex}.hero-content{flex-direction:column-reverse;align-items:center;text-align:center;gap:40px}.hero-sub{margin:0 auto 36px}.hero-cta{justify-content:center}.hero-stats{justify-content:center}.profile-wrapper{width:240px;height:240px}.profile-card{width:155px;height:155px}.tag-1{right:-10px}.tag-2{left:-10px}.tag-3{right:-14px}.skills-grid{grid-template-columns:repeat(2,1fr)}.services-grid{grid-template-columns:1fr}}
@media(max-width:480px){.about-cards{grid-template-columns:1fr}.hero-stats{gap:14px}.stat-divider{height:24px}.floating-tag{font-size:.65rem;padding:4px 10px}.tag-3{display:none}}
@media(max-width:768px){.tilt-card{transform:none!important}}