@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap";*{box-sizing:border-box}:root{font-family:Inter,sans-serif;line-height:1.5;font-weight:400;font-optical-sizing:auto;font-style:normal;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:light dark;color:#ffffffde;background:#0047ab;background:-webkit-gradient(linear,left top,left bottom,from(#1ca9c9),to(#0047ab)) no-repeat;background:linear-gradient(180deg,#1ca9c9,#0047ab) no-repeat;background-size:cover}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;min-width:320px;min-height:100vh;color:#fff}h1,.heading-1{font-family:DM Sans,sans-serif;font-size:3.2rem;line-height:3.6rem;font-weight:900}h2,.heading-2{font-family:DM Sans,sans-serif;font-size:2.6rem;line-height:3rem;font-weight:900}h3,.heading-3{font-family:DM Sans,sans-serif;font-size:2.2rem;line-height:2.6rem;font-weight:900}h4,.heading-4{font-family:DM Sans,sans-serif;font-size:1.8rem;line-height:2.2rem;font-weight:900}h5,.heading-5{font-family:DM Sans,sans-serif;font-size:1.4rem;line-height:1.8rem;font-weight:900}h6,.heading-6{font-family:DM Sans,sans-serif;font-size:1.2rem;line-height:1.6rem;font-weight:900}p{font-size:1rem;line-height:1.4rem;font-weight:400;margin:0 0 1.125rem}ul.no-styling{list-style:none;margin:0;padding:0}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#cdc871}button{background-color:#f9f9f9}}.font-300{font-weight:300}.font-400{font-weight:400}.font-500{font-weight:500}.font-600{font-weight:600}.font-700{font-weight:700}.font-800{font-weight:800}.font-900{font-weight:900}.fade-mask{width:100%;height:400px;object-fit:cover;object-position:top;mask-image:linear-gradient(to bottom,black 60%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,black 60%,transparent 100%)}.title-separate{width:100%;max-width:80px;margin:0 0 20px;border-bottom:1px solid #fff}header img.logo-main{width:75px}header{display:flex;justify-content:center;align-items:center}header .logo-heading{font-family:DM Sans,sans-serif;font-size:30px;font-weight:600;padding:0 8px}footer a{color:#fff;text-decoration:none}footer a:hover{color:#fff;text-decoration:underline}footer .links{font-size:40px;padding:60px 0 30px}footer span{padding:0 10px}.narrow-row{max-width:768px;margin:20px auto 0}.intro-section{padding:60px 0 80px}.intro-section .narrow-row{margin-top:40px}section .hero-section img{max-width:400px}.fader-stage{position:relative;height:100%;overflow:hidden;font-size:2em;display:flex;justify-content:center;align-items:center;height:258px}.fader-slide{width:100%;max-width:300px;position:absolute;top:14%;left:0;right:0;margin:0 auto;opacity:0;animation:fade-in-out 15s infinite}.fader-slide i{font-size:4em}@keyframes fade-in-out{0%,to{opacity:0}10%{opacity:1}40%{opacity:0}}.fader-slide--1{animation-delay:0s}.fader-slide--2{animation-delay:3s}.fader-slide--3{animation-delay:6s}.fader-slide--4{animation-delay:9s}.fader-slide--5{animation-delay:12s}.projects-section{margin:auto;padding:80px 0}.projects-section h2{text-align:center;margin-bottom:40px}.project-tabs{display:flex;justify-content:center;gap:12px;margin-bottom:50px}.project-tabs button{padding:10px 20px;border:2px solid #eee;background:#eee;cursor:pointer;border-radius:20px;transition:all .2s ease}.project-tabs button:hover{border:2px solid #111;background:#eee}.project-tabs button:focus{outline:none}.project-tabs button.active{border:2px solid #111;background:#111;color:#fff;cursor:initial}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:40px;align-items:start}.project-card{display:flex;flex-direction:column}.card-image-wrapper{position:relative;overflow:hidden;cursor:pointer;border-radius:8px}.card-image-wrapper:before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(400px circle at var(--mouse-x) var(--mouse-y),rgba(255,255,255,.18),transparent 40%);opacity:0;transition:opacity .3s ease;z-index:10}.card-image-wrapper:hover:before{opacity:1}.card-image-wrapper img{width:100%;height:400px;object-fit:cover;object-position:top;transition:transform .45s ease,filter .45s ease;mask-image:linear-gradient(to bottom,black 75%,transparent);-webkit-mask-image:linear-gradient(to bottom,black 75%,transparent)}.card-image-wrapper:hover img{transform:scale(1.05);filter:brightness(1.05)}.image-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#00000047;opacity:0;transition:opacity .3s ease;color:#fff;font-weight:700;letter-spacing:.05em}.image-overlay span{display:inline-block;background-color:#0047ab;padding:.625rem;border-radius:.5rem}.card-image-wrapper:hover .image-overlay{opacity:1}.card-title{height:100%;padding:1rem 1rem 0px;margin:0}.card-content{width:100%;max-width:400px;margin:0 auto;padding:1rem 1rem 0px}.card-content p{font-size:20px}.card-content .skills-tags{font-size:14px;font-weight:500}.card-button{font-size:20px;font-weight:700;letter-spacing:.3px;color:#fff;cursor:pointer;justify-self:center;padding:.5rem 1.25rem;margin:0}.card-button:hover{color:#b8b4b4}.modal-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:flex-start;justify-content:center;overflow-y:auto;padding:60px 20px;z-index:1000}.modal-content{position:relative;max-width:90%;max-height:90vh}.modal-content img{max-width:100%;max-height:auto;border-radius:8px}.modal-close{position:absolute;top:-60px;right:-40px;padding:0;font-size:60px;color:#fff;background:none;border:none;cursor:pointer}.modal-close:focus{outline:none}@media(max-width:768px){.projects-grid{grid-template-columns:1fr}}.skills{padding:80px 0;background:transparent;color:#fff;font-family:sans-serif}.skills-container{max-width:1100px;margin:0 auto}.skills-header{text-align:center;max-width:700px;margin:0 auto 60px}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.skill-card{border:1px solid #1ca9c9;border-radius:14px;padding:28px;transition:transform .25s ease,box-shadow .25s ease;background:#0006}.skill-card:hover{transform:translateY(-4px);box-shadow:0 10px 24px #00000014}.skill-card h3{margin-bottom:12px}.skill-description{font-size:.9rem;color:#fff;margin-bottom:18px;line-height:1.5}.skill-tags{display:flex;flex-wrap:wrap;gap:8px}.skill-tag.core{background:#61dafb;color:#111;font-weight:600}.skill-tag.wordpress{background:#21759b;color:#fff;font-weight:600}.skill-tag{background:#f3f3f3;color:#333;padding:6px 12px;border-radius:20px;font-size:.85rem}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}
