*,:before,:after{box-sizing:border-box}html,body{min-height:100vh;margin:0;padding:0}body{color:#e2e8f0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#070b1a;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}#root{min-height:100vh}a{color:inherit}::selection{color:#fff;background:#7c3aed}.portfolio{--bg:#070b1a;--bg-soft:#0d1329;--panel:#ffffff0a;--panel-border:#ffffff14;--text:#e2e8f0;--text-dim:#94a3b8;--accent:#a78bfa;--accent-2:#60a5fa;width:100%;min-height:100vh;color:var(--text);position:relative}.nav{border:1px solid var(--panel-border);-webkit-backdrop-filter:blur(14px);z-index:10;background:#070b1a8c;border-radius:999px;justify-content:space-between;align-items:center;width:min(1120px,100% - 2rem);padding:.7rem 1.2rem;display:flex;position:fixed;top:1rem;left:50%;transform:translate(-50%)}.nav-logo{letter-spacing:.02em;background:linear-gradient(90deg, var(--accent), var(--accent-2));color:#0000;-webkit-background-clip:text;background-clip:text;font-weight:800}.nav-links{gap:1.1rem;margin:0;padding:0;list-style:none;display:flex}.nav-links a{color:var(--text-dim);font-size:.92rem;font-weight:600;text-decoration:none;transition:color .2s}.nav-links a:hover{color:var(--text)}.hero{justify-content:center;align-items:flex-end;min-height:100vh;padding:6rem 1.5rem clamp(5rem,12vh,7rem);display:flex;position:relative;overflow:hidden}.hero-canvas{z-index:0;position:absolute;inset:0}.scene-fallback{background:radial-gradient(#1e1b4b 0%,#070b1a 70%);width:100%;height:100%}.hero-overlay{z-index:1;text-align:center;pointer-events:none;text-shadow:0 2px 28px #070b1aeb,0 1px 2px #070b1abf;width:min(820px,100%);padding:1.2rem;position:relative}.hero-overlay .btn,.hero-overlay a{pointer-events:auto}.hero-kicker{color:#c4b5fd;letter-spacing:.08em;text-transform:uppercase;background:#a78bfa1f;border:1px solid #a78bfa59;border-radius:999px;margin:0 0 1rem;padding:.35rem .85rem;font-size:.8rem;font-weight:700;display:inline-block;box-shadow:0 0 24px #070b1aa6}.hero h1{letter-spacing:-.01em;color:#f8fafc;margin:0 0 1rem;font-size:clamp(2.2rem,5.2vw,3.6rem);font-weight:800;line-height:1.1}.hero-accent{background:linear-gradient(90deg, var(--accent), var(--accent-2));color:#0000;-webkit-background-clip:text;background-clip:text}.hero-text{max-width:640px;color:var(--text-dim);margin:0 auto;font-size:1.05rem;line-height:1.55}.hero-actions{flex-wrap:wrap;justify-content:center;gap:.85rem;margin-top:1.8rem;display:flex}.hero-hint{color:#64748b;letter-spacing:.05em;margin-top:1.4rem;font-size:.82rem}.btn{cursor:pointer;border:0;border-radius:12px;justify-content:center;align-items:center;padding:.75rem 1.2rem;font-size:.95rem;font-weight:700;text-decoration:none;transition:transform .15s,box-shadow .2s,background .2s;display:inline-flex}.btn-primary{color:#fff;background:linear-gradient(135deg,#7c3aed,#3b82f6);box-shadow:0 10px 30px #7c3aed59}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 14px 36px #7c3aed73}.btn-ghost{color:#e2e8f0;border:1px solid var(--panel-border);background:#ffffff0a}.btn-ghost:hover{background:#ffffff14}.section{width:min(1120px,100% - 2rem);margin:0 auto;padding:5rem 0}.section-heading{text-align:center;max-width:720px;margin:0 auto 2.5rem}.eyebrow{color:#93c5fd;letter-spacing:.14em;text-transform:uppercase;background:#60a5fa1a;border:1px solid #60a5fa4d;border-radius:999px;margin-bottom:.7rem;padding:.25rem .7rem;font-size:.72rem;font-weight:700;display:inline-block}.section-heading h2{color:#f8fafc;letter-spacing:-.01em;margin:0 0 .6rem;font-size:clamp(1.6rem,3vw,2.1rem);font-weight:800}.section-heading p{color:var(--text-dim);margin:0;font-size:1rem;line-height:1.55}.highlights{z-index:2;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;width:min(1120px,100% - 2rem);margin:-2rem auto 0;display:grid;position:relative}.highlight-card{background:var(--panel);border:1px solid var(--panel-border);text-align:center;-webkit-backdrop-filter:blur(10px);border-radius:16px;padding:1.2rem}.highlight-value{background:linear-gradient(90deg, var(--accent), var(--accent-2));color:#0000;-webkit-background-clip:text;background-clip:text;margin:0;font-size:1.7rem;font-weight:800}.highlight-label{color:var(--text-dim);margin:.3rem 0 0;font-size:.9rem}.about-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;display:grid}.about-card{background:var(--panel);border:1px solid var(--panel-border);border-radius:16px;padding:1.2rem;transition:transform .2s,border-color .2s}.about-card:hover{border-color:#a78bfa73;transform:translateY(-3px)}.about-card h3{color:#f8fafc;margin:0 0 .4rem;font-size:1.05rem}.about-card p{color:var(--text-dim);margin:0;font-size:.92rem;line-height:1.5}.skills-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;display:grid}.skill-card{background:var(--panel);border:1px solid var(--panel-border);border-radius:16px;padding:1.2rem;transition:transform .2s,border-color .2s;position:relative;overflow:hidden}.skill-card:before{content:"";background:radial-gradient(circle at 0% 0%, color-mix(in srgb, var(--skill-color) 18%, transparent) 0%, transparent 55%);pointer-events:none;position:absolute;inset:0}.skill-card:hover{border-color:color-mix(in srgb, var(--skill-color) 45%, transparent);transform:translateY(-3px)}.skill-header{align-items:center;gap:.6rem;margin-bottom:.6rem;display:flex}.skill-dot{background:var(--skill-color);width:10px;height:10px;box-shadow:0 0 12px var(--skill-color);border-radius:50%}.skill-header h3{color:#f8fafc;flex:1;margin:0;font-size:1.05rem}.skill-level{color:var(--text-dim);font-size:.8rem;font-weight:700}.skill-card p{color:var(--text-dim);margin:0 0 .85rem;font-size:.9rem;line-height:1.5}.skill-bar{background:#ffffff0f;border-radius:999px;height:6px;overflow:hidden}.skill-bar-fill{background:linear-gradient(90deg, var(--skill-color), color-mix(in srgb, var(--skill-color) 60%, white));border-radius:999px;height:100%;transition:width .5s}.contact-section{padding-bottom:3rem}.contact-card{text-align:center;background:linear-gradient(135deg,#7c3aed2e,#3b82f61f);border:1px solid #a78bfa59;border-radius:24px;padding:3rem 1.5rem}.contact-card h2{color:#f8fafc;margin:.5rem 0 .6rem;font-size:clamp(1.6rem,3vw,2.2rem)}.contact-card p{max-width:540px;color:var(--text-dim);margin:0 auto 1.6rem}.contact-actions{flex-wrap:wrap;justify-content:center;gap:.85rem;display:flex}.footer{width:min(1120px,100% - 2rem);color:var(--text-dim);border-top:1px solid var(--panel-border);justify-content:space-between;margin:0 auto;padding:1.5rem 0 2rem;font-size:.85rem;display:flex}@media (width<=900px){.nav-links{gap:.7rem}.highlights{grid-template-columns:1fr}.about-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.skills-grid{grid-template-columns:1fr}.footer{text-align:center;flex-direction:column;gap:.3rem}}@media (width<=520px){.about-grid{grid-template-columns:1fr}.nav-links li:first-child{display:none}}
