:root{--ivory: hsl(45 33% 91%);--smoke: hsl(330 4% 15%);--primary: hsl(330 4% 15%);--primary-foreground: hsl(45 33% 91%);--background: hsl(45 33% 91%);--foreground: hsl(330 4% 15%);--card: hsl(45 30% 94%);--card-foreground: hsl(330 4% 15%);--muted: hsl(45 15% 85%);--muted-foreground: hsl(330 4% 40%);--secondary: hsl(45 20% 88%);--secondary-foreground: hsl(330 4% 15%);--accent: hsl(45 20% 88%);--accent-foreground: hsl(330 4% 15%);--sidebar: hsl(45 25% 93%);--sidebar-foreground: hsl(330 4% 40%);--sidebar-primary: hsl(330 4% 15%);--sidebar-accent: hsl(45 20% 88%);--chart-1: hsl(45 60% 50%);--chart-2: hsl(30 60% 45%);--chart-3: hsl(330 10% 35%);--chart-4: hsl(45 40% 60%);--chart-5: hsl(15 50% 55%);--destructive: hsl(0 72% 51%);--destructive-foreground: hsl(0 0% 100%);--border: hsl(45 15% 80%);--input: hsl(45 15% 80%);--ring: hsl(330 4% 15%);--radius: .5rem;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;font-weight:400;color-scheme:light dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.dark{--primary: hsl(45 33% 91%);--primary-foreground: hsl(330 4% 8%);--background: hsl(330 4% 8%);--foreground: hsl(45 33% 91%);--card: hsl(330 4% 11%);--card-foreground: hsl(45 33% 91%);--muted: hsl(330 4% 18%);--muted-foreground: hsl(45 15% 65%);--secondary: hsl(330 4% 15%);--secondary-foreground: hsl(45 33% 91%);--accent: hsl(330 4% 15%);--accent-foreground: hsl(45 33% 91%);--sidebar: hsl(330 4% 10%);--sidebar-foreground: hsl(45 15% 70%);--sidebar-primary: hsl(45 33% 91%);--sidebar-accent: hsl(330 4% 15%);--chart-1: hsl(45 50% 55%);--chart-2: hsl(30 50% 50%);--chart-3: hsl(45 30% 70%);--chart-4: hsl(15 40% 55%);--chart-5: hsl(330 15% 50%);--border: hsl(330 4% 20%);--input: hsl(330 4% 20%);--ring: hsl(45 33% 91%)}@media(prefers-color-scheme:dark){:root:not(.light){--primary: hsl(45 33% 91%);--primary-foreground: hsl(330 4% 8%);--background: hsl(330 4% 8%);--foreground: hsl(45 33% 91%);--card: hsl(330 4% 11%);--card-foreground: hsl(45 33% 91%);--muted: hsl(330 4% 18%);--muted-foreground: hsl(45 15% 65%);--secondary: hsl(330 4% 15%);--secondary-foreground: hsl(45 33% 91%);--accent: hsl(330 4% 15%);--accent-foreground: hsl(45 33% 91%);--sidebar: hsl(330 4% 10%);--sidebar-foreground: hsl(45 15% 70%);--sidebar-primary: hsl(45 33% 91%);--sidebar-accent: hsl(330 4% 15%);--chart-1: hsl(45 50% 55%);--chart-2: hsl(30 50% 50%);--chart-3: hsl(45 30% 70%);--chart-4: hsl(15 40% 55%);--chart-5: hsl(330 15% 50%);--border: hsl(330 4% 20%);--input: hsl(330 4% 20%);--ring: hsl(45 33% 91%)}}*{margin:0;padding:0;box-sizing:border-box}body{background-color:var(--background);color:var(--foreground);min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.25;color:var(--foreground)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}p{margin-bottom:1rem;color:var(--foreground)}a{color:var(--primary);text-decoration:none;transition:opacity .2s ease}a:hover{opacity:.8}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem}.card{background-color:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}button,.btn{display:inline-flex;align-items:center;justify-content:center;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:var(--radius);border:none;cursor:pointer;transition:all .2s ease;font-family:inherit}.btn-primary{background-color:var(--primary);color:var(--primary-foreground)}.btn-primary:hover{opacity:.9}.btn-secondary{background-color:var(--secondary);color:var(--secondary-foreground)}.btn-secondary:hover{background-color:var(--muted)}code{font-family:JetBrains Mono,Fira Code,monospace;background-color:var(--muted);padding:.125rem .375rem;border-radius:.25rem;font-size:.875em}pre{background-color:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;overflow-x:auto}pre code{background:none;padding:0}.markdown-content{line-height:1.8}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4,.markdown-content h5,.markdown-content h6{margin-top:2rem;margin-bottom:1rem}.markdown-content h1:first-child,.markdown-content h2:first-child{margin-top:0}.markdown-content p{margin-bottom:1.25rem}.markdown-content ul,.markdown-content ol{margin-bottom:1.25rem;padding-left:1.5rem}.markdown-content li{margin-bottom:.5rem}.markdown-content blockquote{border-left:4px solid var(--primary);padding-left:1rem;margin:1.5rem 0;font-style:italic;color:var(--muted-foreground)}.markdown-content img{max-width:100%;height:auto;border-radius:var(--radius);margin:1.5rem 0}.markdown-content hr{border:none;border-top:1px solid var(--border);margin:2rem 0}.markdown-content table{width:100%;border-collapse:collapse;margin:1.5rem 0}.markdown-content th,.markdown-content td{border:1px solid var(--border);padding:.75rem;text-align:left}.markdown-content th{background-color:var(--muted);font-weight:600}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--muted)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--muted-foreground)}::selection{background-color:var(--primary);color:var(--primary-foreground)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background-color:var(--secondary);border:1px solid var(--border);border-radius:var(--radius);color:var(--foreground);cursor:pointer;transition:all .2s ease}.theme-toggle:hover{background-color:var(--muted)}.theme-toggle:focus-visible{outline:2px solid var(--ring);outline-offset:2px}.header{position:sticky;top:0;background-color:var(--background);border-bottom:1px solid var(--border);z-index:100}.header-container{display:flex;align-items:center;justify-content:space-between;height:64px}.logo{display:flex;align-items:center;gap:.75rem;font-weight:600;font-size:1.125rem;color:var(--foreground)}.logo-icon{border-radius:6px;filter:invert(1)}.dark .logo-icon{filter:none}.light .logo-icon{filter:invert(1)}@media(prefers-color-scheme:dark){.logo-icon{filter:none}.light .logo-icon{filter:invert(1)}}.logo-text{color:var(--foreground)}.nav{display:flex;align-items:center;gap:1.5rem}.nav-link{color:var(--muted-foreground);font-size:.875rem;font-weight:500;transition:color .2s ease}.nav-link:hover{color:var(--foreground);opacity:1}.nav-button{display:inline-flex;align-items:center;padding:.5rem 1rem;font-size:.8rem;font-weight:500;color:var(--primary-foreground);background-color:var(--primary);border-radius:6px;transition:opacity .2s ease}.nav-button:hover{opacity:.85}@media(max-width:640px){.nav{gap:1rem}.nav-link{font-size:.8rem}.logo-text{display:none}}.footer{margin-top:auto;padding:3rem 0 2rem;background-color:var(--card);border-top:1px solid var(--border)}.footer-container{display:grid;gap:2rem}.footer-brand{max-width:300px}.footer-logo{font-size:1.25rem;font-weight:700;color:var(--foreground)}.footer-tagline{margin-top:.5rem;font-size:.875rem;color:var(--muted-foreground);margin-bottom:0}.footer-links{display:flex;gap:4rem}.footer-column{display:flex;flex-direction:column;gap:.75rem}.footer-column h4{font-size:.875rem;font-weight:600;color:var(--foreground);margin-bottom:.25rem}.footer-column a{font-size:.875rem;color:var(--muted-foreground);transition:color .2s ease}.footer-column a:hover{color:var(--foreground);opacity:1}.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:2rem;border-top:1px solid var(--border);font-size:.8rem;color:var(--muted-foreground)}.footer-bottom p{margin:0}.footer-built{font-weight:500}@media(min-width:768px){.footer-container{grid-template-columns:1fr auto auto;align-items:start}.footer-bottom{grid-column:1 / -1}}@media(max-width:640px){.footer-links{gap:2rem}.footer-bottom{flex-direction:column;gap:.5rem;text-align:center}}.layout{min-height:100vh;display:flex;flex-direction:column}.main{flex:1;padding:2rem 0}@media(min-width:768px){.main{padding:3rem 0}}.article-card{background-color:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.article-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.article-card-link{display:block;color:inherit}.article-card-image{aspect-ratio:16 / 9;overflow:hidden}.article-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.article-card:hover .article-card-image img{transform:scale(1.05)}.article-card-content{padding:1.5rem}.article-card-meta{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--muted-foreground);margin-bottom:.75rem}.article-card-author:before{content:"•";margin-right:.5rem}.article-card-title{font-size:1.25rem;font-weight:600;line-height:1.4;margin-bottom:.5rem;color:var(--foreground)}.article-card-description{font-size:.9rem;color:var(--muted-foreground);line-height:1.6;margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.article-card-tags{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.25rem;scrollbar-width:thin;scrollbar-color:var(--muted) transparent;-webkit-overflow-scrolling:touch}.article-card-tags::-webkit-scrollbar{height:4px}.article-card-tags::-webkit-scrollbar-track{background:transparent}.article-card-tags::-webkit-scrollbar-thumb{background-color:var(--muted);border-radius:2px}.article-card-tags::-webkit-scrollbar-thumb:hover{background-color:var(--muted-foreground)}.article-card-tag{font-size:.75rem;padding:.25rem .625rem;background-color:var(--secondary);color:var(--secondary-foreground);border-radius:9999px;font-weight:500;white-space:nowrap;flex-shrink:0}.home-page{display:flex;flex-direction:column}.hero{position:relative;padding:6rem 0 4rem;overflow:hidden}.hero-bg{position:absolute;inset:0;pointer-events:none}.hero-gradient{position:absolute;inset:0;background:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(239,239,239,.15) 0%,transparent 70%)}.dark .hero-gradient{background:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(239,239,239,.08) 0%,transparent 70%)}.hero-grid{position:absolute;inset:0;background-image:linear-gradient(to right,var(--border) 1px,transparent 1px),linear-gradient(to bottom,var(--border) 1px,transparent 1px);background-size:60px 60px;opacity:.4;mask-image:linear-gradient(to bottom,black 0%,transparent 80%);-webkit-mask-image:linear-gradient(to bottom,black 0%,transparent 80%)}.hero-content{position:relative;z-index:1}.hero-badge-wrapper{margin-bottom:2rem}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--foreground);padding:.5rem 1rem;background-color:var(--secondary);border:1px solid var(--border);border-radius:100px}.hero-badge-dot{width:6px;height:6px;background-color:#22c55e;border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.hero-title{font-size:2.5rem;font-weight:500;line-height:1.1;letter-spacing:-.03em;color:var(--foreground);margin:0 0 1.5rem}.hero-title-accent{color:var(--muted-foreground)}.hero-subtitle{font-size:1.125rem;color:var(--muted-foreground);margin:0;max-width:400px}.featured{padding:2rem 0;border-top:1px solid var(--border)}.featured-article{display:flex;align-items:flex-start;justify-content:space-between;gap:2rem;padding:2rem 0;color:var(--foreground);transition:opacity .2s ease}.featured-article:hover{opacity:.7}.featured-image{flex-shrink:0;width:280px;aspect-ratio:16 / 10;border-radius:8px;overflow:hidden;background-color:var(--muted)}.featured-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.featured-article:hover .featured-image img{transform:scale(1.03)}.featured-content{flex:1;max-width:640px}.featured-label{display:inline-block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-foreground);margin-bottom:1rem;padding:.25rem .5rem;background-color:var(--secondary);border-radius:3px}.featured-title{font-size:1.75rem;font-weight:500;line-height:1.3;letter-spacing:-.01em;margin:0 0 .75rem}.featured-description{font-size:1rem;color:var(--muted-foreground);line-height:1.6;margin:0 0 1rem}.featured-meta{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--muted-foreground)}.featured-divider{opacity:.4}.featured-arrow{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:48px;height:48px;border:1px solid var(--border);border-radius:50%;color:var(--foreground);transition:all .2s ease}.featured-article:hover .featured-arrow{background-color:var(--foreground);border-color:var(--foreground);color:var(--background)}.recent{padding:3rem 0;border-top:1px solid var(--border)}.recent-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.recent-title{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--muted-foreground);margin:0}.recent-link{display:inline-flex;align-items:center;gap:.375rem;font-size:.8rem;font-weight:500;color:var(--muted-foreground);transition:color .2s ease}.recent-link:hover{color:var(--foreground);opacity:1}.recent-link svg{width:14px;height:14px}.articles-list{display:flex;flex-direction:column;position:relative}.article-row{display:grid;grid-template-columns:auto 1fr auto;align-items:start;gap:1.5rem;padding:1.5rem 0;border-bottom:1px solid var(--border);color:var(--foreground);transition:opacity .2s ease}.article-row:first-child{border-top:1px solid var(--border)}.article-row:hover{opacity:.7}.article-number{font-size:.75rem;font-weight:500;color:var(--muted-foreground);padding-top:.25rem;font-variant-numeric:tabular-nums}.article-info{min-width:0}.article-title{font-size:1.125rem;font-weight:500;line-height:1.4;margin:0 0 .375rem}.article-excerpt{font-size:.875rem;color:var(--muted-foreground);line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.article-date{font-size:.75rem;color:var(--muted-foreground);white-space:nowrap;padding-top:.25rem}.hover-image{position:absolute;width:280px;aspect-ratio:16 / 10;pointer-events:none;z-index:100;transform:translate(-50%,-120%);border-radius:12px;overflow:hidden;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px var(--border);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%,-110%) scale(.95)}to{opacity:1;transform:translate(-50%,-120%) scale(1)}}.hover-image img{width:100%;height:100%;object-fit:cover}.load-more-trigger{display:flex;justify-content:center;padding:2rem 0}.loading-indicator{display:flex;align-items:center;gap:.5rem;color:var(--muted-foreground);font-size:.8rem}.loading-indicator .spinner{width:16px;height:16px;animation:spin 1s linear infinite}.cta{padding:4rem 0;border-top:1px solid var(--border)}.cta-content{max-width:400px}.cta-label{font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--muted-foreground);margin:0 0 .75rem}.cta-title{font-size:1.5rem;font-weight:500;line-height:1.3;letter-spacing:-.01em;margin:0 0 1.5rem}.cta-button{display:inline-flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:var(--primary-foreground);background-color:var(--primary);padding:.75rem 1.25rem;border-radius:6px;transition:opacity .2s ease}.cta-button:hover{opacity:.85}.cta-button svg{width:14px;height:14px}@media(min-width:768px){.hero{padding:8rem 0 5rem}.hero-title{font-size:3.5rem}.hero-subtitle{font-size:1.25rem;max-width:500px}.featured-title{font-size:2rem}.article-row{gap:2rem}.article-title{font-size:1.25rem}}@media(min-width:1024px){.hero{padding:10rem 0 6rem}.hero-title{font-size:4.5rem}.featured-article{align-items:center}}@media(max-width:768px){.featured-article{flex-direction:column}.featured-image{width:100%;aspect-ratio:16 / 9;margin-bottom:1rem}.hover-image{display:none}}@media(max-width:640px){.hero{padding:4rem 0 3rem}.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.article-row{grid-template-columns:1fr;gap:.5rem}.article-number{display:none}.article-date{padding-top:.5rem;font-size:.7rem}.featured-arrow{display:none}}.articles-page{min-height:60vh}.articles-header{text-align:center;margin-bottom:2rem}.articles-title{font-size:2.5rem;font-weight:700;margin-bottom:.75rem}.articles-description{font-size:1.125rem;color:var(--muted-foreground);max-width:500px;margin:0 auto}.tags-filter-container{margin-bottom:2rem}.tags-search{display:flex;align-items:center;gap:.5rem;max-width:300px;margin:0 auto 1rem;padding:.5rem 1rem;background-color:var(--secondary);border:1px solid var(--border);border-radius:9999px;transition:border-color .2s ease,box-shadow .2s ease}.tags-search:focus-within{border-color:var(--primary);box-shadow:0 0 0 2px rgba(var(--primary-rgb),.1)}.search-icon{color:var(--muted-foreground);flex-shrink:0}.tags-search-input{flex:1;border:none;background:transparent;font-size:.875rem;color:var(--foreground);outline:none}.tags-search-input::placeholder{color:var(--muted-foreground)}.search-clear{display:flex;align-items:center;justify-content:center;padding:.25rem;background:transparent;border:none;color:var(--muted-foreground);cursor:pointer;border-radius:50%;transition:color .2s ease,background-color .2s ease}.search-clear:hover{color:var(--foreground);background-color:var(--muted)}.tags-filter{display:flex;gap:.5rem;overflow-x:auto;padding:.5rem 0;scrollbar-width:thin;scrollbar-color:var(--muted) transparent;-webkit-overflow-scrolling:touch}.tags-filter::-webkit-scrollbar{height:6px}.tags-filter::-webkit-scrollbar-track{background:transparent}.tags-filter::-webkit-scrollbar-thumb{background-color:var(--muted);border-radius:3px}.tags-filter::-webkit-scrollbar-thumb:hover{background-color:var(--muted-foreground)}.tag-btn{padding:.5rem 1rem;font-size:.875rem;font-weight:500;background-color:var(--secondary);color:var(--secondary-foreground);border:1px solid var(--border);border-radius:9999px;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.tag-btn:hover{background-color:var(--muted)}.tag-btn.active{background-color:var(--primary);color:var(--primary-foreground);border-color:var(--primary)}.no-tags-found{font-size:.875rem;color:var(--muted-foreground);padding:.5rem 1rem;white-space:nowrap}.articles-grid{display:grid;gap:1.5rem}.no-articles{text-align:center;color:var(--muted-foreground);padding:4rem 2rem}@media(min-width:768px){.articles-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.articles-grid{grid-template-columns:repeat(3,1fr)}}.load-more-trigger{display:flex;justify-content:center;padding:3rem 0}.loading-spinner{display:flex;align-items:center;gap:.75rem;color:var(--muted-foreground);font-size:.875rem}.loading-spinner .spinner{width:20px;height:20px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.all-loaded{display:flex;justify-content:center;padding:2rem 0;color:var(--muted-foreground);font-size:.875rem}.all-loaded span{padding:.5rem 1rem;background-color:var(--secondary);border-radius:9999px}.article-page{padding-bottom:3rem}.article{max-width:720px;margin:0 auto}.article-header{margin-bottom:2rem}.back-link{display:inline-flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--muted-foreground);margin-bottom:2rem;transition:color .2s ease}.back-link:hover{color:var(--foreground);opacity:1}.article-meta{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--muted-foreground);margin-bottom:1rem}.article-author:before{content:"•";margin-right:.5rem}.article-title{font-size:2.5rem;font-weight:700;line-height:1.2;margin-bottom:1rem}.article-description{font-size:1.25rem;color:var(--muted-foreground);line-height:1.6;margin-bottom:1.5rem}.article-tags{display:flex;flex-wrap:wrap;gap:.5rem}.article-tag{font-size:.8rem;padding:.375rem .75rem;background-color:var(--secondary);color:var(--secondary-foreground);border-radius:9999px;font-weight:500}.article-hero-image{margin-bottom:2rem;border-radius:var(--radius);overflow:hidden}.article-hero-image img{width:100%;height:auto;display:block}.article-content{font-size:1.0625rem}@media(max-width:640px){.article-title{font-size:1.75rem}.article-description{font-size:1.0625rem}.article-content{font-size:1rem}}
