:root{--bg:#f7f8fc;--bg2:#ffffff;--bg3:#eef1f8;--bg4:#e7ebf4;--border:rgba(17,24,39,0.08);--border2:rgba(17,24,39,0.12);--border3:rgba(17,24,39,0.2);--text1:#111827;--text2:#374151;--text3:#6b7280;--v:#8b5cf6;--v2:#a78bfa;--v3:#c4b5fd;--vd:rgba(139,92,246,0.14);--vd2:rgba(139,92,246,0.07);--teal:#2dd4bf;--teald:rgba(45,212,191,0.1);--amber:#f59e0b;--amberd:rgba(245,158,11,0.08);--red:#f87171;--redd:rgba(248,113,113,0.08);--green:#4ade80;--greend:rgba(74,222,128,0.08)}#bg-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:.15}.blog-hero{position:relative;z-index:10;max-width:1200px;margin:0 auto;padding:8rem 3rem 4rem;display:flex;flex-direction:column;align-items:center;text-align:center}.hero-kicker{font-family:var(--mono);font-size:.75rem;letter-spacing:.15em;color:var(--v);margin-bottom:1.5rem;text-transform:uppercase;display:flex;align-items:center;gap:.5rem}.hero-kicker::after,.hero-kicker::before{content:"";display:inline-block;width:20px;height:1px;background:var(--v)}.blog-hero h1{font-family:var(--head);font-size:clamp(2.5rem, 4vw, 4rem);font-weight:800;letter-spacing:-.03em;line-height:1.1;margin-bottom:1.5rem;max-width:20ch;text-wrap:balance}.h1-grad{background:linear-gradient(135deg,var(--v),var(--teal));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-desc{font-size:1.1rem;color:var(--text2);line-height:1.7;max-width:600px;margin:0 auto 3rem;text-wrap:balance}.search-wrap{position:relative;max-width:500px;margin:0 auto;width:100%}.search-input{width:100%;background:var(--bg2);border:1px solid var(--border2);border-radius:8px;padding:1rem 1rem 1rem 3rem;font-family:var(--mono);font-size:.9rem;color:var(--text1);outline:0;transition:all .2s}.search-input:focus{border-color:var(--v);box-shadow:0 0 0 3px var(--vd)}.search-input::placeholder{color:var(--text3)}.search-icon{position:absolute;left:1.2rem;top:50%;transform:translateY(-50%);color:var(--text3);pointer-events:none}.filter-section{position:sticky;top:80px;z-index:40;background:rgba(247,248,252,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);margin-bottom:4rem;padding:1rem 3rem}.filter-row{max-width:1200px;margin:0 auto;display:flex;justify-content:center;align-items:center;gap:1rem;flex-wrap:wrap}.filter-chips{display:flex;gap:.5rem;flex-wrap:wrap}.f-chip{font-family:var(--mono);font-size:.75rem;letter-spacing:.05em;color:var(--text2);background:0 0;border:1px solid transparent;padding:.5rem 1rem;border-radius:6px;cursor:pointer;transition:all .2s}.f-chip:hover{color:var(--text1);background:var(--bg2)}.f-chip.active{color:var(--v);background:var(--vd);border:1px solid var(--vd)}.sort-select{font-family:var(--mono);font-size:.75rem;color:var(--text2);background:var(--bg2);border:1px solid var(--border2);padding:.5rem 1rem;border-radius:6px;outline:0;cursor:pointer}.sort-select option{background:var(--bg3)}.featured-section{position:relative;z-index:10;max-width:100%;margin:0 auto;padding:0 5% 4rem}.featured-card{display:grid;grid-template-columns:1.5fr 1fr;background:var(--bg2);border:1px solid var(--border2);border-radius:16px;overflow:hidden;transition:all .3s;cursor:pointer;text-decoration:none;color:inherit}.featured-card:hover{border-color:var(--v);box-shadow:0 10px 40px rgba(0,0,0,.06);transform:translateY(-2px)}.featured-img{position:relative;overflow:hidden;background:var(--bg3);min-height:380px}.featured-img-src{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .6s ease}.featured-card:hover .featured-img-src{transform:scale(1.03)}.featured-body{padding:3.5rem;display:flex;flex-direction:column;justify-content:center}.feat-meta{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.post-cat{font-family:var(--mono);font-size:.65rem;letter-spacing:.1em;padding:.25rem .6rem;border-radius:4px;text-transform:uppercase}.cat-ia{background:var(--vd);color:var(--v);border:1px solid var(--vd)}.cat-auto{background:var(--teald);color:var(--teal);border:1px solid var(--teald)}.cat-web{background:var(--amberd);color:var(--amber);border:1px solid var(--amberd)}.cat-infra{background:var(--redd);color:var(--red);border:1px solid var(--redd)}.cat-odoo{background:var(--greend);color:var(--green);border:1px solid var(--greend)}.feat-badge{font-family:var(--mono);font-size:.6rem;letter-spacing:.08em;color:var(--amber);background:var(--amberd);border:1px solid var(--amberd);padding:.2rem .6rem;border-radius:4px}.post-date{font-family:var(--mono);font-size:.7rem;color:var(--text3)}.feat-title{display:block;font-family:var(--head);font-size:2rem;font-weight:700;letter-spacing:-.03em;line-height:1.2;margin-bottom:1rem;color:var(--text1);text-wrap:balance}.feat-excerpt{font-size:1rem;color:var(--text2);line-height:1.6;margin-bottom:2rem}.feat-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto}.author-row{display:flex;align-items:center;gap:.75rem}.author-avatar{width:36px;height:36px;border-radius:50%;background:var(--vd);border:1px solid var(--vd);display:flex;align-items:center;justify-content:center;font-family:var(--head);font-size:.75rem;font-weight:700;color:var(--v)}.author-name{font-size:.8rem;font-weight:600;color:var(--text1)}.author-role{font-family:var(--mono);font-size:.65rem;color:var(--text3)}.read-link{font-family:var(--mono);font-size:.75rem;color:var(--v);display:flex;align-items:center;gap:.5rem;transition:gap .2s;text-decoration:none}.featured-card:hover .read-link{gap:.8rem}.grid-section{position:relative;z-index:10;max-width:100%;margin:0 auto;padding:0 5% 6rem}.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2.5rem}.post-card{display:flex;flex-direction:column;background:var(--bg2);border:1px solid var(--border2);border-radius:12px;overflow:hidden;transition:all .3s ease;text-decoration:none;color:inherit}.post-card:hover{border-color:var(--v);transform:translateY(-3px);box-shadow:0 12px 30px rgba(0,0,0,.06)}.post-thumb{height:220px;position:relative;overflow:hidden;background:var(--bg3)}.post-thumb-img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.post-card:hover .post-thumb-img{transform:scale(1.03)}.post-body{padding:1.75rem;display:flex;flex-direction:column;flex:1}.post-meta{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.post-title{font-family:var(--head);font-size:1.15rem;font-weight:700;letter-spacing:-.02em;line-height:1.3;margin-bottom:.75rem;color:var(--text1);text-wrap:balance}.post-excerpt{font-size:.9rem;color:var(--text2);line-height:1.6;margin-bottom:1.5rem;flex:1}.post-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:1.25rem;border-top:1px solid var(--border)}.read-time{font-family:var(--mono);font-size:.7rem;color:var(--text3)}.post-arrow{color:var(--text3);transition:transform .2s,color .2s}.post-card:hover .post-arrow{color:var(--v);transform:translateX(4px)}.newsletter-section{position:relative;z-index:10;max-width:100%;margin:0 auto;padding:2rem 5% 6rem}.nl-card{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:4rem;background:var(--text1);color:var(--bg2);padding:4rem;border-radius:24px;box-shadow:0 20px 40px rgba(17,24,39,.1);position:relative;overflow:hidden}.nl-glow{position:absolute;right:-10%;top:-50%;width:50%;height:200%;background:radial-gradient(ellipse at right,var(--vd) 0,transparent 70%);pointer-events:none}.nl-left{flex:1;position:relative;z-index:2}.nl-kicker{font-family:var(--mono);font-size:.75rem;letter-spacing:.15em;color:var(--v2);margin-bottom:1rem;text-transform:uppercase}.nl-title{font-family:var(--head);font-size:clamp(2rem, 3vw, 2.5rem);font-weight:700;letter-spacing:-.02em;line-height:1.2;margin-bottom:1rem;color:#fff}.nl-desc{font-size:1.05rem;color:rgba(255,255,255,.7);line-height:1.6;max-width:500px}.nl-form{flex:1;display:flex;gap:1rem;position:relative;z-index:2;max-width:450px;width:100%}.nl-input{flex:1;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:1rem 1.5rem;font-family:var(--mono);font-size:.9rem;color:#fff;outline:0;transition:all .2s}.nl-input:focus{border-color:var(--v2);background:rgba(255,255,255,.15)}.nl-input::placeholder{color:rgba(255,255,255,.5)}.nl-btn{background:var(--v);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-family:var(--mono);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.nl-btn:hover{background:var(--v2);transform:translateY(-2px)}@media (max-width:1080px){.blog-hero,.featured-section,.filter-section,.grid-section{padding-left:2rem;padding-right:2rem}}@media (max-width:860px){.featured-card{grid-template-columns:1fr}.featured-img{min-height:260px}.featured-body{padding:2rem}.filter-row{justify-content:center}.filter-chips{justify-content:center}.nl-card{flex-direction:column;align-items:flex-start;gap:2.5rem;padding:3rem}.nl-form{max-width:100%}}@media (max-width:640px){.blog-hero,.featured-section,.filter-section,.grid-section{padding-left:1.5rem;padding-right:1.5rem}.posts-grid{grid-template-columns:1fr}.blog-hero h1{font-size:2.2rem}.hero-desc{font-size:1rem}.featured-img{min-height:220px}.feat-title{font-size:1.5rem}.filter-chips{flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;padding-bottom:.5rem;-webkit-overflow-scrolling:touch}.filter-section{padding:1rem 1.5rem}.nl-card{padding:2rem 1.5rem}.nl-form{flex-direction:column}.nl-btn{width:100%}}.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}.reveal.visible{opacity:1;transform:translateY(0)}