:root{--purple:#7c3aed;--purple-hover:#6d28d9;--purple-light:#ede9fe;--purple-muted:#f5f3ff;--bg:#f9f6f2;--bg-card:#fff;--bg-muted:#f0ebe4;--text:#1a1a1a;--text-muted:#6b6b6b;--border:#e8e4df;--border-radius:14px;--shadow:0 2px 10px #0000000f;--shadow-hover:0 8px 28px #0000001a;--font-body:"Inter",system-ui,-apple-system,sans-serif;--font-heading:"Lora",Georgia,"Times New Roman",serif;--container:1100px;--transition:0.18s ease}html.dark{--purple:#a78bfa;--purple-hover:#c4b5fd;--purple-light:#2d1b69;--purple-muted:#1e1a35;--bg:#0d0d0d;--bg-card:#171724;--bg-muted:#13131f;--text:#f0eef5;--text-muted:#9d9aaa;--border:#252535;--shadow:0 2px 10px #0000004d;--shadow-hover:0 8px 28px #00000080}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f9f6f2;background:var(--bg);color:#1a1a1a;color:var(--text);font-family:Inter,system-ui,-apple-system,sans-serif;font-family:var(--font-body);line-height:1.6;transition:background .18s ease,color .18s ease;transition:background var(--transition),color var(--transition)}#root,body{min-height:100vh}#root{display:flex;flex-direction:column}img{display:block;max-width:100%}button{font-family:inherit}a{color:inherit}.navbar{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:var(--bg);border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;z-index:100}.navbar-inner{align-items:center;display:flex;gap:2rem;height:64px;margin:0 auto;max-width:var(--container);padding:0 1.5rem}.navbar-logo{color:var(--text);flex-shrink:0;font-family:var(--font-heading);font-size:1.5rem;font-weight:700;letter-spacing:-.02em;text-decoration:none}.logo-dot{color:var(--purple)}.navbar-links{align-items:center;display:flex;flex:1 1;gap:.25rem}.nav-link{border-radius:6px;color:var(--text-muted);font-size:.925rem;font-weight:500;padding:.4rem .75rem;text-decoration:none;transition:color var(--transition),background var(--transition)}.nav-link:hover{background:var(--bg-muted);color:var(--text)}.nav-link.active{background:var(--purple-muted);color:var(--purple)}.navbar-right{gap:.75rem;margin-left:auto}.navbar-right,.theme-btn{align-items:center;display:flex}.theme-btn{background:#0000;border:1px solid var(--border);border-radius:8px;color:var(--text-muted);cursor:pointer;height:36px;justify-content:center;transition:color var(--transition),background var(--transition),border-color var(--transition);width:36px}.theme-btn:hover{background:var(--purple-muted);border-color:var(--purple);color:var(--purple)}.btn-subscribe{background:var(--purple);border-radius:8px;color:#fff;font-size:.875rem;font-weight:600;padding:.45rem 1.1rem;text-decoration:none;transition:background var(--transition),transform var(--transition)}.btn-subscribe:hover{background:var(--purple-hover);transform:translateY(-1px)}.hamburger{background:none;border:none;cursor:pointer;display:none;flex-direction:column;gap:5px;margin-left:auto;padding:6px}.hamburger span{background:var(--text);border-radius:2px;display:block;height:2px;transform-origin:center;transition:transform .25s ease,opacity .25s ease;width:22px}.hamburger.open span:first-child{transform:translateY(7px) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}@media (max-width:640px){.hamburger{display:flex}.navbar-right .btn-subscribe{display:none}.navbar-links{align-items:flex-start;background:var(--bg);border-bottom:1px solid var(--border);display:none;flex-direction:column;gap:.25rem;left:0;padding:1rem 1.5rem;position:absolute;right:0;top:64px}.navbar-links.open{display:flex}.nav-link{padding:.6rem .75rem;width:100%}}.footer{background:var(--bg-card);border-top:1px solid var(--border);margin-top:auto}.footer-inner{align-items:flex-start;display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between;margin:0 auto;max-width:var(--container);padding:2.5rem 1.5rem 1.5rem}.footer-logo{color:var(--text);font-family:var(--font-heading);font-size:1.4rem;font-weight:700;letter-spacing:-.02em;text-decoration:none}.footer-logo span{color:var(--purple)}.footer-tagline{color:var(--text-muted);font-size:.875rem;margin-top:.4rem}.footer-links{align-items:center;display:flex;gap:1.5rem;padding-top:.25rem}.footer-links a{color:var(--text-muted);font-size:.875rem;text-decoration:none;transition:color var(--transition)}.footer-links a:hover{color:var(--purple)}.footer-bottom{align-items:center;border-top:1px solid var(--border);color:var(--text-muted);display:flex;flex-wrap:wrap;font-size:.8rem;gap:1rem;justify-content:space-between;margin:0 auto;max-width:var(--container);padding:1rem 1.5rem}.blog-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--border-radius);display:flex;flex-direction:column;gap:.75rem;overflow:hidden;padding:1.75rem;transition:box-shadow var(--transition),transform var(--transition),border-color var(--transition)}.card-cover{margin:-1.75rem -1.75rem 0}.card-cover-img{border-radius:var(--border-radius) var(--border-radius) 0 0;display:block;height:180px;object-fit:cover;width:100%}.blog-card:hover{border-color:var(--purple-light);box-shadow:var(--shadow-hover);transform:translateY(-2px)}.card-meta-top{align-items:center;display:flex;gap:.5rem;justify-content:space-between}.card-category{background:var(--purple-muted);border-radius:20px;color:var(--purple);font-size:.75rem;font-weight:600;letter-spacing:.04em;padding:.2rem .6rem;text-transform:uppercase}.card-read-time{color:var(--text-muted);font-size:.8rem}.card-title{font-family:var(--font-heading);font-size:1.25rem;font-weight:600;line-height:1.35;margin:0}.card-title a{color:var(--text);text-decoration:none;transition:color var(--transition)}.card-title a:hover{color:var(--purple)}.card-excerpt{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:var(--text-muted);display:-webkit-box;font-size:.925rem;line-height:1.65;margin:0;overflow:hidden}.card-footer{align-items:center;border-top:1px solid var(--border);display:flex;justify-content:space-between;margin-top:auto;padding-top:.5rem}.card-date{color:var(--text-muted);font-size:.8rem}.card-read-more{align-items:center;color:var(--purple);display:flex;font-size:.875rem;font-weight:600;gap:.3rem;text-decoration:none;transition:gap var(--transition)}.card-read-more:hover{gap:.5rem}.card-tags{display:flex;flex-wrap:wrap;gap:.4rem}.card-tag{color:var(--text-muted);font-size:.75rem}.newsletter{background:linear-gradient(135deg,var(--purple) 0,#5b21b6 100%);border-radius:var(--border-radius);padding:3.5rem 2rem}.newsletter-inner{margin:0 auto;max-width:560px;text-align:center}.newsletter-badge{color:#ffffffb3;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.08em;margin-bottom:.75rem;text-transform:uppercase}.newsletter-text h2{color:#fff;font-family:var(--font-heading);font-size:2rem;font-weight:700;line-height:1.2;margin:0 0 .75rem}.newsletter-text p{color:#fffc;font-size:1rem;line-height:1.6;margin:0 0 2rem}.newsletter-form .input-group{display:flex;gap:.5rem;margin:0 auto;max-width:420px}.newsletter-form input{background:#ffffff26;border:2px solid #ffffff4d;border-radius:8px;color:#fff;flex:1 1;font-size:.925rem;outline:none;padding:.7rem 1rem;transition:border-color var(--transition),background var(--transition)}.newsletter-form input::placeholder{color:#ffffff8c}.newsletter-form input:focus{background:#fff3;border-color:#ffffffb3}.newsletter-form button{background:#fff;border:none;border-radius:8px;color:var(--purple);cursor:pointer;font-size:.925rem;font-weight:700;padding:.7rem 1.4rem;transition:transform var(--transition),background var(--transition);white-space:nowrap}.newsletter-form button:hover:not(:disabled){background:#f0eef5;transform:translateY(-1px)}.newsletter-form button:disabled{cursor:not-allowed;opacity:.7}.newsletter-error{color:#ffffffd9;font-size:.875rem;margin-top:.6rem;text-align:center}.newsletter-success{align-items:center;color:#fff;display:flex;flex-direction:column;gap:.5rem}.success-icon{animation:pop .4s ease;font-size:2rem}.newsletter-success h3{font-family:var(--font-heading);font-size:1.75rem;margin:0}.newsletter-success p{color:#fffc;font-size:1rem;margin:0}@keyframes pop{0%{opacity:0;transform:scale(0)}70%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}@media (max-width:480px){.newsletter{padding:2.5rem 1.25rem}.newsletter-text h2{font-size:1.6rem}.newsletter-form .input-group{flex-direction:column}}.home{display:flex;flex-direction:column;gap:5rem}.hero{margin:0 auto;max-width:var(--container);overflow:hidden;padding:5rem 1.5rem 4rem;position:relative;width:100%}.hero-inner{max-width:680px;position:relative;z-index:1}.hero-label{background:var(--purple-muted);border-radius:20px;color:var(--purple);display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.1em;margin-bottom:1.5rem;padding:.3rem .8rem;text-transform:uppercase}.hero-title{color:var(--text);font-family:var(--font-heading);font-size:clamp(2.5rem,6vw,4rem);font-weight:700;letter-spacing:-.02em;line-height:1.1;margin:0 0 1.25rem}.hero-accent{color:var(--purple)}.hero-subtitle{color:var(--text-muted);font-size:1.1rem;line-height:1.7;margin:0 0 2.25rem;max-width:520px}.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem}.hero-decoration{bottom:0;left:0;overflow:hidden;pointer-events:none;position:absolute;right:0;top:0}.blob{border-radius:50%;filter:blur(60px);opacity:.18;position:absolute}.blob-1{background:var(--purple);height:400px;right:-80px;top:-100px;width:400px}.blob-2{background:#a78bfa;bottom:-80px;height:300px;right:200px;width:300px}.latest-posts{margin:0 auto;max-width:var(--container);padding:0 1.5rem;width:100%}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.75rem}.section-header h2{color:var(--text);font-family:var(--font-heading);font-size:1.75rem;font-weight:700;margin:0}.see-all{align-items:center;color:var(--purple);display:flex;font-size:.875rem;font-weight:600;gap:.3rem;text-decoration:none;transition:gap var(--transition)}.see-all:hover{gap:.5rem}.newsletter-wrapper{max-width:var(--container);padding:0 1.5rem 5rem}.btn-primary{gap:.4rem}.btn-ghost{transition:border-color var(--transition),background var(--transition)}@media (max-width:640px){.hero{padding:3rem 1.25rem 2rem}.posts-grid{grid-template-columns:1fr}}.blog-list{display:flex;flex-direction:column;gap:2.5rem;margin:0 auto;max-width:var(--container);padding:0 1.5rem}.blog-list-header{padding-top:3.5rem}.blog-list-header h1{color:var(--text);font-family:var(--font-heading);font-size:clamp(2rem,5vw,3rem);font-weight:700;margin:0 0 .5rem}.blog-list-header p{color:var(--text-muted);font-size:1rem;margin:0}.category-filter{display:flex;flex-wrap:wrap;gap:.5rem}.filter-btn{background:#0000;border:1.5px solid var(--border);border-radius:20px;color:var(--text-muted);cursor:pointer;font-size:.875rem;font-weight:500;padding:.4rem 1rem;transition:all var(--transition)}.filter-btn:hover{background:var(--purple-muted);border-color:var(--purple);color:var(--purple)}.filter-btn.active{background:var(--purple);border-color:var(--purple);color:#fff}.posts-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.no-posts{color:var(--text-muted);font-size:1rem;padding:3rem 0;text-align:center}.newsletter-wrapper{padding-bottom:5rem}@media (max-width:640px){.posts-grid{grid-template-columns:1fr}}.comment-section{margin-top:1rem}.comments-heading{color:var(--text);font-family:var(--font-heading);font-size:1.2rem;font-weight:600;margin:0 0 1.5rem}.comments-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:2.5rem}.comment{background:var(--bg-muted);border-left:3px solid var(--purple);border-radius:10px;padding:1rem 1.25rem}.comment-header{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.5rem}.comment-name{color:var(--text);font-size:.9rem;font-weight:600}.comment-date{color:var(--text-muted);flex-shrink:0;font-size:.775rem}.comment-body{color:var(--text);font-size:.925rem;line-height:1.65;margin:0;white-space:pre-wrap}.comments-empty{color:var(--text-muted);font-size:.9rem;font-style:italic;margin:0}.comment-form{border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.75rem;padding-top:1.25rem}.comment-form-heading{color:var(--text);font-size:1rem;font-weight:600;margin:0}.comment-input{background:var(--bg-card);border:1.5px solid var(--border);border-radius:8px;box-sizing:border-box;color:var(--text);font-family:var(--font-body);font-size:.925rem;outline:none;padding:.65rem .875rem;transition:border-color var(--transition);width:100%}.comment-input:focus{border-color:var(--purple)}.comment-textarea{line-height:1.6;min-height:100px;resize:vertical}.comment-submit{align-self:flex-start;background:var(--purple);border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:var(--font-body);font-size:.875rem;font-weight:600;padding:.55rem 1.25rem;transition:background var(--transition)}.comment-submit:hover:not(:disabled){background:var(--purple-hover)}.comment-submit:disabled{cursor:not-allowed;opacity:.65}.blog-post-page{display:flex;flex-direction:column;gap:4rem;padding-bottom:5rem}.post-container{margin:0 auto;max-width:720px;padding:2.5rem 1.5rem 0;width:100%}.back-link{align-items:center;color:var(--text-muted);display:inline-flex;font-size:.875rem;font-weight:500;gap:.4rem;margin-bottom:2.5rem;text-decoration:none;transition:color var(--transition)}.back-link:hover{color:var(--purple)}.post-header{margin-bottom:2.5rem}.post-meta{align-items:center;color:var(--text-muted);display:flex;flex-wrap:wrap;font-size:.875rem;gap:.5rem;margin-bottom:1rem}.post-category{background:var(--purple-muted);border-radius:20px;color:var(--purple);font-size:.75rem;font-weight:600;letter-spacing:.04em;padding:.2rem .6rem;text-transform:uppercase}.post-dot{color:var(--border)}.post-title{color:var(--text);font-family:var(--font-heading);font-size:clamp(1.75rem,4vw,2.75rem);font-weight:700;letter-spacing:-.02em;line-height:1.2;margin:0}.post-cover-image{border-radius:var(--border-radius);margin-bottom:2.5rem;max-height:420px;object-fit:cover;width:100%}.post-body{color:var(--text);font-size:1.05rem;line-height:1.8}.post-body p{margin:0 0 1.5rem}.post-body h3{font-family:var(--font-heading);font-size:1.3rem;margin:2.25rem 0 .75rem}.post-body h3,.post-body strong{color:var(--text);font-weight:600}.post-body em{color:var(--text-muted);font-style:italic}.post-body ol,.post-body ul{display:flex;flex-direction:column;gap:.5rem;margin:0 0 1.5rem;padding-left:1.5rem}.post-body li{line-height:1.7}.post-like-row{display:flex;justify-content:center;margin:2.5rem 0 0}.like-btn{align-items:center;background:#0000;border:1.5px solid var(--border);border-radius:2rem;color:var(--text-muted);cursor:pointer;display:inline-flex;font-family:var(--font-body);font-size:.9rem;gap:.5rem;padding:.6rem 1.5rem;transition:border-color var(--transition),color var(--transition),background var(--transition)}.like-btn.liked,.like-btn:hover{border-color:#f43f5e;color:#f43f5e}.like-btn.liked{background:#f43f5e12}.like-btn:disabled{cursor:not-allowed;opacity:.6}.post-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:2.5rem}.post-tag{background:var(--bg-muted);border-radius:4px;color:var(--text-muted);font-size:.8rem;padding:.25rem .6rem}.post-divider{background:var(--border);height:1px;margin:2.5rem 0}.post-author-card{align-items:center;background:var(--bg-muted);border-radius:var(--border-radius);display:flex;gap:1rem;padding:1.25rem}.author-avatar{align-items:center;background:var(--purple);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-family:var(--font-heading);font-size:1.25rem;font-weight:700;height:48px;justify-content:center;width:48px}.author-info{display:flex;flex-direction:column;gap:.2rem}.author-info strong{color:var(--text);font-size:.95rem;font-weight:600}.author-info span{color:var(--text-muted);font-size:.875rem}.newsletter-wrapper.post-newsletter{margin:0 auto;max-width:720px;padding:0 1.5rem;width:100%}.about-page{display:flex;flex-direction:column;gap:4rem;padding-bottom:5rem}.about-container{margin:0 auto;max-width:680px;padding:3.5rem 1.5rem 0;width:100%}.about-avatar-wrap{margin-bottom:2rem}.about-avatar{align-items:center;background:linear-gradient(135deg,var(--purple) 0,#5b21b6 100%);border-radius:50%;box-shadow:0 4px 20px #7c3aed4d;color:#fff;display:flex;font-size:2rem;height:80px;justify-content:center;width:80px}.about-avatar,.about-content h1{font-family:var(--font-heading);font-weight:700}.about-content h1{color:var(--text);font-size:clamp(2rem,5vw,3rem);letter-spacing:-.02em;margin:0 0 1.25rem}.about-lead{border-left:3px solid var(--purple);color:var(--text-muted);font-size:1.15rem;font-style:italic;line-height:1.7;margin:0 0 1.75rem;padding-left:1.25rem}.about-content p{color:var(--text-muted);font-size:1rem;line-height:1.8;margin:0 0 1.25rem}.about-content h2{color:var(--text);font-family:var(--font-heading);font-size:1.4rem;font-weight:600;margin:2.25rem 0 1rem}.about-list{display:flex;flex-direction:column;gap:.75rem;list-style:none;margin:0 0 2rem;padding:0}.about-list li{color:var(--text-muted);font-size:.975rem;line-height:1.65;padding-left:1.25rem;position:relative}.about-list li:before{color:var(--purple);content:"✦";font-size:.6rem;left:0;position:absolute;top:.35rem}.about-list strong{color:var(--text);font-weight:600}.about-cta{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:2.5rem}.btn-primary{align-items:center;background:var(--purple);border-radius:8px;color:#fff;display:inline-flex;font-size:.95rem;font-weight:600;padding:.7rem 1.5rem;text-decoration:none;transition:background var(--transition),transform var(--transition)}.btn-primary:hover{background:var(--purple-hover);transform:translateY(-1px)}.btn-ghost{align-items:center;border:1.5px solid var(--border);border-radius:8px;color:var(--text);display:inline-flex;font-size:.95rem;font-weight:600;padding:.7rem 1.5rem;text-decoration:none;transition:border-color var(--transition),background var(--transition),color var(--transition)}.btn-ghost:hover{background:var(--purple-muted);border-color:var(--purple);color:var(--purple)}.newsletter-wrapper{margin:0 auto;max-width:680px;padding:0 1.5rem;width:100%}.admin-layout{display:flex;min-height:100vh}.admin-sidebar{background:#13131f;display:flex;flex-direction:column;flex-shrink:0;height:100vh;overflow-y:auto;padding:1.5rem .875rem;position:-webkit-sticky;position:sticky;top:0;width:220px}.admin-sidebar-logo{color:#fff;font-family:var(--font-heading);font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.3rem;padding:0 .625rem}.admin-sidebar-logo span{color:#a78bfa}.admin-sidebar-label{color:#ffffff4d;font-size:.68rem;font-weight:600;letter-spacing:.1em;margin-bottom:1.25rem;padding:0 .625rem;text-transform:uppercase}.admin-nav-link{align-items:center;border-radius:8px;color:#ffffff8c;display:flex;font-size:.9rem;font-weight:500;margin-bottom:.15rem;padding:.575rem .75rem;text-decoration:none;transition:background .15s ease,color .15s ease}.admin-nav-link:hover{background:#ffffff12;color:#fff}.admin-nav-link.active{background:#a78bfa2e;color:#c4b5fd}.admin-sidebar-footer{border-top:1px solid #ffffff14;display:flex;flex-direction:column;gap:.4rem;margin-top:auto;padding-top:1rem}.admin-sidebar-user{color:#ffffff4d;font-size:.75rem;overflow:hidden;padding:0 .75rem;text-overflow:ellipsis;white-space:nowrap}.admin-sign-out{background:none;border:none;border-radius:8px;color:#ffffff59;cursor:pointer;font-family:var(--font-body);font-size:.875rem;padding:.5rem .75rem;text-align:left;transition:color .15s,background .15s}.admin-sign-out:hover{background:#ef44441a;color:#fc8181}.admin-main{background:var(--bg);flex:1 1;overflow-y:auto}.admin-page{max-width:960px;padding:2.25rem 2.5rem}.admin-page-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.admin-page-header h1{color:var(--text);flex:1 1;font-family:var(--font-heading);font-size:1.75rem;font-weight:700;margin:0}.admin-back-link{color:var(--text-muted);flex-basis:100%;font-size:.875rem;order:-1;text-decoration:none;transition:color var(--transition)}.admin-back-link:hover{color:var(--purple)}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin-bottom:2.5rem}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--border-radius);padding:1.5rem;text-align:center}.stat-value{color:var(--purple);font-family:var(--font-heading);font-size:2.25rem;font-weight:700;line-height:1;margin-bottom:.35rem}.stat-label{color:var(--text-muted);font-size:.825rem;font-weight:500}.admin-section h2{color:var(--text);font-family:var(--font-heading);font-size:1.15rem;font-weight:600;margin:0 0 1rem}.recent-posts-list{display:flex;flex-direction:column;gap:.5rem}.recent-post-item{align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;display:flex;gap:1rem;justify-content:space-between;padding:.875rem 1rem}.recent-post-left{align-items:center;display:flex;flex:1 1;gap:.75rem;min-width:0}.recent-post-title{color:var(--text);font-size:.925rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.posts-table{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--border-radius);overflow:hidden}.table-header{background:var(--bg-muted);color:var(--text-muted);font-size:.72rem;font-weight:600;letter-spacing:.06em;padding:.7rem 1.25rem;text-transform:uppercase}.table-header,.table-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 120px 110px 130px}.table-row{align-items:center;border-top:1px solid var(--border);padding:.875rem 1.25rem}.table-title{color:var(--text);font-size:.925rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.table-category{color:var(--text-muted);font-size:.825rem}.table-actions{align-items:center;display:flex;gap:.4rem}.post-badge{align-items:center;border:none;border-radius:20px;cursor:default;display:inline-flex;font-size:.7rem;font-weight:600;letter-spacing:.04em;padding:.2rem .6rem;text-transform:uppercase;white-space:nowrap}.post-badge.clickable{cursor:pointer;transition:opacity .15s}.post-badge.clickable:hover{opacity:.75}.badge-published{background:#d1fae5;color:#065f46}html.dark .badge-published{background:#10b98126;color:#6ee7b7}.badge-draft{background:var(--bg-muted);color:var(--text-muted)}.btn-admin-primary{align-items:center;background:var(--purple);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-family:var(--font-body);font-size:.875rem;font-weight:600;gap:.3rem;padding:.55rem 1.1rem;text-decoration:none;transition:background var(--transition);white-space:nowrap}.btn-admin-primary:hover{background:var(--purple-hover)}.btn-admin-primary:disabled{cursor:not-allowed;opacity:.6}.btn-admin-ghost{align-items:center;background:#0000;border:1px solid var(--border);border-radius:7px;color:var(--text);cursor:pointer;display:inline-flex;font-family:var(--font-body);font-size:.825rem;font-weight:500;padding:.42rem .875rem;text-decoration:none;transition:border-color var(--transition),color var(--transition);white-space:nowrap}.btn-admin-ghost:hover{border-color:var(--purple);color:var(--purple)}.btn-admin-danger{align-items:center;background:#0000;border:1px solid #fca5a5;border-radius:7px;color:#ef4444;cursor:pointer;display:inline-flex;font-family:var(--font-body);font-size:.825rem;font-weight:500;padding:.42rem .875rem;transition:background var(--transition),border-color var(--transition);white-space:nowrap}.btn-admin-danger:hover{background:#fef2f2;border-color:#ef4444}html.dark .btn-admin-danger:hover{background:#ef44441a}.post-form{display:flex;flex-direction:column;gap:1.25rem}.form-row{display:flex;gap:1rem}.form-row.two-col>*{flex:1 1}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{color:var(--text);font-size:.85rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{background:var(--bg-card);border:1.5px solid var(--border);border-radius:8px;color:var(--text);font-family:var(--font-body);font-size:.925rem;outline:none;padding:.65rem .875rem;transition:border-color var(--transition);width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--purple)}.form-group textarea{line-height:1.6;resize:vertical}.content-editor{font-family:Monaco,Menlo,Courier New,monospace!important;font-size:.85rem!important;line-height:1.65!important;min-height:360px}.form-hint{color:var(--text-muted);font-size:.78rem}.form-hint-inline{color:var(--text-muted);font-size:.775rem;font-weight:400}.form-publish-row{align-items:center;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-top:.25rem;padding-top:1.25rem}.toggle-label{align-items:center;cursor:pointer;display:flex;gap:.75rem}.toggle-label input[type=checkbox]{accent-color:var(--purple);cursor:pointer;flex-shrink:0;height:17px;width:17px}.toggle-text{color:var(--text-muted);font-size:.9rem}.image-upload-area{align-items:center;background:var(--bg-muted);border:1.5px dashed var(--border);border-radius:10px;color:var(--text-muted);cursor:pointer;display:flex;flex-direction:column;font-size:.875rem;gap:.5rem;justify-content:center;padding:2rem;text-align:center;transition:border-color var(--transition),background var(--transition)}.image-upload-area:hover{background:var(--purple-muted);border-color:var(--purple);color:var(--purple)}.image-upload-area.uploading{cursor:not-allowed;opacity:.65}.upload-status{color:var(--text-muted);font-size:.875rem}.image-preview-wrap{display:flex;flex-direction:column;gap:.75rem}.image-preview{border:1px solid var(--border);border-radius:8px;max-height:280px;object-fit:cover;width:100%}.btn-remove-image{align-self:flex-start;background:none;border:1px solid #fca5a5;border-radius:6px;color:#ef4444;cursor:pointer;font-family:var(--font-body);font-size:.8rem;padding:.3rem .75rem;transition:background var(--transition)}.btn-remove-image:hover{background:#fef2f2}html.dark .btn-remove-image:hover{background:#ef44441a}.preview-cover{border-radius:8px;margin-bottom:1.5rem;max-height:280px;object-fit:cover;width:100%}.post-preview{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--border-radius);max-width:680px;padding:2.5rem}.preview-category{color:var(--purple);font-size:.75rem;font-weight:600;letter-spacing:.06em;margin-bottom:.75rem;text-transform:uppercase}.preview-title{color:var(--text);font-family:var(--font-heading);font-size:2rem;font-weight:700;line-height:1.2;margin-bottom:1rem}.preview-excerpt{border-bottom:1px solid var(--border);color:var(--text-muted);font-size:1.05rem;font-style:italic;margin-bottom:2rem;padding-bottom:1.5rem}.preview-body{color:var(--text);font-size:1.05rem;line-height:1.8}.preview-body p{margin-bottom:1.25rem}.preview-body h3{font-family:var(--font-heading);font-size:1.3rem;font-weight:600;margin:2rem 0 .75rem}.preview-body strong{font-weight:600}.preview-body em{color:var(--text-muted);font-style:italic}.preview-body ol,.preview-body ul{margin-bottom:1.25rem;padding-left:1.5rem}.preview-body li{line-height:1.7;margin-bottom:.35rem}.admin-login-page{align-items:center;background:var(--bg);display:flex;justify-content:center;min-height:100vh;padding:2rem}.admin-login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--border-radius);box-shadow:var(--shadow);max-width:400px;padding:2.5rem;width:100%}.admin-login-logo{color:var(--text);font-family:var(--font-heading);font-size:1.75rem;font-weight:700;letter-spacing:-.02em;margin-bottom:1.25rem}.admin-login-logo span{color:var(--purple)}.admin-login-card h1{color:var(--text);font-family:var(--font-heading);font-size:1.5rem;font-weight:700;margin-bottom:.35rem}.admin-login-card>p{color:var(--text-muted);font-size:.9rem;margin-bottom:1.75rem}.admin-login-form{display:flex;flex-direction:column;gap:1rem}.btn-submit{background:var(--purple);border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:var(--font-body);font-size:.95rem;font-weight:600;margin-top:.25rem;padding:.75rem;transition:background var(--transition);width:100%}.btn-submit:hover:not(:disabled){background:var(--purple-hover)}.btn-submit:disabled{cursor:not-allowed;opacity:.65}.login-back-link{color:var(--text-muted);display:block;font-size:.85rem;margin-top:1.5rem;text-align:center;text-decoration:none;transition:color var(--transition)}.login-back-link:hover{color:var(--purple)}.admin-state-msg{color:var(--text-muted);font-size:.95rem;padding:2rem 0}.admin-state-msg a{color:var(--purple);text-decoration:none}.admin-state-msg a:hover{text-decoration:underline}@media (max-width:768px){.admin-sidebar{align-items:center;flex-direction:row;flex-wrap:wrap;gap:.25rem;height:auto;padding:.875rem 1rem;position:static;width:100%}.admin-sidebar-footer,.admin-sidebar-label{display:none}.admin-sidebar-logo{font-size:1.25rem;margin-bottom:0}.admin-nav-link{font-size:.85rem;padding:.45rem .625rem}.admin-page{padding:1.5rem 1rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}.table-header,.table-row{grid-template-columns:1fr auto auto}.table-header span:nth-child(2),.table-row .table-category{display:none}}
/*# sourceMappingURL=main.b85685a4.css.map*/