© 2024 Hugh's Portfolio. All rights reserved.
diff --git a/css/style.css b/css/style.css
index 2d4f684..032ec42 100644
--- a/css/style.css
+++ b/css/style.css
@@ -1,11 +1,12 @@
-
+/* Inter from https://fonts.google.com/specimen/Inter and Rubik One from https://fonts.google.com/specimen/Rubik */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@100..900&family=Rubik+One&display=swap');
-
+/* General Styles */
:root {
--background-color: #808080;
+ /* Light/Dark mode implementated using CSS variables and a data attribute */
/* Dark theme */
body[data-theme="dark"] {
--accent-color: #9B70ff;
@@ -29,6 +30,8 @@
--secondary-text-color: #666;
transition: background-color 0.5s;
+
+ /* Invert image colors for light theme */
.theme-icon {
filter: invert(1);
}
@@ -65,10 +68,11 @@ body {
font-family: 'Inter', sans-serif;
font-size: 16px;
line-height: 1.5;
- min-height: 100vh;
+ min-height: 100vh; /* Full height of the viewport */
color: var(--primary-text-color);
}
+/* Navigation Menu */
header {
display: flex;
justify-content: center;
@@ -81,15 +85,19 @@ nav {
justify-content: space-between;
align-items: center;
padding: 3px 40px;
+
+ /* Opaque background with blur effect */
background-color: rgba(var(--secondary-background-color-rgb), 0.5);
-webkit-backdrop-filter: blur(20px);
backdrop-filter: blur(20px);
+
width: 700px;
- position: fixed;
+ position: fixed; /* Fixed position to keep the menu at the top of the page */
border-radius: 25px;
top: 20px;
z-index: 1000;
+ /* Responsive design */
@media (max-width: 800px) {
width: auto;
align-items: flex-start;
@@ -110,6 +118,7 @@ nav {
opacity: 1;
}
+ /* Show the menu image on smaller screens */
@media (max-width: 800px) {
display: block;
}
@@ -132,11 +141,11 @@ nav {
> .menu-item:hover, > .menu-item.active {
color: var(--primary-text-color);
- border-bottom: 3px solid var(--accent-color);
- /* box-shadow: 0 3px 0 var(--accent-color); */
+ border-bottom: 3px solid var(--accent-color); /* Underline effect for the active menu item */
}
}
+/* Footer */
footer {
justify-self: flex-end;
width: 100%;
@@ -177,40 +186,47 @@ footer a {
height: 30px;
}
+/* Dark/Light Theme Button */
.theme-button {
position: fixed;
top: 20px;
-
- @media (min-width: 801px) and (max-width: 960px) {
- top: 80px;
- }
-
right: 20px;
width: 50px;
height: 50px;
border-radius: 50%;
border: none;
+
+ /* Opaque background with blur effect */
background-color: rgba(var(--secondary-background-color-rgb), 0.5);
backdrop-filter: blur(20px);
+
display: flex;
justify-content: center;
align-items: center;
cursor: pointer;
z-index: 1000;
+ /* Place below navigation menu on certain screen sizes */
+ @media (min-width: 801px) and (max-width: 960px) {
+ top: 80px;
+ }
+
>.theme-icon {
width: 32px;
height: 32px;
}
}
+/* Additional General Styling */
.row {
+ /* Flexbox row with center alignment */
display: flex;
flex-direction: row;
justify-content: center;
align-items: center;
width: 100%;
+ /* Turn into column on smaller screens */
@media (max-width: 800px) {
flex-direction: column;
}
@@ -221,6 +237,7 @@ footer a {
}
.column {
+ /* Flexbox column with center alignment */
display: flex;
flex-direction: column;
justify-content: center;
@@ -263,6 +280,7 @@ h4 {
align-self: flex-start;
> span {
+ /* Accented text */
font-weight: 400;
color: var(--secondary-text-color);
}
@@ -286,6 +304,7 @@ h5 {
}
p > span {
+ /* Accented text */
font-weight: 600;
color: var(--accent-color);
}
@@ -298,7 +317,8 @@ ul {
align-self: flex-start;
}
-#page {
+/* General Page */
+#page, main {
flex: 1;
display: flex;
align-items: start;
@@ -311,6 +331,11 @@ ul {
}
}
+section {
+ width: 100%;
+}
+
+/* Home Page */
#home {
max-width: 800px;
}
@@ -321,6 +346,7 @@ ul {
flex-direction: column;
word-wrap: hidden;
+ /* Staggered padding for each h1 element */
@media (min-width: 801px) {
h1:nth-child(1) {
padding-left: 0;
@@ -344,6 +370,7 @@ ul {
display: block;
}
+/* Experience Page */
#experience {
max-width: 1000px;
}
@@ -351,6 +378,7 @@ ul {
.grid-container {
display: grid;
width: 100%;
+ /* Responsive grid with a minimum width of 90px and a maximum width of 1fr */
grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
gap: 40px 60px;
padding: 20px;
@@ -367,6 +395,7 @@ ul {
padding-bottom: 10px;
}
+/* Projects Page */
#projects {
max-width: 1000px;
@@ -410,7 +439,8 @@ ul {
}
}
- >.column> :nth-child(3n+4) {
+ /* Gap between each project starting from the second project */
+ section:nth-child(n+2) {
margin-top: 80px;
}
}
@@ -435,6 +465,7 @@ ul {
border-radius: var(--radius);
}
+ /* Place all content on top of each other */
.content:first-child {
position: relative;
}
@@ -443,6 +474,7 @@ ul {
position: absolute;
}
+ /* Place arrows on top of the content */
.arrow {
width: 40px;
height: 40px;
@@ -460,6 +492,7 @@ ul {
}
}
+ /* Position arrows */
.left-arrow {
left: -50px;
}
@@ -468,6 +501,7 @@ ul {
right: -50px;
}
+ /* Place dots at the bottom of the container */
.dots {
display: flex;
justify-content: center;
@@ -496,17 +530,20 @@ ul {
}
}
+/* Testimonials Page */
#testimonials {
width: 1000px;
}
.split-grid {
display: grid;
+ /* Two columns with a gap of 40px */
grid-template-columns: 1fr 1fr;
gap: 40px;
width: 100%;
padding: 20px 0;
+ /* One column on smaller screens */
@media (max-width: 800px) {
grid-template-columns: 1fr;
}
@@ -514,6 +551,7 @@ ul {
.linear-grid {
display: grid;
+ /* One column with a gap of 40px */
grid-template-columns: 1fr;
gap: 40px;
width: 100%;
@@ -579,6 +617,7 @@ ul {
background-color: var(--tertiary-background-color);
}
+/* Blog Page */
#blog {
max-width: 1000px;
diff --git a/experience.html b/experience.html
index 47ef089..6dda55d 100644
--- a/experience.html
+++ b/experience.html
@@ -13,266 +13,288 @@
-
-
+
+
-
Education
-
-
- The University of Queensland
- — Bachelor of Computer Science
-
- 2021 — Present
-
-
- I am currently in my third year pursuing a
- Bachelor of Computer Science, majoring in
- Programming Languages, at The University of
- Queensland.
-
-
- I've gained a comprehensive understanding of
- algorithms, data structures,
- software architecture,
- operating systems, and
- database systems.
-
-
- Additionally, my coursework covered topics such as
- object-oriented programming,
- functional programming,
- compilers and interpreters,
- operating systems and
- networking.
-
-
Experience
-
-
- Software Engineer Intern — FPT Software
-
-
- Jan 2023 — Feb 2023
-
-
- -
- Designed and tested RESTful APIs for a business
- directory application using Node.js.
-
- -
- Implemented a database schema using MongoDB and
- integrated it with the application using Node.js.
-
- -
- Improved the application's search functionality by
- implementing a search feature using ElasticSearch.
-
- -
- Participated in daily stand-up meetings, code
- reviews, and sprint planning sessions.
-
- -
- Implemented unit tests and participated in
- integration testing to ensure code quality and
- reliability.
-
-
-
-
- Academic Tutor
- — The University of Queensland
-
-
- Jul 2023 — Present
-
-
- - Tutor Algorithms & Data Structure course.
- -
- Assisted students in understanding complex concepts
- and solving problems related to programming
- languages, algorithms, and data structures.
-
- -
- Conducted tutorial sessions, graded assignments, and
- provided feedback to students to help them improve
- their understanding and performance.
-
-
-
Skills
-
Programming Languages
-
-
-
data:image/s3,"s3://crabby-images/eb862/eb862690fee8311e051ee36c670244b189afd669" alt="Java"
- Java
-
-
-
data:image/s3,"s3://crabby-images/f8630/f8630195a8a1e36d4eac4ba72f8203d942136484" alt="Python"
- Python
-
-
-
data:image/s3,"s3://crabby-images/d7c6d/d7c6d1c8805291994698c9aa99a65cbd9f7dd3ef" alt="JavaScript"
- JavaScript
-
-
-
data:image/s3,"s3://crabby-images/bf6bc/bf6bc8f0a8b47d52da03b1bf609cdea69be96b1b" alt="Swift"
- Swift
-
-
-
data:image/s3,"s3://crabby-images/d15d6/d15d6875ba41ccf12ebb8bf943c0dde332dd113c" alt="C/C++"
- C/C++
-
-
-
data:image/s3,"s3://crabby-images/aadb4/aadb4ab09847753f719c108066e2fe8b7d10b549" alt="HTML"
- HTML
-
-
-
data:image/s3,"s3://crabby-images/1ffdb/1ffdb6dc175af653cda8906b482be6cbb671c906" alt="CSS"
- CSS
+
+ Education
+
+
+ The University of Queensland
+ — Bachelor of Computer Science
+
+ 2021 — Present
+
+ I am currently in my third year pursuing a
+ Bachelor of Computer Science, majoring
+ in Programming Languages, at The
+ University of Queensland.
+
+
+ I've gained a comprehensive understanding of
+ algorithms,
+ data structures,
+ software architecture,
+ operating systems, and
+ database systems.
+
+
+ Additionally, my coursework covered topics such as
+ object-oriented programming,
+ functional programming,
+ compilers and interpreters,
+ operating systems and
+ networking.
+
+
+
+ Experience
+
+
+ Software Engineer Intern
+ — FPT Software
+
-
-
data:image/s3,"s3://crabby-images/af7b3/af7b387b7148d70d57d6298565d68dba1298cd9c" alt="SQL"
- SQL
-
-
-
data:image/s3,"s3://crabby-images/a64f3/a64f3d02f76115907817638adb07c91389f9cb2e" alt="Bash"
- Bash
+
Jan 2023 — Feb 2023
-
-
data:image/s3,"s3://crabby-images/9637a/9637aa8e034a380c0e20777d58a8241ab5b3aebe" alt="Haskell"
- Haskell
-
-
- Frameworks and Tools
-
-
-
data:image/s3,"s3://crabby-images/c80c0/c80c0d58cb3278535c84b20159a03e829a1d81a8" alt="Flutter"
- Flutter
-
-
-
data:image/s3,"s3://crabby-images/308f9/308f97d565ad0c88ae45a3487354c1818986d1b8" alt="Firebase"
- Firebase
-
-
-
data:image/s3,"s3://crabby-images/a894c/a894c81f81b4c0f9bc86283ccede98dbf1e38427" alt="Node.js"
- Node.js
-
-
-
data:image/s3,"s3://crabby-images/16e4f/16e4f1876aba4b91b8ac011c57325fc96b47ebfe" alt="React"
- React
-
-
-
data:image/s3,"s3://crabby-images/0c3ed/0c3eda12fc1a6b56cd4d3cc73f95131be4aa4dd4" alt="jQuery"
- jQuery
-
-
-
data:image/s3,"s3://crabby-images/474e7/474e7317143dce3af7f9ec09fe9dbca2836630b1" alt="Angular"
- Angular
-
-
-
data:image/s3,"s3://crabby-images/1cdae/1cdaef3709eedbc424368a3cba22fac3163feb53" alt="MongoDB"
- MongoDB
-
-
-
data:image/s3,"s3://crabby-images/1c302/1c3022589b427c8a5ca3c38ef007b8a0a27766fe" alt="PostgreSQL"
- PostgreSQL
+
+ -
+ Designed and tested RESTful APIs for a business
+ directory application using Node.js.
+
+ -
+ Implemented a database schema using MongoDB and
+ integrated it with the application using
+ Node.js.
+
+ -
+ Improved the application's search functionality
+ by implementing a search feature using
+ ElasticSearch.
+
+ -
+ Participated in daily stand-up meetings, code
+ reviews, and sprint planning sessions.
+
+ -
+ Implemented unit tests and participated in
+ integration testing to ensure code quality and
+ reliability.
+
+
+
+
+ Academic Tutor
+ — The University of Queensland
+
+
+ Jul 2023 — Present
+
+ - Tutor Algorithms & Data Structure course.
+ -
+ Assisted students in understanding complex
+ concepts and solving problems related to
+ programming languages, algorithms, and data
+ structures.
+
+ -
+ Conducted tutorial sessions, graded assignments,
+ and provided feedback to students to help them
+ improve their understanding and performance.
+
+
+
+
+ Skills
+ Programming Languages
+
+
+
data:image/s3,"s3://crabby-images/eb862/eb862690fee8311e051ee36c670244b189afd669" alt="Java"
+ Java
+
+
+
data:image/s3,"s3://crabby-images/f8630/f8630195a8a1e36d4eac4ba72f8203d942136484" alt="Python"
+ Python
+
+
+
data:image/s3,"s3://crabby-images/d7c6d/d7c6d1c8805291994698c9aa99a65cbd9f7dd3ef" alt="JavaScript"
+ JavaScript
+
+
+
data:image/s3,"s3://crabby-images/bf6bc/bf6bc8f0a8b47d52da03b1bf609cdea69be96b1b" alt="Swift"
+ Swift
+
+
+
data:image/s3,"s3://crabby-images/d15d6/d15d6875ba41ccf12ebb8bf943c0dde332dd113c" alt="C/C++"
+ C/C++
+
+
+
data:image/s3,"s3://crabby-images/aadb4/aadb4ab09847753f719c108066e2fe8b7d10b549" alt="HTML"
+ HTML
+
+
+
data:image/s3,"s3://crabby-images/1ffdb/1ffdb6dc175af653cda8906b482be6cbb671c906" alt="CSS"
+ CSS
+
-
-
data:image/s3,"s3://crabby-images/83b94/83b949aa94c1f287ba90282fbd1cbce97494fa26" alt="Git"
- Git
+
+
data:image/s3,"s3://crabby-images/af7b3/af7b387b7148d70d57d6298565d68dba1298cd9c" alt="SQL"
+ SQL
+
+
+
data:image/s3,"s3://crabby-images/a64f3/a64f3d02f76115907817638adb07c91389f9cb2e" alt="Bash"
+ Bash
+
+
+
data:image/s3,"s3://crabby-images/9637a/9637aa8e034a380c0e20777d58a8241ab5b3aebe" alt="Haskell"
+ Haskell
+
-
-
data:image/s3,"s3://crabby-images/6e6cf/6e6cf1915cf86b4feba1c3a8108ce32b9965a915" alt="Docker"
- Docker
+
Frameworks and Tools
+
+
+
data:image/s3,"s3://crabby-images/c80c0/c80c0d58cb3278535c84b20159a03e829a1d81a8" alt="Flutter"
+ Flutter
+
+
+
data:image/s3,"s3://crabby-images/308f9/308f97d565ad0c88ae45a3487354c1818986d1b8" alt="Firebase"
+ Firebase
+
+
+
data:image/s3,"s3://crabby-images/a894c/a894c81f81b4c0f9bc86283ccede98dbf1e38427" alt="Node.js"
+ Node.js
+
+
+
data:image/s3,"s3://crabby-images/16e4f/16e4f1876aba4b91b8ac011c57325fc96b47ebfe" alt="React"
+ React
+
+
+
data:image/s3,"s3://crabby-images/0c3ed/0c3eda12fc1a6b56cd4d3cc73f95131be4aa4dd4" alt="jQuery"
+ jQuery
+
+
+
data:image/s3,"s3://crabby-images/474e7/474e7317143dce3af7f9ec09fe9dbca2836630b1" alt="Angular"
+ Angular
+
+
+
data:image/s3,"s3://crabby-images/1cdae/1cdaef3709eedbc424368a3cba22fac3163feb53" alt="MongoDB"
+ MongoDB
+
+
+
data:image/s3,"s3://crabby-images/1c302/1c3022589b427c8a5ca3c38ef007b8a0a27766fe" alt="PostgreSQL"
+ PostgreSQL
+
+
+
+
data:image/s3,"s3://crabby-images/83b94/83b949aa94c1f287ba90282fbd1cbce97494fa26" alt="Git"
+ Git
+
+
+
data:image/s3,"s3://crabby-images/6e6cf/6e6cf1915cf86b4feba1c3a8108ce32b9965a915" alt="Docker"
+ Docker
+
-
+
-
+