body{animation:animatedBackground 20s ease infinite;background:linear-gradient(-45deg,#ee7752,#e73c7e,#23a6d5,#23d5ab);background-size:400% 400%;min-height:100vh;--card-tag-background: #e0e0e0;--card-tag-text: #333333;--card-category-background: #d0d0d0;--card-category-text: #333333;--card-border-radius: 8px;--link-color: #F25922;--link-secondary: #ff914d;--text-primary: #213547;--text-secondary: #333;--button-background: #F25922;--button-background-hover: #ff914d}.dark{--card-tag-background: #3a3a3a;--card-tag-text: #f0f0f0;--card-category-background: #4a4a4a;--card-category-text: #f0f0f0;--text-primary: rgba(255, 255, 255, .9);--text-secondary: #ccc;--card-background: #1e1e1e;--link-color: #F25922;--link-secondary: #ffa773}@keyframes animatedBackground{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.app{width:100%;max-width:900px;margin:0 auto;padding:20px;box-sizing:border-box}.intro{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;max-width:90vw;animation:fadeOut 3s ease-in-out}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;width:100%;margin-bottom:40px;padding:0 20px;box-sizing:border-box}.header-text{display:flex;flex-direction:column;margin-right:auto}.profile-section{display:flex;align-items:center;margin-top:10px;animation:glowFade 1.5s ease-in-out}.profile-photo{border-radius:50%;width:70px;height:70px;margin-right:15px;object-fit:cover;border:3px solid var(--link-color, #F25922);transition:transform .3s ease-in-out,border-color .3s ease-in-out}.profile-photo:hover{transform:scale(1.1);border-color:var(--button-background-hover, #ff914d)}.profile-description{font-size:1.05em;line-height:1.6;margin:0;color:var(--text-secondary, #333)}.profile-description svg{margin-left:2px;margin-right:4px;vertical-align:middle;font-size:1.05em}@keyframes glowFade{0%{opacity:0;filter:brightness(.5)}50%{opacity:1;filter:brightness(1.2)}to{opacity:1;filter:brightness(1)}}.theme-toggle{background:transparent;border:none;cursor:pointer;font-size:28px;color:var(--text-primary, #213547);transition:color .3s;margin-left:auto}.theme-toggle:hover{color:var(--button-background, #F25922)}.header h1{font-size:3em;font-weight:700;color:var(--text-primary, #213547);margin:0;animation:fadeIn 2s ease-out;text-shadow:1px 1px 3px rgba(0,0,0,.15)}.projects{width:100%}.project-list{display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:20px}.project-card:nth-child(1){animation-delay:.1s}.project-card:nth-child(2){animation-delay:.2s}.project-card:nth-child(3){animation-delay:.3s}.project-card:nth-child(4){animation-delay:.4s}.project-card:nth-child(5){animation-delay:.5s}.project-card:nth-child(6){animation-delay:.6s}.project-card{cursor:pointer;background:var(--card-background, #f2f2f2);padding:20px;border-radius:var(--card-border-radius, 8px);box-shadow:0 2px 5px #0000001a;transition:box-shadow .3s ease-in-out,transform .3s ease-in-out;animation:cardEntrance .5s ease-out forwards;opacity:0}.project-card:hover{box-shadow:0 8px 25px #0000004d;transform:scale(1.05) translateY(-5px)}@keyframes cardEntrance{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.project-cover-container{width:100%;display:flex;justify-content:center;align-items:center;overflow:hidden}.project-card-content h3{font-size:24px;font-weight:600;margin-bottom:10px;color:var(--text-primary, #213547);transition:color .3s}.project-card:hover h3{color:var(--link-color, #F25922)}.project-card-content p{font-size:16px;line-height:1.5;margin-bottom:15px;color:var(--text-primary, #213547)}.project-card-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.project-card-links a{text-decoration:none;font-weight:500;transition:color .3s}.project-card-links a:first-child{color:var(--link-color, #F25922)}.project-card-links a:not(:first-child){color:var(--link-secondary, #ff914d)}.project-card-links a:hover{color:var(--text-primary, #213547)}.project-tech-tags span{font-weight:500}.project-tech-tags svg{font-size:1em}.project-card-links a svg{margin-right:5px;vertical-align:text-bottom;font-size:.95em}@media (max-width: 768px){.header{flex-direction:column;align-items:flex-start}.profile-section{flex-wrap:wrap}.profile-photo{margin-right:0;margin-bottom:10px}.profile-description{text-align:center;width:100%;margin-bottom:12px}}@media (max-width: 480px){.header h1{font-size:2em}.profile-photo{width:60px;height:60px}.profile-description{font-size:14px}.project-list{grid-template-columns:1fr}}.image-popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000}.image-popup-content{position:relative;background-color:#fff;padding:20px;border-radius:5px;max-width:90vw;max-height:90vh;display:flex;align-items:center;justify-content:center}.image-popup-image{max-width:100%;max-height:calc(90vh - 80px);object-fit:contain}.image-popup-close{position:absolute;top:10px;right:15px;background:none;border:none;font-size:2rem;color:#333;cursor:pointer}:root{--background: #ffffff;--text-primary: rgba(0, 0, 0, .87);--card-background: #f2f2f2;--button-background: #F25922;--button-text: #ffffff;--link-color: #F25922;--header-height: 60px;--padding: 20px;--transition-speed: .3s;--font-size-large: 2em;--font-size-medium: 1.2em;--font-size-small: 1em}.dark{--background: #32333d;--text-primary: rgba(255, 255, 255, .9);--card-background: #1e1e1e;--link-color: #F25922}body{background:var(--background);color:var(--text-primary);font-family:Helvetica Neue,Arial,sans-serif;margin:0;padding:0;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;transition:background var(--transition-speed),color var(--transition-speed)}.project-detail-page{width:100%;padding:var(--padding);box-sizing:border-box;margin:0 auto;display:flex;flex-direction:column;gap:20px;overflow-x:hidden}.hoverable-screenshot{transition:transform .2s ease-in-out,box-shadow .2s ease-in-out;cursor:pointer}.hoverable-screenshot:hover{transform:scale(1.1);box-shadow:0 4px 15px #0003}.screenshots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:15px;padding:5px}.screenshot{width:100%;height:auto;border-radius:4px}.description-text-container{white-space:pre-wrap;line-height:1.6;margin-bottom:1em}.typewriter-wrapper{display:inline;font-family:inherit;font-size:inherit;color:inherit}.typewriter-cursor{display:inline-block;font-weight:700;animation:blink .7s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes slideInFromBottomSubtle{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInSubtle{0%{opacity:0}to{opacity:1}}.animate-slideInBottomSubtle{animation:slideInFromBottomSubtle .5s ease-out forwards;opacity:0}.animate-fadeInSubtle{animation:fadeInSubtle .7s ease-out forwards;opacity:0}.project-links a,.project-tags .tag{opacity:0;animation:slideInFromBottomSubtle .5s ease-out forwards}.project-links a:nth-child(1){animation-delay:.1s}.project-links a:nth-child(2){animation-delay:.2s}.project-links a:nth-child(3){animation-delay:.3s}.project-links a:nth-child(4){animation-delay:.4s}.project-tags .tag:nth-child(1){animation-delay:.1s}.project-tags .tag:nth-child(2){animation-delay:.2s}.project-tags .tag:nth-child(3){animation-delay:.3s}.project-tags .tag:nth-child(4){animation-delay:.4s}.project-tags .tag:nth-child(5){animation-delay:.5s}.project-detail-page{transition:transform .3s ease-out}.squash-effect-active{animation:squashAnimation .4s ease-out}@keyframes squashAnimation{0%{transform:translateY(0) scaleY(1)}50%{transform:translateY(15px) scaleY(.98)}to{transform:translateY(0) scaleY(1)}}.project-detail-page h2{font-size:var(--font-size-large);font-weight:700;margin-bottom:10px;color:var(--text-primary);animation:fadeIn 1s ease-out}.project-detail-page h3{font-size:var(--font-size-medium);font-weight:600;margin-bottom:10px;color:var(--text-primary)}.project-detail-page p{font-size:var(--font-size-small);line-height:1.5;color:#0009}.project-detail-page a{color:var(--link-color);text-decoration:none;font-weight:500;margin-right:15px;display:inline-block;transition:color var(--transition-speed);font-size:var(--font-size-small)}.project-detail-page a:hover{color:var(--text-primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.dark .project-detail-page p{color:#ffffffbf}.dark .project-detail-page a{color:var(--link-color)}.dark .project-detail-page a:hover{color:var(--text-primary)}@media (max-width: 768px){.project-detail-page{padding:15px}.project-detail-page h2{font-size:1.8em}.project-detail-page h3{font-size:1.1em}.project-detail-page a{font-size:.9em}}@media (max-width: 480px){.project-detail-page{padding:10px}.project-detail-page h2{font-size:1.6em}.project-detail-page h3{font-size:1em}.project-detail-page a{font-size:.85em}}.project-screenshots{position:static;width:100%;max-height:none;overflow-y:visible;margin-top:20px;padding:.5rem 0}.screenshots-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.screenshot{width:100%;height:auto;max-height:150px;object-fit:cover;border-radius:4px}.dark .back-button{background-color:#444;color:#fff}.dark .back-button:hover{background-color:#666}.back-button svg{margin-right:8px}.project-detail-page{max-width:1200px;margin:0 auto;padding:2rem;box-sizing:border-box;position:relative}.back-button{margin:1rem 0;display:inline-flex;align-items:center;padding:10px;background-color:#f5f5f5;border:none;cursor:pointer;font-size:1.2rem;color:var(--primary-color);transition:background-color .3s ease}.back-button:hover{color:var(--link-color)}.project-detail-container{display:grid;gap:2rem}.project-cover-container{width:100%;max-height:500px;overflow:hidden;border-radius:var(--card-border-radius);box-shadow:0 2px 5px #0000001a}.project-cover{display:block;width:100%;height:auto;max-height:500px;object-fit:cover}.project-header{text-align:center;margin-bottom:1.5rem}.project-header h1{font-size:2.5rem;margin-bottom:1rem;color:var(--link-color)}.project-meta{display:flex;gap:1.5rem;justify-content:center;color:var(--text-primary);opacity:.8;font-size:.9rem}.project-links{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap;margin-bottom:2rem}.project-links a{color:var(--link-secondary);text-decoration:none;font-weight:500;padding:.5rem 1rem;border-radius:20px;background-color:var(--card-background);transition:all var(--transition-speed)}.project-links a:hover{color:var(--button-text);background-color:var(--link-color)}.project-content{display:grid;gap:2rem}.project-description{max-width:800px;margin:0 auto}.short-description{font-size:1.1rem;line-height:1.6;margin-bottom:2rem;color:var(--text-primary)}.full-description{white-space:pre-line;line-height:1.7;color:var(--text-primary);opacity:.9}.project-tags{display:flex;gap:.8rem;flex-wrap:wrap;justify-content:center}.tag{background-color:var(--card-background);color:var(--link-secondary);padding:.4rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500}.loading-text{margin-top:20px}@media (max-width: 768px){.project-detail-page{padding:1rem}.back-button{left:1rem;top:1rem}.project-header h1{font-size:2rem}.project-meta{flex-direction:column;align-items:center;gap:.5rem}.project-links{gap:1rem}.short-description{font-size:1rem}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#213547;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.dark{color:#ffffffde;background-color:#242424}body{color-scheme:light dark;margin:0;padding:0;width:100%;overflow-x:hidden;display:block;background-color:#fff;color:#213547;transition:background .3s,color .3s}h1{font-size:3.2em;line-height:1.1}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#f9f9f9;color:#213547;cursor:pointer;transition:border-color .25s,background-color .3s,color .3s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.dark button{background-color:#1a1a1a;color:#ffffffde}.dark a:hover{color:#747bff}
