body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff8f0;color:var(--color-primary);font-family:var(--font-secondary),-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#74d8ff;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@font-face{font-family:Brushelva;font-style:normal;font-weight:400;src:url(/portfolio/static/media/Brushelva-Personal-Used-BF64db3ea3db737.40f75e84da1b41be00d0.ttf) format("truetype")}:root{--font-primary:"Playfair Display",serif;--font-secondary:"Poppins",sans-serif;--font-tertiary:"Poppins",sans-serif;--color-primary:#5d4037;--color-secondary:#8d6e63;--small-block-color:#bcaaa4;--card-color:#fff}*{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}.big-header{-webkit-text-stroke:.5px #5d4037;-webkit-text-stroke:.5px var(--color-primary);font-size:96px;letter-spacing:.1em}.big-header,.small-header{color:#5d4037;color:var(--color-primary);font-family:Playfair Display,serif;font-family:var(--font-primary);font-weight:500;text-align:center}.small-header{-webkit-text-stroke:.4px #5d4037;-webkit-text-stroke:.4px var(--color-primary);font-size:48px;padding-right:90px}.paragraph{color:#8d6e63;color:var(--color-secondary);font-family:Poppins,sans-serif;font-family:var(--font-secondary);line-height:1.6;text-align:center}.portfolio-container{margin:0 auto;max-width:1400px;overflow-x:hidden;padding:0 2rem}.hero{background:linear-gradient(135deg,#fff8f0,#f5e6d9);border-radius:0 0 2rem 2rem;display:flex;flex-direction:column;justify-content:center;margin-bottom:4rem;min-height:100vh;overflow:hidden;padding:0 0 6rem;position:relative}.hero:before{background:url('data:image/svg+xml;utf8,<svg width="100" height="100" viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg"><path d="M30,10 L70,10 L90,50 L70,90 L30,90 L10,50 Z" fill="none" stroke="%238D6E63" stroke-width="0.5" opacity="0.1"/></svg>');background-size:100px;content:"";height:100%;left:0;opacity:.3;position:absolute;right:0;top:0;z-index:0}.hero-content{align-items:center;display:flex;gap:4rem;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 2rem;position:relative;z-index:1}.hero-text{flex:1 1;max-width:600px}.hero-title{color:var(--color-primary);font-family:var(--font-primary);font-size:4.5rem;font-weight:700;line-height:1.1;margin-bottom:1.5rem}.hero-subtitle{color:var(--color-secondary);font-family:var(--font-secondary);font-size:1.5rem;font-weight:400;margin-bottom:2rem}.hero-description{color:var(--color-primary);font-size:1.2rem;line-height:1.8;margin-bottom:3rem;opacity:.9}.hero-cta{display:flex;gap:1.5rem;margin-top:2.5rem}.cta-button{align-items:center;border-radius:50px;cursor:pointer;display:inline-flex;font-family:var(--font-secondary);font-size:1.1rem;font-weight:500;justify-content:center;padding:1rem 2rem;text-decoration:none;transition:all .3s ease}.cta-button:first-child{background-color:var(--color-primary);border:2px solid var(--color-primary);color:#fff}.cta-button.secondary{background-color:initial;border:2px solid var(--color-primary);color:var(--color-primary)}.cta-button:hover{box-shadow:0 10px 20px #0000001a;transform:translateY(-2px)}.cta-button:active{transform:translateY(0)}.hero-visual{align-items:center;display:flex;flex:1 1;justify-content:flex-end;perspective:1000px;position:relative}.hero-image-container{height:400px;position:relative;transform-style:preserve-3d;transition:transform .5s ease;width:300px}.hero-image{border:5px solid #fff;border-radius:15px;box-shadow:0 15px 35px #0000001a;height:100%;object-fit:cover;position:relative;transform:translateZ(20px);transition:all .3s ease;width:100%;z-index:2}.hero-image:hover{box-shadow:0 20px 40px #00000026;transform:translateZ(30px) scale(1.02)}.hero-image-decoration{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-secondary) 100%);border-radius:20px;bottom:-15px;left:-15px;opacity:.8;position:absolute;right:-15px;top:-15px;transform:translateZ(-10px);transition:all .3s ease;z-index:1}.hero-image-container:hover .hero-image-decoration{opacity:.9;transform:translateZ(-20px) rotate(2deg)}.scroll-indicator{align-items:center;animation:bounce 2s infinite;bottom:2rem;color:var(--color-secondary);cursor:pointer;display:flex;flex-direction:column;font-family:var(--font-secondary);font-size:.9rem;left:50%;position:absolute;transform:translateX(-50%);z-index:10}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0) translateX(-50%)}40%{transform:translateY(-10px) translateX(-50%)}60%{transform:translateY(-5px) translateX(-50%)}}.arrow-down{border-bottom:2px solid var(--color-secondary);border-right:2px solid var(--color-secondary);height:24px;margin-top:.5rem;transform:rotate(45deg);width:24px}.main-content{margin:0 auto;max-width:1200px;padding:0 2rem}.section-header{margin-bottom:2rem;text-align:center}.section-title{color:var(--color-primary);display:inline-block;font-family:var(--font-primary);font-size:2.5rem;margin-bottom:1.5rem;position:relative}.section-divider{background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));border-radius:2px;height:4px;margin:0 auto;width:80px}.projects-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin:3rem 0}@media (max-width:992px){.hero-content{flex-direction:column;text-align:center}.hero-visual{height:280px;margin-top:3rem}}@media (max-width:768px){.hero{padding:4rem 1rem}.hero-title{font-size:2.8rem}.hero-subtitle{font-size:1.2rem}.projects-grid{grid-template-columns:1fr}.cta-button{font-size:1rem;padding:.8rem 1.5rem}}.project-card{background:#fff;border:1px solid #8d6e631a;border-radius:16px;box-shadow:0 4px 20px #5d403714;cursor:pointer;display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative;transition:all .4s cubic-bezier(.23,1,.32,1)}.project-card:before{background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));content:"";height:4px;left:0;position:absolute;top:0;transform:scaleX(0);transform-origin:left;transition:transform .4s ease;width:100%}.project-card:hover{box-shadow:0 12px 30px #5d403726;transform:translateY(-8px)}.project-card:hover:before{transform:scaleX(1)}.card-image{background:#f5f0ed;display:grid;height:200px;margin:0 auto;min-height:200px;overflow:hidden;padding:1.5rem;place-items:center;position:relative;width:100%}.project-card:hover .card-image{transform:scale(1.03)}.card-image img{display:block;filter:grayscale(20%);height:auto;margin:0 auto;max-height:70%;max-width:70%;object-fit:contain;transition:all .3s ease;width:auto}.project-card:hover .card-image img{filter:grayscale(0)}.card-content{box-sizing:border-box;display:flex;flex-direction:column;min-height:200px;padding:1.5rem}.card-title{-webkit-text-stroke:0;font-family:var(--font-primary);font-size:1.5rem;line-height:1.3;margin:0 0 1rem}.card-description{color:var(--color-secondary);flex-grow:1;font-size:.95rem;line-height:1.6;margin-bottom:1.5rem}.technologies{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:auto}.tech-tag{background:#8d6e631a;border-radius:50px;color:var(--color-secondary);font-size:.75rem;font-weight:500;padding:.3rem .8rem;transition:all .2s ease}.project-card:hover .tech-tag{background:#5d403726;color:var(--color-primary)}.card-cta{align-items:center;color:var(--color-primary);display:inline-flex;font-size:.95rem;font-weight:500;margin-top:1rem;text-decoration:none;transition:all .3s ease}.card-cta:hover{color:var(--color-secondary)}.card-cta svg{margin-left:.5rem;transition:transform .3s ease}.card-cta:hover svg{transform:translateX(4px)}@media (max-width:768px){.project-card{max-width:100%}.card-image{height:180px}.card-title{font-size:1.3rem}}.about-me-container{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(3,1fr);margin:0 auto;max-width:1200px;padding:2rem;position:relative;z-index:1}.about-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border:1px solid #fff3;border-radius:16px;box-shadow:0 8px 32px #0000001a;display:flex;flex-direction:column;height:auto;min-height:280px;overflow:hidden;padding:1.5rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.about-card:before{background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));content:"";height:4px;left:0;position:absolute;right:0;top:0;transition:all .3s ease}.about-card:hover{box-shadow:0 12px 40px #00000026;transform:translateY(-8px)}.about-card:hover:before{height:6px}.card-icon{display:inline-block;font-size:2rem;margin-bottom:1rem;transition:transform .3s ease}.about-card:hover .card-icon{transform:scale(1.1) rotate(5deg)}.card-title{color:var(--color-primary);display:inline-block;font-size:1.25rem;font-weight:600;margin-bottom:.75rem;position:relative}.card-title:after{background:var(--color-secondary);bottom:-5px;content:"";height:3px;left:0;position:absolute;transition:width .3s ease;width:40px}.about-card:hover .card-title:after{width:80px}.card-content{-webkit-line-clamp:4;-webkit-box-orient:vertical;color:var(--color-text);display:-webkit-box;flex-grow:1;font-size:.9rem;line-height:1.5;margin-bottom:1.25rem;overflow:hidden;text-overflow:ellipsis}.card-links{display:flex;flex-wrap:wrap;gap:1rem;margin-top:auto}.card-link{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border-radius:50px;box-shadow:0 2px 8px #0000001a;color:#fff;display:inline-block;font-size:.85rem;font-weight:500;padding:.5rem 1rem;text-decoration:none;transition:all .3s ease;white-space:nowrap}.card-link:hover{background:linear-gradient(135deg,var(--color-secondary),var(--color-primary));box-shadow:0 6px 20px #00000026;transform:translateY(-2px)}@media (max-width:1024px){.about-me-container{gap:1.5rem;grid-template-columns:1fr;max-width:600px}}@media (max-width:768px){.about-me-container{padding:1rem}.about-card{padding:1.5rem}.card-links{justify-content:center}}.up-button{align-items:center;background-color:var(--small-block-color);border-radius:50%;bottom:20px;display:flex;height:40px;justify-content:center;position:fixed;right:20px;width:40px}.up-button:hover{box-shadow:3px 3px 5px #0003;cursor:pointer;visibility:visible}.up-button:active{transform:scale(.9)}.back-button{align-items:center;background-color:var(--small-block-color);border-radius:50%;display:flex;height:40px;justify-content:center;left:20px;position:fixed;top:20px;width:40px}.back-button:hover{box-shadow:3px 3px 5px #0003;cursor:pointer;visibility:visible}.back-button:active{transform:scale(.9)}.project-information{background:#f9f7f5;border-radius:12px;margin:2rem auto;max-width:1200px;padding:2rem}.project-header{margin-bottom:3rem;padding-bottom:1.5rem;position:relative;text-align:center}.project-header h1{color:var(--color-primary);font-family:var(--font-primary);font-size:2.5rem;font-weight:700;margin-bottom:1rem}.project-header:after{background:linear-gradient(90deg,#8d6e63,#d7ccc8);border-radius:2px;bottom:0;content:"";height:4px;left:50%;position:absolute;transform:translateX(-50%);width:100px}.project-content{gap:2.5rem;margin-bottom:3rem}.project-content,.section{display:flex;flex-direction:column}.section{background:#fff;border:1px solid #eee;border-radius:12px;box-shadow:0 2px 10px #5d40370d;gap:2rem;padding:2rem}.section-text{background:#fff8f1;border-left:4px solid #d7ccc8;border-radius:8px;color:#5d4037;flex:1 1;font-size:1.1rem;line-height:1.7;padding:1.5rem;text-align:left}.project-image{background:#fff;border:1px solid #e0e0e0;border-radius:8px;height:auto;padding:.5rem;width:100%}.repo-button-container{display:flex;justify-content:center;margin:1.5rem 0}.repoButton{align-items:center;background:#8d6e63;border:none;border-radius:6px;box-shadow:0 2px 5px #0000001a;color:#fff!important;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:500;gap:.75rem;padding:.9rem 1.8rem;text-decoration:none}@media (min-width:768px){.section{align-items:center;flex-direction:row}.section:nth-child(2n){flex-direction:row-reverse}.project-image{width:50%}.section-text{padding:1.5rem}}.footer{background-color:var(--color-primary);color:#fff;font-family:var(--font-secondary);overflow:hidden;padding:4rem 0 0;position:relative}.footer:before{background:linear-gradient(90deg,var(--color-secondary),var(--small-block-color));content:"";height:4px;left:0;position:absolute;right:0;top:0}.footer-container{margin:0 auto;max-width:1200px;padding:0 2rem}.footer-content{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:3rem}.footer-brand{margin-bottom:2rem}.logo{align-items:center;color:#fff;display:flex;font-family:var(--font-primary);font-size:1.5rem;font-weight:600;gap:.75rem;margin-bottom:1.5rem}.logo-icon{color:gold;font-size:1.8rem}.tagline{color:#fffc;line-height:1.6;margin-bottom:1.5rem}.copyright{color:#fff9;font-size:.9rem}.footer-contact h3,.footer-links h3{color:#fff;font-family:var(--font-primary);font-size:1.25rem;margin-bottom:1.5rem;padding-bottom:.75rem;position:relative}.footer-contact h3:after,.footer-links h3:after{background:var(--small-block-color);bottom:0;content:"";height:2px;left:0;position:absolute;width:50px}.footer-links ul{list-style:none;margin:0;padding:0}.footer-links li{margin-bottom:.75rem}.footer-links a{color:#fffc;display:inline-block;text-decoration:none;transition:color .3s ease,padding-left .3s ease}.footer-links a:hover{color:#fff;padding-left:5px}.social-links{display:flex;gap:1rem;margin-bottom:1.5rem}.social-links a{align-items:center;background:#ffffff1a;border-radius:50%;color:#fff;display:flex;font-size:1.25rem;height:40px;justify-content:center;transition:all .3s ease;width:40px}.social-links a:hover{background:var(--color-secondary);box-shadow:0 5px 15px #0003;transform:translateY(-3px)}.weather{align-items:center;color:#fffc;display:flex;font-size:.95rem;gap:.5rem;margin-top:1.5rem}.sun-icon{color:gold}.footer-bottom{border-top:1px solid #ffffff1a;color:#ffffff80;font-size:.9rem;padding:1.5rem 0;text-align:center}.footer-bottom p{margin:0}@media (max-width:768px){.footer-content{gap:2rem;grid-template-columns:1fr;text-align:center}.footer-contact h3:after,.footer-links h3:after{left:50%;transform:translateX(-50%)}.footer-links ul{display:flex;flex-wrap:wrap;gap:1rem}.footer-links ul,.logo,.social-links{justify-content:center}}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-5px)}to{transform:translateY(0)}}.logo-icon{animation:float 3s ease-in-out infinite}
/*# sourceMappingURL=main.d646caa2.css.map*/