.navbar{position:sticky;top:0;z-index:100;padding:1rem 0;background:transparent;border:none;transition:all .8s cubic-bezier(.25,.46,.45,.94);pointer-events:auto;box-shadow:none;border-bottom:none}.navbar.idle{opacity:.15;transform:scale(1);pointer-events:auto}.navbar.browsing{opacity:.4;transform:scale(1);pointer-events:auto}.navbar.seeking{opacity:.7;transform:scale(1);pointer-events:auto;background:linear-gradient(to bottom,rgba(var(--bg-color-rgb, 255, 255, 255),.05) 0%,rgba(var(--bg-color-rgb, 255, 255, 255),0) 100%)}.app.dark .navbar.seeking{background:linear-gradient(to bottom,rgba(var(--bg-color-rgb, 15, 23, 42),.05) 0%,rgba(var(--bg-color-rgb, 15, 23, 42),0) 100%)}.navbar.interacting{opacity:.95;transform:scale(1);pointer-events:auto;background:rgba(var(--bg-color-rgb, 255, 255, 255),.8);box-shadow:none}.navbar.seeking:after{content:"";position:absolute;bottom:-1px;left:50%;transform:translate(-50%);width:60px;height:2px;background:var(--primary-color);border-radius:1px;opacity:.6;animation:breathe 3s ease-in-out infinite}@keyframes breathe{0%,to{width:60px;opacity:.3}50%{width:120px;opacity:.8}}.navbar-container{max-width:1600px;margin:0 auto;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:center;position:relative}.navbar-logo{position:absolute;left:1.5rem;z-index:2}.navbar-menu{flex:1;display:flex;justify-content:center;gap:2rem;align-items:center}.navbar-controls{position:absolute;right:1.5rem;z-index:2;display:flex;align-items:center;gap:1rem}.navbar-logo{font-size:1.8rem;font-weight:700;color:var(--primary-color);text-decoration:none;transition:all .3s ease}@media (min-width: 1440px){.navbar-container{max-width:1800px;padding:0 1rem}.navbar-logo{left:1rem}.navbar-controls{right:1rem}}@media (min-width: 1920px){.navbar-container{max-width:2000px;padding:0 1.5rem}.navbar-logo{left:1.5rem}.navbar-controls{right:1.5rem}}@media (min-width: 2560px){.navbar-container{max-width:2200px;padding:0 2rem}.navbar-logo{left:2rem}.navbar-controls{right:2rem}}.navbar-link{color:var(--text-color);text-decoration:none;font-weight:500;padding:.75rem 1.5rem;border-radius:25px;transition:all .3s ease;position:relative}.nav-text{transition:all .3s ease}.navbar-link:hover{color:var(--primary-color)}.navbar-link.active{color:var(--primary-color);font-weight:600}.navbar-link.active:after{content:"";position:absolute;bottom:-2px;left:50%;transform:translate(-50%);width:20px;height:2px;background:var(--primary-color);border-radius:1px;transition:all .3s ease}.theme-toggle,.mobile-menu-toggle{background:none;border:none;font-size:1.2rem;color:var(--text-color);cursor:pointer;padding:.75rem;border-radius:50%;transition:all .3s ease;display:flex;align-items:center;justify-content:center;width:44px;height:44px;min-width:44px;min-height:44px}.theme-toggle:hover,.mobile-menu-toggle:hover{background:rgba(37,99,235,.1);color:var(--primary-color)}.mobile-menu-toggle{display:none}.mobile-menu{position:absolute;top:100%;left:0;right:0;background:var(--bg-color);box-shadow:0 1px #0000000d;overflow:hidden;transition:all .5s cubic-bezier(.25,.46,.45,.94)}.app.dark .mobile-menu{box-shadow:0 1px #ffffff0d}.mobile-menu.idle{opacity:.1;transform:translateY(-10px)}.mobile-menu.browsing{opacity:.3;transform:translateY(0)}.mobile-menu.seeking{opacity:.6;transform:translateY(0);box-shadow:0 2px 10px #0000001a}.mobile-menu.interacting{opacity:1;transform:translateY(0);box-shadow:0 4px 20px #00000026}.mobile-menu-link{display:block;padding:1.25rem 2rem;color:var(--text-color);text-decoration:none;font-weight:500;transition:all .3s ease;border-bottom:1px solid var(--border-color);min-height:60px;font-size:1.1rem}.mobile-menu-link:last-child{border-bottom:none}.mobile-menu-link:hover{background:rgba(37,99,235,.1);color:var(--primary-color);padding-left:2.5rem}@media (max-width: 768px){.navbar-menu{display:none}.mobile-menu-toggle{display:flex}.navbar-container{padding:0 1rem}.navbar-logo{font-size:1.5rem}}@media (max-width: 480px){.navbar-container{padding:0 1rem}.theme-toggle,.mobile-menu-toggle{width:35px;height:35px;font-size:1rem}}html{scroll-behavior:smooth}@media (max-width: 768px) and (orientation: landscape){.navbar{padding:.75rem 0}.navbar-logo{font-size:1.4rem}.theme-toggle,.mobile-menu-toggle{width:40px;height:40px;min-width:40px;min-height:40px}}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;padding:2rem}.hero-container{max-width:1600px;width:100%;text-align:center;margin:0 auto;padding:0 1.5rem}@media (min-width: 1440px){.hero-container{max-width:1800px;padding:0 1rem}}@media (min-width: 1920px){.hero-container{max-width:2000px;padding:0 1.5rem}}@media (min-width: 2560px){.hero-container{max-width:2200px;padding:0 2rem}}.hero-content{z-index:2;position:relative}.hero-avatar{position:relative;display:inline-block;margin-bottom:2rem}.avatar-img{width:150px;height:150px;border-radius:50%;border:4px solid var(--primary-color);box-shadow:0 0 30px #2563eb4d;transition:transform .3s ease}.avatar-img:hover{transform:scale(1.1)}.avatar-glow{position:absolute;top:-10px;left:-10px;right:-10px;bottom:-10px;background:linear-gradient(45deg,var(--primary-color),var(--accent-color));border-radius:50%;opacity:.3;filter:blur(20px);animation:pulse 2s ease-in-out infinite;z-index:-1}.hero-title{font-size:clamp(2rem,8vw,4rem);font-weight:700;margin-bottom:1rem;line-height:1.2}.highlight{background:linear-gradient(135deg,var(--primary-color),var(--accent-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative}.hero-subtitle{font-size:clamp(1.2rem,4vw,1.8rem);color:var(--text-light);margin-bottom:1.5rem;font-weight:500;min-height:2em;display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap}.typing-text{background:linear-gradient(90deg,var(--primary-color),var(--accent-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative}.separator{color:var(--text-light);opacity:.6}.hero-description{font-size:clamp(1rem,3vw,1.2rem);color:var(--text-light);margin-bottom:2rem;max-width:600px;margin-left:auto;margin-right:auto;line-height:1.8}.hero-achievements{display:flex;gap:1.5rem;justify-content:center;margin-bottom:2.5rem;flex-wrap:wrap}.achievement-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);padding:.75rem 1.25rem;border-radius:25px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.achievement-badge:hover{background:rgba(255,255,255,.15);border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 5px 15px #2563eb4d}.achievement-icon{color:#fbbf24;font-size:1rem}.achievement-text{color:var(--text-color);font-weight:600;font-size:.95rem}.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;border-radius:50px;text-decoration:none;font-weight:600;font-size:1rem;transition:all .3s ease;border:none;cursor:pointer;position:relative;overflow:hidden}.btn-primary{background:linear-gradient(135deg,var(--primary-color),var(--accent-color));color:#fff;box-shadow:0 4px 15px #2563eb4d}.btn-primary:hover{box-shadow:0 6px 20px #2563eb66;transform:translateY(-2px)}.btn-secondary{background:rgba(255,255,255,.1);color:var(--text-color);border:2px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-secondary:hover{background:rgba(255,255,255,.2);border-color:var(--primary-color);transform:translateY(-2px)}.scroll-indicator{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);font-size:2rem;color:var(--text-light);animation:bounce 2s ease-in-out infinite;cursor:pointer}.scroll-indicator:hover{color:var(--primary-color)}@keyframes bounce{0%,20%,50%,80%,to{transform:translate(-50%) translateY(0)}40%{transform:translate(-50%) translateY(-10px)}60%{transform:translate(-50%) translateY(-5px)}}.hero-about{margin:3rem 0;padding:2rem;background:rgba(255,255,255,.05);border-radius:var(--border-radius);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.about-stats{display:flex;justify-content:center;gap:2rem;margin-bottom:2rem;flex-wrap:wrap}.stat-item{text-align:center;padding:1rem;border-radius:var(--border-radius);background:rgba(37,99,235,.1);border:1px solid rgba(37,99,235,.2);min-width:120px;transition:all .3s ease}.stat-number{font-size:2rem;font-weight:700;color:var(--primary-color);margin-bottom:.5rem}.stat-label{font-size:.9rem;color:var(--text-light);font-weight:500}.about-text{font-size:1.1rem;color:var(--text-light);line-height:1.8;max-width:800px;margin:0 auto;text-align:center}.hero-contact{margin:2rem 0}.contact-links{display:flex;justify-content:center;gap:2rem;margin-bottom:2rem;flex-wrap:wrap}.contact-link{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:rgba(255,255,255,.05);border-radius:var(--border-radius);text-decoration:none;color:var(--text-color);border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;min-width:250px}.contact-link:hover{background:rgba(37,99,235,.1);border-color:var(--primary-color);transform:translateY(-5px);box-shadow:0 10px 25px #2563eb33}.contact-icon{font-size:1.5rem;color:var(--primary-color);display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:rgba(37,99,235,.1);border-radius:50%}.contact-info{flex:1}.contact-label{font-size:1rem;font-weight:600;color:var(--text-color);margin-bottom:.25rem}.contact-description{font-size:.9rem;color:var(--text-light)}.contact-text{font-size:1rem;color:var(--text-light);font-style:italic;text-align:center}.btn-github{background:#24292e;color:#fff;border:1px solid #333}.btn-github:hover{background:#333;transform:translateY(-2px);box-shadow:0 4px 15px #0003}.app.dark .btn-github{background:#2f363d;border-color:#444}.app.dark .btn-github:hover{background:#3c434a}.btn-contact{background:rgba(255,255,255,.1);color:var(--text-color);border:2px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-contact:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 15px #2563eb4d}@media (max-width: 768px){.hero{padding-top:5rem}.hero-buttons{flex-direction:column;align-items:center}.btn{width:200px;justify-content:center}.about-stats{flex-direction:column;align-items:center;gap:1rem}.stat-item{min-width:200px}.contact-links{flex-direction:column;align-items:center}.contact-link{min-width:280px}.hero-about{margin:2rem 0;padding:1.5rem}}.projects{min-height:100vh;padding:6rem 2rem 4rem;background:var(--bg-light)}.projects-intro{text-align:center;max-width:900px;margin:0 auto 3rem;font-size:1.1rem;color:var(--text-light);line-height:1.8;padding:0 1rem}.projects-intro strong{color:var(--primary-color);font-weight:700}.projects-controls{max-width:1600px;margin:0 auto 2rem;display:flex;gap:1rem;align-items:center;flex-wrap:wrap;padding:0 1rem}@media (min-width: 1440px){.projects-controls{max-width:1800px}}@media (min-width: 1920px){.projects-controls{max-width:2000px}}@media (min-width: 2560px){.projects-controls{max-width:2200px}}.search-box{position:relative;flex:1;min-width:250px;max-width:400px}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-light);font-size:1rem}.search-input{width:100%;padding:.75rem 1rem .75rem 2.5rem;border:2px solid var(--border-color);border-radius:25px;background:var(--bg-color);color:var(--text-color);font-size:.9rem;transition:all .3s ease}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.filter-controls{display:flex;gap:1rem;align-items:center}.filter-group,.sort-group{display:flex;align-items:center;gap:.5rem}.filter-icon{color:var(--text-light);font-size:.9rem}.filter-select,.sort-select{padding:.5rem 2rem .5rem 1rem;border:2px solid var(--border-color);border-radius:20px;background:var(--bg-color);color:var(--text-color);font-size:.9rem;cursor:pointer;transition:all .3s ease}.filter-select:focus,.sort-select:focus{outline:none;border-color:var(--primary-color)}.category-stats{max-width:1600px;margin:0 auto 2rem;display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap;padding:0 1rem}@media (min-width: 1440px){.category-stats{max-width:1800px}}@media (min-width: 1920px){.category-stats{max-width:2000px}}@media (min-width: 2560px){.category-stats{max-width:2200px}}.category-chip{padding:.5rem 1rem;background:var(--bg-color);color:var(--text-light);border:1px solid var(--border-color);border-radius:20px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease}.category-chip:hover{background:rgba(37,99,235,.1);border-color:var(--primary-color);color:var(--primary-color)}.category-chip.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.projects-grid{max-width:1600px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;padding:0 1rem}@media (min-width: 1440px){.projects-grid{max-width:1800px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2.5rem}}@media (min-width: 1920px){.projects-grid{max-width:2000px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:3rem}}@media (min-width: 2560px){.projects-grid{max-width:2200px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:3.5rem}}.project-card{background:linear-gradient(145deg,var(--bg-color) 0%,rgba(var(--bg-color-rgb, 255, 255, 255),.8) 100%);border-radius:20px;padding:2rem;box-shadow:0 8px 32px #1f268726,0 2px 8px #00000014,inset 0 1px #ffffff1a;border:1px solid rgba(255,255,255,.1);cursor:pointer;position:relative;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;flex-direction:column;height:100%}.project-card:hover{box-shadow:0 20px 60px #1f268740,0 8px 16px #0000001f,inset 0 1px #fff3;border:1px solid rgba(37,99,235,.3);transform:translateY(-8px) scale(1.02);background:linear-gradient(145deg,var(--bg-color) 0%,rgba(var(--bg-color-rgb, 255, 255, 255),.95) 100%)}.project-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.project-title-group{flex:1;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.project-title{font-size:1.3rem;font-weight:700;color:var(--text-color);margin:0;line-height:1.4}.archive-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:rgba(108,117,125,.1);color:#6c757d;border-radius:12px;font-size:.75rem;font-weight:500;border:1px solid rgba(108,117,125,.2)}.project-links{display:flex;gap:.5rem;align-items:center}.project-link{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1.2rem;min-height:40px;color:var(--primary-color);font-size:.9rem;font-weight:500;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:12px;background:linear-gradient(135deg,rgba(37,99,235,.1) 0%,rgba(37,99,235,.05) 100%);border:1px solid rgba(37,99,235,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.project-link.github-link{color:var(--text-color);background:rgba(36,41,46,.1);border:1px solid rgba(36,41,46,.2)}.project-link.github-link:hover{background:#24292e;color:#fff;border-color:#24292e}.project-link.homepage-link{color:var(--accent-color);background:rgba(139,92,246,.1);border:1px solid rgba(139,92,246,.2)}.project-link.homepage-link:hover{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.pypi-logo{transition:transform .3s ease}.project-link.homepage-link.pypi-link:hover .pypi-logo{transform:scale(1.1)}.project-link:hover{color:#fff;background:linear-gradient(135deg,var(--primary-color) 0%,rgba(37,99,235,.8) 100%);border-color:var(--primary-color);transform:translateY(-2px) scale(1.05);box-shadow:0 8px 25px #2563eb4d}.project-description{color:var(--text-light);margin-bottom:1.5rem;line-height:1.6;font-size:.95rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;min-height:4.5rem}.project-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.project-stats{display:flex;gap:1rem}.stat{display:flex;align-items:center;gap:.25rem;font-size:.85rem;color:var(--text-light);font-weight:500}.star-icon{color:#f1c40f}.project-language{padding:.25rem .75rem;background:rgba(37,99,235,.1);color:var(--primary-color);border-radius:15px;font-size:.8rem;font-weight:500}.version-info{display:flex;align-items:center;gap:.25rem;font-size:.8rem;color:var(--text-light);font-weight:500;padding:.25rem .75rem;background:rgba(46,204,113,.1);border-radius:15px;border:1px solid rgba(46,204,113,.2)}.version-icon{color:#2ecc71;font-size:.75rem}.project-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.category-tag{background:var(--primary-color);color:#fff;padding:6px 12px;border-radius:18px;font-size:.8rem;font-weight:600;letter-spacing:.025em}.tech-tag{background:var(--bg-light);color:var(--text-color);padding:6px 12px;border-radius:18px;font-size:.8rem;font-weight:500;border:1px solid var(--border-color);letter-spacing:.025em;transition:all .2s ease}.tech-tag:hover{background:var(--accent-color);color:#fff;border-color:var(--accent-color);transform:translateY(-1px)}.project-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:1rem;border-top:1px solid var(--border-color)}.update-time{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-light)}.project-view-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--primary-color);text-decoration:none;font-weight:600;font-size:.9rem;transition:all .3s ease;padding:.5rem 1rem;border-radius:20px;background:rgba(37,99,235,.1)}.project-view-link:hover{background:var(--primary-color);color:#fff;gap:.75rem}.project-actions{display:flex;gap:.75rem;align-items:center}.project-view-link.github-link{background:rgba(24,24,27,.1);color:var(--text-color);border:1px solid var(--border-color)}.project-view-link.github-link:hover{background:#24292e;color:#fff;border-color:#24292e}.project-detail-btn{display:inline-flex;align-items:center;gap:.5rem;color:var(--primary-color);background:rgba(37,99,235,.1);border:1px solid rgba(37,99,235,.2);text-decoration:none;font-weight:600;font-size:.9rem;transition:all .3s ease;padding:.5rem 1rem;border-radius:20px;cursor:pointer}.project-detail-btn:hover{background:linear-gradient(135deg,var(--primary-color) 0%,rgba(37,99,235,.9) 100%);border-color:var(--primary-color);color:#fff;transform:translateY(-2px) scale(1.05);box-shadow:0 8px 25px #2563eb40}.project-card.clickable{-webkit-user-select:none;-moz-user-select:none;user-select:none}.project-card.clickable:hover{box-shadow:0 20px 40px -10px #2563eb4d;border-color:var(--primary-color)}.project-card.clickable:active{transform:translateY(-2px);box-shadow:0 10px 25px -5px #2563eb33}.loading-container,.error-container,.no-results{text-align:center;padding:4rem 2rem}.loading-spinner{font-size:3rem;color:var(--primary-color);margin-bottom:1rem}.spinner{animation:spin 1s linear infinite}.error-container{color:#dc3545}.error-icon{font-size:3rem;margin-bottom:1rem}.no-results{color:var(--text-light)}.no-results-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.data-footer{text-align:center;margin-top:4rem;padding-top:2rem;border-top:1px solid var(--border-color)}.data-footer p{color:var(--text-light);font-size:.9rem;font-style:italic}@media (max-width: 1024px){.projects-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}}@media (max-width: 768px){.projects{padding-top:5rem}.projects-controls{flex-direction:column;align-items:stretch;gap:1rem}.search-box{max-width:100%}.filter-controls{justify-content:center;flex-wrap:wrap}.projects-grid{grid-template-columns:1fr;gap:1.5rem}.project-card{padding:1.5rem}.project-title-group{flex-direction:column;align-items:flex-start;gap:.5rem}.project-footer{flex-direction:column;align-items:flex-start;gap:1rem}.project-view-link{align-self:flex-end}}@media (max-width: 480px){.projects{padding:2rem 1rem}.project-card{padding:1rem}.category-stats{gap:.5rem}.category-chip{font-size:.8rem;padding:.4rem .8rem}}.app.dark .project-card{background:linear-gradient(145deg,var(--bg-color) 0%,rgba(var(--bg-color-rgb, 0, 0, 0),.6) 100%);border:1px solid rgba(255,255,255,.05)}.app.dark .project-card:hover{background:linear-gradient(145deg,var(--bg-color) 0%,rgba(var(--bg-color-rgb, 0, 0, 0),.8) 100%);border:1px solid rgba(37,99,235,.3)}.app.dark .project-link{background:linear-gradient(135deg,rgba(37,99,235,.15) 0%,rgba(37,99,235,.08) 100%);border:1px solid rgba(37,99,235,.3)}.app.dark .project-detail-btn{background:linear-gradient(135deg,rgba(37,99,235,.12) 0%,rgba(37,99,235,.06) 100%);border:1px solid rgba(37,99,235,.25)}.app.dark .category-chip:hover{background:rgba(139,92,246,.1);border-color:var(--accent-color);color:var(--accent-color)}.app.dark .category-chip.active{background:var(--accent-color);border-color:var(--accent-color)}.app.dark .tech-tag{background:rgba(255,255,255,.05);border-color:#ffffff1a}.app.dark .project-view-link{background:rgba(139,92,246,.1)}.app.dark .project-view-link:hover{background:var(--accent-color)}.project-tags .category-badge{font-size:.75rem;font-weight:600}.project-tags .tech-badge{font-size:.7rem;opacity:.9}.project-tags .tech-badge:hover{opacity:1;transform:translateY(-1px);transition:all .2s ease}.app.dark .project-tags .tech-badge{opacity:.85}.app.dark .project-tags .tech-badge:hover{opacity:1}.retry-btn{margin-top:1rem}.category-chip{font-size:.9rem;font-weight:500}.category-chip.active{background:var(--primary-color)!important;color:#fff!important}.project-detail-btn{font-size:.9rem;font-weight:500;padding:.6rem 1.2rem;min-height:40px;border-radius:12px;background:linear-gradient(135deg,rgba(37,99,235,.08) 0%,rgba(37,99,235,.03) 100%);border:1px solid rgba(37,99,235,.15);color:var(--primary-color);transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;outline:none}.modal-content{background:var(--card-bg);border-radius:24px;box-shadow:0 40px 80px -16px #0006,0 0 0 1px #ffffff0d inset;max-width:580px;width:100%;max-height:85vh;overflow-y:auto;position:relative;border:none;transform:translateZ(0)}.modal-content::-webkit-scrollbar{width:4px}.modal-content::-webkit-scrollbar-track{background:transparent}.modal-content::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}.modal-content::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.2)}.modal-card{padding:2rem}.card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.06)}.header-left{flex:1;display:flex;flex-direction:column;gap:.75rem}.header-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.github-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.06);color:var(--text-primary);text-decoration:none;transition:all .2s ease;border:1px solid rgba(255,255,255,.1)}.github-btn:hover{background:rgba(255,255,255,.1);border-color:#fff3;color:var(--text-primary)}.card-title{font-size:1.8rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.2;display:flex;flex-direction:column;gap:.5rem}.card-language{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.9rem;font-weight:500}.language-icon{font-size:1rem;color:var(--primary-color)}.archive-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(251,191,36,.1);color:#fbbf24;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600;align-self:flex-start}.card-close-btn{background:none;border:none;color:var(--text-secondary);font-size:1.2rem;cursor:pointer;padding:10px;border-radius:50%;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;flex-shrink:0;width:40px;height:40px}.card-close-btn:hover{background:rgba(255,255,255,.08);color:var(--text-primary);transform:scale(1.1) rotate(90deg)}.card-description{margin-bottom:1.5rem}.card-description p{font-size:1rem;line-height:1.6;color:var(--text-secondary);margin:0}.card-metrics{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.06)}.metrics-list{display:flex;align-items:center;gap:2rem;flex-wrap:wrap}.metric-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.metric-icon{color:var(--text-secondary);font-size:1rem}.metric-icon.star{color:#fbbf24}.metric-icon.fork{color:#60a5fa}.metric-value{font-weight:700;color:var(--text-primary);font-size:1rem}.metric-label{color:var(--text-secondary);font-size:.9rem}.metric-item.category .metric-label{color:var(--primary-color);font-weight:600}.card-technologies{margin-bottom:2rem}.tech-label{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.tech-list{display:flex;flex-wrap:wrap;gap:.5rem}.tech-badge{font-size:.8rem;font-weight:500}.card-demo-link{margin-top:1.5rem;text-align:center}.demo-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:12px;text-decoration:none;font-weight:500;font-size:.9rem;transition:all .2s ease;background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:#fff;border:none;min-height:36px}.demo-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px -6px #6366f180}.demo-btn .pypi-logo{transition:transform .3s ease}.demo-btn:hover .pypi-logo{transform:scale(1.1)}@media (max-width: 768px){.modal-backdrop{padding:16px}.modal-card{padding:1.5rem}.card-title{font-size:1.5rem}.card-header{flex-direction:column;gap:1rem;align-items:flex-start}.header-actions{align-self:flex-end;margin-top:.5rem}.metrics-list{gap:1rem}}.app.dark .modal-content{background:var(--card-bg-dark)}.app.dark .card-header,.app.dark .card-metrics{border-color:#ffffff08}.app.dark .action-btn.secondary{background:rgba(255,255,255,.04);border-color:#ffffff14}.app.dark .action-btn.secondary:hover{background:rgba(255,255,255,.08);border-color:#ffffff26}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:modalSlideIn .3s ease-out}.modal-backdrop{animation:backdropFadeIn .2s ease-out}:root{--card-bg: rgba(255, 255, 255, .95);--card-bg-dark: rgba(17, 24, 39, .95);--text-primary: #1f2937;--text-secondary: #6b7280;--primary-color: #6366f1;--primary-dark: #4f46e5;--border-color: rgba(229, 231, 235, .5)}.app.dark{--text-primary: #f9fafb;--text-secondary: #d1d5db;--border-color: rgba(75, 85, 99, .3)}.modal-content{background:rgba(255,255,255,.95);background:var(--card-bg, rgba(255, 255, 255, .95))}.card-title{color:#1f2937;color:var(--text-primary, #1f2937)}.card-description p,.card-language,.metric-label{color:#6b7280;color:var(--text-secondary, #6b7280)}.tech-label{color:#1f2937;color:var(--text-primary, #1f2937)}.blog{min-height:100vh;padding:6rem 2rem 4rem;background:var(--bg-light)}.blog-intro{text-align:center;max-width:900px;margin:0 auto 3rem;font-size:1.1rem;color:var(--text-light);line-height:1.8;padding:0 1rem}.blog-grid{max-width:1600px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;padding:0 1rem}@media (min-width: 1440px){.blog-grid{max-width:1800px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2.5rem}}@media (min-width: 1920px){.blog-grid{max-width:2000px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:3rem}}@media (min-width: 2560px){.blog-grid{max-width:2200px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:3.5rem}}.blog-card-link{text-decoration:none;color:inherit;display:block}.blog-card{background:var(--bg-color);border-radius:var(--border-radius);padding:2rem;box-shadow:var(--shadow);border:1px solid var(--border-color);cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;height:100%}.blog-card-link:hover .blog-card{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--primary-color)}.blog-header{margin-bottom:1.5rem}.blog-meta{display:flex;gap:1rem;font-size:.9rem;color:var(--text-light);margin-bottom:1rem}.blog-date,.blog-read-time{display:flex;align-items:center;gap:.5rem}.blog-title{font-size:1.3rem;font-weight:700;color:var(--text-color);margin-bottom:1rem;line-height:1.4}.blog-excerpt{color:var(--text-light);margin-bottom:1.5rem;line-height:1.6}.blog-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.blog-tag{display:flex;align-items:center;gap:.3rem;padding:.3rem .8rem;background:rgba(37,99,235,.1);color:var(--primary-color);border-radius:15px;font-size:.85rem;font-weight:500;border:1px solid rgba(37,99,235,.2)}.blog-link{display:inline-flex;align-items:center;color:var(--primary-color);text-decoration:none;font-weight:600;font-size:.9rem;transition:all .3s ease}.blog-link:hover{color:var(--primary-dark);gap:.5rem}.blog-footer{text-align:center;margin-top:4rem}.blog-footer p{color:var(--text-light);font-style:italic;font-size:1.1rem}.last-updated{font-size:.9rem;color:var(--text-light);opacity:.7;margin-top:.5rem}.loading-container,.error-container{text-align:center;padding:4rem 2rem}.error-container{color:var(--text-color)}.error-container h3{color:var(--text-color);margin-bottom:1rem}.retry-btn{margin-top:1rem;padding:.75rem 1.5rem;background:var(--primary-color);color:#fff;border:none;border-radius:25px;font-weight:600;cursor:pointer;transition:all .3s ease}.retry-btn:hover{background:var(--primary-dark);transform:translateY(-2px)}.blog-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary-color),var(--accent-color));transform:translate(-100%);transition:transform .3s ease}.blog-card-link:hover .blog-card:before{transform:translate(0)}.app.dark .blog-tag{background:rgba(139,92,246,.1);color:var(--accent-color);border-color:#8b5cf633}@media (max-width: 768px){.blog{padding-top:5rem}.blog-grid{grid-template-columns:1fr;gap:1.5rem}.blog-card{padding:1.5rem}.blog-meta{flex-direction:column;gap:.5rem}}.blog-tags .blog-category-badge{font-size:.75rem;font-weight:600;display:inline-flex;align-items:center;gap:.25rem}.blog-tags .blog-tag-badge{font-size:.7rem;opacity:.9;display:inline-flex;align-items:center;gap:.25rem}.blog-tags .blog-tag-badge:hover{opacity:1;transform:translateY(-1px);transition:all .2s ease}.app.dark .blog-tags .blog-tag-badge{opacity:.85}.app.dark .blog-tags .blog-tag-badge:hover{opacity:1}.code-block-wrapper{margin:1.5rem 0;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000001a;background:var(--bg-light);border:1px solid var(--border-color);transition:all .3s ease}.code-block-wrapper:hover{box-shadow:0 8px 20px #00000026;transform:translateY(-2px)}.code-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:rgba(0,0,0,.02);border-bottom:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.code-info{display:flex;align-items:center;gap:.75rem}.language-badge{font-size:.85rem;font-weight:600;color:var(--primary-color);background:rgba(37,99,235,.1);padding:.25rem .75rem;border-radius:12px;text-transform:uppercase;letter-spacing:.025em}.code-lines{font-size:.8rem;color:var(--text-secondary);font-weight:500}.code-actions{display:flex;gap:.5rem}.theme-toggle,.copy-button{padding:.5rem;border:1px solid var(--border-color);background:var(--bg-color);color:var(--text-secondary);cursor:pointer;border-radius:8px;transition:all .2s ease;font-size:1rem;display:flex;align-items:center;justify-content:center;min-width:36px;height:36px}.theme-toggle:hover:not(:disabled),.copy-button:hover:not(:disabled){background:var(--hover-bg);color:var(--text-primary);border-color:var(--primary-color);transform:scale(1.05)}.theme-toggle:disabled,.copy-button:disabled{opacity:.5;cursor:not-allowed}.copy-button.success{color:#10b981;border-color:#10b981}.code-content{overflow-x:auto;font-size:.9rem;line-height:1.5;background:var(--bg-color);max-height:400px;overflow-y:auto}.code-content pre{margin:0;padding:1rem!important;background:transparent!important;border:none!important;font-family:Fira Code,Cascadia Code,JetBrains Mono,Source Code Pro,Menlo,Monaco,Ubuntu Mono,monospace;font-size:.9rem;line-height:1.5;overflow-x:auto;font-feature-settings:"calt" 1,"ss01" 1,"ss02" 1,"liga" 1;-webkit-font-feature-settings:"calt" 1,"ss01" 1,"ss02" 1,"liga" 1;-moz-font-feature-settings:"calt" 1,"ss01" 1,"ss02" 1,"liga" 1}.code-content code{background:transparent!important;font-family:inherit;font-size:inherit;line-height:inherit;padding:0!important}.code-loading{padding:1rem;background:var(--bg-color);font-family:Fira Code,Cascadia Code,JetBrains Mono,Source Code Pro,Menlo,Monaco,Ubuntu Mono,monospace;font-size:.9rem;line-height:1.5;color:var(--text-secondary);font-feature-settings:"calt" 1,"ss01" 1,"ss02" 1,"liga" 1;-webkit-font-feature-settings:"calt" 1,"ss01" 1,"ss02" 1,"liga" 1;-moz-font-feature-settings:"calt" 1,"ss01" 1,"ss02" 1,"liga" 1}.code-loading pre{margin:0;padding:0;overflow-x:auto}.code-loading code{background:transparent;font-family:inherit;font-size:inherit;line-height:inherit;padding:0}.code-content::-webkit-scrollbar{height:8px;width:8px}.code-content::-webkit-scrollbar-track{background:var(--bg-color)}.code-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.code-content::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.app.dark .code-block-wrapper{background:#1e293b;border-color:#334155}.app.dark .code-header{background:#334155;border-color:#475569}.app.dark .code-content{background:#1e293b}.app.dark .theme-toggle,.app.dark .copy-button{background:#475569;border-color:#64748b;color:#e2e8f0}.app.dark .theme-toggle:hover:not(:disabled),.app.dark .copy-button:hover:not(:disabled){background:#64748b;border-color:var(--primary-color);color:#f1f5f9}@media (max-width: 768px){.code-header{padding:.5rem .75rem;flex-direction:column;gap:.5rem;align-items:flex-start}.code-info{flex-wrap:wrap;gap:.5rem}.code-actions{align-self:flex-end}.language-badge{font-size:.75rem;padding:.2rem .6rem}.code-lines{font-size:.75rem}.code-content{font-size:.85rem;padding:.75rem;max-height:300px}}@keyframes copySuccess{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.copy-button.success{animation:copySuccess .3s ease-in-out}.code-content .shiki{background:transparent!important}.code-content .shiki pre{background:transparent!important;padding:1rem!important}.language-badge.javascript,.language-badge.typescript{color:#f7df1e;background:rgba(247,223,30,.2)}.language-badge.python{color:#3776ab;background:rgba(55,118,171,.2)}.language-badge.css{color:#1572b6;background:rgba(21,114,182,.2)}.language-badge.html{color:#e34c26;background:rgba(227,76,38,.2)}.language-badge.json{color:#000;background:rgba(0,0,0,.1)}.language-badge.bash{color:#4eaa25;background:rgba(78,170,37,.2)}.language-badge.go{color:#00add8;background:rgba(0,173,216,.2)}.language-badge.rust{color:#ce4e2a;background:rgba(206,78,42,.2)}.code-block-wrapper.error{border-color:#ef4444}.code-block-wrapper.error .code-header{background:rgba(239,68,68,.1);border-bottom-color:#ef4444}@media (prefers-contrast: high){.code-block-wrapper{border-width:2px}.language-badge{border:1px solid currentColor}.theme-toggle,.copy-button{border-width:2px}}.prism-code-block{margin:16px 0;border-radius:12px;overflow:hidden;border:1px solid var(--border-color);background-color:var(--bg-color);box-shadow:0 4px 12px #0000001a;transition:all .3s ease}.prism-code-block:hover{border-color:var(--accent-color);box-shadow:0 6px 20px #00000026}.prism-code-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:linear-gradient(135deg,var(--border-color),rgba(128,128,128,.1));border-bottom:1px solid var(--border-color);min-height:48px}.prism-code-info{display:flex;align-items:center;gap:12px}.prism-language-badge{background:var(--accent-color);color:#fff;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 4px #0000001a}.prism-code-lines{color:var(--text-color);font-size:12px;opacity:.7;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace}.prism-code-actions{display:flex;gap:8px}.prism-action-button{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:var(--text-color);padding:6px 10px;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;min-width:32px;height:32px}.prism-action-button:hover:not(:disabled){background:rgba(255,255,255,.2);border-color:var(--accent-color);color:var(--accent-color);transform:translateY(-1px)}.prism-action-button:disabled{opacity:.5;cursor:not-allowed}.prism-action-button:active:not(:disabled){transform:translateY(0)}.prism-loading-skeleton{padding:16px;background:linear-gradient(90deg,var(--border-color) 25%,rgba(128,128,128,.1) 50%,var(--border-color) 75%);background-size:200% 100%;animation:prism-loading 1.5s infinite;border-radius:8px;margin:8px 0}@keyframes prism-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.prism-loading-text{text-align:center;color:var(--text-color);opacity:.7;font-size:14px;padding:20px;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace}.prism-code-content pre[class*=language-]{margin:0;padding:20px;background:var(--bg-color);color:var(--text-color);font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:14px;line-height:1.6;overflow-x:auto;white-space:pre;word-wrap:normal;-webkit-overflow-scrolling:touch}.prism-code-content code[class*=language-]{background:none;padding:0;border:none;font-size:inherit;color:inherit;font-family:inherit;white-space:pre;word-wrap:normal}.prism-code-block .token.comment,.prism-code-block .token.prolog,.prism-code-block .token.doctype,.prism-code-block .token.cdata{color:#6a737d;font-style:italic}.prism-code-block .token.punctuation{color:#e1e4e8}.prism-code-block .token.property,.prism-code-block .token.tag,.prism-code-block .token.boolean,.prism-code-block .token.number,.prism-code-block .token.constant,.prism-code-block .token.symbol,.prism-code-block .token.deleted{color:#79b8ff}.prism-code-block .token.selector,.prism-code-block .token.attr-name,.prism-code-block .token.string,.prism-code-block .token.char,.prism-code-block .token.builtin,.prism-code-block .token.inserted{color:#9ecbff}.prism-code-block .token.operator,.prism-code-block .token.entity,.prism-code-block .token.url,.prism-code-block .language-css .token.string,.prism-code-block .style .token.string{color:#b392f0}.prism-code-block .token.atrule,.prism-code-block .token.attr-value,.prism-code-block .token.keyword{color:#f97583}.prism-code-block .token.function,.prism-code-block .token.class-name{color:#b392f0}.prism-code-block .token.regex,.prism-code-block .token.important,.prism-code-block .token.variable{color:#ffab70}@media (max-width: 768px){.prism-code-header{padding:10px 12px;flex-direction:column;gap:8px;align-items:flex-start}.prism-code-actions{align-self:flex-end}.prism-code-content pre[class*=language-]{padding:16px;font-size:13px}.prism-language-badge{font-size:11px;padding:3px 8px}}.app:not(.dark) .prism-code-block{background-color:#fff;border-color:#e1e4e8;box-shadow:0 2px 8px #0000000d}.app:not(.dark) .prism-code-header{background:linear-gradient(135deg,#f6f8fa,#e1e4e8);border-bottom-color:#e1e4e8}.app:not(.dark) .prism-code-content pre[class*=language-]{background-color:#fff;color:#24292e}.prism-code-content pre[class*=language-]::-webkit-scrollbar{height:8px;width:8px}.prism-code-content pre[class*=language-]::-webkit-scrollbar-track{background:var(--border-color);border-radius:4px}.prism-code-content pre[class*=language-]::-webkit-scrollbar-thumb{background:var(--accent-color);border-radius:4px}.prism-code-content pre[class*=language-]::-webkit-scrollbar-thumb:hover{background:var(--primary-color)}.markdown-content{line-height:1.7;color:var(--text-color);font-size:1rem;max-width:none}.markdown-title{font-size:2.5rem;font-weight:800;color:var(--text-color);margin:2rem 0 1.5rem;line-height:1.2;background:linear-gradient(135deg,var(--primary-color),var(--accent-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.markdown-heading{font-size:1.8rem;font-weight:700;color:var(--text-color);margin:2rem 0 1rem;line-height:1.3;border-bottom:2px solid var(--border-color);padding-bottom:.5rem}.markdown-subheading{font-size:1.4rem;font-weight:600;color:var(--text-color);margin:1.5rem 0 .8rem;line-height:1.4}.markdown-paragraph{margin:2rem 0;line-height:1.8;color:var(--text-light)}.markdown-list,.markdown-ordered-list{margin:1.5rem 0;padding-left:2rem}.markdown-list-item{margin:.8rem 0;line-height:1.6;color:var(--text-light)}.markdown-list-item::marker{color:var(--primary-color);font-weight:700}.markdown-list.contains-task-list{list-style:none;padding-left:0;margin:1.2rem 0}.task-list-item{display:flex;align-items:flex-start;margin:.8rem 0;padding:.25rem 0;line-height:1.6;color:var(--text-light);border-radius:4px;transition:all .15s ease;background:transparent;min-height:20px}.task-list-item:hover{background:var(--hover-bg)}.task-list-item input[type=checkbox]{width:16px;height:16px;margin-right:.75rem;margin-top:2px;border:1.5px solid var(--border-color);border-radius:3px;cursor:pointer;transition:all .15s ease;flex-shrink:0;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-color:#fff;position:relative}.task-list-item input[type=checkbox]:hover{border-color:var(--primary-color)}.task-list-item input[type=checkbox]:checked{background-color:var(--primary-color);border-color:var(--primary-color);position:relative}.task-list-item input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:11px;font-weight:700}.task-list-item input[type=checkbox]:checked+*{text-decoration:line-through;color:var(--text-secondary);opacity:.7}.task-list-item>*:not(input[type=checkbox]){flex:1;margin-top:2px;line-height:1.2;white-space:pre-line;word-break:break-word;min-width:0}.task-list-item p{margin:0;line-height:1.2}.app.dark .task-list-item{color:var(--text-light)}.app.dark .task-list-item input[type=checkbox]{border-color:#475569;background-color:#1e293b}.app.dark .task-list-item input[type=checkbox]:hover{border-color:var(--primary-color)}.app.dark .task-list-item input[type=checkbox]:checked{background-color:var(--primary-color);border-color:var(--primary-color)}.markdown-inline-code{background:rgba(37,99,235,.08);color:var(--primary-color);padding:.1rem .3rem;border-radius:3px;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.85em;border:1px solid rgba(37,99,235,.2);font-weight:500}.markdown-link{color:var(--primary-color);text-decoration:none;border-bottom:1px solid transparent;transition:all .3s ease}.markdown-link:hover{color:var(--primary-dark);border-bottom-color:var(--primary-color)}.markdown-quote{border-left:4px solid var(--primary-color);padding:1rem 1.5rem;margin:1.5rem 0;background:rgba(37,99,235,.05);border-radius:0 8px 8px 0;color:var(--text-light);font-style:italic}.markdown-table-wrapper{overflow-x:auto;margin:1.5rem 0;border-radius:8px;box-shadow:var(--shadow)}.markdown-table{width:100%;border-collapse:collapse;background:var(--bg-color);border:1px solid var(--border-color)}.markdown-table-header{background:var(--bg-light);color:var(--text-color);font-weight:600;text-align:left;padding:1rem;border-bottom:2px solid var(--border-color)}.markdown-table-cell{padding:1rem;border-bottom:1px solid var(--border-color);color:var(--text-light)}.markdown-table tr:nth-child(2n){background:rgba(0,0,0,.02)}.app.dark .markdown-pre{background:#1e293b;border-color:#334155}.app.dark .markdown-code-block{color:#e2e8f0}.app.dark .markdown-inline-code{background:rgba(96,165,250,.1);color:#60a5fa;border-color:#60a5fa4d}@media (max-width: 768px){.markdown-content{font-size:.95rem}.markdown-title{font-size:2rem}.markdown-heading{font-size:1.5rem}.markdown-subheading{font-size:1.2rem}.markdown-pre{padding:1rem;font-size:.85rem}.markdown-table-wrapper{font-size:.9rem}.markdown-table-header,.markdown-table-cell{padding:.75rem .5rem}}.markdown-pre::-webkit-scrollbar{height:8px}.markdown-pre::-webkit-scrollbar-track{background:var(--bg-light);border-radius:4px}.markdown-pre::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.markdown-pre::-webkit-scrollbar-thumb:hover{background:var(--text-light)}.blog-post{min-height:100vh;padding:6rem 2rem 4rem;background:var(--bg-light)}.container{max-width:1000px;margin:0 auto;padding:0 1rem}@media (min-width: 1440px){.container{max-width:1100px}}@media (min-width: 1920px){.container{max-width:1200px}}@media (min-width: 2560px){.container{max-width:1300px}}.blog-post-nav{margin-bottom:2rem}.back-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--bg-color);color:var(--text-color);text-decoration:none;border-radius:25px;border:1px solid var(--border-color);font-weight:500;transition:all .3s ease}.back-button:hover{background:var(--primary-color);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow)}.blog-post-loading,.blog-post-error{display:flex;justify-content:center;align-items:center;min-height:60vh}.loading-container,.error-container{text-align:center;padding:2rem}.loading-spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top:4px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-container h2{color:var(--text-color);margin-bottom:1rem}.error-container p{color:var(--text-light);margin-bottom:2rem}.blog-post-header{margin-bottom:3rem}.blog-post-cover{position:relative;width:100%;height:400px;border-radius:var(--border-radius);overflow:hidden;margin-bottom:2rem;box-shadow:var(--shadow-lg)}.cover-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.cover-overlay{position:absolute;bottom:0;left:0;right:0;height:50%;background:linear-gradient(to top,rgba(0,0,0,.8),transparent)}.blog-post-meta{background:var(--bg-color);padding:2rem;border-radius:var(--border-radius);box-shadow:var(--shadow);border:1px solid var(--border-color)}.meta-primary{margin-bottom:1.5rem}.blog-post-title{font-size:2.5rem;font-weight:800;color:var(--text-color);line-height:1.2;margin-bottom:1rem;background:linear-gradient(135deg,var(--primary-color),var(--accent-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.blog-post-excerpt{font-size:1.1rem;color:var(--text-light);line-height:1.6;margin:0}.meta-secondary{border-top:1px solid var(--border-color);padding-top:1.5rem}.meta-info{display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:1rem}.meta-item{display:flex;align-items:center;gap:.5rem;color:var(--text-light);font-size:.9rem}.meta-item svg{color:var(--primary-color)}.meta-tags{display:flex;flex-wrap:wrap;gap:.5rem}.category-tag{background:linear-gradient(135deg,var(--primary-color),var(--accent-color));color:#fff;padding:.3rem .8rem;border-radius:15px;font-size:.8rem;font-weight:600}.tag{display:flex;align-items:center;gap:.3rem;padding:.3rem .8rem;background:var(--bg-light);color:var(--text-color);border-radius:15px;font-size:.8rem;font-weight:500;border:1px solid var(--border-color)}.blog-post-actions{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem}.action-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--bg-color);color:var(--text-color);border:1px solid var(--border-color);border-radius:25px;text-decoration:none;font-weight:500;cursor:pointer;transition:all .3s ease}.action-button:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow)}.blog-post-content{background:var(--bg-color);padding:3rem;border-radius:var(--border-radius);box-shadow:var(--shadow);border:1px solid var(--border-color);margin-bottom:3rem}.blog-post-footer{background:var(--bg-color);padding:2rem;border-radius:var(--border-radius);box-shadow:var(--shadow);border:1px solid var(--border-color)}.footer-content{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem}.author-info{flex:1}.author-info h3{color:var(--text-color);margin-bottom:1rem;font-size:1.2rem}.author-info p{color:var(--text-light);line-height:1.6;margin-bottom:1.5rem}.author-links{display:flex;gap:1rem}.author-link{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-light);color:var(--text-color);text-decoration:none;border-radius:20px;border:1px solid var(--border-color);font-size:.9rem;font-weight:500;transition:all .3s ease}.author-link:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.article-navigation{flex-shrink:0}.nav-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--primary-color);color:#fff;text-decoration:none;border-radius:25px;font-weight:500;transition:all .3s ease}.nav-button:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow)}@media (max-width: 1024px){.blog-post{padding:5rem 1rem 3rem}.blog-post-title{font-size:2rem}.footer-content{flex-direction:column;align-items:stretch;text-align:center}.article-navigation{margin-top:2rem}}@media (max-width: 768px){.blog-post{padding:6rem 1rem 2rem}.blog-post-cover{height:250px}.blog-post-meta{padding:1.5rem}.blog-post-title{font-size:1.8rem}.meta-info{flex-direction:column;gap:1rem}.blog-post-actions{flex-direction:column;align-items:stretch}.action-button{justify-content:center}.blog-post-content{padding:2rem 1.5rem}.footer-content{flex-direction:column;gap:1.5rem}.author-links{justify-content:center}}@media (max-width: 480px){.blog-post-title{font-size:1.6rem}.meta-info,.meta-tags,.blog-post-actions{gap:.75rem}.blog-post-content{padding:1.5rem 1rem}.blog-post-footer{padding:1.5rem}}.app.dark .blog-post{background:var(--bg-dark)}.app.dark .action-button:hover{box-shadow:0 4px 20px #8b5cf64d}.app.dark .tag{background:rgba(255,255,255,.05);border-color:#ffffff1a}.app.dark .author-link:hover{box-shadow:0 4px 20px #8b5cf64d}.meta-tags .blogpost-category-badge{font-size:.8rem;font-weight:600}.meta-tags .blogpost-tag-badge{font-size:.75rem;display:inline-flex;align-items:center;gap:.25rem;opacity:.9}.meta-tags .blogpost-tag-badge:hover{opacity:1;transform:translateY(-1px);transition:all .2s ease}.back-button{margin-bottom:1rem}.nav-button{margin-top:1rem}.app.dark .meta-tags .blogpost-tag-badge{opacity:.85}.app.dark .meta-tags .blogpost-tag-badge:hover{opacity:1}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}.\@container{container-type:inline-size}.visible{visibility:visible}.fixed{position:fixed}.static{position:static}.sticky{position:sticky}.container{width:100%}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-flex{display:inline-flex}.list-item{display:list-item}.table{display:table}.flex-shrink,.shrink{flex-shrink:1}.grow{flex-grow:1}.border-collapse{border-collapse:collapse}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.rounded-full{border-radius:3.40282e38px}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-\[\#333\]{border-color:#333}.border-transparent{border-color:#0000}.bg-\[\#24292e\]{background-color:#24292e}.text-current{color:currentColor}.underline{text-decoration-line:underline}.underline-offset-4{text-underline-offset:4px}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.invert{--tw-invert:invert(100%);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}@media (hover:hover){.hover\:translate-y-\[-2px\]:hover{--tw-translate-y:-2px;translate:var(--tw-translate-x)var(--tw-translate-y)}.hover\:bg-\[\#333\]:hover{background-color:#333}.hover\:underline:hover{text-decoration-line:underline}}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,)0 0 0 var(--tw-ring-offset-width)var(--tw-ring-offset-color)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:ring-2:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,)0 0 0 var(--tw-ring-offset-width)var(--tw-ring-offset-color)}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:opacity-50:disabled{opacity:.5}@layer base{:root{--radius:.5rem}}@layer components;.badge-base{letter-spacing:.025em;border:1px solid var(--border-color);background:var(--bg-light);color:var(--text-color);cursor:default;white-space:nowrap;border-radius:18px;align-items:center;padding:6px 12px;font-size:.75rem;font-weight:600;transition:all .2s;display:inline-flex}.badge-default{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.badge-secondary{background:var(--bg-light);color:var(--text-color);border-color:var(--border-color)}.badge-destructive{color:#fff;background:#ef4444;border-color:#ef4444}.badge-outline{color:var(--text-color);border-color:var(--border-color);background:0 0}.badge-success{color:#fff;background:#10b981;border-color:#10b981}.badge-warning{color:#fff;background:#f59e0b;border-color:#f59e0b}.badge-info{color:#fff;background:#3b82f6;border-color:#3b82f6}.badge-base:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.badge-default:hover{background:var(--primary-dark);border-color:var(--primary-dark)}.badge-secondary:hover{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.badge-destructive:hover{background:#dc2626;border-color:#dc2626}.badge-outline:hover{background:var(--bg-color);border-color:var(--text-color)}.badge-success:hover{background:#059669;border-color:#059669}.badge-warning:hover{background:#d97706;border-color:#d97706}.badge-info:hover{background:#2563eb;border-color:#2563eb}.badge-number{justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 6px;font-family:ui-monospace,SFMono,Monaco,Cascadia Code,Roboto Mono,Consolas,Liberation Mono,Courier New,monospace;font-size:.7rem;display:flex}.badge-with-icon{align-items:center;gap:4px;display:flex}.badge-icon{justify-content:center;align-items:center;width:14px;height:14px;display:flex}.app.dark .badge-secondary{background:var(--bg-light);color:var(--text-color);border-color:var(--border-color)}.app.dark .badge-outline{color:var(--text-color);border-color:var(--border-color)}.app.dark .badge-secondary:hover{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.badge-base:focus{box-shadow:0 0 0 2px var(--ring),0 0 0 0 var(--ring-offset);outline:none}.badge-base.disabled{opacity:.5;cursor:not-allowed;transform:none}.badge-base.disabled:hover{box-shadow:none;transform:none}.button-base{border-radius:50px;transition:all .3s;position:relative;overflow:hidden}.button-base[class*=bg-primary]{background:linear-gradient(135deg,var(--primary-color),var(--accent-color));box-shadow:0 4px 15px #2563eb4d}.button-base[class*=bg-primary]:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2563eb66}.button-base[class*=bg-destructive]{color:#fff;background:#ef4444}.button-base[class*=bg-destructive]:hover{background:#dc2626;transform:translateY(-1px)}.button-base[class*=outline]{color:var(--text-color);border:2px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a}.button-base[class*=outline]:hover{border-color:var(--primary-color);background:#fff3;transform:translateY(-2px)}.button-base[class*=bg-secondary]{background:var(--bg-light);color:var(--text-color);border:1px solid var(--border-color)}.button-base[class*=bg-secondary]:hover{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.button-base[class*=ghost]{color:var(--text-color);background:0 0}.button-base[class*=ghost]:hover{color:var(--primary-color);background:#2563eb1a}.button-base[class*=link]{color:var(--primary-color);background:0 0;border:none;height:auto;padding:0;text-decoration:none}.button-base[class*=link]:hover{box-shadow:none;text-decoration:underline;transform:none}.button-base[class*=bg-green-500]{color:#fff;background:#10b981;box-shadow:0 4px 15px #10b9814d}.button-base[class*=bg-green-500]:hover{background:#059669;transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.button-base[class*=bg-yellow-500]{color:#fff;background:#f59e0b;box-shadow:0 4px 15px #f59e0b4d}.button-base[class*=bg-yellow-500]:hover{background:#d97706;transform:translateY(-2px);box-shadow:0 6px 20px #f59e0b66}.button-base[class*=bg-blue-500]{color:#fff;background:#3b82f6;box-shadow:0 4px 15px #3b82f64d}.button-base[class*=bg-blue-500]:hover{background:#2563eb;transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.button-base[class*="bg-[#24292e]"]{color:#fff;background:#24292e;border:1px solid #333}.button-base[class*="bg-[#24292e]"]:hover{background:#333;transform:translateY(-2px);box-shadow:0 4px 15px #0003}.button-base[class*="bg-white/10"]{color:var(--text-color);border:2px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a}.button-base[class*="bg-white/10"]:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 15px #2563eb4d}.button-base.h-10{height:40px;padding:0 16px}.button-base.h-9{height:36px;padding:0 12px;font-size:.875rem}.button-base.h-11{height:44px;padding:0 32px;font-size:1rem}.button-base.h-12{height:48px;padding:0 40px;font-size:1rem}.button-base.w-10{width:40px;height:40px;padding:0}.button-base:focus-visible{box-shadow:0 0 0 2px var(--ring),0 0 0 4px var(--ring-offset);outline:none}.button-base:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.button-base:disabled:hover{box-shadow:none;transform:none}.button-base.loading{pointer-events:none;opacity:.8}.button-base.loading:before{content:"";border:2px solid #0000;border-top-color:currentColor;border-radius:50%;width:16px;height:16px;margin:-8px 0 0 -8px;animation:.8s linear infinite spin;position:absolute;top:50%;left:50%}@keyframes spin{to{transform:rotate(360deg)}}.button-group{align-items:center;gap:.5rem;display:flex}.button-group .button-base:not(:last-child){margin-right:.5rem}.button-group.vertical{flex-direction:column;gap:.75rem}.button-group.vertical .button-base:not(:last-child){margin-bottom:.75rem;margin-right:0}.app.dark .button-base[class*="bg-[#24292e]"]{background:#2f363d;border-color:#444}.app.dark .button-base[class*="bg-[#24292e]"]:hover{background:#3c434a}.app.dark .button-base[class*=outline]{border-color:var(--border-color);background:#ffffff0d}.app.dark .button-base[class*=outline]:hover{border-color:var(--primary-color);background:#ffffff1a}.app.dark .button-base[class*="bg-white/10"]{border-color:var(--border-color);background:#ffffff0d}.app.dark .button-base[class*="bg-white/10"]:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}@media (max-width:768px){.button-base.h-10{height:44px;padding:0 20px;font-size:.9rem}.button-base.h-11{height:48px;padding:0 24px}.button-base.h-12{height:52px;padding:0 32px}.button-group{flex-wrap:wrap;justify-content:center}.button-group.vertical{align-items:stretch}.button-group.vertical .button-base{width:100%}}.button-base.shine{position:relative;overflow:hidden}.button-base.shine:before{content:"";background:linear-gradient(45deg,#0000 30%,#ffffff4d 50%,#0000 70%);width:200%;height:200%;transition:transform .6s;position:absolute;top:-50%;left:-50%;transform:rotate(45deg)translate(-100%)}.button-base.shine:hover:before{transform:rotate(45deg)translate(100%)}.button-base.pulse{animation:2s ease-in-out infinite button-pulse}@keyframes button-pulse{0%,to{box-shadow:0 4px 15px #2563eb4d}50%{box-shadow:0 4px 25px #2563eb80}}.button-base.float:hover{animation:1s ease-in-out infinite button-float}@keyframes button-float{0%,to{transform:translateY(-2px)}50%{transform:translateY(-4px)}}:root{--primary-color:#2563eb;--primary-dark:#1d4ed8;--secondary-color:#64748b;--accent-color:#8b5cf6;--text-color:#1e293b;--text-light:#64748b;--bg-color:#fff;--bg-light:#f8fafc;--border-color:#e2e8f0;--shadow:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--card-bg:#fffffff2;--hover-bg:#f8fafccc;--text-primary:#1e293b;--text-secondary:#64748b;--warning-bg:#fbbf241a;--warning-text:#d97706;--radius:.5rem;--ring:0 0 0 3px #3b82f680;--ring-offset:#fff}.app.dark{--primary-color:#3b82f6;--primary-dark:#2563eb;--secondary-color:#94a3b8;--accent-color:#a78bfa;--text-color:#f1f5f9;--text-light:#cbd5e1;--bg-color:#0f172a;--bg-light:#1e293b;--border-color:#334155;--card-bg:#0f172af2;--card-bg-dark:#0f172af2;--hover-bg:#1e293bcc;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--warning-bg:#fbbf2426;--warning-text:#fbbf24}*{box-sizing:border-box;margin:0;padding:0}body{color:var(--text-color);background-color:var(--bg-color);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6;transition:all .3s;overflow-x:hidden}.app{min-height:100vh;position:relative}.app-content,.main-content{width:100%;min-height:100vh;position:relative}.page-content{min-height:calc(100vh - 80px);padding-top:0}#particles-background{z-index:-1;background:linear-gradient(135deg,var(--bg-color)0%,var(--bg-light)100%);width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.app.dark #particles-background{background:linear-gradient(135deg,var(--bg-color)0%,#1a1f3a 100%)}.gradient-overlay{background:radial-gradient(circle,#2563eb1a 0%,#0000 70%);width:200%;height:200%;animation:20s ease-in-out infinite float;position:absolute;top:-50%;left:-50%}.app.dark .gradient-overlay{background:radial-gradient(circle,#8b5cf61a 0%,#0000 70%)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-light)}::-webkit-scrollbar-thumb{background:var(--primary-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary-dark)}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.float-animation{animation:3s ease-in-out infinite float}.pulse-animation{animation:2s ease-in-out infinite pulse}@media (max-width:768px){.app{font-size:14px}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}
