:root{--primary:#5aa9ff;--secondary:#93c5fd;--dark-bg:#f5fbff;--card-bg:#fff;--text-main:#0f172a;--text-sub:#475569;--gradient:linear-gradient(135deg, #5aa9ff 0%, #7dd3fc 60%, #a7f3d0 100%);--vue-color:#42b883}*{box-sizing:border-box;margin:0;padding:0;font-family:Inter,system-ui,-apple-system,sans-serif}body{background-color:var(--dark-bg);color:var(--text-main);line-height:1.6}a{color:inherit;text-decoration:none;transition:all .3s}.container{max-width:1400px;margin:0 auto;padding:0 2rem}header{text-align:center;background:radial-gradient(circle at top,#fff 0%,#eef6ff 70%);border-bottom:1px solid #0f172a14;padding:6rem 0 4rem}.header-icon{margin-bottom:1rem;font-size:4rem}h1{background:var(--gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:1rem;font-size:3rem;font-weight:800}.subtitle{color:var(--text-sub);font-size:1.2rem;font-weight:300}.btn{background:var(--primary);color:#fff;cursor:pointer;border-radius:50px;margin-top:1.5rem;padding:.8rem 2.5rem;font-weight:600;display:inline-block;box-shadow:0 6px 20px #4f8df740}.btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px #4f8df759}.tech-stack{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:2rem;display:flex}.chip{color:var(--primary);background:#0284c71a;border-radius:4px;padding:5px 10px;font-size:.8rem;font-weight:500}.vue-chip{color:var(--vue-color);background:#42b88326}.gallery-section{padding:4rem 0}.tabs{flex-wrap:wrap;justify-content:center;gap:1rem;margin-bottom:3rem;display:flex}.tab-btn{border:1px solid var(--text-sub);color:var(--text-sub);cursor:pointer;background:0 0;border-radius:50px;padding:.6rem 2rem;font-size:1.1rem;transition:all .3s}.tab-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 0 15px #4f8df733}.grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem;animation:.5s fadeIn;display:grid}.card{background:var(--card-bg);cursor:pointer;border:1px solid #0f172a14;border-radius:16px;flex-direction:column;transition:all .3s;display:flex;overflow:hidden}.card:hover{border-color:var(--secondary);transform:translateY(-5px);box-shadow:0 14px 40px #0f172a1f}.card-img-wrapper{background:#e2e8f0;justify-content:center;align-items:center;width:100%;height:240px;display:flex;overflow:hidden}.card img{object-fit:cover;object-position:top center;width:100%;height:100%;transition:all .5s}.card:hover img{transform:scale(1.05)}.card-body{flex-direction:column;flex-grow:1;justify-content:space-between;padding:1.5rem;display:flex}.card-title{color:var(--text-main);margin-bottom:.5rem;font-size:1.2rem;font-weight:700}.card-desc{color:var(--text-sub);font-size:.95rem;line-height:1.5}.card-meta{color:#64748b;margin-top:1rem;font-family:monospace;font-size:.8rem}.modal{z-index:9999;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000000f2;justify-content:center;align-items:center;width:100%;height:100%;display:none;position:fixed;top:0;left:0}.modal.open{animation:.2s fadeIn;display:flex}.modal img{cursor:default;border-radius:4px;max-width:95%;max-height:95%;box-shadow:0 0 50px #00000080}.modal-close{color:#fff;cursor:pointer;font-size:4rem;line-height:1;transition:color .3s;position:absolute;top:20px;right:30px}.modal-close:hover{color:#ff5c5c}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (width<=768px){h1{font-size:2rem}.grid{grid-template-columns:1fr}.card-img-wrapper{height:200px}}
