body{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);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}.dark body{background:linear-gradient(135deg,#2c3e50,#34495e)}.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-text{display:flex;flex-direction:column;margin-right:auto}.header-controls{display:flex;align-items:center;gap:10px}.contact-button{display:flex;align-items:center;gap:8px;background:#f25922;color:#fff;border:none;padding:10px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;text-decoration:none}.contact-button:hover{background:#ff914d;transform:translateY(-1px);box-shadow:0 4px 12px #f259224d}.contact-button svg{font-size:16px}.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;transition:all .3s ease;box-shadow:0 4px 20px #0000001a}.profile-photo:hover{transform:scale(1.05);box-shadow:0 8px 30px #f259224d}.profile-description{font-size:1.05em;line-height:1.6;margin:0;color:#333}.dark .profile-description{color:#ccc}.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:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);border-radius:50%;cursor:pointer;font-size:1px;color:#213547;transition:all .3s ease;width:50px;height:50px;display:flex;align-items:center;justify-content:center}.theme-toggle:hover{background:#f2592233;transform:scale(1.1)}.dark .theme-toggle{background:#1e1e1e33;border:1px solid rgba(255,255,255,.2);color:#ffffffde}.header h1{font-size:3em;font-weight:700;color:#213547;margin:0;animation:fadeIn 2s ease-out;text-shadow:1px 1px 3px rgba(0,0,0,.15)}.dark .header h1{color:#ffffffe6}.projects{width:100%}.search-container{margin:20px 0}.search-input-wrapper{position:relative;display:flex;align-items:center;max-width:600px;margin:0 auto}.search-icon{position:absolute;left:15px;color:#666;z-index:1;font-size:16px}.search-input{width:100%;padding:12px 45px;border:2px solid rgba(255,255,255,.3);border-radius:25px;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:16px;color:#333;transition:all .3s ease;box-shadow:0 4px 15px #0000001a}.search-input:focus{outline:none;border-color:#f25922;box-shadow:0 4px 20px #f2592233}.search-input::placeholder{color:#666}.clear-search{position:absolute;right:15px;background:none;border:none;font-size:20px;color:#666;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;transition:color .3s ease}.clear-search:hover{color:#f25922}.search-results{text-align:center;margin:10px 0 0;font-size:14px;opacity:.8;color:var(--text-primary)}.dark .search-input{background:#1e1e1ee6;border-color:#fff3;color:#fff}.dark .search-input::placeholder{color:#ccc}.dark .search-icon,.dark .clear-search{color:#ccc}.dark .clear-search:hover{color:#f25922}.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:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:20px;border-radius:16px;border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 20px #0000001a;transition:all .3s cubic-bezier(.25,.8,.25,1);animation:cardEntrance .5s ease-out forwards;opacity:0}.project-card:hover{box-shadow:0 12px 40px #00000026;transform:translateY(-8px)}.dark .project-card{background:#1e1e1ee6;border:1px solid rgba(255,255,255,.1)}@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:#213547;transition:color .3s}.project-card:hover h3{color:#f25922}.project-card-content p{font-size:16px;line-height:1.5;margin-bottom:15px;color:#213547}.dark .project-card-content h3,.dark .project-card-content p{color:#ffffffe6}.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:#f25922}.project-card-links a:not(:first-child){color:#ff914d}.project-card-links a:hover{color:#213547}.dark .project-card-links a:hover{color:#ffffffe6}.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;gap:15px}.header-controls{align-self:stretch;justify-content:space-between}.profile-section{flex-wrap:wrap}.profile-photo{margin-right:0;margin-bottom:10px}.profile-description{text-align:center;width:100%;margin-bottom:12px}.contact-button{font-size:13px;padding:8px 12px}.search-input{padding:10px 40px;font-size:14px}.search-input::placeholder{font-size:14px}}@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}.search-input{padding:8px 35px;font-size:14px}.search-icon{left:12px;font-size:14px}.clear-search{right:12px;font-size:18px}}.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}}.contact-page{min-height:100vh;color:#213547;width:100%;max-width:900px;margin:0 auto;padding:20px;box-sizing:border-box}.dark .contact-page{color:#ffffffde}.header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;width:100%;margin-bottom:40px;padding:20px;box-sizing:border-box;background:#fffc;border-radius:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a}.dark .header{background:#1e1e1ecc;border:1px solid rgba(255,255,255,.1)}.header-navigation{display:flex;align-items:center;gap:1rem}.back-button{display:flex;align-items:center;gap:.5rem;background:none;border:1px solid rgba(0,0,0,.1);color:#213547;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.back-button:hover{background:#f259221a;border-color:#f25922}.dark .back-button{border:1px solid rgba(255,255,255,.1);color:#ffffffde}.dark .back-button:hover{background:#f2592233;border-color:#f25922}.theme-toggle{background:none;border:1px solid rgba(0,0,0,.1);color:#213547;padding:.5rem;border-radius:6px;cursor:pointer;width:44px;height:44px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.theme-toggle:hover{background:#f259221a;border-color:#f25922}.dark .theme-toggle{border:1px solid rgba(255,255,255,.1);color:#ffffffde}.dark .theme-toggle:hover{background:#f2592233;border-color:#f25922}.contact-main{display:flex;justify-content:center;min-height:calc(100vh - 140px)}.contact-container{width:100%;max-width:600px}.contact-intro{text-align:center;margin-bottom:2rem}.contact-intro h2{font-size:2rem;margin-bottom:1rem;color:#f25922}.contact-intro p{font-size:1.1rem;line-height:1.6;opacity:.8}.contact-form{background:#ffffffe6;padding:2rem;border-radius:12px;border:1px solid rgba(0,0,0,.1);box-shadow:0 4px 20px #0000001a}.dark .contact-form{background:#1e1e1ee6;border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #0000004d}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#213547}.dark .form-group label{color:#ffffffde}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid rgba(0,0,0,.1);border-radius:6px;background:#fff;color:#213547;font-size:1rem;transition:border-color .2s ease;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#f25922;box-shadow:0 0 0 2px #007bff1a}.form-group input:disabled,.form-group textarea:disabled{background:#f5f5f5;opacity:.6;cursor:not-allowed}.dark .form-group input,.dark .form-group textarea{border:1px solid rgba(255,255,255,.1);background:#1a1a1a;color:#ffffffde}.dark .form-group input:disabled,.dark .form-group textarea:disabled{background:#3a3a3a}.form-group textarea{resize:vertical;min-height:120px}.submit-button{width:100%;padding:.75rem 1.5rem;background:#f25922;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s ease}.submit-button:hover:not(:disabled){background:#ff914d;transform:translateY(-1px)}.submit-button:disabled{background:#6c757d;cursor:not-allowed;transform:none}.dark .submit-button:disabled{background:#3a3a3a}.status-message{margin-top:1rem;padding:1rem;border-radius:6px;font-weight:500;text-align:center}.status-message.success{background:#28a7451a;border:1px solid rgba(40,167,69,.3);color:#28a745}.status-message.error{background:#dc35451a;border:1px solid rgba(220,53,69,.3);color:#dc3545}.dark .status-message.success{color:#4ade80}.dark .status-message.error{color:#f87171}@media (max-width: 768px){.header{padding:1rem;flex-direction:column;gap:1rem}.header-navigation{flex-direction:column;text-align:center}.contact-main{padding:1rem}.contact-form{padding:1.5rem}.contact-intro h2{font-size:1.5rem}.back-button{font-size:.8rem;padding:.4rem .8rem}}@media (max-width: 480px){.header{padding:.75rem}.contact-form{padding:1rem}.form-group input,.form-group textarea{padding:.6rem}.submit-button{padding:.6rem 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}
