.app-container{display:flex;flex-direction:column;min-height:100vh;font-family:var(--font-primary, "Segoe UI", Tahoma, Geneva, Verdana, sans-serif);background-color:var(--background-color, #f4f7f6)}.app-header{background-color:var(--primary-color, #007bff);color:var(--light-text-color, #ffffff);padding:1rem 2rem;box-shadow:0 2px 4px #0000001a;position:sticky;top:0;z-index:1000}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.site-title{font-size:1.8rem;font-weight:700;color:var(--light-text-color, #ffffff);text-decoration:none;transition:opacity .3s ease}.site-title:hover{text-decoration:none;opacity:.85}.nav-and-switcher-wrapper{display:flex;align-items:center;gap:1rem}.app-nav ul{list-style:none;padding:0;margin:0;display:flex;gap:.5rem}.app-nav .nav-link{color:var(--light-text-color, #ffffff);text-decoration:none;font-size:1rem;font-weight:500;padding:.5rem 0;margin:0 .75rem;position:relative;transition:color .3s ease}.app-nav .nav-link:hover,.app-nav .nav-link.active{color:var(--accent-color, #ffc107)}.app-nav .nav-link:after{content:"";position:absolute;width:0;height:3px;bottom:-5px;left:50%;transform:translate(-50%);background-color:var(--accent-color, #ffc107);transition:width .3s ease-in-out}.app-nav .nav-link:hover:after,.app-nav .nav-link.active:after{width:100%}.app-main{flex-grow:1;padding:2rem;max-width:1200px;width:100%;margin:0 auto;box-sizing:border-box}.app-main h2{font-size:2rem;color:var(--primary-color-dark, #0056b3);margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid var(--primary-color-light, #e0efff)}.app-footer{background-color:var(--text-color, #333);color:var(--light-text-color, #f8f9fa);text-align:center;padding:1.5rem 2rem;font-size:.9rem;margin-top:auto}.page-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:2rem;background-color:var(--card-background, #fff);border-radius:8px;box-shadow:0 4px 8px #0000000d}.page-placeholder h2{font-size:2.2rem;color:var(--primary-color, #007bff);margin-bottom:1rem;border-bottom:none}.page-placeholder p{font-size:1.1rem;color:var(--text-color-muted, #555);margin-bottom:1.5rem;max-width:500px;line-height:1.6}.page-placeholder .btn{padding:.8rem 1.8rem;border-radius:8px;text-decoration:none;font-weight:600;font-size:1rem;transition:background-color .3s ease,transform .2s ease,box-shadow .3s ease;border:none;cursor:pointer;display:inline-block;box-shadow:0 2px 5px #0000001a}.page-placeholder .btn-primary{background-color:var(--primary-color, #007bff);color:var(--light-text-color, #fff)}.page-placeholder .btn-primary:hover{background-color:var(--primary-color-dark, #0056b3);transform:translateY(-2px);box-shadow:0 4px 8px #00000026}@media (max-width: 768px){.app-header{padding:1rem 1.5rem}.header-content{flex-direction:column;align-items:center}.site-title{margin-bottom:.75rem}.nav-and-switcher-wrapper{flex-direction:column;align-items:center;width:100%;gap:.75rem}.app-nav{margin-top:0;width:100%}.app-nav ul{flex-direction:row;justify-content:center;flex-wrap:wrap;gap:.25rem .5rem}.app-nav .nav-link{font-size:.9rem;margin:0 .5rem}.app-main{padding:1.5rem}.app-main h2{font-size:1.8rem}}@media (max-width: 480px){.site-title{font-size:1.6rem}.app-nav ul{gap:.1rem .3rem}.app-nav .nav-link{font-size:.85rem;margin:0 .3rem}}.home-page-container{padding:0}.hero-section{background-color:var(--primary-color-dark, #0056b3);color:var(--light-text-color, #ffffff);padding:4rem 2rem;text-align:center;min-height:70vh;display:flex;align-items:center;justify-content:center}.hero-content{max-width:1000px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:2rem;text-align:left}.hero-text{flex:1;max-width:600px}.hero-name{font-size:3rem;font-weight:700;margin-bottom:.5rem;line-height:1.2}.hero-tagline{font-size:1.5rem;font-weight:300;margin-bottom:1.5rem;color:var(--primary-color-light, #e0efff)}.hero-intro{font-size:1.1rem;line-height:1.7;margin-bottom:2rem}.hero-buttons{display:flex;gap:1rem;flex-wrap:wrap}.btn{padding:.8rem 1.8rem;border-radius:8px;text-decoration:none;font-weight:600;font-size:1rem;transition:background-color .3s ease,transform .2s ease,box-shadow .3s ease;border:none;cursor:pointer;display:inline-block;box-shadow:0 2px 5px #0000001a}.btn-primary{background-color:var(--accent-color, #ffc107);color:var(--text-color, #333)}.btn-primary:hover{background-color:#e0a800;transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.btn-secondary{background-color:transparent;color:var(--light-text-color, #ffffff);border:2px solid var(--accent-color, #ffc107)}.btn-secondary:hover{background-color:var(--accent-color, #ffc107);color:var(--text-color, #333);transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.hero-image-container{flex-shrink:0}.hero-profile-image{width:280px;height:280px;border-radius:50%;object-fit:cover;border:5px solid var(--accent-color, #ffc107);box-shadow:0 8px 16px #0003}.quick-summary-section{padding:3rem 2rem;background-color:var(--background-color, #f4f7f6);text-align:center}.quick-summary-section h2{font-size:2.2rem;color:var(--primary-color-dark, #0056b3);margin-bottom:2.5rem}.summary-cards{display:flex;justify-content:space-around;flex-wrap:wrap;gap:2rem;max-width:1200px;margin:0 auto}.summary-card{background-color:#fff;padding:2rem;border-radius:10px;box-shadow:0 5px 15px #00000012;flex:1;min-width:280px;max-width:350px;text-align:left;transition:transform .3s ease,box-shadow .3s ease}.summary-card:hover{transform:translateY(-5px);box-shadow:0 8px 20px #0000001a}.summary-card h3{font-size:1.5rem;color:var(--primary-color, #007bff);margin-bottom:1rem}.summary-card p{font-size:1rem;line-height:1.6;color:var(--text-color-muted, #555)}@media (max-width: 992px){.hero-content{flex-direction:column-reverse;text-align:center}.hero-text{max-width:100%}.hero-buttons{justify-content:center}.hero-profile-image{width:220px;height:220px;margin-bottom:2rem}.hero-name{font-size:2.5rem}.hero-tagline{font-size:1.3rem}}@media (max-width: 768px){.hero-section{padding:3rem 1.5rem;min-height:auto}.hero-name{font-size:2.2rem}.hero-tagline{font-size:1.2rem}.hero-intro{font-size:1rem}.btn{padding:.7rem 1.5rem;font-size:.9rem}.quick-summary-section{padding:2.5rem 1.5rem}.quick-summary-section h2{font-size:2rem}}:root{--accent-color: #ffc107}.about-page-container{padding:1rem 0}.about-page-container section{margin-bottom:2.5rem;padding:1.5rem;background-color:#fff;border-radius:8px;box-shadow:0 4px 8px #0000000d}.profile-intro{text-align:center}.profile-intro h1{font-size:2.5rem;color:var(--primary-color, #007bff);margin-bottom:.5rem}.profile-intro .location{font-size:1.1rem;color:var(--secondary-color, #6c757d);margin-bottom:1rem}.contact-info p{margin-bottom:.5rem;font-size:1rem}.contact-info a{color:var(--primary-color, #007bff);text-decoration:none}.contact-info a:hover{text-decoration:underline}.bio{font-size:1.1rem;line-height:1.7;text-align:left;margin-top:1.5rem;color:var(--text-color, #333)}.about-page-container h2{font-size:1.8rem;color:var(--primary-color, #007bff);margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid var(--primary-color, #007bff)}.skills-list{list-style:none;padding:0;display:flex;flex-wrap:wrap;gap:.75rem}.skill-item{background-color:var(--primary-color-light, #e0efff);color:var(--primary-color-dark, #0056b3);padding:.5rem 1rem;border-radius:20px;font-size:.95rem;font-weight:500;box-shadow:0 2px 4px #0000000d}.experience-item,.education-item{margin-bottom:1.5rem;padding-left:1rem;border-left:3px solid var(--primary-color-light, #e0efff)}.experience-item:last-child,.education-item:last-child{margin-bottom:0}.experience-item h3,.education-item h3{font-size:1.4rem;color:var(--text-color, #333);margin-bottom:.25rem}.company-period,.institution-year{font-size:1rem;font-style:italic;color:var(--secondary-color, #6c757d);margin-bottom:.75rem}.experience-item ul{list-style:disc;padding-left:1.5rem;margin-top:.5rem}.experience-item ul li,.education-item p{font-size:1rem;line-height:1.6;color:var(--text-color-muted, #555);margin-bottom:.4rem}.languages-list{list-style:none;padding:0}.language-item{font-size:1rem;margin-bottom:.5rem;color:var(--text-color, #333)}.language-item strong{font-weight:600}:root{--primary-color-light: #e0efff;--primary-color-dark: #0056b3;--text-color-muted: #555}.project-card{background-color:#fff;border-radius:12px;box-shadow:0 6px 12px #00000014;overflow:hidden;display:flex;flex-direction:column;transition:transform .3s ease-in-out,box-shadow .3s ease-in-out}.project-card:hover{transform:translateY(-5px);box-shadow:0 10px 20px #0000001f}.project-image-container{width:100%;height:220px;overflow:hidden;background-color:#e9ecef}.project-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.project-card:hover .project-image{transform:scale(1.05)}.project-content{padding:1.5rem;display:flex;flex-direction:column;flex-grow:1}.project-title{font-size:1.6rem;color:var(--primary-color, #007bff);margin-bottom:.75rem;font-weight:600}.project-description{font-size:.95rem;color:var(--text-color-muted, #555);line-height:1.6;margin-bottom:1rem;flex-grow:1}.project-technologies{margin-bottom:1rem}.project-technologies h4{font-size:.9rem;font-weight:700;color:var(--secondary-color, #6c757d);margin-bottom:.5rem;text-transform:uppercase}.project-technologies ul{list-style:none;padding:0;display:flex;flex-wrap:wrap;gap:.5rem}.project-technologies li{background-color:var(--primary-color-light, #e0efff);color:var(--primary-color-dark, #0056b3);padding:.3rem .8rem;border-radius:15px;font-size:.85rem}.project-links{margin-top:auto;padding-top:1rem;border-top:1px solid #eee;display:flex;gap:1rem;justify-content:flex-start}.project-link{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;border-radius:8px;text-decoration:none;font-weight:500;font-size:.9rem;transition:background-color .3s ease,color .3s ease,box-shadow .3s ease;box-shadow:0 2px 4px #0000000d}.live-link{background-color:var(--primary-color, #007bff);color:#fff}.live-link:hover{background-color:var(--primary-color-dark, #0056b3);box-shadow:0 4px 8px #0000001a}.repo-link{background-color:var(--secondary-color, #6c757d);color:#fff}.repo-link:hover{background-color:#5a6268;box-shadow:0 4px 8px #0000001a}.portofolio-page-container{padding:1rem 0}.portofolio-page-container h1{font-size:2.5rem;color:var(--primary-color, #007bff);margin-bottom:1rem;text-align:center;border-bottom:2px solid var(--primary-color, #007bff);padding-bottom:.75rem;display:inline-block;margin-left:auto;margin-right:auto;display:block}.portofolio-intro{font-size:1.1rem;color:var(--text-color-muted, #555);text-align:center;margin-bottom:2.5rem;max-width:800px;margin-left:auto;margin-right:auto;line-height:1.7}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}@media (max-width: 768px){.projects-grid{grid-template-columns:1fr}.portofolio-page-container h1{font-size:2rem}}.contact-page-container{padding:1rem 0}.contact-page-container h1{font-size:2.5rem;color:var(--primary-color, #007bff);margin-bottom:1rem;text-align:center;border-bottom:2px solid var(--primary-color, #007bff);padding-bottom:.75rem;display:inline-block;margin-left:auto;margin-right:auto;display:block}.contact-intro{font-size:1.1rem;color:var(--text-color-muted, #555);text-align:center;margin-bottom:3rem;max-width:800px;margin-left:auto;margin-right:auto;line-height:1.7}.contact-content-wrapper{display:flex;flex-wrap:wrap;gap:3rem;justify-content:space-between;background-color:#fff;padding:2.5rem;border-radius:10px;box-shadow:0 6px 20px #00000012}.contact-details-section,.contact-form-section{flex:1;min-width:300px}.contact-details-section h2,.contact-form-section h2{font-size:1.8rem;color:var(--primary-color-dark, #0056b3);margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:1px solid #eee}.detail-item{margin-bottom:1rem;font-size:1.05rem;line-height:1.6}.detail-item strong{color:var(--text-color, #333);margin-right:.5rem}.detail-item a{color:var(--primary-color, #007bff);text-decoration:none}.detail-item a:hover{text-decoration:underline}.contact-form .form-group{margin-bottom:1.5rem}.contact-form label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-color, #333);font-size:.95rem}.contact-form input[type=text],.contact-form input[type=email],.contact-form textarea{width:100%;padding:.8rem 1rem;border:1px solid #ccc;border-radius:6px;font-size:1rem;box-sizing:border-box;transition:border-color .3s ease,box-shadow .3s ease}.contact-form input[type=text]:focus,.contact-form input[type=email]:focus,.contact-form textarea:focus{border-color:var(--primary-color, #007bff);box-shadow:0 0 0 .2rem #007bff40;outline:none}.contact-form textarea{resize:vertical;min-height:120px}.btn-submit{padding:.8rem 1.8rem;border-radius:8px;text-decoration:none;font-weight:600;font-size:1rem;transition:background-color .3s ease,transform .2s ease,box-shadow .3s ease;border:none;cursor:pointer;display:inline-block;box-shadow:0 2px 5px #0000001a;background-color:var(--primary-color, #007bff);color:#fff}.btn-submit:hover{background-color:var(--primary-color-dark, #0056b3);transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.success-message{background-color:#d4edda;color:#155724;padding:1rem;border:1px solid #c3e6cb;border-radius:6px;margin-bottom:1.5rem;text-align:center}@media (max-width: 768px){.contact-content-wrapper{flex-direction:column;padding:1.5rem}.contact-page-container h1{font-size:2rem}}.launcher-container{max-width:900px;margin:2rem auto;padding:0 1.5rem 2rem;font-family:var(--font-primary, "Segoe UI", Tahoma, Geneva, Verdana, sans-serif)}.launcher-header{text-align:center;margin-bottom:3rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color-light, #e0e0e0)}.launcher-header h1{font-size:2.8rem;font-weight:700;color:var(--primary-color-dark, #004a99);margin-bottom:.75rem}.launcher-header .launcher-subtitle{font-size:1.15rem;color:var(--text-color-muted, #555);line-height:1.7;max-width:700px;margin:0 auto 1.5rem}.github-profile-link{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background-color:var(--primary-color, #007bff);color:var(--light-text-color, #fff);text-decoration:none;border-radius:8px;font-weight:600;transition:background-color .3s ease,transform .2s ease}.github-profile-link:hover{background-color:var(--primary-color-dark, #0056b3);transform:translateY(-2px)}.loading-container,.error-message,.empty-state{text-align:center;padding:3rem 1rem;margin-top:2rem;background-color:var(--background-light-accent, #f8f9fa);border-radius:8px}.error-message.critical-error{background-color:#fff3cd;color:#856404;border:1px solid #ffeeba}.error-message.critical-error strong{color:#664d03}.spinner{border:6px solid var(--border-color-light, #f3f3f3);border-top:6px solid var(--primary-color, #007bff);border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p,.error-message p,.empty-state p{font-size:1.1rem;color:var(--text-color-muted, #555);line-height:1.6}.error-message p strong{color:var(--danger-color, #dc3545)}.empty-state .empty-icon{color:var(--primary-color-light, #a0cfff);margin-bottom:1rem}.empty-state h2{font-size:1.8rem;color:var(--text-color, #333);margin-bottom:.5rem}.repo-list{list-style:none;padding:0;margin:0}.repo-item{background-color:var(--card-background, #ffffff);border:1px solid var(--border-color-light, #e9ecef);border-radius:10px;padding:1.75rem;margin-bottom:1.5rem;box-shadow:0 4px 12px #0000000d;transition:transform .25s ease-out,box-shadow .25s ease-out}.repo-item:hover{transform:translateY(-4px);box-shadow:0 8px 16px #00000014}.repo-main-info{margin-bottom:1.25rem}.repo-name{font-size:1.6rem;font-weight:600;color:var(--primary-color, #007bff);text-decoration:none;display:inline-flex;align-items:center;gap:.6rem;margin-bottom:.5rem;transition:color .2s ease}.repo-name:hover{color:var(--primary-color-dark, #0056b3);text-decoration:underline}.repo-name .repo-icon{flex-shrink:0}.repo-description{font-size:1rem;color:var(--text-color-muted, #666);line-height:1.65;margin-bottom:0}.repo-meta{display:flex;flex-wrap:wrap;gap:.5rem 1.25rem;font-size:.9rem;color:var(--text-color-subtle, #777);padding-top:1.25rem;border-top:1px dashed var(--border-color-extralight, #f1f1f1)}.meta-item{display:inline-flex;align-items:center;gap:.4rem}.meta-item.language svg{color:var(--info-color, #17a2b8)}.meta-item.stars svg{color:var(--warning-color, #ffc107)}.meta-item.forks svg{color:var(--secondary-color, #6c757d)}.meta-item.updated svg{color:var(--success-color, #28a745)}.load-more-container{text-align:center;margin-top:2.5rem}.load-more-button{padding:.9rem 2rem;font-size:1.05rem;font-weight:600;color:var(--light-text-color, #fff);background-color:var(--primary-color, #007bff);border:none;border-radius:8px;cursor:pointer;transition:background-color .3s ease,transform .2s ease}.load-more-button:hover{background-color:var(--primary-color-dark, #0056b3);transform:translateY(-2px)}:root{--border-color-light: #e0e0e0;--border-color-extralight: #f1f1f1;--background-light-accent: #f8f9fa;--card-background: #ffffff;--text-color-subtle: #777;--danger-color: #dc3545;--info-color: #17a2b8;--warning-color: #ffc107;--success-color: #28a745}.language-switcher{display:flex;align-items:center;margin-left:1rem;background-color:#ffffff1a;padding:.3rem .5rem;border-radius:20px;box-shadow:0 1px 3px #0000001a}.language-switcher button{background-color:transparent;color:var(--light-text-color, #ffffff);border:none;padding:.4rem .8rem;cursor:pointer;font-size:.9rem;font-weight:600;transition:color .2s ease,background-color .2s ease;border-radius:15px}.language-switcher button:disabled{color:var(--accent-color, #ffc107);cursor:default;font-weight:700}.language-switcher button:not(:disabled):hover{color:var(--accent-color, #ffc107);background-color:#ffffff14}.lang-separator{color:#ffffff80;margin:0 .2rem;font-size:.9rem}@media (max-width: 768px){.language-switcher{margin-left:0;margin-top:.5rem}}html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}body{line-height:1.5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:#f4f7f6;color:#333;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:"";content:none}table{border-collapse:collapse;border-spacing:0}a{color:#007bff;text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;height:auto}:root{--primary-color: #007bff;--secondary-color: #6c757d;--text-color: #333;--background-color: #f4f7f6;--light-text-color: #fff}
