:root{--primary-color: #2a2a72;--secondary-color: #009ffd;--accent-color: #ff7e5f;--text-color: #333;--light-bg: #f5f5f5;--card-shadow: 0 4px 6px rgba(0, 0, 0, .1);--transition: all .3s ease}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6;color:var(--text-color);background-color:#f4f4f4;margin:0}.app{max-width:1200px;margin:0 auto;padding:2rem}h1,h2,h3{margin:0;padding:0}.projects-section,.skills-section{padding:4rem 0}.projects-section h2,.skills-section h2{text-align:center;margin-bottom:2rem;font-size:2rem;color:var(--primary-color)}.hero{min-height:40vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:2rem 0;color:#fff}.description-container{min-height:140px;margin-top:1.5rem}.hero-content h1{font-size:3rem;margin-bottom:1rem;color:var(--primary-color)}.tagline{font-size:1.5rem;margin-bottom:1.5rem;color:var(--secondary-color);min-height:1.5em}.description{max-width:600px;margin:0 auto;font-size:1.1rem;color:var(--text-color)}.github-stats.card{background:linear-gradient(135deg,#fffffffa,#fafaffe6);border-radius:12px;padding:1rem 1.25rem;margin:1.25rem auto;max-width:780px;box-shadow:0 8px 24px #14143c14;border:1px solid rgba(0,0,0,.04)}.github-stats-grid{display:grid;grid-template-columns:1fr;gap:8px 20px;align-items:center}.github-stats-grid.three-col{display:grid;grid-template-columns:180px 240px 1fr;gap:0 28px;align-items:center}.github-left{display:flex;align-items:center;padding-left:12px}.github-center,.github-right{display:flex;flex-direction:column;gap:12px}.github-center{align-items:flex-start}.github-right{align-items:flex-end}.github-in-the-last{font-size:1.25rem;font-weight:700}.github-commits-header{font-size:1.25rem;font-weight:700;text-align:center}.github-row-center,.github-row-right{padding:.85rem 1rem}.github-row-center{color:#444;font-weight:700;min-width:140px;white-space:nowrap;font-size:1rem;text-align:center;align-items:center}.github-row-right{font-size:1.25rem;color:var(--secondary-color);font-weight:800;border-radius:10px;min-width:100px;text-align:center}.github-mobile-list{display:none;width:100%}.github-mobile-row{display:flex;justify-content:space-between;gap:1rem;padding:.6rem .75rem;border-radius:10px;background:#fff9;box-shadow:inset 0 0 0 1px #0000000a}.github-mobile-label{font-weight:700;color:#444;font-size:.95rem}.github-mobile-value{font-weight:800;color:var(--secondary-color);font-size:1.1rem;text-align:right;min-width:70px}.error{color:#b00020}.cursor{display:inline-block;width:3px;height:1em;background-color:currentColor;margin-left:2px;vertical-align:text-bottom;opacity:0}.cursor.visible{opacity:1}.project-grid,.projects{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;padding:20px}.project-card,.skill-item{background:#fff;border-radius:8px;overflow:hidden;box-shadow:var(--card-shadow);transition:var(--transition)}.project-card{cursor:pointer}.project-card:hover,.skill-item:hover{transform:translateY(-5px);box-shadow:0 10px 20px #00000026}.project-image{height:200px;overflow:hidden}.project-image img,.project-card img{width:100%;height:100%;object-fit:cover}.project-info{padding:1.5rem}.project-info h3,.project-card h3{margin-bottom:.5rem;padding:10px;font-size:1.5rem}.project-card p{padding:0 10px 10px}.project-tags,.skill-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.tag{background:var(--light-bg);padding:.25rem .75rem;border-radius:50px;font-size:.8rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}@keyframes footerTransformBounce{0%{transform:translateY(30px);opacity:0}60%{transform:translateY(-7px)}80%{transform:translateY(3px)}to{transform:translateY(0);opacity:1}}.modal-content{background:#fff;padding:2rem;border-radius:8px;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;position:relative}.close-button{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer}.project-link{display:block;width:100%;margin-top:1rem;background:var(--primary-color);color:#fff;padding:.75rem 1rem;border-radius:4px;text-decoration:none;text-align:center;transition:var(--transition)}.project-link:hover{background:var(--secondary-color)}.skills-category{margin-bottom:2rem}.skills-category h3{margin-bottom:1rem;color:var(--secondary-color)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.skills{display:flex;flex-wrap:wrap;justify-content:center;padding:20px}.skill-item{padding:1rem;position:relative;display:flex;flex-direction:column}.skill-content{display:flex;justify-content:space-between;align-items:center;min-height:60px}.skill-info{flex:1}.skill-name{font-weight:700;margin-bottom:.5rem;display:block}.skill-icon-wrapper{display:flex;align-items:center;justify-content:center;height:100%;font-size:2.5rem;color:var(--primary-color);opacity:.8;margin-left:1rem}.skill-level{display:flex;gap:4px}.level-dot{width:12px;height:12px;border-radius:50%;background:var(--light-bg);display:inline-block}.level-dot.filled{background:var(--accent-color)}.project-icon,.modal-icon{display:flex;align-items:center;justify-content:center;color:var(--primary-color)}.project-icon{height:200px;background-color:var(--light-bg)}.modal-icon{margin:1rem 0}.modal-image,.embedded-image{width:100%;margin:1rem 0}.modal-image img,.embedded-image{width:100%;height:auto;border-radius:4px}.project-description{margin:1.5rem 0}.project-description h1{font-size:1.8rem;margin-bottom:1rem;color:var(--primary-color)}.project-description h2{font-size:1.4rem;margin:1.5rem 0 1rem;color:var(--secondary-color)}.project-description p{margin-bottom:1rem}.project-description ul,.project-description ol{margin-left:1.5rem;margin-bottom:1rem}.project-description strong{font-weight:600}.project-description code{background:var(--light-bg);padding:.2rem .4rem;border-radius:3px;font-family:monospace}.project-description pre{background:var(--light-bg);padding:1rem;border-radius:4px;overflow-x:auto;margin-bottom:1rem}.background-animation{position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;pointer-events:none}.sidebar{position:fixed;left:20px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;justify-content:space-between;height:300px;z-index:100;transition:all .5s cubic-bezier(.22,1,.36,1);opacity:1}.sidebar.hidden{opacity:0;pointer-events:none}.sidebar.visible{opacity:1}.sidebar-top{display:flex;flex-direction:column;gap:12px}.sidebar-link{display:flex;align-items:center;padding:10px;color:var(--primary-color);text-decoration:none;font-weight:500;background-color:#fffc;border-radius:8px;box-shadow:0 4px 12px #0000000d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:transform .3s ease,box-shadow .3s ease}.sidebar-link:hover{transform:translate(5px);box-shadow:0 6px 16px #0000001a;color:var(--secondary-color)}.sidebar-icon{margin-right:8px;font-size:18px}.sidebar-bottom{display:flex;flex-direction:column;gap:12px}.social-link{display:flex;justify-content:center;align-items:center;width:40px;height:40px;border-radius:50%;background-color:#fffc;color:var(--primary-color);box-shadow:0 4px 8px #0000000d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:transform .3s ease,color .3s ease,box-shadow .3s ease}.social-link:hover{transform:translateY(-3px) rotate(5deg);color:var(--secondary-color);box-shadow:0 6px 16px #0000001a}.sidebar.footer-mode{position:fixed;left:0;top:auto;bottom:0;transform:translateY(0);width:100%;height:auto;display:flex;flex-direction:row;justify-content:space-between;padding:16px 24px;background-color:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid rgba(0,0,0,.05);box-shadow:0 -4px 12px #0000000d;animation:footerTransformBounce .6s cubic-bezier(.2,.8,.2,1) forwards}.sidebar.footer-mode .sidebar-top,.sidebar.footer-mode .sidebar-bottom{display:flex;flex-direction:row;align-items:center;gap:12px}.sidebar.footer-mode .sidebar-link{background:none;box-shadow:none;padding:8px 12px}.sidebar.footer-mode .social-link{box-shadow:none;background:none}@media (max-width: 640px){.github-stats.card{padding:.85rem .9rem;margin:.85rem auto}.github-stats-grid.three-col{grid-template-columns:1fr;gap:.65rem}.github-left{padding-left:0;align-items:flex-start;grid-column:1}.github-in-the-last{font-size:1.05rem}.github-center,.github-right,.github-commits-header{display:none}.github-mobile-list{display:flex;flex-direction:column;gap:.5rem;grid-column:1}.github-mobile-row{padding:.55rem .65rem}.github-mobile-label{font-size:.9rem}.github-mobile-value{font-size:1rem;min-width:auto}}@media (max-width: 768px){.hero-content h1{font-size:2.5rem}.tagline{font-size:1.2rem}.project-grid,.projects{grid-template-columns:1fr}@keyframes footerBounce{0%{transform:translateY(100%)}70%{transform:translateY(-5px)}to{transform:translateY(0)}}.sidebar{left:0;top:auto;bottom:0;transform:none;flex-direction:row;width:100%;height:auto;background-color:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(0,0,0,.05);padding:12px;box-shadow:0 -2px 10px #0000000d;opacity:1;transition:transform .3s ease;animation:footerBounce .5s ease forwards}.sidebar-top{flex-direction:row}.sidebar-link{padding:8px 12px}.sidebar-bottom{flex-direction:row}.sidebar-text{display:none}.social-link{width:36px;height:36px}.sidebar.hidden{transform:translateY(110%);opacity:0;pointer-events:none}}@media (max-width: 480px){.sidebar.footer-mode{flex-direction:column;gap:16px}.sidebar.footer-mode .sidebar-text{display:none}}@media (prefers-reduced-motion: reduce){.github-row-center,.github-row-right{transition:none!important;animation:none!important}}
