:root{--font-ui: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-article: "Source Serif 4", "Georgia", "Charter", "Times New Roman", serif;--font-code: "JetBrains Mono", "Fira Code", "Consolas", monospace;--color-bg: #ffffff;--color-bg-secondary: #f7f7f7;--color-bg-elevated: #ffffff;--color-surface: #fafafa;--color-text-primary: #242424;--color-text-secondary: #6b6b6b;--color-text-tertiary: #9a9a9a;--color-border: #e6e6e6;--color-border-light: #f2f2f2;--color-accent: #1a8917;--color-accent-hover: #0f7b0f;--color-accent-light: rgba(26, 137, 23, .08);--color-link: #1a8917;--color-danger: #c94a4a;--color-warning: #e09200;--color-success: #1a8917;--color-code-bg: #f6f8fa;--color-code-border: #e1e4e8;--color-tag-bg: #f2f2f2;--color-tag-text: #6b6b6b;--color-shadow: rgba(0, 0, 0, .05);--color-shadow-hover: rgba(0, 0, 0, .1);--color-overlay: rgba(0, 0, 0, .4);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--max-width-article: 728px;--max-width-page: 1200px;--max-width-narrow: 680px;--header-height: 65px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease}[data-theme=dark]{--color-bg: #0d1117;--color-bg-secondary: #161b22;--color-bg-elevated: #1c2129;--color-surface: #161b22;--color-text-primary: #e6edf3;--color-text-secondary: #8b949e;--color-text-tertiary: #6e7681;--color-border: #30363d;--color-border-light: #21262d;--color-accent: #3fb950;--color-accent-hover: #2ea043;--color-accent-light: rgba(63, 185, 80, .1);--color-link: #58a6ff;--color-code-bg: #161b22;--color-code-border: #30363d;--color-tag-bg: #21262d;--color-tag-text: #8b949e;--color-shadow: rgba(0, 0, 0, .3);--color-shadow-hover: rgba(0, 0, 0, .5);--color-overlay: rgba(0, 0, 0, .6)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{font-family:var(--font-ui);color:var(--color-text-primary);background-color:var(--color-bg);line-height:1.6;min-height:100vh;transition:background-color var(--transition-normal),color var(--transition-normal)}a{color:var(--color-link);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-hover)}img{max-width:100%;height:auto;display:block}.header{position:sticky;top:0;z-index:100;background:var(--color-bg);border-bottom:1px solid var(--color-border);height:var(--header-height);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffd9}[data-theme=dark] .header{background:#0d1117d9}.header-inner{max-width:var(--max-width-page);margin:0 auto;padding:0 var(--space-6);height:100%;display:flex;align-items:center;justify-content:space-between}.header-logo{font-family:var(--font-ui);font-size:1.25rem;font-weight:700;color:var(--color-text-primary);letter-spacing:-.02em}.header-logo:hover{color:var(--color-text-primary)}.header-nav{display:flex;align-items:center;gap:var(--space-6)}.header-nav a{font-size:.875rem;font-weight:500;color:var(--color-text-secondary);padding:var(--space-2) 0;position:relative}.header-nav a:hover,.header-nav a.active{color:var(--color-text-primary)}.header-nav a.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--color-accent);border-radius:1px}.theme-toggle{background:none;border:none;cursor:pointer;font-size:1.2rem;color:var(--color-text-secondary);padding:var(--space-2);border-radius:var(--radius-full);transition:all var(--transition-fast);display:flex;align-items:center}.theme-toggle:hover{background:var(--color-accent-light);color:var(--color-accent)}.page{max-width:var(--max-width-page);margin:0 auto;padding:var(--space-10) var(--space-6);min-height:calc(100vh - var(--header-height))}.page-narrow{max-width:var(--max-width-article)}.blog-grid{display:grid;gap:var(--space-10)}.blog-card{display:flex;gap:var(--space-8);padding-bottom:var(--space-10);border-bottom:1px solid var(--color-border-light);transition:transform var(--transition-fast)}.blog-card-content{flex:1;display:flex;flex-direction:column;gap:var(--space-3)}.blog-card-meta{display:flex;align-items:center;gap:var(--space-2);font-size:.8125rem;color:var(--color-text-secondary)}.blog-card-author{font-weight:600;color:var(--color-text-primary)}.blog-card h2{font-family:var(--font-ui);font-size:1.25rem;font-weight:700;line-height:1.3;color:var(--color-text-primary);letter-spacing:-.018em}.blog-card h2:hover{color:var(--color-text-primary)}.blog-card-subtitle{font-size:.9375rem;color:var(--color-text-secondary);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.blog-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:var(--space-3)}.blog-card-tags{display:flex;gap:var(--space-2);flex-wrap:wrap}.tag{display:inline-block;font-size:.75rem;font-weight:500;padding:var(--space-1) var(--space-3);background:var(--color-tag-bg);color:var(--color-tag-text);border-radius:var(--radius-full);transition:all var(--transition-fast)}.tag:hover{background:var(--color-accent-light);color:var(--color-accent)}.blog-card-stats{display:flex;align-items:center;gap:var(--space-4);font-size:.8125rem;color:var(--color-text-tertiary)}.blog-card-cover{width:200px;height:134px;object-fit:cover;border-radius:var(--radius-md);flex-shrink:0}.article{max-width:var(--max-width-article);margin:0 auto;padding:var(--space-10) var(--space-6)}.article-header{margin-bottom:var(--space-10)}.article-header h1{font-family:var(--font-article);font-size:clamp(2rem,5vw,2.75rem);font-weight:700;line-height:1.18;letter-spacing:-.021em;color:var(--color-text-primary);margin-bottom:var(--space-5);font-optical-sizing:auto}.article-header .subtitle{font-family:var(--font-article);font-size:1.375rem;color:var(--color-text-secondary);line-height:1.58;font-weight:400;margin-top:var(--space-3);font-optical-sizing:auto}.article-meta{display:flex;align-items:center;gap:var(--space-4);margin-top:var(--space-8);padding:var(--space-5) 0;border-top:1px solid var(--color-border-light);border-bottom:1px solid var(--color-border-light)}.article-meta-author{display:flex;align-items:center;gap:var(--space-3)}.article-meta-avatar{width:48px;height:48px;border-radius:var(--radius-full);object-fit:cover;background:var(--color-accent-light);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--color-accent);font-size:1.25rem}.article-meta-info{display:flex;flex-direction:column;gap:3px}.article-meta-name{font-weight:600;font-size:.9375rem;color:var(--color-text-primary)}.article-meta-details{font-size:.8125rem;color:var(--color-text-secondary)}.article-cover{width:100%;border-radius:var(--radius-lg);margin:var(--space-10) 0}.article-content{font-family:var(--font-article);font-size:1.225rem;line-height:1.92;color:var(--color-text-primary);font-optical-sizing:auto;word-break:break-word;-webkit-font-smoothing:antialiased;letter-spacing:-.003em}.article-content h2{font-family:var(--font-ui);font-size:1.65rem;font-weight:700;line-height:1.25;letter-spacing:-.025em;color:var(--color-text-primary);margin-top:2.75em;margin-bottom:.55em}.article-content h3{font-family:var(--font-ui);font-size:1.3rem;font-weight:700;line-height:1.3;letter-spacing:-.018em;color:var(--color-text-primary);margin-top:2.1em;margin-bottom:.5em}.article-content h4{font-family:var(--font-ui);font-size:1.1rem;font-weight:700;line-height:1.35;color:var(--color-text-primary);margin-top:1.75em;margin-bottom:.45em}.article-content p{margin-bottom:1.45em;margin-top:0}.article-content h2+p,.article-content h3+p,.article-content h4+p{margin-top:0}.article-content a{color:var(--color-link);text-decoration:underline;text-underline-offset:4px;text-decoration-thickness:1px}.article-content a:hover{text-decoration-thickness:2px}.article-content strong{font-weight:700;color:var(--color-text-primary)}.article-content em{font-style:italic}.article-content blockquote{border-left:3px solid var(--color-text-primary);padding:var(--space-2) 0 var(--space-2) var(--space-6);margin:2em 0;font-style:italic;font-size:1.3rem;line-height:1.7;color:var(--color-text-secondary)}.article-content blockquote p{margin-bottom:0}.article-content ul,.article-content ol{margin:1em 0 1.5em 1.5em;padding:0}.article-content li{margin-bottom:.4em;line-height:1.8}.article-content li::marker{color:var(--color-text-secondary)}.article-content code{font-family:var(--font-code);font-size:.825em;background:#0000000d;border-radius:4px;padding:.18em .45em;word-break:break-word;color:var(--color-text-primary)}[data-theme=dark] .article-content code{background:#ffffff1a}.article-content pre{background:var(--color-code-bg);border:1px solid var(--color-code-border);border-radius:var(--radius-md);padding:var(--space-5) var(--space-6);margin:2em 0;overflow-x:auto;font-size:.875rem;line-height:1.7}.article-content pre code{background:none;border:none;padding:0;font-size:inherit;color:inherit}.article-content img{width:100%;border-radius:var(--radius-md);margin:2em 0;display:block}.article-content figure{margin:2em 0}.article-content figcaption{font-family:var(--font-ui);font-size:.82rem;color:var(--color-text-tertiary);text-align:center;margin-top:var(--space-2);line-height:1.5}.article-content hr{border:none;text-align:center;margin:3em 0;color:var(--color-text-tertiary)}.article-content hr:before{content:"· · ·";font-size:1.25rem;letter-spacing:.5em;color:var(--color-text-tertiary)}.article-content table{width:100%;border-collapse:collapse;margin:2em 0;font-size:.95em}.article-content th{background:var(--color-surface);font-family:var(--font-ui);font-weight:600;font-size:.875rem;text-align:left;padding:var(--space-3) var(--space-4);border-bottom:2px solid var(--color-border)}.article-content td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-light);vertical-align:top;line-height:1.6}.reading-progress{position:fixed;top:var(--header-height);left:0;width:0;height:3px;background:var(--color-accent);z-index:101;transition:width .1s linear}.engagement-bar{position:sticky;bottom:var(--space-6);display:flex;align-items:center;justify-content:center;gap:var(--space-6);margin:var(--space-10) auto;max-width:300px;padding:var(--space-3) var(--space-6);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-full);box-shadow:0 4px 20px var(--color-shadow)}.engagement-btn{display:flex;align-items:center;gap:var(--space-2);background:none;border:none;cursor:pointer;font-size:.875rem;color:var(--color-text-secondary);padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);transition:all var(--transition-fast)}.engagement-btn:hover{color:var(--color-accent);background:var(--color-accent-light)}.engagement-btn.active{color:var(--color-accent)}.engagement-btn svg{width:20px;height:20px}.comments-section{max-width:var(--max-width-article);margin:0 auto;padding:var(--space-10) var(--space-6);border-top:1px solid var(--color-border)}.comments-section h3{font-family:var(--font-ui);font-size:1.25rem;font-weight:700;margin-bottom:var(--space-8)}.comment{padding:var(--space-5) 0;border-bottom:1px solid var(--color-border-light)}.comment-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.comment-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--color-accent-light);color:var(--color-accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8125rem}.comment-author{font-weight:600;font-size:.875rem}.comment-date{font-size:.75rem;color:var(--color-text-tertiary)}.comment-body{font-size:.9375rem;line-height:1.6;color:var(--color-text-primary)}.comment-reply{margin-left:var(--space-10);border-left:2px solid var(--color-border-light);padding-left:var(--space-5)}.comment-form{margin-top:var(--space-8);display:flex;flex-direction:column;gap:var(--space-4)}.input,.textarea{font-family:var(--font-ui);font-size:.9375rem;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text-primary);transition:border-color var(--transition-fast);width:100%}.input:focus,.textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.textarea{min-height:100px;resize:vertical}.btn{font-family:var(--font-ui);font-size:.875rem;font-weight:600;padding:var(--space-3) var(--space-5);border:none;border-radius:var(--radius-full);cursor:pointer;display:inline-flex;align-items:center;gap:var(--space-2);transition:all var(--transition-fast);white-space:nowrap}.btn-primary{background:var(--color-accent);color:#fff}.btn-primary:hover{background:var(--color-accent-hover)}.btn-secondary{background:transparent;color:var(--color-accent);border:1px solid var(--color-accent)}.btn-secondary:hover{background:var(--color-accent-light)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover{background:var(--color-surface);color:var(--color-text-primary)}.btn-danger{background:var(--color-danger);color:#fff}.btn-sm{font-size:.8125rem;padding:var(--space-2) var(--space-4)}.btn-lg{font-size:1rem;padding:var(--space-4) var(--space-8)}.newsletter{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-10);text-align:center;margin:var(--space-16) 0}.newsletter h3{font-family:var(--font-article);font-size:1.5rem;font-weight:700;margin-bottom:var(--space-3)}.newsletter p{color:var(--color-text-secondary);margin-bottom:var(--space-6)}.newsletter-form{display:flex;gap:var(--space-3);max-width:400px;margin:0 auto}.newsletter-form .input{flex:1}.footer{border-top:1px solid var(--color-border);padding:var(--space-10) var(--space-6);text-align:center;color:var(--color-text-secondary);font-size:.8125rem}.footer-inner{max-width:var(--max-width-page);margin:0 auto;display:flex;align-items:center;justify-content:space-between}.footer-links{display:flex;gap:var(--space-5)}.footer-links a{color:var(--color-text-secondary);font-size:.8125rem}.footer-links a:hover{color:var(--color-text-primary)}.admin-layout{display:flex;height:calc(100vh - var(--header-height))}.admin-sidebar{width:240px;background:var(--color-bg-secondary);border-right:1px solid var(--color-border);padding:var(--space-6) 0;flex-shrink:0}.admin-sidebar a{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-6);font-size:.875rem;font-weight:500;color:var(--color-text-secondary);transition:all var(--transition-fast)}.admin-sidebar a:hover,.admin-sidebar a.active{color:var(--color-text-primary);background:var(--color-accent-light)}.admin-content{flex:1;padding:var(--space-8);overflow-y:auto}.admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-8)}.admin-header h1{font-size:1.5rem;font-weight:700}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-5);margin-bottom:var(--space-8)}.stat-card{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6)}.stat-card-label{font-size:.8125rem;color:var(--color-text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.stat-card-value{font-size:2rem;font-weight:700;color:var(--color-text-primary);margin-top:var(--space-2)}.stat-card-change{font-size:.8125rem;margin-top:var(--space-1)}.stat-card-change.positive{color:var(--color-success)}.stat-card-change.negative{color:var(--color-danger)}.table-container{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-lg)}table{width:100%;border-collapse:collapse;font-size:.875rem}th{text-align:left;padding:var(--space-3) var(--space-4);font-weight:600;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border);background:var(--color-surface);white-space:nowrap}td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-light);color:var(--color-text-primary)}tr:hover td{background:var(--color-surface)}.badge{display:inline-block;font-size:.6875rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em}.badge-success{background:#1a89171f;color:var(--color-success)}.badge-warning{background:#e092001f;color:var(--color-warning)}.badge-danger{background:#c94a4a1f;color:var(--color-danger)}.badge-neutral{background:var(--color-tag-bg);color:var(--color-tag-text)}.editor-wrapper{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:visible}.editor-toolbar{display:flex;flex-wrap:wrap;gap:var(--space-1);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;position:sticky;top:0;z-index:10}.editor-toolbar button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);cursor:pointer;font-size:.9375rem;transition:all var(--transition-fast)}.editor-toolbar button:hover,.editor-toolbar button.active{background:var(--color-accent-light);color:var(--color-accent)}.editor-toolbar .divider{width:1px;height:24px;background:var(--color-border);margin:0 var(--space-2);align-self:center}.ProseMirror{min-height:400px;padding:var(--space-6);font-family:var(--font-article);font-size:1.125rem;line-height:1.8;outline:none}.ProseMirror p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--color-text-tertiary);pointer-events:none;height:0}.ProseMirror pre{background:#1e1e2e;color:#cdd6f4;border-radius:var(--radius-md);padding:var(--space-5);margin:var(--space-4) 0;overflow-x:auto;font-family:JetBrains Mono,Fira Code,Cascadia Code,monospace;font-size:.875rem;line-height:1.7;border:1px solid rgba(255,255,255,.06)}.ProseMirror pre code{background:none;color:inherit;padding:0;font-size:inherit;border-radius:0}.ProseMirror code{background:#7f849c26;color:#e64553;padding:.15em .4em;border-radius:4px;font-family:JetBrains Mono,Fira Code,monospace;font-size:.85em}.ProseMirror pre .hljs-keyword,.ProseMirror pre .hljs-selector-tag,.ProseMirror pre .hljs-built_in{color:#cba6f7}.ProseMirror pre .hljs-string,.ProseMirror pre .hljs-addition{color:#a6e3a1}.ProseMirror pre .hljs-number,.ProseMirror pre .hljs-literal{color:#fab387}.ProseMirror pre .hljs-comment,.ProseMirror pre .hljs-quote{color:#6c7086;font-style:italic}.ProseMirror pre .hljs-type,.ProseMirror pre .hljs-class,.ProseMirror pre .hljs-title{color:#f9e2af}.ProseMirror pre .hljs-function,.ProseMirror pre .hljs-title.function_{color:#89b4fa}.ProseMirror pre .hljs-variable,.ProseMirror pre .hljs-attr{color:#89dceb}.ProseMirror pre .hljs-params{color:#f2cdcd}.ProseMirror pre .hljs-meta,.ProseMirror pre .hljs-meta .hljs-keyword{color:#f38ba8}.ProseMirror pre .hljs-symbol,.ProseMirror pre .hljs-bullet{color:#f5c2e7}.ProseMirror pre .hljs-deletion{color:#f38ba8;background:#f38ba81a}.ProseMirror pre .hljs-addition{background:#a6e3a11a}.ProseMirror pre .hljs-operator{color:#94e2d5}.ProseMirror pre .hljs-punctuation{color:#9399b2}.ProseMirror blockquote{border-left:3px solid var(--color-accent);padding-left:var(--space-4);margin:var(--space-4) 0;color:var(--color-text-secondary);font-style:italic}.toast-container{position:fixed;bottom:var(--space-6);right:var(--space-6);z-index:1000;display:flex;flex-direction:column;gap:var(--space-3)}.toast{padding:var(--space-4) var(--space-6);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;color:#fff;animation:slideIn .3s ease;box-shadow:0 4px 12px var(--color-shadow)}.toast-success{background:var(--color-success)}.toast-error{background:var(--color-danger)}.toast-info{background:#1976d2}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}.modal-content{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-8);width:100%;max-width:500px;box-shadow:0 10px 40px #0003;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}.modal-title{font-family:var(--font-article);font-size:1.5rem;font-weight:700;color:var(--color-text-primary);margin-bottom:var(--space-2)}.modal-actions{margin-top:var(--space-8);display:flex;justify-content:flex-end;gap:var(--space-4)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.login-page{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - var(--header-height))}.login-card{width:100%;max-width:400px;padding:var(--space-10);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 4px 24px var(--color-shadow)}.login-card h1{font-family:var(--font-article);font-size:1.5rem;font-weight:700;text-align:center;margin-bottom:var(--space-8)}.login-card .form-group{margin-bottom:var(--space-5)}.login-card label{display:block;font-size:.8125rem;font-weight:600;margin-bottom:var(--space-2);color:var(--color-text-secondary)}.login-card .btn{width:100%;justify-content:center;margin-top:var(--space-4)}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-3);margin-top:var(--space-10)}.pagination button{padding:var(--space-2) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text-primary);cursor:pointer;font-size:.875rem;transition:all var(--transition-fast)}.pagination button:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.pagination button.active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.featured-section{margin-bottom:var(--space-16);padding-bottom:var(--space-10);border-bottom:1px solid var(--color-border)}.featured-section h2{font-family:var(--font-ui);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-secondary);margin-bottom:var(--space-6)}.loading{display:flex;align-items:center;justify-content:center;padding:var(--space-16)}.spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}.empty-state{text-align:center;padding:var(--space-16);color:var(--color-text-secondary)}.empty-state h3{font-size:1.25rem;margin-bottom:var(--space-3);color:var(--color-text-primary)}@media(max-width:768px){.blog-card{flex-direction:column-reverse}.blog-card-cover{width:100%;height:200px}.article-header h1{font-size:1.75rem}.article-content{font-size:1.0625rem}.header-nav{gap:var(--space-4)}.admin-layout{flex-direction:column}.admin-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--color-border);padding:var(--space-3) 0;display:flex;overflow-x:auto}.admin-sidebar a{padding:var(--space-2) var(--space-4);white-space:nowrap}.newsletter-form{flex-direction:column}.footer-inner{flex-direction:column;gap:var(--space-4)}.engagement-bar{max-width:100%;margin-left:var(--space-4);margin-right:var(--space-4)}.stats-grid{grid-template-columns:1fr 1fr}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}}
