:root{--bg-gradient-from: #f5f7fa;--bg-gradient-to: #e9eef8;--text-color: #333;--heading-color: #1a365d;--card-bg: white;--card-shadow: rgba(0, 0, 0, .08);--card-shadow-hover: rgba(0, 0, 0, .15);--subtitle-color: #4a5568;--desc-color: #4a5568;--primary-color: #4299e1;--primary-color-hover: #2b6cb0;--border-color: #e2e8f0;--search-bg: white;--filter-btn-bg: white;--filter-btn-border: #e2e8f0;--filter-btn-active-bg: #4299e1;--filter-btn-active-color: white;--footer-link-color: #4299e1}[data-theme=dark]{--bg-gradient-from: #1a202c;--bg-gradient-to: #2d3748;--text-color: #e2e8f0;--heading-color: #90cdf4;--card-bg: #2d3748;--card-shadow: rgba(0, 0, 0, .2);--card-shadow-hover: rgba(0, 0, 0, .35);--subtitle-color: #cbd5e0;--desc-color: #a0aec0;--primary-color: #63b3ed;--primary-color-hover: #4299e1;--border-color: #4a5568;--search-bg: #2d3748;--filter-btn-bg: #2d3748;--filter-btn-border: #4a5568;--filter-btn-active-bg: #4299e1;--filter-btn-active-color: #e2e8f0;--footer-link-color: #90cdf4}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:Inter,sans-serif;line-height:1.6;color:var(--text-color);background:linear-gradient(to bottom,var(--bg-gradient-from),var(--bg-gradient-to));min-height:100vh;transition:background .3s ease}h1,h2,h3,h4{color:var(--heading-color);margin-top:0}.projects-container{max-width:1200px;margin:0 auto;padding:2rem 1rem}.category-filters{display:flex;gap:.5rem;justify-content:center;margin-bottom:2rem;flex-wrap:wrap}.category-btn{padding:.5rem 1rem;border-radius:4px;background-color:var(--filter-btn-bg);border:1px solid var(--filter-btn-border);cursor:pointer;font-weight:500;transition:all .2s;color:var(--text-color)}.category-btn:hover{background-color:var(--filter-btn-bg);border-color:var(--primary-color)}.category-btn.active{background-color:var(--filter-btn-active-bg);color:var(--filter-btn-active-color);border-color:var(--primary-color-hover)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;margin-bottom:3rem}.project-card{background:var(--card-bg);border-radius:10px;box-shadow:0 4px 20px var(--card-shadow);transition:transform .3s,box-shadow .3s;overflow:hidden;height:100%;display:flex;flex-direction:column;cursor:pointer}.project-icon{font-size:3.5rem;color:var(--primary-color);transition:transform .2s}.project-description{margin-bottom:1rem;color:var(--desc-color);text-align:center}.project-link{display:block;text-align:center;color:var(--text-color);text-decoration:none;font-weight:500;transition:color .2s}.project-link:hover{color:var(--primary-color);text-decoration:underline}.project-category{margin-bottom:3rem}.category-title{font-size:1.8rem;margin-bottom:1.5rem;border-bottom:2px solid var(--primary-color);padding-bottom:.5rem;display:inline-block;color:var(--heading-color)}.compact-view .projects-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem}.compact-view .projects-container{max-width:none}.compact-view .project-category{display:none}.compact-view .all-projects{display:block}.compact-view .project-card{padding:1rem;min-height:auto}.compact-view .project-icon{font-size:2.5rem;margin-bottom:.5rem}.compact-view .project-title{font-size:1.1rem;margin-bottom:.5rem}.compact-view .project-description{font-size:.9rem;margin-bottom:.5rem}.compact-view .project-link{font-size:.9rem}.utility-controls{position:absolute;top:1rem;right:1rem;display:flex;gap:1rem;z-index:100;align-items:center}.language-btn{padding:.4rem .8rem;border-radius:4px;background-color:var(--filter-btn-bg);border:1px solid var(--filter-btn-border);cursor:pointer;font-weight:500;transition:all .2s;color:var(--text-color)}.language-btn:hover{background-color:var(--filter-btn-bg);border-color:var(--primary-color)}.language-btn.active{background-color:var(--filter-btn-active-bg);color:var(--filter-btn-active-color);border-color:var(--primary-color-hover)}.theme-toggle,.compact-view-btn{background-color:transparent;border:none;cursor:pointer;font-size:1.2rem;color:var(--text-color);padding:.4rem;display:flex;align-items:center;justify-content:center}.header{text-align:center;margin-bottom:3rem;padding-top:4rem}.subtitle{color:var(--desc-color);font-size:1.25rem;margin-bottom:2rem}.search-container{margin-bottom:2rem;position:relative;max-width:500px;margin:0 auto 2rem}.footer{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border-color);text-align:center;color:var(--desc-color);font-size:.9rem}.footer-links{margin-top:1rem}.footer-links a{color:var(--footer-link-color);text-decoration:none;padding:.25rem .5rem;transition:all .2s;font-weight:500}.footer-links a:hover{color:var(--primary-color-hover);text-decoration:underline}@media (max-width: 768px){.projects-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.title{font-size:2rem}.utility-controls{position:relative;top:0;right:0;justify-content:center;margin-bottom:1.5rem;padding-top:1rem}.header{padding-top:0}}:root{--bg-gradient-from: #f5f7fa;--bg-gradient-to: #e9eef8;--text-color: #333;--heading-color: #1a365d;--card-bg: white;--card-shadow: rgba(0, 0, 0, .08);--card-shadow-hover: rgba(0, 0, 0, .15);--subtitle-color: #4a5568;--desc-color: #4a5568;--primary-color: #4299e1;--primary-color-hover: #2b6cb0;--border-color: #e2e8f0;--search-bg: white;--filter-btn-bg: white;--filter-btn-border: #e2e8f0;--filter-btn-active-bg: #4299e1;--filter-btn-active-color: white;--footer-link-color: #4299e1;--border-radius: 8px;--box-shadow: 0 4px 20px var(--card-shadow);--padding: 1rem}[data-theme=dark]{--bg-gradient-from: #1a202c;--bg-gradient-to: #2d3748;--text-color: #e2e8f0;--heading-color: #90cdf4;--card-bg: #2d3748;--card-shadow: rgba(0, 0, 0, .2);--card-shadow-hover: rgba(0, 0, 0, .35);--subtitle-color: #cbd5e0;--desc-color: #a0aec0;--primary-color: #63b3ed;--primary-color-hover: #4299e1;--border-color: #4a5568;--search-bg: #2d3748;--filter-btn-bg: #2d3748;--filter-btn-border: #4a5568;--filter-btn-active-bg: #4299e1;--filter-btn-active-color: #e2e8f0;--footer-link-color: #90cdf4;--box-shadow: 0 4px 20px var(--card-shadow)}body{margin:0;padding:0;font-family:Inter,sans-serif;background:linear-gradient(to bottom,var(--bg-gradient-from),var(--bg-gradient-to));color:var(--text-color);line-height:1.6;min-height:100vh;transition:background .3s ease}.container{max-width:1200px;margin:0 auto;padding:.5rem var(--padding) var(--padding)}.header{text-align:center;margin-bottom:0}.title{font-size:2.5rem;margin-bottom:.5rem;background:linear-gradient(45deg,var(--heading-color),var(--primary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{color:var(--subtitle-color);margin-top:0;font-size:1.2rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem}.project-card{background:var(--card-bg);border-radius:10px;box-shadow:0 4px 20px var(--card-shadow);overflow:hidden;transition:transform .3s,box-shadow .3s;height:100%;display:flex;flex-direction:column;cursor:pointer}.project-card:hover{transform:translateY(-5px);box-shadow:0 10px 25px var(--card-shadow-hover)}.card-content{padding:1.5rem;flex-grow:1;display:flex;flex-direction:column}.project-icon-wrapper{text-align:center;margin-bottom:1rem}.project-icon{font-size:3.5rem;color:var(--primary-color);margin-bottom:1rem;transition:transform .2s}.project-card:hover .project-icon{transform:scale(1.1)}.project-title{font-size:1.25rem;margin-bottom:.75rem;text-align:center;color:var(--heading-color)}.project-description{margin-bottom:0;color:var(--desc-color);text-align:center;flex-grow:1}.clickable-link{color:inherit;text-decoration:none;display:block}.clickable-link:hover{color:var(--primary-color)}.filters-container{display:flex;justify-content:center;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}.filter-btn{padding:.4rem 1rem;border-radius:20px;border:1px solid var(--filter-btn-border);background:var(--filter-btn-bg);color:var(--text-color);cursor:pointer;font-weight:500;transition:all .2s}.filter-btn:hover{border-color:var(--primary-color)}.filter-btn.active{background:var(--filter-btn-active-bg);color:var(--filter-btn-active-color);border-color:var(--primary-color-hover)}.search-container{margin-bottom:2rem;position:relative;max-width:500px;margin:0 auto 1rem}.search-input{width:100%;padding:.8rem 1rem .8rem 2.5rem;border-radius:8px;border:1px solid var(--border-color);background:var(--search-bg);color:var(--text-color);font-family:inherit;font-size:1rem}.search-icon{position:absolute;left:.8rem;top:50%;transform:translateY(-50%);color:var(--desc-color)}.utility-controls{display:flex;justify-content:flex-end;gap:1rem;margin-bottom:1rem}.theme-toggle{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--text-color)}.language-switcher{display:flex;gap:.5rem}.language-btn{padding:.25rem .5rem;border-radius:4px;border:1px solid #ddd;background:none;cursor:pointer}.language-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.footer{text-align:center;margin-top:3rem;padding-top:1rem;border-top:1px solid #ddd;color:var(--text-color)}.footer-links{margin-top:.5rem}.footer-links a{color:var(--primary-color);margin:0 .5rem;text-decoration:none}.footer-links a:hover{text-decoration:underline}.fas{font-family:"Font Awesome 6 Free";font-weight:900}body.compact-view-body{padding:1rem;margin:0;width:100%;box-sizing:border-box}body.compact-view-body .container{max-width:none;width:100%;padding:0}body.compact-view-body .project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem;width:100%;max-width:none;margin:0;padding:0}body.compact-view-body .project-card{margin-bottom:0;min-height:220px;box-sizing:border-box}body.compact-view-body .project-title{font-size:1.15rem;margin:.5rem 0;line-height:1.3}body.compact-view-body .project-description{font-size:.95rem;margin:.5rem 0;line-height:1.4}.compact-view .project-icon{font-size:2.5rem}.compact-view .project-title{font-size:1.1rem}.compact-view .project-description{font-size:.9rem}.compact-view-btn{background-color:transparent;border:none;cursor:pointer;font-size:1.2rem;color:var(--text-color);padding:.4rem;display:flex;align-items:center;justify-content:center}.container{max-width:1280px;margin:0 auto;padding:2rem;color:var(--text-color)}.header{margin-bottom:2rem}.title{color:var(--heading-color);font-size:2.5rem;margin-bottom:.5rem}.subtitle{color:var(--subtitle-color);font-size:1.25rem;margin-bottom:2rem}.project-card{background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:.5rem;padding:1.5rem;transition:transform .2s}.project-card:hover{transform:translateY(-2px)}.project-card .description{color:var(--desc-color)}.filters-container{display:flex;gap:.5rem;margin:1rem 0;flex-wrap:wrap}.filter-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-color);padding:.5rem 1rem;border-radius:20px;cursor:pointer}.filter-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:var(--filter-btn-active-color)}.footer{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border-color)}.footer-links a{color:var(--footer-link-color);margin:0 .5rem}.unlock-notice-container{display:flex;justify-content:center;margin-bottom:1rem}.unlock-notice{display:inline-flex;align-items:center;justify-content:center;gap:1rem;background-color:var(--primary-color);color:#fff;border-radius:20px;padding:.5rem 1rem;margin:.75rem 0 1.25rem;box-shadow:0 2px 8px #00000026;animation:slideIn .3s cubic-bezier(.16,1,.3,1);font-size:.95rem;font-weight:500;line-height:1.5;max-width:fit-content}.unlock-notice span{display:flex;align-items:center}.unlock-notice span:before{content:"🔓";font-size:1.1rem;margin-right:.5rem}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.unlock-notice button{padding:.25rem .75rem;border-radius:4px;border:1px solid white;background:#fff3;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease-out;color:#fff}.unlock-notice button:hover{background:#ffffff4d;transform:translateY(-1px)}.unlock-notice button:active{transform:translateY(0)}@media (max-width: 768px){.unlock-notice{flex-direction:column;text-align:center;gap:.8rem}.unlock-notice span:before{margin-bottom:.5rem}}
