@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{--bg:#080808;--bg-s:#0f0f0f;--bg-e:#161616;--bg-h:#1e1e1e;--border:#ffffff12;--border-s:#ffffff21;--t1:#f2f2f2;--t2:#8a8a8a;--t3:#4a4a4a;--accent:#6366f1;--accent-s:#6366f12e;--r-sm:8px;--r-md:14px;--r-lg:20px;--r-xl:28px;--r-2xl:36px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--t1);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,sans-serif;line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}button{font-family:inherit}img{max-width:100%;display:block}.container{max-width:1180px;margin:0 auto;padding-inline:40px}.gradient-text{background:linear-gradient(135deg,#818cf8 0%,#c084fc 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.section-title{letter-spacing:-.04em;margin-bottom:10px;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;line-height:1.1}.section-subtitle{color:var(--t2);font-size:1rem}.btn-primary{color:#fff;background:var(--accent);cursor:pointer;white-space:nowrap;border:none;border-radius:999px;align-items:center;gap:8px;padding:11px 22px;font-size:.9rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary:hover{background:#5558e8;transform:translateY(-1px);box-shadow:0 8px 24px #6366f159}.btn-secondary{color:var(--t1);border:1px solid var(--border-s);cursor:pointer;background:#ffffff0f;border-radius:999px;align-items:center;gap:8px;padding:11px 22px;font-size:.9rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-secondary:hover{background:#ffffff1a;border-color:#fff3}.btn-ghost{color:var(--t2);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:999px;align-items:center;gap:6px;padding:11px 18px;font-size:.88rem;font-weight:500;transition:all .2s;display:inline-flex}.btn-ghost:hover{color:var(--t1);border-color:var(--border-s)}.stack-chip{letter-spacing:.02em;color:var(--t2);border:1px solid var(--border);background:#ffffff0d;border-radius:999px;padding:3px 10px;font-size:.71rem;font-weight:600}.live-dot{background:#22c55e;border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:2s ease-in-out infinite livePulse;box-shadow:0 0 0 2px #22c55e40}@keyframes livePulse{0%,to{box-shadow:0 0 0 2px #22c55e40}50%{box-shadow:0 0 0 6px #22c55e1a}}.status-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.card-status-live .status-dot,.card-status-public .status-dot{background:#22c55e}.card-status-private .status-dot{background:#6b7280}.card-status-wip .status-dot{background:#f59e0b}.cursor-glow{pointer-events:none;z-index:0;will-change:left, top;background:radial-gradient(circle,#6366f10e 0%,#0000 65%);border-radius:50%;width:600px;height:600px;position:fixed;transform:translate(-50%,-50%)}.nav{z-index:100;-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--border);background:#080808bf;justify-content:space-between;align-items:center;padding:16px 40px;display:flex;position:fixed;inset:0 0 auto}.nav-logo{letter-spacing:-.04em;background:linear-gradient(135deg,#fff 0%,#666 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.05rem;font-weight:900}.nav-links{align-items:center;gap:6px;display:flex}.nav-link{color:var(--t2);border-radius:var(--r-sm);padding:7px 14px;font-size:.875rem;font-weight:500;transition:color .15s}.nav-link:hover{color:var(--t1)}.nav-github{color:var(--t1);border:1px solid var(--border-s);background:#ffffff0d;border-radius:999px;align-items:center;gap:7px;margin-left:8px;padding:7px 16px;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.nav-github:hover{background:#ffffff17;border-color:#fff3}.hero{justify-content:center;align-items:center;min-height:100svh;padding:100px 40px 80px;display:flex;position:relative;overflow:hidden}.hero-bg{pointer-events:none;position:absolute;inset:0}.hero-orb{filter:blur(80px);opacity:.35;border-radius:50%;position:absolute}.hero-orb-1{background:radial-gradient(circle,#6366f1 0%,#0000 70%);width:500px;height:500px;animation:18s ease-in-out infinite alternate orbFloat1;top:-100px;left:-100px}.hero-orb-2{background:radial-gradient(circle,#8b5cf6 0%,#0000 70%);width:400px;height:400px;animation:22s ease-in-out infinite alternate orbFloat2;bottom:-80px;right:-80px}.hero-orb-3{opacity:.18;background:radial-gradient(circle,#06b6d4 0%,#0000 70%);width:300px;height:300px;animation:26s ease-in-out infinite alternate-reverse orbFloat1;top:40%;left:60%}@keyframes orbFloat1{0%{transform:translate(0)scale(1)}to{transform:translate(60px,40px)scale(1.1)}}@keyframes orbFloat2{0%{transform:translate(0)scale(1)}to{transform:translate(-50px,-30px)scale(1.08)}}.hero-grid{background-image:radial-gradient(#ffffff0f 1px,#0000 1px);background-size:36px 36px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(70% 60%,#000 30%,#0000 100%);mask-image:radial-gradient(70% 60%,#000 30%,#0000 100%)}.hero-content{z-index:1;text-align:center;opacity:0;max-width:780px;transition:opacity .7s,transform .7s;position:relative;transform:translateY(28px)}.hero-content.visible{opacity:1;transform:translateY(0)}.hero-eyebrow{color:var(--t2);border:1px solid var(--border-s);letter-spacing:.02em;background:#ffffff0a;border-radius:999px;align-items:center;gap:9px;margin-bottom:36px;padding:7px 16px;font-size:.8rem;font-weight:500;display:inline-flex}.hero-heading{letter-spacing:-.04em;color:var(--t1);flex-direction:column;align-items:center;gap:.05em;margin-bottom:24px;font-size:clamp(2.6rem,7vw,5.5rem);font-weight:900;line-height:1.05;display:flex}.typewriter-wrap{align-items:center;gap:2px;min-height:1.1em;display:inline-flex}.typewriter-text{background:linear-gradient(135deg,#818cf8 0%,#c084fc 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.typewriter-cursor{color:#818cf8;margin-left:2px;font-weight:300;animation:1s step-end infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-body{color:var(--t2);max-width:580px;margin:0 auto 40px;font-size:1.1rem;line-height:1.75}.hero-actions{flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;margin-bottom:64px;display:flex}.hero-stats{background:var(--border);border:1px solid var(--border);border-radius:var(--r-lg);grid-template-columns:repeat(4,1fr);gap:1px;max-width:540px;margin:0 auto;display:grid;overflow:hidden}.hero-stat{background:var(--bg-s);flex-direction:column;align-items:center;gap:4px;padding:20px 16px;transition:background .2s;display:flex}.hero-stat:hover{background:var(--bg-e)}.hero-stat-num{letter-spacing:-.04em;color:var(--t1);font-size:1.5rem;font-weight:800}.hero-stat-label{color:var(--t3);text-transform:uppercase;letter-spacing:.06em;text-align:center;font-size:.7rem;font-weight:500}.hero-scroll-hint{cursor:pointer;color:var(--t3);background:0 0;border:none;padding:8px;animation:2.5s ease-in-out infinite scrollBounce;position:absolute;bottom:32px;left:50%;transform:translate(-50%)}@keyframes scrollBounce{0%,to{opacity:.4;transform:translate(-50%)translateY(0)}50%{opacity:.9;transform:translate(-50%)translateY(6px)}}.work-section{padding:100px 0}.work-header{margin-bottom:56px}.featured-card{background:var(--bg-s);border:1px solid var(--border);border-radius:var(--r-2xl);opacity:0;grid-template-columns:1fr 1.1fr;gap:0;margin-bottom:56px;transition:opacity .65s,transform .65s,border-color .3s;display:grid;position:relative;overflow:hidden;transform:translateY(36px)}.featured-card.visible{opacity:1;transform:translateY(0)}.featured-card:hover{border-color:var(--border-s);box-shadow:0 24px 80px #00000080}.featured-blob{opacity:.07;filter:blur(60px);pointer-events:none;border-radius:50%;width:400px;height:400px;position:absolute;top:-120px;left:-120px}.featured-content{z-index:1;flex-direction:column;gap:20px;padding:48px;display:flex;position:relative}.featured-meta{align-items:center;gap:12px;display:flex}.featured-badge{color:var(--accent);background:var(--accent-s);letter-spacing:.03em;border:1px solid #6366f140;border-radius:999px;padding:4px 12px;font-size:.75rem;font-weight:700}.featured-year{color:var(--t3);font-size:.8rem;font-weight:500}.featured-name{letter-spacing:-.04em;color:var(--t1);font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:800;line-height:1.1}.featured-tagline{color:var(--card-color,var(--accent));font-size:1rem;font-weight:600}.featured-desc{color:var(--t2);font-size:.93rem;line-height:1.75}.featured-highlights{flex-direction:column;gap:8px;list-style:none;display:flex}.featured-highlights li{color:var(--t2);align-items:center;gap:10px;font-size:.875rem;font-weight:500;display:flex}.featured-highlights svg{color:var(--card-color,var(--accent));flex-shrink:0}.featured-stack{flex-wrap:wrap;gap:6px;display:flex}.featured-actions{flex-wrap:wrap;align-items:center;gap:10px;margin-top:auto;padding-top:8px;display:flex}.featured-preview{background:var(--bg);border-left:1px solid var(--border);flex-direction:column;display:flex}.featured-preview-frame{flex-direction:column;flex:1;display:flex}.preview-bar{background:var(--bg-s);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;padding:10px 16px;display:flex}.dot{border-radius:50%;width:11px;height:11px}.dot.red{background:#ff5f57}.dot.yellow{background:#febc2e}.dot.green{background:#28c840}.preview-url-text{color:var(--t3);border:1px solid var(--border);text-overflow:ellipsis;white-space:nowrap;background:#ffffff08;border-radius:6px;flex:1;padding:3px 10px;font-family:monospace;font-size:.75rem;overflow:hidden}.featured-thumbnail-wrap{flex:1;min-height:0;position:relative;overflow:hidden}.featured-thumbnail{object-fit:cover;object-position:top;width:100%;height:100%;transition:transform .5s}.featured-card:hover .featured-thumbnail{transform:scale(1.03)}.thumbnail-overlay{background:0 0;justify-content:center;align-items:center;transition:background .25s;display:flex;position:absolute;inset:0}.thumbnail-overlay:hover{background:#0000008c}.thumbnail-open-hint{color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;background:#ffffff1f;border:1px solid #ffffff40;border-radius:999px;align-items:center;gap:8px;padding:10px 20px;font-size:.9rem;font-weight:600;transition:all .25s;display:flex;transform:translateY(6px)}.thumbnail-overlay:hover .thumbnail-open-hint{opacity:1;transform:translateY(0)}.featured-status-row{border-top:1px solid var(--border);color:var(--t2);align-items:center;gap:8px;padding:12px 16px;font-size:.78rem;display:flex}.featured-status-text{font-weight:500}.project-grid-section{margin-top:0}.grid-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:28px;display:flex}.grid-subheading{color:var(--t2);letter-spacing:-.02em;font-size:1.1rem;font-weight:700}.filter-bar{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.filter-pill{color:var(--t2);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:999px;padding:5px 13px;font-family:Inter,sans-serif;font-size:.775rem;font-weight:500;transition:all .18s}.filter-pill:hover{color:var(--t1);border-color:var(--border-s);background:#ffffff0a}.filter-pill.active{color:#fff;background:#6366f133;border-color:#6366f173}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.grid-empty{text-align:center;color:var(--t3);grid-column:1/-1;padding:60px 0;font-size:.95rem}.project-card{background:var(--bg-s);border:1px solid var(--border);border-radius:var(--r-xl);cursor:pointer;transition:opacity .5s,translate .5s cubic-bezier(.16,1,.3,1),transform .22s cubic-bezier(.16,1,.3,1),border-color .22s,box-shadow .22s;position:relative;overflow:hidden}.project-card:hover{border-color:color-mix(in srgb, var(--card-color) 40%, transparent);box-shadow:0 12px 48px #0006, 0 0 0 1px color-mix(in srgb, var(--card-color) 25%, transparent);background:var(--bg-e)}.project-card:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.card-topline{width:100%;height:3px}.card-thumbnail-wrap{background:var(--bg);height:180px;position:relative;overflow:hidden}.card-thumbnail{object-fit:cover;object-position:top;width:100%;height:100%;transition:transform .4s}.project-card:hover .card-thumbnail{transform:scale(1.05)}.card-thumbnail-overlay{background:linear-gradient(to bottom, transparent 50%, var(--bg-s) 100%);position:absolute;inset:0}.card-body{flex-direction:column;gap:10px;padding:20px 22px 22px;display:flex}.card-header-row{justify-content:space-between;align-items:center;display:flex}.card-icon{font-size:1.6rem;line-height:1;transition:transform .25s}.project-card:hover .card-icon{transform:scale(1.1)rotate(-5deg)}.card-status{color:var(--t3);border:1px solid var(--border);background:#ffffff0a;border-radius:999px;align-items:center;gap:6px;padding:3px 10px;font-size:.73rem;font-weight:600;display:flex}.card-status-live,.card-status-public{color:#4ade80}.card-status-live .status-dot,.card-status-public .status-dot{background:#22c55e;animation:2s infinite livePulse}.card-name{letter-spacing:-.025em;color:var(--t1);font-size:1.15rem;font-weight:700;transition:color .2s}.project-card:hover .card-name{color:var(--card-color,var(--t1))}.card-tagline{color:var(--t2);font-size:.83rem;line-height:1.5}.card-stack{flex-wrap:wrap;gap:5px;display:flex}.stack-chip-more{color:var(--t3)}.card-footer-row{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:4px;padding-top:6px;display:flex}.card-year{color:var(--t3);font-size:.75rem;font-weight:500}.card-arrow{color:var(--t3);transition:all .2s}.project-card:hover .card-arrow{color:var(--card-color,var(--t2));transform:translate(3px,-3px)}.card-shimmer{pointer-events:none;background:linear-gradient(135deg,#0000 30%,#ffffff05 50%,#0000 70%);animation:2s ease-in-out infinite shimmer;position:absolute;inset:0}@keyframes shimmer{0%{background-position:200% 200%}to{background-position:-200% -200%}}.skills-section{opacity:0;padding:80px 0 100px;transition:opacity .6s,transform .6s;transform:translateY(28px)}.skills-section.visible{opacity:1;transform:translateY(0)}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;display:grid}.skill-card{background:var(--bg-s);border:1px solid var(--border);border-radius:var(--r-lg);text-align:center;opacity:0;flex-direction:column;align-items:center;gap:8px;padding:22px 16px 18px;transition:all .22s;animation:.5s forwards fadeUp;display:flex}.skills-section.visible .skill-card{opacity:1}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.skill-card:hover{border-color:var(--border-s);background:var(--bg-e);transform:translateY(-3px);box-shadow:0 8px 24px #0000004d}.skill-icon{font-size:1.8rem;line-height:1}.skill-name{color:var(--t1);letter-spacing:-.01em;font-size:.875rem;font-weight:700}.skill-bar-wrap{background:#ffffff12;border-radius:999px;width:100%;height:3px;overflow:hidden}.skill-bar{background:linear-gradient(90deg,#818cf8,#c084fc);border-radius:999px;height:100%;transition:width 1s cubic-bezier(.16,1,.3,1)}.skill-count{color:var(--t3);font-size:.7rem;font-weight:500}.footer{border-top:1px solid var(--border);background:var(--bg-s);padding:28px 0}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;display:flex}.footer-left{align-items:center;gap:14px;display:flex}.footer-logo{letter-spacing:-.04em;color:var(--t1);font-size:.95rem;font-weight:900}.footer-copy{color:var(--t3);font-size:.82rem}.footer-links{align-items:center;gap:6px;display:flex}.footer-link{color:var(--t2);border-radius:var(--r-sm);align-items:center;gap:6px;padding:6px 12px;font-size:.82rem;transition:all .15s;display:flex}.footer-link:hover{color:var(--t1);background:#ffffff0d}.modal-backdrop{-webkit-backdrop-filter:blur(16px);z-index:200;background:#000000d1;justify-content:center;align-items:center;padding:24px;animation:.2s backdropIn;display:flex;position:fixed;inset:0}@keyframes backdropIn{0%{opacity:0}to{opacity:1}}.modal-panel{background:var(--bg-s);border:1px solid var(--border-s);border-radius:var(--r-2xl);flex-direction:column;width:100%;max-width:860px;max-height:90vh;animation:.3s cubic-bezier(.16,1,.3,1) modalIn;display:flex;overflow:hidden;box-shadow:0 40px 120px #000000b3}@keyframes modalIn{0%{opacity:0;translate:0 16px;scale:.94}to{opacity:1;translate:0;scale:1}}.modal-topbar{flex-shrink:0;width:100%;height:4px}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:16px;padding:24px 28px 20px;display:flex}.modal-title-group{align-items:center;gap:16px;display:flex}.modal-icon{font-size:2.2rem;line-height:1}.modal-title{letter-spacing:-.03em;color:var(--t1);margin-bottom:4px;font-size:1.5rem;font-weight:800}.modal-tagline{color:var(--card-color,var(--accent));font-size:.875rem;font-weight:500}.modal-close{border:1px solid var(--border);color:var(--t2);cursor:pointer;background:#ffffff0d;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;transition:all .15s;display:flex}.modal-close:hover{color:var(--t1);background:#ffffff17}.modal-body{flex:1;grid-template-columns:1.1fr 1fr;display:grid;overflow:hidden}.modal-thumb-wrap{background:var(--bg);border-right:1px solid var(--border);position:relative;overflow:hidden}.modal-thumb{object-fit:cover;object-position:top;width:100%;height:100%}.modal-thumb-link{color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);white-space:nowrap;background:#000000b3;border:1px solid #fff3;border-radius:999px;align-items:center;gap:7px;padding:8px 16px;font-size:.82rem;font-weight:600;transition:all .2s;display:flex;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.modal-thumb-link:hover{background:#000000e6}.modal-details{flex-direction:column;gap:20px;padding:28px;display:flex;overflow-y:auto}.modal-long-desc{color:var(--t2);font-size:.88rem;line-height:1.75}.modal-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--t3);margin-bottom:10px;font-size:.72rem;font-weight:700}.highlights-list{flex-direction:column;gap:8px;list-style:none;display:flex}.highlights-list li{color:var(--t2);align-items:center;gap:9px;font-size:.85rem;font-weight:500;display:flex}.modal-meta-grid{flex-direction:column;gap:14px;display:flex}.modal-meta-item{flex-direction:column;gap:6px;display:flex}.meta-label{text-transform:uppercase;letter-spacing:.08em;color:var(--t3);font-size:.7rem;font-weight:700}.meta-value{color:var(--t2);font-size:.88rem}.status-badge{color:var(--t1);font-size:.85rem;font-weight:600}.modal-stack{flex-wrap:wrap;gap:5px;display:flex}.modal-actions{flex-wrap:wrap;gap:8px;margin-top:auto;padding-top:8px;display:flex}@media (width<=900px){.featured-card{grid-template-columns:1fr}.featured-preview{border-left:none;border-top:1px solid var(--border);min-height:260px}.modal-body{grid-template-columns:1fr}.modal-thumb-wrap{border-right:none;border-bottom:1px solid var(--border);min-height:200px;max-height:220px}.hero-stats{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.container{padding-inline:20px}.nav{padding:14px 20px}.nav-link{display:none}.hero{padding:90px 20px 70px}.hero-heading{font-size:2.4rem}.hero-body{font-size:.95rem}.projects-grid{grid-template-columns:1fr}.skills-grid{grid-template-columns:repeat(2,1fr)}.featured-content{padding:28px 24px}.grid-header,.footer-inner{flex-direction:column;align-items:flex-start}.modal-panel{max-height:95vh}.cursor-glow{display:none}}
