*{box-sizing:border-box}body{background-color:var(--color-bg-secondary)}main{margin:120px auto;max-width:1200px}.blog-page{display:flex;flex-wrap:nowrap;flex-direction:row-reverse;width:100%;gap:40px}.blog-filters{position:sticky;background:var(--color-bg);padding:20px;border-radius:12px;margin-bottom:30px;max-width:400px;min-width:320px;height:fit-content;width:25%;top:80px}.search-container{position:relative;margin-bottom:20px}#blog-search-input{width:90%;padding:12px;border:none;border-radius:12px;font-size:16px;transition:all .3s ease;background-color:var(--color-bg-secondary);color:var(--color-text-secondary);height:10px}#blog-search-input:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px rgba(102,126,234,.1)}.search-button{position:absolute;right:0;top:0;height:100%;width:50px;background:0 0;border:none;cursor:pointer;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;transition:color .3s ease}.search-button:hover{color:var(--color-accent-purple)}.tags-container{margin-bottom:15px;display:flex;flex-direction:column}.tag-list{margin-bottom:20px;margin-top:8px;display:flex;flex-wrap:wrap;gap:12px}.tag-button{position:relative;display:inline-block;background:0 0;color:var(--color-text-primary);background:var(--color-bg);color:var(--color-text-primary);border-radius:8px;padding:8px 16px;border:none;cursor:pointer;overflow:hidden;transition:color .4s ease,transform .2s ease;text-align:center;z-index:0}.tag-button:before{content:"";position:absolute;inset:0;padding:2px;border-radius:inherit;background:var(--color-accent-gradient);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;z-index:-1}.tag-button:after{content:"";position:absolute;inset:0;border-radius:inherit;background:var(--color-accent-gradient);opacity:0;transition:opacity .4s ease;z-index:-2}.tag-button:hover:after,.tag-button.active:after{opacity:1}.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px;width:80%;align-items:stretch}.post-card{background:var(--color-bg);border-radius:12px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.08);transition:transform .3s ease;height:100%;display:flex;flex-direction:column}.post-card:hover{transform:translateY(-5px)}.post-image{height:200px;flex-shrink:0}.post-image img{width:100%;height:100%;object-fit:cover}.post-content{padding:20px;flex:1 0 auto;display:flex;flex-direction:column}.post-card h3{margin:0 0 10px;font-size:1.5rem;line-height:1.3;flex-shrink:0}.post-card h3 a{color:#fff;text-decoration:none;transition:color .3s ease}.post-card h3 a:hover{color:var(--color-accent-purple)}.post-meta{display:flex;justify-content:space-between;align-items:center;font-size:14px;color:#64748b;flex-shrink:0}time{float:right}.post-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;flex-shrink:0}.post-tag{padding:8px 12px;background:var(--color-accent-gradient);color:#f5f5f5;border-radius:12px;font-size:12px;font-family:'Inter'}.post-excerpt{line-height:1.6;color:#475569;flex:1;min-height:60px}.read-more{display:inline-block;color:#f5f5f5;text-decoration:none;font-weight:500;width:100%;font-size:20px;text-align:center;padding:8px 0;transition:transform .3s ease;background:var(--color-accent-gradient);border-radius:12px;margin-top:auto;flex-shrink:0}.read-more:hover{transform:translateY(-5px)}#loading-indicator{text-align:center;padding:30px;color:#666;grid-column:1/-1}.spinner{display:inline-block;width:30px;height:30px;border:3px solid #f3f3f3;border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-right:10px;vertical-align:middle}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}.no-posts{text-align:center;padding:60px 20px;color:#666;font-size:18px;grid-column:1/-1}.error{text-align:center;padding:40px;color:#e53e3e;grid-column:1/-1}@media screen and (max-width:720px){main{padding:0 15px;margin:80px auto}.blog-page{flex-wrap:wrap;flex-direction:column;gap:25px;width:100%;margin:0}.posts-grid{width:100%;margin:0;grid-template-columns:1fr;gap:15px}.blog-filters{width:100%;position:relative;top:0;min-width:100%;max-width:100%}#blog-search-input{width:100%}.tag-button:hover:after{opacity:0}.tag-button.active:after{opacity:1}}