body{font-family:Poppins,sans-serif}.home-container{display:flex;flex-direction:column;align-items:center;width:100%;padding:20px;margin:50px auto;animation:fadeIn .6s ease forwards}.intro-box{display:flex;flex-direction:row;align-items:center;width:100%;max-width:900px;padding:30px;margin-bottom:40px;border-radius:var(--radius-lg);animation:fadeInUp .7s ease forwards}.intro-box h1{font-size:clamp(2.5rem,8vw,6rem);font-weight:800;margin:0;padding-left:30px;background:linear-gradient(135deg,var(--colour-dark) 0%,#444 50%,var(--colour-accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-2px}.profile-section{margin-bottom:20px;transition:all var(--transition-normal);position:relative}.profile-pic{width:160px;height:150px;border-radius:50%;object-fit:cover;border:4px solid transparent;background:linear-gradient(var(--colour-light),var(--colour-light)) padding-box,linear-gradient(135deg,var(--colour-accent),var(--colour-accent-warm));box-shadow:var(--shadow-lg);transition:all var(--transition-slow)}.profile-section:hover img{transform:scale(1.1);box-shadow:var(--shadow-hover),0 0 30px #e76f5166}.text-boxes{display:flex;flex-direction:column;gap:24px;width:85%;max-width:800px}.text-box{background:linear-gradient(135deg,var(--colour-dark) 0%,#252525 100%);color:var(--colour-light);padding:32px 36px;border-radius:var(--radius-md);box-shadow:var(--shadow-md);transition:all var(--transition-normal);border:1px solid rgba(255,255,255,.05);position:relative;overflow:hidden}.text-box:before{content:"";position:absolute;left:0;top:0;height:100%;width:4px;background:linear-gradient(180deg,var(--colour-accent),var(--colour-accent-warm));opacity:0;transition:opacity var(--transition-normal)}.text-box:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.text-box:hover:before{opacity:1}.text-box:nth-child(1){animation:fadeInUp .6s ease .1s forwards;opacity:0}.text-box:nth-child(2){animation:fadeInUp .6s ease .2s forwards;opacity:0}.text-box:nth-child(3){animation:fadeInUp .6s ease .3s forwards;opacity:0}.text-box h2{margin:0 0 16px;font-size:1.6rem;font-weight:600;color:var(--colour-light);position:relative;display:inline-block}.text-box h2:after{content:"";position:absolute;bottom:-4px;left:0;width:40px;height:3px;background:linear-gradient(90deg,var(--colour-accent),var(--colour-accent-warm));border-radius:2px}.text-box p{font-size:1.05rem;color:#f5f5f5e6;line-height:1.7;margin:0}@media (max-width: 768px){.intro-box{flex-direction:column;text-align:center;padding:20px}.intro-box h1{padding-left:0;padding-top:20px;font-size:clamp(2rem,10vw,4rem)}.text-boxes{width:95%}.text-box{padding:24px}.profile-pic{width:140px;height:140px}}.projects-page{display:flex;flex-direction:column;align-items:center;width:100%;padding:20px;margin:50px auto}.tags-container{position:sticky;top:100px;padding:16px 20px;z-index:90;display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:24px;width:100%;max-width:1200px;font-family:Poppins,sans-serif;background-color:var(--colour-light);animation:fadeIn .5s ease forwards}.selected-tag,.unselected-tag{height:auto;display:flex;align-items:center;padding:10px 18px;border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-normal);font-family:Poppins,sans-serif;font-size:.9rem;font-weight:500}.selected-tag{background:linear-gradient(135deg,var(--colour-dark) 0%,#333 100%);color:#fff;border:2px solid transparent;box-shadow:var(--shadow-md)}.selected-tag:hover{background:linear-gradient(135deg,#333,#444);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.unselected-tag{background-color:var(--colour-white);color:var(--colour-dark);border:2px solid var(--colour-border)}.unselected-tag:hover{background-color:var(--colour-light);border-color:var(--colour-accent);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.projects-container{width:100%;max-width:1200px;display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));padding:20px;gap:28px;animation:fadeInUp .6s ease forwards;justify-content:center}.project-card{background-color:var(--colour-white);border:1px solid var(--colour-border);border-radius:var(--radius-md);padding:0;box-shadow:var(--shadow-sm);text-align:left;display:flex;flex-direction:column;font-family:Poppins,sans-serif;transition:all var(--transition-normal);overflow:hidden;cursor:pointer}.project-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-hover);border-color:var(--colour-accent)}.project-image{width:100%;height:180px;object-fit:cover;transition:transform var(--transition-slow)}.project-card:hover .project-image{transform:scale(1.05)}.project-card-content{padding:20px;display:flex;flex-direction:column;flex-grow:1}.project-title{font-size:1.3rem;font-weight:600;margin:0 0 10px;color:var(--colour-dark);transition:color var(--transition-fast)}.project-card:hover .project-title{color:var(--colour-accent)}.project-description{font-size:.95rem;color:var(--colour-text-muted);margin-bottom:16px;line-height:1.5;flex-grow:1}.project-link{text-decoration:none;color:var(--colour-accent);font-weight:600;font-size:.9rem;display:inline-flex;align-items:center;gap:6px;transition:all var(--transition-fast)}.project-link:hover{color:var(--colour-accent-hover);gap:10px}.project-link:after{content:"→";transition:transform var(--transition-fast)}.project-link:hover:after{transform:translate(4px)}.projects-message{grid-column:1 / -1;font-family:Poppins,sans-serif;text-align:center;padding:60px 40px;color:var(--colour-text-muted);font-size:1.1rem}.projects-message.loading{animation:pulse 1.5s ease-in-out infinite}.projects-message.no-results{animation:fadeIn .3s ease forwards}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background-color:var(--colour-white);padding:0;width:90%;max-width:900px;max-height:85vh;overflow-y:auto;display:flex;flex-direction:column;box-shadow:var(--shadow-hover);z-index:1000;font-family:Poppins,sans-serif;border-radius:var(--radius-lg);animation:modalScaleIn .3s ease forwards}@keyframes modalScaleIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.modal::-webkit-scrollbar{width:6px}.modal::-webkit-scrollbar-thumb{background:var(--colour-accent);border-radius:3px}.modal::-webkit-scrollbar-track{background:transparent}.close-button{position:absolute;top:16px;right:20px;background:var(--colour-light);border:none;font-size:24px;cursor:pointer;color:var(--colour-dark);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);z-index:10}.close-button:hover{background-color:var(--colour-accent);color:#fff;transform:rotate(90deg)}.overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999;animation:fadeIn .2s ease forwards}.modal-header{display:flex;justify-content:space-between;padding:24px 28px;border-bottom:1px solid var(--colour-border)}.modal-body{display:flex;flex-direction:column;padding:28px;gap:24px}@media (min-width: 768px){.modal-body{flex-direction:row}}.modal-content-left{flex:1}.modal-content-right{width:100%;display:flex;flex-direction:column;align-items:center}@media (min-width: 768px){.modal-content-right{width:40%}}.modal-image{width:100%;height:auto;border-radius:var(--radius-md);margin-bottom:16px;box-shadow:var(--shadow-md)}.modal-markdown{margin-top:20px;overflow:visible;padding:20px;border-top:1px solid var(--colour-border);line-height:1.7}.modal-markdown h1,.modal-markdown h2,.modal-markdown h3{color:var(--colour-dark);margin-top:24px;margin-bottom:12px}.modal-markdown p{color:var(--colour-text-muted);margin-bottom:16px}.modal-markdown code{background-color:var(--colour-light);padding:2px 6px;border-radius:4px;font-size:.9em}.modal-markdown pre{background-color:var(--colour-dark);color:var(--colour-light);padding:16px;border-radius:var(--radius-sm);overflow-x:auto}button{margin-top:16px;padding:12px 24px;background:linear-gradient(135deg,var(--colour-accent) 0%,var(--colour-accent-warm) 100%);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-family:Poppins,sans-serif;font-weight:600;font-size:.95rem;transition:all var(--transition-normal);box-shadow:var(--shadow-sm)}button:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);filter:brightness(1.05)}button:active{transform:translateY(0)}@media (max-width: 768px){.projects-page{padding:10px}.projects-container{grid-template-columns:1fr;padding:16px;gap:20px}.tags-container{top:80px;padding:12px 16px}.modal{width:95%;max-height:90vh}}.contact-container{display:flex;justify-content:center;align-items:center;padding:4rem 1rem;min-height:80vh;box-sizing:border-box;margin-top:0;animation:fadeIn .5s ease forwards}.contact-box{background:linear-gradient(135deg,var(--colour-accent) 0%,var(--colour-accent-hover) 100%);color:var(--colour-light);border-radius:var(--radius-lg);padding:2.5rem;width:100%;max-width:520px;box-shadow:var(--shadow-lg);font-family:Poppins,sans-serif;animation:scaleIn .5s ease forwards;position:relative;overflow:hidden}.contact-box:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);pointer-events:none}.contact-header{text-align:center;font-size:2rem;font-weight:700;margin-bottom:2rem;position:relative}.contact-header:after{content:"";display:block;width:50px;height:3px;background-color:#ffffff80;margin:12px auto 0;border-radius:2px}.contact-list{list-style:none;padding:0 1rem 1.5rem;margin:0;display:flex;flex-direction:column;gap:1.4rem;width:100%}.contact-list li{display:flex;align-items:center;width:100%;gap:1rem;font-size:1.2rem;padding:12px 16px;background-color:#ffffff1a;border-radius:var(--radius-sm);transition:all var(--transition-normal)}.contact-list li:hover{background-color:#fff3;transform:translate(8px)}.contact-list li a,.email-button{text-decoration:none;color:var(--colour-light);background:none;cursor:pointer;font-size:1.1rem;font-family:Poppins,sans-serif;transition:all var(--transition-fast);font-weight:500}.contact-list li a:hover,.email-button:hover{color:#fff9}.contact-icon{width:28px;height:28px;object-fit:contain;filter:brightness(0) invert(1);opacity:.9;transition:transform var(--transition-fast);flex-shrink:0}.contact-list li:hover .contact-icon{transform:scale(1.18)}.popup{margin-top:.5rem;background-color:#ffffff40;color:#fff;border-radius:var(--radius-xl);font-size:.85rem;padding:.4rem 1rem;display:inline-block;animation:fadeIn .3s ease forwards;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@media (max-width: 480px){.contact-box{padding:2rem 1.5rem;margin:0 1rem}.contact-header{font-size:1.6rem}.contact-list li{font-size:1rem;padding:10px 12px;gap:.8rem}.contact-list li a,.email-button{font-size:1rem}.popup{font-size:.8rem}.contact-icon{width:24px;height:24px}}.blogs-container{max-width:800px;margin:0 auto;padding:20px;justify-content:space-around;flex-wrap:wrap}.blog-card{display:flex;flex-direction:row;align-items:flex-start;background-color:#fff;border:1px solid #e1e4e8;border-radius:8px;margin-bottom:20px;padding:15px;box-shadow:0 4px 6px #0000001a;transition:box-shadow .2s ease;font-family:Poppins,sans-serif}.blog-card:hover{box-shadow:0 6px 10px #00000026}.blog-img{width:100px;height:100px;object-fit:scale-down;margin-right:20px;border-radius:8px}.blog-content{flex-grow:1}.temp-blog-loading{font-family:Poppins,sans-serif;margin-left:40%}.blog-title{font-size:1.5rem;margin:0 0 10px;color:#0366d6}.blog-title:hover{text-decoration:underline;cursor:pointer}.blog-teaser{font-size:1rem;color:#586069}.loading-blogs{text-align:center;font-size:1.2rem;color:#586069}.blog-details-container{max-width:800px;margin:0 auto;padding:20px;position:relative;font-family:Poppins,"sans-serif"}.back-button{position:absolute;top:10px;right:10px;padding:8px 16px;background-color:#0366d6;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.back-button:hover{background-color:#024ea2}.blog-content-wrapper{margin-top:60px}.blog-header{display:flex;align-items:center;margin-bottom:20px}.blog-details-img{width:200px;height:200px;object-fit:scale-down;margin-right:20px;border-radius:10px}.blog-detail-title{font-size:2rem;margin:0;color:#333;flex-grow:1}.blog-markdown-content{font-size:1.2rem;line-height:1.6;margin-top:20px}.navbar{background:linear-gradient(135deg,var(--colour-dark) 0%,var(--colour-dark-hover) 100%);padding:12px 0;position:fixed;top:0;width:90%;z-index:100;margin-left:5%;margin-right:5%;margin-top:1%;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);font-family:Poppins,sans-serif;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.05);animation:slideDown .5s ease forwards}.navbar-container{display:flex;justify-content:space-between;align-items:center;padding:0 2%}.logo{color:var(--colour-light);text-decoration:none;font-size:1.8rem;cursor:pointer;padding-left:3%;font-weight:700;letter-spacing:-.5px;transition:var(--transition-normal);background:linear-gradient(135deg,var(--colour-light) 0%,var(--colour-accent-warm) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo:hover{transform:scale(1.02);filter:brightness(1.1)}.nav-links{list-style:none;display:flex;gap:.5rem;margin:0;padding-right:3%;z-index:111}.nav-links li{margin:0}.nav-links a{color:var(--colour-light);text-decoration:none;font-size:1rem;font-weight:500;transition:all var(--transition-normal);padding:.7rem 1.2rem;border-radius:var(--radius-sm);position:relative;overflow:hidden}.nav-links a:after{content:"";position:absolute;bottom:6px;left:50%;width:0;height:2px;background:linear-gradient(90deg,var(--colour-accent),var(--colour-accent-warm));transition:all var(--transition-normal);transform:translate(-50%);border-radius:2px}.nav-links a:hover:after{width:60%}.nav-links a:hover{color:var(--colour-accent-warm);background-color:#ffffff0d}.nav-links a:active{color:var(--colour-accent);transform:scale(.98)}.hamburger{display:none;flex-direction:column;cursor:pointer;padding:.5rem;transition:var(--transition-normal);border-radius:var(--radius-sm)}.hamburger:hover{background-color:#ffffff1a}.bar{background:linear-gradient(90deg,var(--colour-light),var(--colour-accent-warm));height:3px;width:28px;margin:4px;transition:all .4s cubic-bezier(.68,-.6,.32,1.6);border-radius:5px}.hamburger.open .bar:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.hamburger.open .bar:nth-child(2){opacity:0;transform:translate(-10px)}.hamburger.open .bar:nth-child(3){transform:rotate(45deg) translate(6px,6px)}@media (max-width: 768px){.navbar{width:94%;margin-left:3%;margin-right:3%}.hamburger{display:flex}.nav-links{position:absolute;top:65px;right:3%;background:linear-gradient(135deg,var(--colour-dark) 0%,var(--colour-dark-hover) 100%);flex-direction:column;width:200px;padding:1rem;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);display:none;border:1px solid rgba(255,255,255,.05);gap:.25rem}.nav-links.open{display:flex;animation:fadeInDown .3s ease forwards}.nav-links a{padding:.8rem 1rem;width:100%;text-align:center}.nav-links a:after{display:none}.nav-links a:hover{background-color:#ffffff1a}}:root{--colour-dark: #1E1E1E;--colour-dark-hover: #2a2a2a;--colour-light: #F5F5F5;--colour-white: #FFFFFF;--colour-accent: #E76F51;--colour-accent-hover: #d45A3D;--colour-accent-warm: #F4A261;--colour-accent-muted: #586069;--colour-text-muted: #586069;--colour-border: #E1E4E8;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .12);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .16);--shadow-hover: 0 12px 32px rgba(0, 0, 0, .18);--transition-fast: .2s ease;--transition-normal: .3s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px}*{box-sizing:border-box}html{scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--colour-accent) transparent;overflow-y:scroll}body{background-color:var(--colour-light);margin:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.contents{padding-top:250px;margin-left:5%;margin-right:5%}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,var(--colour-accent-hover),var(--colour-accent))}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in-up{animation:fadeInUp .6s var(--transition-slow) forwards}.animate-fade-in{animation:fadeIn .5s ease forwards}.animate-scale-in{animation:scaleIn .4s var(--transition-slow) forwards}
