*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,picture,video,canvas,svg{display:block;max-width:100%}a{text-decoration:none;color:var(--link-color-light)}body.dark-theme a{color:var(--link-color-dark)}a:hover{color:var(--link-hover-light)}body.dark-theme a:hover{color:var(--link-hover-dark)}.page-section{padding:var(--section-padding);max-width:1000px;margin:0 auto}.page-section h2{font-size:2rem;margin-bottom:1.5rem;color:var(--primary-color-light);text-align:center}body.dark-theme .page-section h2{color:var(--primary-color-dark)}.theme-toggle-button{background:none;border:1px solid var(--secondary-color-light);color:var(--text-color-light);padding:.5rem .75rem;border-radius:5px;cursor:pointer;font-size:1rem;transition:background-color .3s ease,color .3s ease,border-color .3s ease}.theme-toggle-button:hover{background-color:var(--secondary-color-light);color:var(--background-color-light)}body.dark-theme .theme-toggle-button{border-color:var(--secondary-color-dark);color:var(--text-color-dark)}body.dark-theme .theme-toggle-button:hover{background-color:var(--secondary-color-dark);color:var(--background-color-dark)}.app-header{background-color:var(--header-bg-light);color:var(--header-text-light);padding:1rem 2rem;box-shadow:0 2px 4px #0000001a;position:sticky;top:0;z-index:1000;transition:background-color .3s ease,color .3s ease}body.dark-theme .app-header{background-color:var(--header-bg-dark);color:var(--header-text-dark)}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.nav-and-toggle{display:flex;align-items:center;gap:1.5rem}.app-header .logo{font-size:1.5rem;font-weight:700;text-decoration:none;color:var(--header-text-light)}body.dark-theme .app-header .logo{color:var(--header-text-dark)}.app-header nav ul{list-style:none;padding:0;margin:0;display:flex;gap:1.5rem}.app-header nav ul li a{text-decoration:none;color:var(--link-color-light);font-weight:500;transition:color .2s ease-in-out}body.dark-theme .app-header nav ul li a{color:var(--link-color-dark)}.app-header nav ul li a:hover,.app-header nav ul li a.active{color:var(--link-hover-light)}body.dark-theme .app-header nav ul li a:hover,body.dark-theme .app-header nav ul li a.active{color:var(--link-hover-dark)}.menu-toggle{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--header-text-light)}body.dark-theme .menu-toggle{color:var(--header-text-dark)}@media (max-width: 768px){.app-header nav ul{display:none;flex-direction:column;position:absolute;top:100%;left:0;width:100%;background-color:var(--header-bg-light);box-shadow:0 2px 4px #0000001a;padding:1rem 0}body.dark-theme .app-header nav ul{background-color:var(--header-bg-dark)}.app-header nav ul.active{display:flex}.app-header nav ul li{text-align:center;padding:.5rem 0}.menu-toggle{display:block}}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;transition:background .3s ease}.modal-content{background:var(--card-bg-light);color:var(--text-color-light);padding:2rem;border-radius:8px;max-width:500px;max-height:70vh;overflow:auto;position:relative;border:1px solid var(--card-border-light);box-shadow:0 4px 24px var(--primary-color-light-transparent);transition:background .3s,color .3s,border .3s}body.dark-theme .modal-content{background:var(--card-bg-dark);color:var(--text-color-dark);border:1px solid var(--card-border-dark);box-shadow:0 4px 24px var(--primary-color-dark-transparent)}.modal-close{position:absolute;top:8px;right:12px;background:none;border:none;font-size:1.5rem;color:var(--primary-color-light);cursor:pointer;transition:color .3s}body.dark-theme .modal-close{color:var(--primary-color-dark)}.modal-close:hover{color:var(--link-hover-light)}body.dark-theme .modal-close:hover{color:var(--link-hover-dark)}.modal-body{margin-top:1.5rem}.about-section .about-content{display:flex;flex-direction:column;align-items:center;gap:2rem;padding-top:2rem}.more-aboutme{display:flex;flex-direction:column;align-items:center;gap:1rem}@media (min-width: 768px){.about-section .about-content{flex-direction:row;align-items:flex-start;gap:3rem}.more-aboutme{flex-direction:row;align-items:center}}.about-image-container{flex-shrink:0;max-width:240px;width:100%;margin-bottom:1rem}@media (min-width: 768px){.about-image-container{margin-bottom:0}}.profile-photo{width:100%;height:auto;border-radius:50%;border:3px solid var(--primary-color-light);box-shadow:0 4px 15px #0000001a}body.dark-theme .profile-photo{border-color:var(--primary-color-dark)}.about-text-container{text-align:left;max-width:650px;width:100%}.about-text-container h2{text-align:left;margin-bottom:1rem;font-size:2.2rem}.about-text-container .tagline{font-size:1.2rem;font-style:italic;color:var(--secondary-color-light);margin-bottom:1.5rem}body.dark-theme .about-text-container .tagline{color:var(--secondary-color-dark)}.about-text-container p{margin-bottom:1rem;line-height:1.7}@media (min-width: 768px){.about-section .about-content{flex-direction:row;align-items:flex-start;gap:3rem}.about-text-container{text-align:left}.about-text-container h2{margin-top:0}}.about-modal-btn{display:block;margin:1rem 0;background:var(--card-bg-light);color:var(--primary-color-light);border:1px solid var(--card-border-light);padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:1rem;font-family:inherit;transition:background .2s,color .2s,border .2s}.about-modal-btn:hover,.about-modal-btn:focus{background:var(--primary-color-light-transparent);color:var(--link-hover-light);border-color:var(--primary-color-light)}body.dark-theme .about-modal-btn{background:var(--card-bg-dark);color:var(--primary-color-dark);border:1px solid var(--card-border-dark)}body.dark-theme .about-modal-btn:hover,body.dark-theme .about-modal-btn:focus{background:var(--primary-color-dark-transparent);color:var(--link-hover-dark);border-color:var(--primary-color-dark)}.project-card{background-color:var(--card-bg-light);border:1px solid var(--card-border-light);border-radius:8px;overflow:hidden;box-shadow:0 4px 8px #0000000d;display:flex;flex-direction:column;transition:transform .3s ease,box-shadow .3s ease,background-color .3s ease,border-color .3s ease}body.dark-theme .project-card{background-color:var(--card-bg-dark);border-color:var(--card-border-dark)}.project-card:hover{transform:translateY(-5px);box-shadow:0 6px 12px #0000001a}body.dark-theme .project-card:hover{box-shadow:0 6px 12px #ffffff14}.project-image-container{width:100%;aspect-ratio:16 / 10;overflow:hidden;background-color:#e0e0e0}body.dark-theme .project-image-container{background-color:#424242}.project-screenshot{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}.project-card:hover .project-screenshot{transform:scale(1.03)}.project-info{padding:1rem 1.25rem;flex-grow:1;display:flex;flex-direction:column}.project-name{font-size:1.3rem;color:var(--primary-color-light);margin-bottom:.5rem}body.dark-theme .project-name{color:var(--primary-color-dark)}.project-description{font-size:.95rem;line-height:1.5;margin-bottom:1rem;flex-grow:1}.project-technologies{margin-bottom:1.25rem;font-size:.9rem}.project-technologies strong{display:block;margin-bottom:.5rem;color:var(--secondary-color-light)}body.dark-theme .project-technologies strong{color:var(--secondary-color-dark)}.tech-tags{list-style:none;padding:0;display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{background-color:var(--background-color-light);border:1px solid var(--secondary-color-light);color:var(--text-color-light);padding:.25rem .6rem;border-radius:15px;font-size:.8rem}body.dark-theme .tech-tag{background-color:var(--background-color-dark);border:1px solid var(--secondary-color-dark);color:var(--text-color-dark)}.project-links{margin-top:auto;display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap}.project-link{display:inline-block;padding:.5rem 1rem;border-radius:5px;text-decoration:none;font-weight:500;font-size:.9rem;text-align:center;transition:background-color .3s ease,color .3s ease,transform .2s ease}.project-link.demo-link{background-color:var(--primary-color-light);color:#fff}body.dark-theme .project-link.demo-link{background-color:var(--primary-color-dark)}.project-link.demo-link:hover{background-color:var(--link-hover-light);transform:translateY(-1px)}body.dark-theme .project-link.demo-link:hover{background-color:var(--link-hover-dark)}.project-link.source-link{background-color:transparent;color:var(--primary-color-light);border:1px solid var(--primary-color-light)}body.dark-theme .project-link.source-link{color:var(--primary-color-dark);border-color:var(--primary-color-dark)}.project-link.source-link:hover{background-color:var(--primary-color-light);color:#fff;transform:translateY(-1px)}body.dark-theme .project-link.source-link:hover{background-color:var(--primary-color-dark);color:var(--background-color-dark)}.projects-summary-section h2{margin-bottom:2rem}.projects-summary-grid{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:2.5rem}@media (min-width: 600px){.projects-summary-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}}@media (min-width: 992px){.projects-summary-grid{grid-template-columns:repeat(3,1fr)}}.no-projects-summary-message{text-align:center;font-style:italic;color:var(--secondary-color-light);margin-bottom:2.5rem}body.dark-theme .no-projects-summary-message{color:var(--secondary-color-dark)}.view-all-projects-container{text-align:center;margin-top:1rem}.button-primary{display:inline-block;background-color:var(--primary-color-light);color:#fff;padding:.75rem 2rem;border-radius:5px;text-decoration:none;font-weight:700;font-size:1rem;border:2px solid transparent;transition:background-color .3s ease,transform .2s ease}body.dark-theme .button-primary{background-color:var(--primary-color-dark);color:var(--background-color-dark)}.button-primary:hover{background-color:var(--link-hover-light);transform:translateY(-2px)}body.dark-theme .button-primary:hover{background-color:var(--link-hover-dark)}.technologies-section h2{margin-bottom:2rem}.tech-categories{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.tech-category{background-color:var(--card-bg-light);padding:1.5rem;border-radius:8px;border:1px solid var(--card-border-light);box-shadow:0 2px 8px #0000000d;transition:background-color .3s ease,border-color .3s ease}body.dark-theme .tech-category{background-color:var(--card-bg-dark);border-color:var(--card-border-dark)}.tech-category h3{font-size:1.3rem;color:var(--primary-color-light);margin-bottom:1rem;border-bottom:2px solid var(--primary-color-light);padding-bottom:.5rem;display:inline-block}body.dark-theme .tech-category h3{color:var(--primary-color-dark);border-bottom-color:var(--primary-color-dark)}.tech-list{list-style:none;padding:0;display:flex;flex-wrap:wrap;gap:.75rem}.tech-item{background-color:var(--background-color-light);color:var(--text-color-light);padding:.5rem 1rem;border-radius:20px;font-size:.9rem;border:1px solid var(--secondary-color-light);transition:background-color .3s ease,color .3s ease,border-color .3s ease}body.dark-theme .tech-item{background-color:var(--background-color-dark);color:var(--text-color-dark);border-color:var(--secondary-color-dark)}.tech-list.simple-list{justify-content:center;gap:1rem;margin-top:1rem}.resume-section{text-align:center}.resume-section h2{margin-bottom:1rem}.resume-section p{margin-bottom:2rem;max-width:600px;margin-left:auto;margin-right:auto}.resume-download-button{display:inline-block;background-color:var(--primary-color-light);color:var(--background-color-light);padding:.75rem 1.5rem;border-radius:5px;text-decoration:none;font-weight:700;font-size:1rem;border:2px solid transparent;transition:background-color .3s ease,color .3s ease,border-color .3s ease,transform .2s ease}body.dark-theme .resume-download-button{background-color:var(--primary-color-dark);color:var(--background-color-dark)}.resume-download-button:hover{background-color:var(--link-hover-light);color:var(--background-color-light);transform:translateY(-2px);box-shadow:0 4px 10px #0000001a}body.dark-theme .resume-download-button:hover{background-color:var(--link-hover-dark);color:var(--background-color-dark)}.contact-section h2{margin-bottom:1rem}.contact-intro{text-align:center;max-width:700px;margin:0 auto 2.5rem;font-size:1.05rem;color:var(--secondary-color-light)}body.dark-theme .contact-intro{color:var(--secondary-color-dark)}.contact-form{max-width:650px;margin:0 auto;background-color:var(--card-bg-light);padding:2rem;border-radius:8px;border:1px solid var(--card-border-light);box-shadow:0 4px 15px #00000012}body.dark-theme .contact-form{background-color:var(--card-bg-dark);border-color:var(--card-border-dark)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-color-light)}body.dark-theme .form-group label{color:var(--text-color-dark)}.form-group input[type=text],.form-group input[type=email],.form-group textarea{width:100%;padding:.75rem;border:1px solid var(--card-border-light);border-radius:5px;font-size:1rem;background-color:var(--background-color-light);color:var(--text-color-light);transition:border-color .3s ease,box-shadow .3s ease}body.dark-theme .form-group input[type=text],body.dark-theme .form-group input[type=email],body.dark-theme .form-group textarea{border-color:var(--card-border-dark);background-color:var(--background-color-dark);color:var(--text-color-dark)}.form-group input[type=text]:focus,.form-group input[type=email]:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color-light);box-shadow:0 0 0 2px var(--primary-color-light-transparent, rgba(0, 123, 255, .25))}body.dark-theme .form-group input[type=text]:focus,body.dark-theme .form-group input[type=email]:focus,body.dark-theme .form-group textarea:focus{border-color:var(--primary-color-dark);box-shadow:0 0 0 2px var(--primary-color-dark-transparent, rgba(13, 110, 253, .25))}.form-group input.input-error,.form-group textarea.input-error{border-color:#dc3545}.form-group input.input-error:focus,.form-group textarea.input-error:focus{box-shadow:0 0 0 2px #dc354540}.error-message{color:#dc3545;font-size:.875rem;margin-top:.25rem}.form-status{margin-bottom:1.5rem;min-height:1.5em}.status-message{padding:.75rem;border-radius:5px;font-size:.95rem}.status-message.submitting{background-color:#e0e0e0;border:1px solid #c0c0c0;color:#333}body.dark-theme .status-message.submitting{background-color:#424242;border-color:#505050;color:#f0f0f0}.status-message.success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}body.dark-theme .status-message.success{background-color:#203d24;border-color:#2a522e;color:#c3e6cb}.status-message.error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}body.dark-theme .status-message.error{background-color:#442023;border-color:#5a2a2d;color:#f5c6cb}.submit-button{display:inline-block;background-color:var(--primary-color-light);color:#fff;padding:.75rem 2rem;border:none;border-radius:5px;font-weight:700;font-size:1rem;cursor:pointer;transition:background-color .3s ease,opacity .3s ease}body.dark-theme .submit-button{background-color:var(--primary-color-dark);color:var(--background-color-dark)}.submit-button:hover:not(:disabled){background-color:var(--link-hover-light)}body.dark-theme .submit-button:hover:not(:disabled){background-color:var(--link-hover-dark)}.submit-button:disabled{opacity:.65;cursor:not-allowed}.app-footer{background-color:var(--footer-bg-light);color:var(--footer-text-light);padding:2rem;text-align:center;transition:background-color .3s ease,color .3s ease}body.dark-theme .app-footer{background-color:var(--footer-bg-dark);color:var(--footer-text-dark)}.footer-content{max-width:1200px;margin:0 auto}.social-links{margin-bottom:1rem}.social-links a{color:var(--footer-text-light);margin:0 .75rem;text-decoration:none;font-size:1.2rem;transition:color .2s ease-in-out}body.dark-theme .app-footer .social-links a{color:var(--footer-text-dark)}.social-links a:hover{color:#007bff}.copyright{font-size:.9rem;margin:0}.social-links{margin-bottom:1rem;display:flex;justify-content:center;gap:1.5rem}.social-links a{color:var(--footer-text-light);text-decoration:none;font-size:1rem;transition:color .2s ease-in-out,transform .2s ease}body.dark-theme .social-links a{color:var(--footer-text-dark)}.social-links a:hover{color:var(--primary-color-light);transform:translateY(-2px)}body.dark-theme .social-links a:hover{color:var(--primary-color-dark)}.projects-page-header{text-align:center;margin-bottom:2.5rem}.projects-page-header h2{margin-bottom:.75rem}.projects-page-header p{font-size:1.1rem;color:var(--secondary-color-light);max-width:700px;margin:0 auto 1rem}body.dark-theme .projects-page-header p{color:var(--secondary-color-dark)}.projects-grid{display:grid;grid-template-columns:1fr;gap:2rem}@media (min-width: 600px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 992px){.projects-grid{grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}}.no-projects-message{text-align:center;padding:2rem;background-color:var(--card-bg-light);border:1px dashed var(--card-border-light);border-radius:8px;margin-top:2rem}body.dark-theme .no-projects-message{background-color:var(--card-bg-dark);border-color:var(--card-border-dark)}:root{--background-color-light: #f8f8f8;--text-color-light: #444444;--primary-color-light: #008080;--secondary-color-light: #708090;--header-bg-light: #ffffff;--header-text-light: #333333;--footer-bg-light: #333333;--footer-text-light: #f8f8f8;--card-bg-light: #ffffff;--card-border-light: #e0e0e0;--link-color-light: #008080;--link-hover-light: #006666;--primary-color-light-transparent: rgba(0, 128, 128, .25);--background-color-dark: #2a2a2a;--text-color-dark: #e0e0e0;--primary-color-dark: #48d1cc;--secondary-color-dark: #a9a9a9;--header-bg-dark: #3a3a3a;--header-text-dark: #f8f8f8;--footer-bg-dark: #3a3a3a;--footer-text-dark: #c0c0c0;--card-bg-dark: #444444;--card-border-dark: #666666;--link-color-dark: #48d1cc;--link-hover-dark: #80e6e3;--primary-color-dark-transparent: rgba(72, 209, 204, .25);--font-family-sans-serif: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-family-monospace: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--section-padding: 4rem 2rem}body{background-color:var(--background-color-light);color:var(--text-color-light);font-family:var(--font-family-sans-serif);margin:0;padding:0;box-sizing:border-box;transition:background-color .3s ease,color .3s ease}body.dark-theme{background-color:var(--background-color-dark);color:var(--text-color-dark)}
