.header{background:#fff;box-shadow:0 2px 4px #0000001a;left:0;position:fixed;right:0;top:0;z-index:1000}.navbar{align-items:center;display:flex;justify-content:space-between;max-width:100%;padding:1rem 2rem}.nav-brand{flex-shrink:0}.brand-link{color:#2c3e50;font-size:1.5rem;font-weight:700;text-decoration:none}.nav-links{display:flex;gap:2rem;left:50%;margin:0;padding:0;position:absolute;transform:translateX(-50%)}.nav-link{color:#64748b;font-weight:500;padding:.5rem;text-decoration:none;transition:color .3s ease}.nav-link:hover{color:#3b82f6}.nav-auth{align-items:center;display:flex;gap:1rem;margin-left:auto}.auth-link{border:none;border-radius:.375rem;cursor:pointer;font-family:inherit;font-size:inherit;font-weight:500;padding:.5rem 1rem;text-decoration:none;transition:all .3s ease}.auth-link:not(.login-btn):not(.logout-btn){color:#64748b}.auth-link:not(.login-btn):not(.logout-btn):hover{color:#3b82f6}.login-btn:focus,.login-btn:hover{background:#2563eb}.login-btn:focus{outline:none}.login-btn:active{background:#1d4ed8;outline:none;transform:translateY(1px)}.logout-btn{background:#ef4444;color:#fff}.logout-btn:focus,.logout-btn:hover{background:#dc2626}.logout-btn:focus{outline:none}.logout-btn:active{background:#b91c1c;outline:none;transform:translateY(1px)}.nav-brand img{display:block;max-height:40px;width:auto}@media (max-width:768px){.navbar{padding:1rem}.nav-links{display:none}.nav-auth{gap:.5rem}.auth-link{font-size:.875rem;padding:.5rem .75rem}}.footer{background-color:#1e293b;color:#f8fafc;margin-top:0;padding:3rem 0 1.2rem}.footer-container{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:0 auto;max-width:1400px;padding:0 2rem}.footer-section{margin-bottom:1.5rem}.footer-title{color:#f8fafc;font-size:1.5rem;font-weight:700;margin-bottom:1rem}.footer-description{color:#cbd5e1;line-height:1.6;margin-bottom:1.5rem}.footer-subtitle{color:#e2e8f0;font-size:1.125rem;font-weight:600;margin-bottom:1rem}.footer-links{list-style:none;margin:0;padding:0}.footer-links li{margin-bottom:.75rem}.footer-links a{color:#cbd5e1;text-decoration:none;transition:color .2s}.footer-links a:hover{color:#f8fafc;text-decoration:underline}.social-links{display:flex;gap:1rem}.social-icon{color:#cbd5e1;transition:color .2s,transform .2s}.social-icon:hover{color:#f8fafc;transform:translateY(-3px)}.footer-bottom{border-top:1px solid #cbd5e133;color:#94a3b8;font-size:.875rem;margin-top:2rem;padding-top:1.2rem;text-align:center}@media (max-width:768px){.footer{padding:2rem 0 1rem}.footer-container{gap:1.5rem;grid-template-columns:1fr;padding:0 1.5rem}.footer-section{margin-bottom:1rem}.footer-title{font-size:1.25rem}.footer-subtitle{font-size:1rem}}.home-container{background-color:#f8fafc;min-height:calc(100vh - 64px);padding-bottom:12rem;padding-top:2rem;width:100%}.home-header{margin-bottom:3rem;padding:0 1rem;text-align:center}.home-title{color:#1e293b;font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.home-subtitle{color:#64748b;font-size:1.125rem;margin-bottom:1.5rem}.search-container{margin:0 auto 1.5rem;max-width:600px;padding:0 1rem}.search-bar{align-items:center;background-color:#fff;border:1px solid #e2e8f0;border-radius:9999px;box-shadow:0 2px 4px #0000000d;display:flex;overflow:hidden;padding:0 1rem;position:relative;transition:all .2s}.search-bar:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-icon{color:#64748b;height:1.25rem;margin-right:.75rem;width:1.25rem}.search-input{background-color:initial;border:none;color:#334155;font-size:1rem;outline:none;padding:1rem 0;width:100%}.search-input::placeholder{color:#94a3b8}.clear-search{background:none;border:none;color:#64748b;cursor:pointer;font-size:1.5rem;line-height:1;padding:0;transition:color .2s}.clear-search:hover{color:#dc2626}.no-results-message{background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;color:#475569;grid-column:1/-1;padding:2rem;text-align:center}.no-results-message p{font-size:1.125rem;margin-bottom:1rem}.reset-search{background-color:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:background-color .2s}.reset-search:hover{background-color:#2563eb}.blog-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin:0 auto;max-width:1400px;padding:0 2rem}.blog-card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;cursor:pointer;position:relative;transition:transform .2s,box-shadow .2s}.blog-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-4px)}.blog-card-content{display:flex;flex-direction:column;min-height:280px;padding:1.5rem}.blog-card-header{justify-content:space-between;margin-bottom:1rem}.blog-card-header,.category-wrapper{align-items:center;display:flex;position:relative}.category-wrapper{gap:4px}.blog-read-time{color:#64748b;font-size:.75rem}.blog-card-title{-webkit-line-clamp:2;color:#1e293b;font-size:1.25rem;font-weight:600;line-height:1.4;margin-bottom:.75rem;max-height:2.8em;min-height:2.8em}.blog-card-excerpt,.blog-card-title{-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden;text-overflow:ellipsis}.blog-card-excerpt{-webkit-line-clamp:3;color:#475569;flex-grow:1;font-size:.875rem;line-height:1.6;margin-bottom:1.5rem;max-height:4.8em;min-height:4.8em}.blog-card-meta{border-top:1px solid #e2e8f0;justify-content:space-between;margin-top:auto;padding-top:1rem}.blog-author,.blog-card-meta{align-items:center;display:flex}.blog-author{gap:.5rem}.author-avatar{align-items:center;background-color:#3b82f6;border-radius:50%;color:#fff;display:flex;font-size:1rem;font-weight:600;height:2rem;justify-content:center;width:2rem}.author-name{font-size:.875rem;font-weight:500}.blog-date{color:#64748b;font-size:.75rem}.loading-spinner{border:3px solid #0000001a;margin:3rem auto}.error-message{padding:2rem}.home-category-chip,.home-category-view{align-items:center;display:inline-flex;position:relative}.home-category-chip{background-color:#e0f2fe;border-radius:9999px;height:auto;margin:2px 0;min-height:24px;overflow:hidden;padding:.25rem .25rem .25rem .75rem}.home-category-tag{align-items:center;background-color:initial;border-radius:9999px;color:#0369a1;display:inline-block;display:flex;font-size:.75rem;font-weight:500;height:100%;padding:0 .5rem 0 0}.home-counter-badge{align-items:center;background-color:#0369a1;border-radius:50%;box-sizing:border-box;color:#fff;cursor:default;display:inline-flex;font-size:.7rem;font-weight:500;height:20px;justify-content:center;line-height:1;margin-left:.25rem;min-width:20px;width:20px}.home-category-hint-text{word-wrap:break-word;background-color:#1e293b;border-radius:4px;bottom:130%;box-shadow:0 2px 8px #00000026;color:#fff;font-size:.75rem;left:50%;line-height:1.3;margin-bottom:5px;max-width:250px;min-width:120px;opacity:0;padding:6px 10px;pointer-events:none;position:absolute;text-align:center;transform:translateX(-50%);transition:opacity .2s,visibility .2s;visibility:hidden;white-space:normal;z-index:100}.home-category-view:hover .home-category-hint-text{opacity:1;visibility:visible}.home-category-tag.no-tag{background-color:#f1f5f9;color:#94a3b8}@media (max-width:768px){.home-container{padding:1.5rem 0}.blog-grid{gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));padding:0 1rem}.home-title{font-size:2rem}.home-subtitle{font-size:1rem}.search-bar{padding:0 .75rem}.search-input{font-size:.875rem;padding:.75rem 0}.search-icon{height:1rem;width:1rem}.home-category-view{max-width:150px}.home-category-hint-text{max-width:200px}}@media (max-width:480px){.home-category-hint-text{max-width:150px}}.blog-post-container{align-items:center;display:flex;flex-direction:column;margin:0 auto;max-width:1440px;padding:2rem}.footer-ad-container,.header-ad-container{align-items:center;border:2px dashed #ccc;border-radius:4px;display:flex;height:120px;justify-content:center;width:800px}.footer-ad-container:after,.header-ad-container:after{color:#666;font-size:14px;text-align:center}.header-ad-container:after{content:"Header Ad Space 800x120 Pixels"}.footer-ad-container:after{content:"Footer Ad Space 800x120 Pixels"}.blog-content-wrapper{align-items:flex-start;display:flex;gap:20px;justify-content:space-between;width:100%}.left-ad-container{align-items:center;border:2px dashed #ccc;border-radius:4px;display:flex;flex-shrink:0;height:600px;justify-content:center;margin-top:2rem;order:1;width:150px}.left-ad-container:after{color:#666;content:"Left Ad Space 150x600 Pixels";font-size:14px;text-align:center}.right-ad-container{align-items:center;border:2px dashed #ccc;border-radius:4px;display:flex;flex-shrink:0;height:600px;justify-content:center;margin-top:2rem;order:3;width:150px}.right-ad-container:after{color:#666;content:"Right Ad Space 150x600 Pixels";font-size:14px;text-align:center}.blog-post-article{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;flex-grow:1;margin:2rem auto 0;max-width:800px;min-width:0;order:2;padding:2rem;position:relative;transform:translateX(0);transition:transform .3s ease;width:100%}.blog-post-header{border-bottom:1px solid #e2e8f0;margin-bottom:2rem;padding-bottom:1.5rem}.blog-post-title{color:#1e293b;font-size:2.5rem;font-weight:700;line-height:1.2;margin-bottom:1rem}.blog-post-meta{align-items:center;color:#64748b;display:flex;font-size:.875rem;gap:1rem}.blog-post-author{align-items:center;color:#1e293b;display:flex;gap:.25rem}.author-name,.by-text{color:#1e293b;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-weight:700}.blog-post-date{color:#64748b}.blog-post-content{color:#334155;font-size:1.125rem;line-height:1.7}.blog-post-content h2{color:#1e293b;font-size:2rem;font-weight:600;margin:2rem 0 1rem}.blog-post-content h3{color:#1e293b;font-size:1.5rem;font-weight:600;margin:1.5rem 0 1rem}.blog-post-content p{margin-bottom:1.5rem}.blog-post-content ol,.blog-post-content ul{margin:1rem 0;padding-left:1.5rem}.blog-post-content li{margin-bottom:.5rem}.blog-post-content blockquote{border-left:4px solid #3b82f6;color:#475569;font-style:italic;margin:1.5rem 0;padding-left:1rem}.blog-post-content pre{background:#f1f5f9;border-radius:6px;margin:1.5rem 0;overflow-x:auto;padding:1rem}.blog-post-content code{font-family:Courier New,Courier,monospace;font-size:.875rem;line-height:1.6}.blog-post-content img{display:block;height:auto;max-width:100%}.blog-sidebar{height:fit-content;position:sticky;top:2rem}.ad-container{background:#f8fafc;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.ad-title{color:#1e293b;font-size:1.25rem;font-weight:600;margin-bottom:1rem}.ad-content{color:#475569;line-height:1.6}.ad-content p{margin-bottom:.75rem}.ad-button{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;margin-top:1rem;padding:.5rem 1rem;transition:background-color .2s}.ad-button:hover{background:#2563eb}.error-message{margin:2rem auto;max-width:600px}@media (max-width:1200px){.blog-content-wrapper{gap:2rem;grid-template-columns:1fr}.left-ad-container,.right-ad-container{height:120px;margin-top:1rem;max-width:800px;order:0;width:100%}.blog-post-article{margin:1rem auto 0;order:0;transform:none!important}.left-ad-container[style*="display: none"],.right-ad-container[style*="display: none"]{display:none!important;height:0;margin:0;padding:0;width:0}.blog-content-wrapper:has(.left-ad-container[style*="display: none"]){align-items:center;display:flex;flex-direction:column}.blog-content-wrapper{gap:1rem}.blog-content-wrapper,.blog-content-wrapper.left-ad-hidden{align-items:center;display:flex;flex-direction:column}.left-ad-container:after{content:"Left Ad Space Horizontal"}.right-ad-container:after{content:"Right Ad Space Horizontal"}}@media (max-width:900px){.blog-post-container{padding:1rem}.footer-ad-container,.header-ad-container,.left-ad-container,.right-ad-container{height:100px;max-width:800px;width:100%}.square-ad{aspect-ratio:1/1;height:auto;max-width:800px;width:100%}.square-ads-wrapper{align-items:center;flex-direction:column;gap:1rem;width:100%}}@media (max-width:480px){.blog-post-container{padding:.5rem}.footer-ad-container,.header-ad-container,.left-ad-container,.right-ad-container{height:80px}.footer-ad-container:after,.header-ad-container:after,.left-ad-container:after,.right-ad-container:after{content:"Ad Space Mobile"}.square-ad:after{content:"Square Ad Mobile"}.blog-post-article{padding:1rem}.blog-post-title{font-size:1.5rem}.blog-post-meta{flex-direction:column;gap:.5rem}.bottom-ads-container{gap:1rem;width:100%}.popup-ad-content{aspect-ratio:1/1;height:90vw;max-height:98vw;max-width:98vw;padding:0;width:90vw}.popup-ad-container{max-height:80vh;max-width:98vw;min-height:0;min-width:0;padding:.5rem}.popup-close-btn{font-size:18px;height:28px;right:-10px;top:-10px;width:28px}}.bottom-ads-container{align-items:center;display:flex;flex-direction:column;gap:20px;margin-top:2rem;width:100%}.square-ads-wrapper{gap:20px}.square-ad,.square-ads-wrapper{display:flex;justify-content:center}.square-ad{align-items:center;border:2px dashed #ccc;border-radius:4px;height:390px;width:390px}.square-ad:after{color:#666;content:"Square Ad 390x390 Pixels";font-size:14px;text-align:center}.popup-ad-overlay{align-items:center;animation:fadeIn .3s ease-out;background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.popup-ad-container{animation:slideIn .3s ease-out;background:#fff;border-radius:8px;box-shadow:0 4px 20px #0000004d;max-height:90vh;max-width:90%;padding:0;position:relative}.popup-close-btn{align-items:center;background:#ef4444;border:none;border-radius:50%;box-shadow:0 2px 10px #0003;color:#fff;cursor:pointer;display:flex;font-size:20px;height:30px;justify-content:center;line-height:1;padding:0;position:absolute;right:-15px;top:-15px;transition:all .2s;width:30px;z-index:1}.popup-close-btn:hover{background:#dc2626;transform:scale(1.1)}.popup-ad-content{aspect-ratio:1/1;background:#f8fafc;height:400px;padding:0;width:400px}.popup-ad-content,.popup-ad-placeholder{align-items:center;box-sizing:border-box;display:flex;justify-content:center}.popup-ad-placeholder{background:#fff;flex-direction:column;height:100%;max-height:100%;max-width:100%;overflow-wrap:break-word;width:100%;word-break:break-word}.popup-ad-debug{color:#1e40af;font-size:16px;font-weight:500;line-height:1.8;text-align:center}.popup-ad-debug small{color:#6b7280;display:block;font-size:14px;font-style:italic;margin-top:1rem}@keyframes slideIn{0%{opacity:0;transform:translateY(-40px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.popup-ad-content{aspect-ratio:1/1;height:90vw;max-height:98vw;max-width:98vw;padding:0;width:90vw}.popup-close-btn{font-size:20px;height:30px;right:-15px;top:-15px;width:30px}}.blog-content-wrapper.left-ad-hidden:not(.right-ad-hidden) .blog-post-article{transform:translateX(80px)}.blog-content-wrapper.right-ad-hidden:not(.left-ad-hidden) .blog-post-article{transform:translateX(-80px)}.blog-content-wrapper.left-ad-hidden.right-ad-hidden .blog-post-article{transform:translateX(0)}.admin-dashboard-container{margin:0 auto;max-width:1200px;padding:2rem 2rem 12rem}.admin-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.admin-title{color:#1e293b;font-size:2rem;font-weight:600}.admin-actions{display:flex;gap:1rem}.create-blog-btn{background-color:#3b82f6;border:1px solid #3b82f6;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.create-blog-btn:hover{background-color:#2563eb;border-color:#2563eb}.create-blog-btn:active{background-color:#1d4ed8;border-color:#1d4ed8;outline:none;transform:translateY(1px)}.manage-categories-btn{background-color:#10b981;border:1px solid #10b981;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.manage-categories-btn:hover{background-color:#059669;border-color:#059669}.manage-categories-btn:active{background-color:#047857;border-color:#047857;outline:none;transform:translateY(1px)}.manage-ads-btn{background-color:#3b82f6;border:1px solid #3b82f6;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.manage-ads-btn:hover{background-color:#2563eb;border-color:#2563eb}.manage-ads-btn:active{background-color:#1d4ed8;border-color:#1d4ed8;outline:none;transform:translateY(1px)}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-container{background-color:#fff;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1rem 1.5rem}.modal-header h2{color:#1e293b;font-size:1.25rem;font-weight:600;margin:0}.close-btn{background:none;border:none;color:#64748b;cursor:pointer;font-size:1.5rem;line-height:1}.close-btn:hover{color:#334155}.modal-body{padding:1.5rem}.add-category-form{display:flex;gap:.5rem;margin-bottom:1.5rem;padding:.1rem}.add-category-form,.category-input{border:1px solid #e2e8f0;border-radius:6px}.category-input{flex:1 1;outline:none;padding:.75rem 1rem;transition:border-color .2s}.category-input:focus{border-color:#3b82f6}.add-category-btn{background-color:#3b82f6;border:1px solid #3b82f6;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1rem;transition:all .2s;white-space:nowrap}.add-category-btn:hover{background-color:#2563eb;border-color:#2563eb}.add-category-btn:active{background-color:#1d4ed8;border-color:#1d4ed8;outline:none;transform:translateY(1px)}.category-item{align-items:center;background-color:#f8fafc;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:.5rem;padding:.5rem;width:100%}.category-name{background-color:#e0f2fe;border-radius:9999px;color:#0369a1;display:inline-block;font-size:.875rem;font-weight:500;padding:.25rem .75rem}.category-actions{display:flex;gap:.5rem}.delete-category-btn,.edit-category-btn{border:none;border-radius:4px;cursor:pointer;font-size:.75rem;font-weight:500;padding:.25rem .5rem;transition:all .2s}.edit-category-btn{background-color:#f1f5f9;border:1px solid #f1f5f9;color:#475569}.edit-category-btn:hover{background-color:#e2e8f0;border-color:#e2e8f0}.edit-category-btn:active{background-color:#cbd5e1;border-color:#cbd5e1;outline:none;transform:translateY(1px)}.delete-category-btn{background-color:#fee2e2;border:1px solid #fee2e2;color:#dc2626}.delete-category-btn:hover{background-color:#fecaca;border-color:#fecaca}.delete-category-btn:active{background-color:#fca5a5;border-color:#fca5a5;outline:none;transform:translateY(1px)}.edit-category-form{display:flex;flex-direction:column;gap:.5rem;width:100%}.category-edit-input{border:1px solid #e2e8f0;border-radius:6px;flex:1 1;font-size:.875rem;outline:none;padding:.5rem .75rem;transition:border-color .2s}.category-edit-input:focus{border-color:#3b82f6}.edit-actions{display:flex;gap:.5rem;justify-content:flex-end}.save-btn{align-items:center;background-color:#10b981;border:1px solid #10b981;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:.7rem;font-weight:500;height:26px;justify-content:center;line-height:1;min-width:50px;padding:.15rem .5rem;transition:all .2s}.save-btn:hover{background-color:#059669;border-color:#059669}.save-btn:active{background-color:#047857;border-color:#047857;outline:none;transform:translateY(1px)}.save-btn-cancel{align-items:center;background-color:#f1f5f9;border:1px solid #cbd5e1;border-radius:4px;color:#475569;cursor:pointer;display:flex;font-size:.7rem;font-weight:500;height:26px;justify-content:center;line-height:1;min-width:50px;padding:.15rem .5rem;transition:all .2s}.save-btn-cancel:hover{background-color:#e2e8f0;border-color:#e2e8f0}.save-btn-cancel:active{background-color:#cbd5e1;border-color:#cbd5e1;outline:none;transform:translateY(1px)}.categories-list{margin-top:1rem}.categories-list h3{color:#334155;font-size:1rem;font-weight:600;margin-bottom:.75rem}.categories-list ul{display:flex;flex-direction:column;gap:.5rem;list-style:none;margin:0;padding:0;width:100%}.admin-table-container{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow-x:auto}.admin-table{border-collapse:collapse;width:100%}.admin-table-header{background-color:#f8fafc;border-bottom:1px solid #e2e8f0}.admin-table-header th{color:#64748b;font-size:.875rem;font-weight:500;padding:1rem;text-align:left}.admin-table-row{border-bottom:1px solid #e2e8f0}.admin-table-row:last-child{border-bottom:none}.admin-table-cell{color:#334155;font-size:.875rem;padding:1rem}.category-tags{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.admin-category-chip,.category-chip{background-color:#e0f2fe;border-radius:9999px;display:inline-flex;height:auto;margin:2px 0;min-height:24px;overflow:hidden;padding:.25rem .25rem .25rem .75rem;position:relative}.admin-category-chip{align-items:center}.category-tag{background-color:#e0f2fe;border-radius:9999px;color:#0369a1;display:inline-block;font-size:.75rem;font-weight:500;padding:.25rem .75rem}.admin-category-chip .category-tag,.category-chip .category-tag{align-items:center;background-color:initial;display:flex;height:100%;padding:0 .5rem 0 0}.admin-counter-badge{align-items:center;background-color:#0369a1;border-radius:50%;box-sizing:border-box;color:#fff;cursor:default;display:inline-flex;font-size:.7rem;font-weight:500;height:20px;justify-content:center;line-height:1;margin-left:.25rem;min-width:20px;width:20px}.admin-category-view{align-items:center;display:inline-flex;position:relative}.category-hint-text{word-wrap:break-word;background-color:#1e293b;border-radius:4px;bottom:130%;box-shadow:0 2px 8px #00000026;color:#fff;font-size:.75rem;line-height:1.3;margin-bottom:5px;max-width:250px;min-width:120px;opacity:0;padding:6px 10px;pointer-events:none;text-align:center;transition:opacity .2s,visibility .2s;visibility:hidden;white-space:normal;z-index:100}.category-hint-text,.category-hint-text:after{left:50%;position:absolute;transform:translateX(-50%)}.category-hint-text:after{border-left:5px solid #0000;border-right:5px solid #0000;border-top:5px solid #1e293b;content:"";height:0;top:100%;width:0}.admin-category-view:hover .category-hint-text{opacity:1;visibility:visible}.category-tag.no-tag{background-color:#f1f5f9;color:#94a3b8;font-style:italic}.action-buttons{display:flex;gap:.5rem}.delete-btn,.edit-btn,.view-btn{border:1px solid #0000;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s}.view-btn{background-color:#e0f2fe;border-color:#e0f2fe;color:#0369a1}.view-btn:hover{background-color:#bae6fd;border-color:#bae6fd}.view-btn:active{background-color:#7dd3fc;border-color:#7dd3fc;outline:none;transform:translateY(1px)}.edit-btn{border-color:#f1f5f9}.edit-btn:hover{border-color:#e2e8f0}.edit-btn:active{background-color:#cbd5e1;border-color:#cbd5e1;outline:none;transform:translateY(1px)}.delete-btn{border-color:#fee2e2}.delete-btn:hover{border-color:#fecaca}.delete-btn:active{background-color:#fca5a5;border-color:#fca5a5;outline:none;transform:translateY(1px)}.login-required{color:#6b7280;font-style:italic}@media (max-width:768px){.admin-dashboard-container{padding:1rem}.admin-header{align-items:stretch;flex-direction:column;gap:1rem;text-align:center}.admin-actions{flex-direction:column;gap:.5rem}.admin-table-container{margin-top:1rem}.admin-table{display:block}.admin-table-header{display:none}.admin-table-row{border-bottom:1px solid #e2e8f0;display:block;padding:1rem}.admin-table-cell{align-items:center;display:flex;justify-content:space-between;padding:.5rem 0}.admin-table-cell:before{color:#64748b;content:attr(data-label);font-weight:500}.action-buttons{justify-content:flex-end;margin-top:1rem}.add-category-form,.category-item{flex-direction:column}.category-item{align-items:flex-start;gap:.5rem}.category-actions{align-self:flex-end}}.login-container{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);display:flex;justify-content:center;min-height:calc(100vh - 64px);padding:2rem}.login-box{background:#fff;border-radius:15px;box-shadow:0 10px 30px #0000001a;max-width:400px;padding:2rem;width:100%}.login-header{margin-bottom:2rem;text-align:center}.login-title{color:#2c3e50;font-family:Playfair Display,serif;font-size:2rem;margin-bottom:.5rem}.login-subtitle{color:#64748b;font-size:1rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-label{color:#475569}.form-input{border:2px solid #e2e8f0;border-radius:8px;box-sizing:border-box;padding:.75rem 1rem}.form-input,.login-btn{font-size:1rem;transition:all .3s ease}.login-btn{align-items:center;background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-weight:600;height:2.75rem;justify-content:center;padding:.875rem}.login-btn:hover:not(:disabled){background:#2563eb;box-shadow:0 4px 6px -1px #3b82f633;transform:translateY(-2px)}.login-btn:disabled{background:#94a3b8;cursor:not-allowed}.error-message{background:#fee2e2;border:1px solid #ef4444;border-radius:8px;color:#b91c1c;padding:.75rem 1rem;text-align:center}@media (max-width:768px){.login-container{padding:1rem}.login-box{padding:1.5rem}.login-title{font-size:1.75rem}} 
/*!
 * Quill Editor v1.3.7
 * https://quilljs.com/
 * Copyright (c) 2014, Jason Chen
 * Copyright (c) 2013, salesforce.com
 */.ql-container{box-sizing:border-box;font-family:Helvetica,Arial,sans-serif;font-size:13px;height:100%;margin:0;position:relative}.ql-container.ql-disabled .ql-tooltip{visibility:hidden}.ql-container.ql-disabled .ql-editor ul[data-checked]>li:before{pointer-events:none}.ql-clipboard{height:1px;left:-100000px;overflow-y:hidden;position:absolute;top:50%}.ql-clipboard p{margin:0;padding:0}.ql-editor{word-wrap:break-word;box-sizing:border-box;height:100%;line-height:1.42;outline:none;overflow-y:auto;padding:12px 15px;tab-size:4;-moz-tab-size:4;text-align:left;white-space:pre-wrap}.ql-editor>*{cursor:text}.ql-editor blockquote,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6,.ql-editor ol,.ql-editor p,.ql-editor pre,.ql-editor ul{counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;margin:0;padding:0}.ql-editor ol,.ql-editor ul{padding-left:1.5em}.ql-editor ol>li,.ql-editor ul>li{list-style-type:none}.ql-editor ul>li:before{content:"\2022"}.ql-editor ul[data-checked=false],.ql-editor ul[data-checked=true]{pointer-events:none}.ql-editor ul[data-checked=false]>li *,.ql-editor ul[data-checked=true]>li *{pointer-events:all}.ql-editor ul[data-checked=false]>li:before,.ql-editor ul[data-checked=true]>li:before{color:#777;cursor:pointer;pointer-events:all}.ql-editor ul[data-checked=true]>li:before{content:"\2611"}.ql-editor ul[data-checked=false]>li:before{content:"\2610"}.ql-editor li:before{display:inline-block;white-space:nowrap;width:1.2em}.ql-editor li:not(.ql-direction-rtl):before{margin-left:-1.5em;margin-right:.3em;text-align:right}.ql-editor li.ql-direction-rtl:before{margin-left:.3em;margin-right:-1.5em}.ql-editor ol li:not(.ql-direction-rtl),.ql-editor ul li:not(.ql-direction-rtl){padding-left:1.5em}.ql-editor ol li.ql-direction-rtl,.ql-editor ul li.ql-direction-rtl{padding-right:1.5em}.ql-editor ol li{counter-increment:list-0;counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li:before{content:counter(list-0,decimal) ". "}.ql-editor ol li.ql-indent-1{counter-increment:list-1}.ql-editor ol li.ql-indent-1:before{content:counter(list-1,lower-alpha) ". "}.ql-editor ol li.ql-indent-1{counter-reset:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-2{counter-increment:list-2}.ql-editor ol li.ql-indent-2:before{content:counter(list-2,lower-roman) ". "}.ql-editor ol li.ql-indent-2{counter-reset:list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-3{counter-increment:list-3}.ql-editor ol li.ql-indent-3:before{content:counter(list-3,decimal) ". "}.ql-editor ol li.ql-indent-3{counter-reset:list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-4{counter-increment:list-4}.ql-editor ol li.ql-indent-4:before{content:counter(list-4,lower-alpha) ". "}.ql-editor ol li.ql-indent-4{counter-reset:list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-5{counter-increment:list-5}.ql-editor ol li.ql-indent-5:before{content:counter(list-5,lower-roman) ". "}.ql-editor ol li.ql-indent-5{counter-reset:list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-6{counter-increment:list-6}.ql-editor ol li.ql-indent-6:before{content:counter(list-6,decimal) ". "}.ql-editor ol li.ql-indent-6{counter-reset:list-7 list-8 list-9}.ql-editor ol li.ql-indent-7{counter-increment:list-7}.ql-editor ol li.ql-indent-7:before{content:counter(list-7,lower-alpha) ". "}.ql-editor ol li.ql-indent-7{counter-reset:list-8 list-9}.ql-editor ol li.ql-indent-8{counter-increment:list-8}.ql-editor ol li.ql-indent-8:before{content:counter(list-8,lower-roman) ". "}.ql-editor ol li.ql-indent-8{counter-reset:list-9}.ql-editor ol li.ql-indent-9{counter-increment:list-9}.ql-editor ol li.ql-indent-9:before{content:counter(list-9,decimal) ". "}.ql-editor .ql-indent-1:not(.ql-direction-rtl){padding-left:3em}.ql-editor li.ql-indent-1:not(.ql-direction-rtl){padding-left:4.5em}.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:3em}.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:4.5em}.ql-editor .ql-indent-2:not(.ql-direction-rtl){padding-left:6em}.ql-editor li.ql-indent-2:not(.ql-direction-rtl){padding-left:7.5em}.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:6em}.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:7.5em}.ql-editor .ql-indent-3:not(.ql-direction-rtl){padding-left:9em}.ql-editor li.ql-indent-3:not(.ql-direction-rtl){padding-left:10.5em}.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:9em}.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:10.5em}.ql-editor .ql-indent-4:not(.ql-direction-rtl){padding-left:12em}.ql-editor li.ql-indent-4:not(.ql-direction-rtl){padding-left:13.5em}.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:12em}.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:13.5em}.ql-editor .ql-indent-5:not(.ql-direction-rtl){padding-left:15em}.ql-editor li.ql-indent-5:not(.ql-direction-rtl){padding-left:16.5em}.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:15em}.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:16.5em}.ql-editor .ql-indent-6:not(.ql-direction-rtl){padding-left:18em}.ql-editor li.ql-indent-6:not(.ql-direction-rtl){padding-left:19.5em}.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:18em}.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:19.5em}.ql-editor .ql-indent-7:not(.ql-direction-rtl){padding-left:21em}.ql-editor li.ql-indent-7:not(.ql-direction-rtl){padding-left:22.5em}.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:21em}.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:22.5em}.ql-editor .ql-indent-8:not(.ql-direction-rtl){padding-left:24em}.ql-editor li.ql-indent-8:not(.ql-direction-rtl){padding-left:25.5em}.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:24em}.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:25.5em}.ql-editor .ql-indent-9:not(.ql-direction-rtl){padding-left:27em}.ql-editor li.ql-indent-9:not(.ql-direction-rtl){padding-left:28.5em}.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:27em}.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:28.5em}.ql-editor .ql-video{display:block;max-width:100%}.ql-editor .ql-video.ql-align-center{margin:0 auto}.ql-editor .ql-video.ql-align-right{margin:0 0 0 auto}.ql-editor .ql-bg-black{background-color:#000}.ql-editor .ql-bg-red{background-color:#e60000}.ql-editor .ql-bg-orange{background-color:#f90}.ql-editor .ql-bg-yellow{background-color:#ff0}.ql-editor .ql-bg-green{background-color:#008a00}.ql-editor .ql-bg-blue{background-color:#06c}.ql-editor .ql-bg-purple{background-color:#93f}.ql-editor .ql-color-white{color:#fff}.ql-editor .ql-color-red{color:#e60000}.ql-editor .ql-color-orange{color:#f90}.ql-editor .ql-color-yellow{color:#ff0}.ql-editor .ql-color-green{color:#008a00}.ql-editor .ql-color-blue{color:#06c}.ql-editor .ql-color-purple{color:#93f}.ql-editor .ql-font-serif{font-family:Georgia,Times New Roman,serif}.ql-editor .ql-font-monospace{font-family:Monaco,Courier New,monospace}.ql-editor .ql-size-small{font-size:.75em}.ql-editor .ql-size-large{font-size:1.5em}.ql-editor .ql-size-huge{font-size:2.5em}.ql-editor .ql-direction-rtl{direction:rtl;text-align:inherit}.ql-editor .ql-align-center{text-align:center}.ql-editor .ql-align-justify{text-align:justify}.ql-editor .ql-align-right{text-align:right}.ql-editor.ql-blank:before{color:#0009;content:attr(data-placeholder);font-style:italic;left:15px;pointer-events:none;position:absolute;right:15px}.ql-snow .ql-toolbar:after,.ql-snow.ql-toolbar:after{clear:both;content:"";display:table}.ql-snow .ql-toolbar button,.ql-snow.ql-toolbar button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:28px}.ql-snow .ql-toolbar button svg,.ql-snow.ql-toolbar button svg{float:left;height:100%}.ql-snow .ql-toolbar button:active:hover,.ql-snow.ql-toolbar button:active:hover{outline:none}.ql-snow .ql-toolbar input.ql-image[type=file],.ql-snow.ql-toolbar input.ql-image[type=file]{display:none}.ql-snow .ql-toolbar .ql-picker-item.ql-selected,.ql-snow .ql-toolbar .ql-picker-item:hover,.ql-snow .ql-toolbar .ql-picker-label.ql-active,.ql-snow .ql-toolbar .ql-picker-label:hover,.ql-snow .ql-toolbar button.ql-active,.ql-snow .ql-toolbar button:focus,.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar .ql-picker-item.ql-selected,.ql-snow.ql-toolbar .ql-picker-item:hover,.ql-snow.ql-toolbar .ql-picker-label.ql-active,.ql-snow.ql-toolbar .ql-picker-label:hover,.ql-snow.ql-toolbar button.ql-active,.ql-snow.ql-toolbar button:focus,.ql-snow.ql-toolbar button:hover{color:#06c}.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:focus .ql-fill,.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover .ql-fill,.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:focus .ql-fill,.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill{fill:#06c}.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow .ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar button:focus .ql-stroke,.ql-snow .ql-toolbar button:focus .ql-stroke-miter,.ql-snow .ql-toolbar button:hover .ql-stroke,.ql-snow .ql-toolbar button:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar button:focus .ql-stroke,.ql-snow.ql-toolbar button:focus .ql-stroke-miter,.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button:hover .ql-stroke-miter{stroke:#06c}@media (pointer:coarse){.ql-snow .ql-toolbar button:hover:not(.ql-active),.ql-snow.ql-toolbar button:hover:not(.ql-active){color:#444}.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter{stroke:#444}}.ql-snow,.ql-snow *{box-sizing:border-box}.ql-snow .ql-hidden{display:none}.ql-snow .ql-out-bottom,.ql-snow .ql-out-top{visibility:hidden}.ql-snow .ql-tooltip{position:absolute;transform:translateY(10px)}.ql-snow .ql-tooltip a{cursor:pointer;text-decoration:none}.ql-snow .ql-tooltip.ql-flip{transform:translateY(-10px)}.ql-snow .ql-formats{display:inline-block;vertical-align:middle}.ql-snow .ql-formats:after{clear:both;content:"";display:table}.ql-snow .ql-stroke{fill:none;stroke:#444;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.ql-snow .ql-stroke-miter{fill:none;stroke:#444;stroke-miterlimit:10;stroke-width:2}.ql-snow .ql-fill,.ql-snow .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-empty{fill:none}.ql-snow .ql-even{fill-rule:evenodd}.ql-snow .ql-stroke.ql-thin,.ql-snow .ql-thin{stroke-width:1}.ql-snow .ql-transparent{opacity:.4}.ql-snow .ql-direction svg:last-child{display:none}.ql-snow .ql-direction.ql-active svg:last-child{display:inline}.ql-snow .ql-direction.ql-active svg:first-child{display:none}.ql-snow .ql-editor h1{font-size:2em}.ql-snow .ql-editor h2{font-size:1.5em}.ql-snow .ql-editor h3{font-size:1.17em}.ql-snow .ql-editor h4{font-size:1em}.ql-snow .ql-editor h5{font-size:.83em}.ql-snow .ql-editor h6{font-size:.67em}.ql-snow .ql-editor a{text-decoration:underline}.ql-snow .ql-editor blockquote{border-left:4px solid #ccc;margin-bottom:5px;margin-top:5px;padding-left:16px}.ql-snow .ql-editor code,.ql-snow .ql-editor pre{background-color:#f0f0f0;border-radius:3px}.ql-snow .ql-editor pre{margin-bottom:5px;margin-top:5px;padding:5px 10px;white-space:pre-wrap}.ql-snow .ql-editor code{font-size:85%;padding:2px 4px}.ql-snow .ql-editor pre.ql-syntax{background-color:#23241f;color:#f8f8f2;overflow:visible}.ql-snow .ql-editor img{max-width:100%}.ql-snow .ql-picker{color:#444;display:inline-block;float:left;font-size:14px;font-weight:500;height:24px;position:relative;vertical-align:middle}.ql-snow .ql-picker-label{cursor:pointer;display:inline-block;height:100%;padding-left:8px;padding-right:2px;position:relative;width:100%}.ql-snow .ql-picker-label:before{display:inline-block;line-height:22px}.ql-snow .ql-picker-options{background-color:#fff;display:none;min-width:100%;padding:4px 8px;position:absolute;white-space:nowrap}.ql-snow .ql-picker-options .ql-picker-item{cursor:pointer;display:block;padding-bottom:5px;padding-top:5px}.ql-snow .ql-picker.ql-expanded .ql-picker-label{color:#ccc;z-index:2}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill{fill:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke{stroke:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-options{display:block;margin-top:-1px;top:100%;z-index:1}.ql-snow .ql-color-picker,.ql-snow .ql-icon-picker{width:28px}.ql-snow .ql-color-picker .ql-picker-label,.ql-snow .ql-icon-picker .ql-picker-label{padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-label svg,.ql-snow .ql-icon-picker .ql-picker-label svg{right:4px}.ql-snow .ql-icon-picker .ql-picker-options{padding:4px 0}.ql-snow .ql-icon-picker .ql-picker-item{height:24px;padding:2px 4px;width:24px}.ql-snow .ql-color-picker .ql-picker-options{padding:3px 5px;width:152px}.ql-snow .ql-color-picker .ql-picker-item{border:1px solid #0000;float:left;height:16px;margin:2px;padding:0;width:16px}.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg{margin-top:-9px;position:absolute;right:0;top:50%;width:18px}.ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=""]):before{content:attr(data-label)}.ql-snow .ql-picker.ql-header{width:98px}.ql-snow .ql-picker.ql-header .ql-picker-item:before,.ql-snow .ql-picker.ql-header .ql-picker-label:before{content:"Normal"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]:before{content:"Heading 1"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]:before{content:"Heading 2"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]:before{content:"Heading 3"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]:before{content:"Heading 4"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]:before{content:"Heading 5"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]:before{content:"Heading 6"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{font-size:2em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{font-size:1.5em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{font-size:1.17em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{font-size:1em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{font-size:.83em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{font-size:.67em}.ql-snow .ql-picker.ql-font{width:108px}.ql-snow .ql-picker.ql-font .ql-picker-item:before,.ql-snow .ql-picker.ql-font .ql-picker-label:before{content:"Sans Serif"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]:before{content:"Serif"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]:before{content:"Monospace"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{font-family:Georgia,Times New Roman,serif}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{font-family:Monaco,Courier New,monospace}.ql-snow .ql-picker.ql-size{width:98px}.ql-snow .ql-picker.ql-size .ql-picker-item:before,.ql-snow .ql-picker.ql-size .ql-picker-label:before{content:"Normal"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]:before{content:"Small"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]:before{content:"Large"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]:before{content:"Huge"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{font-size:10px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{font-size:18px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{font-size:32px}.ql-snow .ql-color-picker.ql-background .ql-picker-item{background-color:#fff}.ql-snow .ql-color-picker.ql-color .ql-picker-item{background-color:#000}.ql-toolbar.ql-snow{border:1px solid #ccc;box-sizing:border-box;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;padding:8px}.ql-toolbar.ql-snow .ql-formats{margin-right:15px}.ql-toolbar.ql-snow .ql-picker-label{border:1px solid #0000}.ql-toolbar.ql-snow .ql-picker-options{border:1px solid #0000;box-shadow:0 2px 8px #0003}.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label,.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options{border-color:#ccc}.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover{border-color:#000}.ql-toolbar.ql-snow+.ql-container.ql-snow{border-top:0}.ql-snow .ql-tooltip{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 5px #ddd;color:#444;padding:5px 12px;white-space:nowrap}.ql-snow .ql-tooltip:before{content:"Visit URL:";line-height:26px;margin-right:8px}.ql-snow .ql-tooltip input[type=text]{border:1px solid #ccc;display:none;font-size:13px;height:26px;margin:0;padding:3px 5px;width:170px}.ql-snow .ql-tooltip a.ql-preview{display:inline-block;max-width:200px;overflow-x:hidden;text-overflow:ellipsis;vertical-align:top}.ql-snow .ql-tooltip a.ql-action:after{border-right:1px solid #ccc;content:"Edit";margin-left:16px;padding-right:8px}.ql-snow .ql-tooltip a.ql-remove:before{content:"Remove";margin-left:8px}.ql-snow .ql-tooltip a{line-height:26px}.ql-snow .ql-tooltip.ql-editing a.ql-preview,.ql-snow .ql-tooltip.ql-editing a.ql-remove{display:none}.ql-snow .ql-tooltip.ql-editing input[type=text]{display:inline-block}.ql-snow .ql-tooltip.ql-editing a.ql-action:after{border-right:0;content:"Save";padding-right:0}.ql-snow .ql-tooltip[data-mode=link]:before{content:"Enter link:"}.ql-snow .ql-tooltip[data-mode=formula]:before{content:"Enter formula:"}.ql-snow .ql-tooltip[data-mode=video]:before{content:"Enter video:"}.ql-snow a{color:#06c}.ql-container.ql-snow{border:1px solid #ccc}.create-blog-container{background-color:#f8fafc;min-height:calc(100vh - 64px);padding:2rem;width:100%}.create-blog-box{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin:0 auto;max-width:900px;padding:2rem}.create-blog-header{margin-bottom:2rem;text-align:center}.create-blog-title{color:#1e293b;font-size:1.875rem;font-weight:600;margin-bottom:.5rem;text-align:center}.create-blog-subtitle{color:#64748b;font-size:1rem;text-align:center}.create-blog-form{display:flex;flex-direction:column;gap:1.5rem}.form-label{color:#334155;font-size:.875rem;font-weight:500}.form-input{border:1px solid #e2e8f0;border-radius:6px;color:#1e293b;font-size:.875rem;padding:.75rem;transition:border-color .2s;width:100%}.form-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}textarea.form-input{font-family:inherit;line-height:1.5;min-height:80px;resize:vertical}.editor-container{background-color:#f8fafc;border-radius:6px;overflow:hidden}.editor-container .ql-container{font-family:inherit;font-size:1rem;min-height:300px}.editor-container .ql-editor{font-size:1rem;line-height:1.6;min-height:300px;padding:1rem}.editor-container .ql-toolbar{background-color:#fff;border-color:#e2e8f0;border-top-left-radius:6px;border-top-right-radius:6px;display:flex;flex-wrap:wrap;gap:6px;padding:8px}.editor-container .ql-formats{align-items:center;display:flex;gap:4px;margin-bottom:0!important;margin-right:0!important}.editor-container .ql-toolbar button{align-items:center;display:flex;height:28px;justify-content:center;margin:0!important;padding:4px;width:28px}.editor-container .ql-toolbar .ql-picker{height:28px;margin:0!important}.editor-container .ql-container{border-bottom-left-radius:6px;border-bottom-right-radius:6px;border-color:#e2e8f0}.editor-container .ql-toolbar button:hover{color:#3b82f6}.editor-container .ql-toolbar .ql-stroke{stroke:#64748b}.editor-container .ql-toolbar button:hover .ql-stroke{stroke:#3b82f6}.editor-container .ql-toolbar .ql-fill{fill:#64748b}.editor-container .ql-toolbar button:hover .ql-fill{fill:#3b82f6}.editor-container .ql-toolbar .ql-picker-options{background-color:#fff;border-color:#e2e8f0;box-shadow:0 4px 6px -1px #0000001a}.editor-container .ql-snow.ql-toolbar .ql-picker-label.ql-active,.editor-container .ql-snow.ql-toolbar button.ql-active{color:#3b82f6}.editor-container .ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.editor-container .ql-snow.ql-toolbar button.ql-active .ql-stroke{stroke:#3b82f6}.editor-container .ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.editor-container .ql-snow.ql-toolbar button.ql-active .ql-fill{fill:#3b82f6}.form-actions{border-top:1px solid #e2e8f0;justify-content:flex-end;padding-top:1rem}.cancel-btn{background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#64748b;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.cancel-btn:hover{background-color:#f1f5f9;border-color:#cbd5e1;color:#334155}.cancel-btn:focus{border-color:#e2e8f0}.cancel-btn:active{background-color:#f1f5f9;color:#334155}.submit-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-weight:500;justify-content:center;min-width:120px;padding:.75rem 1.5rem;transition:all .2s}.submit-btn:focus{border:none}.submit-btn:disabled{opacity:.7}.error-message{align-items:center;display:flex;font-size:.875rem}.error-message:before{content:"⚠️";margin-right:.5rem}.category-chips-container{align-items:center;background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;cursor:text;display:flex;flex-wrap:wrap;gap:.5rem;min-height:45px;padding:.75rem}.category-chips-container.is-focused,.category-chips-container:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.category-chip{background:#f1f5f9;border-radius:.25rem;padding:.25rem .5rem}.category-search-input{background:#0000;border:none;flex:1 1;font-size:.875rem;min-width:120px;outline:none;padding:.25rem;transition:all .2s ease}.category-search-input:focus{outline:none}.category-chips-container .category-chip:first-child,.category-chips-container .category-chip:nth-child(2),.category-chips-container .category-chip:nth-child(3),.category-chips-container .category-chip:nth-child(n+4){display:inline-flex;left:auto;position:static}.category-search-input[data-chip-count="0"],.category-search-input[data-chip-count="1"],.category-search-input[data-chip-count="2"],.category-search-input[data-chip-count="3"]{padding:.25rem}@media (max-width:768px){.create-blog-container{padding:1rem}.create-blog-box{padding:1.5rem}.create-blog-title{font-size:1.5rem}.editor-container .ql-toolbar{flex-wrap:wrap;padding:8px}.editor-container .ql-formats{margin-bottom:8px;margin-right:8px}.form-actions{flex-direction:column-reverse}.blog-cancel-btn,.blog-submit-btn,.cancel-btn,.submit-btn{box-sizing:border-box;height:45px;width:100%}.category-chips-container{padding:.5rem}.category-chip{height:26px;max-width:120px}}.blog-cancel-btn{align-items:center;background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;box-sizing:border-box;color:#64748b;cursor:pointer;display:inline-flex;font-weight:500;height:45px;justify-content:center;padding:.75rem 1.5rem;transition:all .2s}.blog-cancel-btn:hover{background-color:#f1f5f9;border-color:#cbd5e1;color:#334155}.blog-cancel-btn:focus{border-color:#e2e8f0;height:45px;outline:none}.blog-cancel-btn:active{background-color:#f1f5f9;color:#334155;height:45px;outline:none;transform:translateY(1px)}.blog-submit-btn{align-items:center;background-color:#3b82f6;border:none;border-radius:6px;box-sizing:border-box;color:#fff;cursor:pointer;display:flex;font-weight:500;height:45px;justify-content:center;min-width:120px;padding:.75rem 1.5rem;transition:all .2s}.blog-submit-btn:hover{background-color:#2563eb}.blog-submit-btn:focus{border:none;height:45px;outline:none}.blog-submit-btn:active{background-color:#1d4ed8;height:45px;outline:none;transform:translateY(1px)}.blog-submit-btn:disabled{cursor:not-allowed;opacity:.7}.success-message{font-size:.875rem}.blog-form-group{border-bottom:none;display:flex;flex-direction:column;gap:.5rem;margin-bottom:0}.blog-form-label{color:#334155;font-size:.875rem;font-weight:500}.blog-form-input{background-color:#fff;border:1px solid #e2e8f0;border-radius:.375rem;color:#1e293b;font-size:.875rem;height:42px;padding:.75rem;transition:all .2s ease;width:100%}.blog-form-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}select.blog-form-input{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;background-size:1em;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;font-size:1rem;outline:none;padding:.75rem 2.5rem .75rem .75rem;transition:border-color .2s,box-shadow .2s}select.blog-form-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}select.blog-form-input:hover{border-color:#cbd5e1}select.blog-form-input option{cursor:pointer;padding:.75rem}select.blog-form-input::-webkit-listbox{border-top-left-radius:0;border-top-right-radius:0}select.blog-form-input{-moz-appearance:none;border-radius:.375rem}select.blog-form-input::-moz-list{border-top-left-radius:0;border-top-right-radius:0}select.blog-form-input::-ms-expand{display:none}select.blog-form-input::-ms-value{border-radius:0}textarea.blog-form-input{font-family:inherit;line-height:1.5;min-height:80px;resize:vertical}.blog-error-message{align-items:center;background-color:#fee2e2;border-radius:6px;color:#dc2626;display:flex;font-size:.875rem;margin-bottom:1.5rem;padding:1rem}.blog-error-message:before{content:"⚠️";margin-right:.5rem}.blog-success-message{animation:fadeIn .3s ease-in;background-color:#dcfce7;border-radius:6px;color:#166534;font-weight:500;margin-bottom:1rem;padding:1rem;text-align:center}.blog-success-message:before{content:"✅";margin-right:.5rem}.blog-loading-spinner{animation:spin 1s linear infinite;border:2px solid #fff;border-radius:50%;border-top-color:#0000;display:inline-block;height:20px;margin:0;width:20px}.category-chips-container{display:block;position:relative}.category-chips-container .category-chip{left:.5rem;position:absolute;top:50%;transform:translateY(-50%);z-index:5}.category-chips-container .category-search-input{padding-left:calc(.5rem + 150px)}.category-chips-container .category-chip:first-child{left:.5rem}.category-chips-container .category-chip:nth-child(2){left:calc(.5rem + 150px)}.category-chips-container .category-chip:nth-child(3){left:calc(.5rem + 300px)}.category-chips-container .category-chip:nth-child(n+4){display:none}.category-chips-container:focus-within{border-color:#0000;box-shadow:none}.chip-text{align-items:center;display:flex;line-height:1.2;max-width:120px;overflow:hidden;padding:2px 0;text-overflow:ellipsis;white-space:nowrap}.category-search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.category-list-dropdown{background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 4px 6px -1px #0000001a;left:0;margin-top:.25rem;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;width:100%;z-index:50}.category-list{list-style:none;margin:0;padding:0}.category-list-item{border-bottom:1px solid #f1f5f9;color:#334155;cursor:pointer;font-size:.875rem;padding:.75rem 1rem}.category-list-item:last-child{border-bottom:none}.category-list-item:hover{background-color:#f8fafc;color:#0369a1}.no-categories-found{padding:.75rem 1rem;text-align:center}.no-categories-found,.no-categories-selected{color:#94a3b8;font-size:.875rem;font-style:italic}.no-categories-selected{margin-top:.5rem}.category-chips-container.has-categories .category-search-input{height:28px;margin:0;min-width:0;opacity:0;padding:0;transition:all .2s ease;width:0}.category-chips-container.has-categories:focus-within .category-search-input{min-width:120px;opacity:1;padding:.25rem;transition:all .2s ease;width:auto}.category-chips-container.has-categories:after{align-items:center;background-color:#f1f5f9;border-radius:4px;color:#94a3b8;content:"+";cursor:pointer;display:flex;font-size:1.25rem;height:28px;justify-content:center;margin-left:4px;transition:all .2s ease;width:28px}.category-chips-container.has-categories:focus-within:after{display:none}.categories-placeholder{color:#94a3b8;cursor:text;flex:1 1;font-size:.875rem;padding:.25rem}.category-chips-container.has-categories .categories-placeholder{align-items:center;display:flex}.category-chips-container.has-categories .categories-placeholder:before{color:#3b82f6;content:"+";font-size:1.2rem;font-weight:500;margin-right:.5rem}.category-chips-container.has-categories:after{display:none}.category-chips-container.has-categories .category-search-input,.category-chips-container.has-categories:focus-within .category-search-input{min-width:120px;opacity:1;padding:.25rem;width:auto}.category-select-btn{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;color:#334155;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .2s}.category-select-btn:hover{background-color:#f1f5f9;border-color:#cbd5e1}.selected-category-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.selected-category-tag{align-items:center;background-color:#e0f2fe;border-radius:9999px;color:#0369a1;display:inline-flex;font-size:.875rem;padding:.25rem .75rem}.tag-remove-btn{align-items:center;background:none;border:none;color:#0369a1;cursor:pointer;display:flex;font-size:1.25rem;height:20px;justify-content:center;line-height:1;margin-left:.25rem;padding:0;width:20px}.tag-remove-btn:hover{color:#dc2626}.category-search-input-standalone{border:1px solid #e2e8f0;border-radius:6px;font-size:.875rem;margin-bottom:.5rem;padding:.5rem;width:100%}.category-search-input-standalone:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.selected-categories-display{margin-top:.75rem}.selected-categories-list{display:flex;flex-wrap:wrap;gap:.5rem}.selected-category-item{align-items:center;background-color:#e0f2fe;border-radius:6px;color:#0369a1;display:inline-flex;font-size:.875rem;padding:.25rem .5rem}.remove-category-btn{align-items:center;background:none;border:none;color:#0369a1;cursor:pointer;display:flex;font-size:1.25rem;height:20px;justify-content:center;line-height:1;margin-left:.25rem;padding:0;width:20px}.remove-category-btn:hover{color:#dc2626}.category-tags-wrapper{display:flex;flex-wrap:wrap;gap:.5rem;margin:.5rem 0}.category-mini-tag{align-items:center;background-color:#e0f2fe;border-radius:4px;color:#0369a1;cursor:default;display:inline-flex;font-size:.75rem;padding:.25rem .5rem}.mini-remove-btn{align-items:center;background:none;border:none;color:#0369a1;cursor:pointer;display:flex;font-size:1rem;height:16px;justify-content:center;line-height:1;margin-left:.25rem;padding:0;width:16px}.mini-remove-btn:hover{color:#dc2626}.custom-select,.select-header{position:relative;width:100%}.select-header{align-items:center;background-color:#fff;border:1px solid #e2e8f0;border-radius:.375rem;color:#1e293b;cursor:pointer;display:flex;font-size:.875rem;height:42px;padding:.75rem;transition:border-color .2s;-webkit-user-select:none;user-select:none}.select-header:hover{border-color:#cbd5e1}.select-header:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.select-header:after{border-color:#64748b #0000 #0000;border-style:solid;border-width:5px 5px 0;content:"";position:absolute;right:1rem;top:50%;transform:translateY(-50%);transition:transform .2s ease}.select-options{background:#fff;border:1px solid #e2e8f0;border-radius:0 0 .375rem .375rem;border-top:none;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;left:0;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;width:100%;z-index:50}.select-option{cursor:pointer;padding:.75rem;transition:background-color .2s}.select-option:hover{background-color:#f8fafc}.select-option.selected{background-color:#f1f5f9;color:#1e293b}.category-input-container{align-items:center;background-color:#fff;border:1px solid #e2e8f0;border-radius:.375rem;display:flex;flex-wrap:wrap;gap:.5rem;min-height:42px;padding:.25rem .6rem;position:relative;transition:border-color .2s;width:100%}.category-input-container:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.category-chips{flex-wrap:wrap;gap:.5rem}.category-chip,.category-chips{align-items:center;display:flex}.category-chip{background:#e0f2fe;border-radius:1rem;color:#1e293b;font-size:.875rem;gap:.25rem;height:28px;justify-content:center;padding:.5rem .5rem .5rem .8rem}.category-chip span{align-items:center;display:flex;line-height:1}.chip-remove{align-items:center;background:none;border:none;border-radius:50%;color:#64748b;cursor:pointer;display:flex;font-size:1.25rem;height:20px;justify-content:center;line-height:.85;padding:0;position:relative;top:-1px;transition:all .2s;width:20px}.chip-remove:hover{background:#e2e8f0;color:#475569}.category-input{background:#0000;border:none;color:#1e293b;font-size:.875rem;padding:.75rem;width:100%}.category-dropdown{background:#fff;border:1px solid #e2e8f0;border-radius:0 0 .375rem .375rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;left:0;margin-top:2px;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;width:100%;z-index:50}.category-option{color:#1e293b;cursor:pointer;font-size:.875rem;padding:.75rem;transition:background-color .2s}.category-option:hover{background-color:#f8fafc}.no-results{color:#64748b;font-size:.875rem;padding:.75rem;text-align:center}.manage-ads-container{margin:0 auto;max-width:1200px;padding:2rem}.manage-ads-header{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:12px;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem}.manage-ads-header h1{color:#1e293b;font-size:2rem;font-weight:600;margin:0}.manage-ads-layout{display:flex;gap:2rem}.ads-sidebar{background:#f8fafc;border-right:1px solid #e2e8f0;padding:1rem;width:250px}.ads-content{background:#fff;border:2px solid #e2e8f0;border-radius:8px;flex:1 1;padding:1rem}.ads-nav-list{list-style:none;margin:0;padding:0}.ads-nav-item{border-radius:6px;color:#475569;cursor:pointer;margin-bottom:.5rem;padding:.75rem 1rem;transition:all .2s}.ads-nav-item.active,.ads-nav-item:hover{background-color:#e2e8f0}.ads-nav-item.active{color:#1e293b;font-weight:500}.create-ad-btn{align-items:center;background-color:#3b82f6;border:0 solid #2563eb;border-radius:6px;box-sizing:border-box;color:#fff;cursor:pointer;display:flex;font-weight:500;height:45px;justify-content:center;min-width:200px;outline:none;padding:.75rem 1rem;transition:all .2s}.create-ad-btn:hover{background-color:#2563eb;border-color:#1d4ed8}.create-ad-btn:focus{border-color:#1d4ed8;outline:none}.create-ad-btn:active{background-color:#2563eb;border-color:#1d4ed8;transform:translateY(1px)}.ad-details{padding:1rem}.ad-details-header{border-bottom:1px solid #e2e8f0;margin-bottom:1.5rem;padding-bottom:1rem}.ad-details-title{color:#1e293b;font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.ad-info-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:1rem}.ad-info-item{background:#f9fafb;border:2px solid #e2e8f0;border-radius:8px;margin-bottom:.5rem;padding-bottom:.5rem}.ad-info-label{color:#64748b;font-size:.875rem;margin-bottom:.5rem}.ad-info-value{color:#1e293b;font-size:1rem;font-weight:500}.ad-actions{display:flex;gap:1rem;margin-top:1.5rem}.delete-btn,.edit-btn{border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;outline:none;padding:.5rem .75rem;transition:all .2s}.edit-btn{background-color:#f1f5f9;color:#475569}.edit-btn:hover{background-color:#e2e8f0;color:#1e293b}.edit-btn:focus{border-color:#3b82f6;outline:none}.delete-btn{background-color:#fee2e2;color:#dc2626}.delete-btn:hover{background-color:#fecaca;color:#b91c1c}.delete-btn:focus{border-color:#dc2626;outline:none}.success-message{align-items:center;display:flex;margin-bottom:1.5rem}.success-message:before{content:"✓";font-size:1rem;font-weight:700;margin-right:.5rem}.loading-spinner{border:3px solid #e2e8f0;margin:2rem auto}@media (max-width:768px){.manage-ads-layout{flex-direction:column}.ads-sidebar{border-bottom:1px solid #e2e8f0;border-right:none;width:100%}.ads-content{padding:1rem 0}}.add-info-section{background:#0000;border:none;border-radius:8px;box-shadow:none;display:flex;flex:1 1;flex-direction:column;margin:0;min-height:0;padding:1.5rem;width:100%}.field-group{background:#f8fafc;border-bottom:1px solid #e2e8f0;border-radius:8px;margin-bottom:1rem;padding:1rem}.field-group:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.delete-field-btn{background:#fee2e2;border:none;border-radius:6px;color:#dc2626;cursor:pointer;font-size:.875rem;margin-left:.5rem;padding:.4rem .75rem;transition:background .2s}.delete-field-btn:hover{background:#fecaca}.add-info-row{align-items:flex-start;display:flex;flex-wrap:nowrap;gap:.75rem;margin-bottom:.75rem;width:100%}.add-info-label{color:#475569;font-size:.95rem;min-width:100px;padding-top:.4rem;white-space:nowrap}.add-info-select{background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#334155;flex:1 1;font-size:1rem;min-width:300px;padding:.4rem;transition:border-color .2s}.add-info-select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.add-info-input{background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#334155;flex:2 1;font-size:1rem;padding:.4rem}.add-info-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:auto;padding-top:1rem}.add-info-btn{background-color:#f1f5f9;border:1px solid #cbd5e1;border-radius:6px;color:#475569;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s}.add-info-btn:hover{background-color:#e2e8f0;border-color:#94a3b8}.add-info-btn.save{background-color:#3b82f6;border:1px solid #2563eb;color:#fff}.add-info-btn.save:hover{background-color:#2563eb;border-color:#1d4ed8}.add-info-btn:focus,.vendor-info-box .add-info-btn:focus{border-color:#94a3b8;outline:none}.add-info-btn.save:focus,.vendor-info-box .add-info-btn.save:focus{border-color:#1d4ed8;outline:none}@media (max-width:600px){.add-info-section{max-width:100%;min-width:0;padding:.75rem .5rem 1rem}.add-info-row{align-items:flex-start;flex-direction:column;gap:.5rem}.add-info-actions{align-items:stretch;flex-direction:column;gap:.5rem}.add-info-actions .ads-add-btn,.add-info-actions .ads-add-btn.ads-save{width:100%}}.manage-ads-split-layout{align-items:stretch;display:flex;gap:1.5rem;min-height:500px}.vendor-list-box{background:#fff;border:2px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;height:auto;min-height:500px;width:300px}.vendor-list-title{background:#f8fafc;border-bottom:1px solid #e2e8f0;border-radius:12px 12px 0 0;color:#1e293b;font-size:1.2rem;font-weight:600;padding:1.25rem}.vendor-list-scroll{flex:1 1;overflow-y:auto;padding:1rem}.vendor-list-item{background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;margin-bottom:.75rem;padding:1rem;transition:all .2s}.vendor-list-item:hover{border-color:#cbd5e1}.vendor-list-item.selected{background:#e0f2fe;border:2px solid #3b82f6}.vendor-list-name{color:#1e293b;font-size:1.125rem;font-weight:500;margin-bottom:.5rem}.vendor-list-status-row{align-items:center;display:flex;justify-content:space-between;margin-top:.5rem}.vendor-list-status{align-items:center;background-color:#f1f5f9;border-radius:9999px;color:#475569;display:inline-flex;font-size:.75rem;font-weight:500;margin-top:.5rem;padding:.25rem .75rem;text-transform:uppercase;text-transform:capitalize}.vendor-list-status.active{background-color:#dcfce7;color:#166534}.vendor-list-status.inactive{background-color:#fee2e2;color:#991b1b}.vendor-list-status.pending{background-color:#fef3c7;color:#92400e}.vendor-list-email{color:#64748b;font-size:.875rem;margin-bottom:.5rem}.vendor-info-box{background:#fff;border:2px solid #e2e8f0;border-radius:12px;display:flex;flex:1 1;flex-direction:column;height:auto;min-height:500px;padding:0}.vendor-info-title{background:#f8fafc;border-bottom:1px solid #e2e8f0;border-radius:12px 12px 0 0;color:#1e293b;font-size:1.2rem;font-weight:600;margin-bottom:0;padding:1.25rem}.vendor-info-placeholder{color:#64748b;font-size:1.1rem;margin-top:2rem;text-align:center}@media (max-width:900px){.manage-ads-split-layout{flex-direction:column;gap:1.5rem}.vendor-list-box{margin-bottom:1rem;max-height:none;max-width:100%;min-height:0;min-height:auto;width:100%}.vendor-info-box{min-height:200px;min-width:0;padding:1.5rem 1rem}}.add-info-description{background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#334155;flex:1 1;font-size:1rem;min-height:80px;min-width:300px;padding:.4rem;resize:vertical;transition:border-color .2s}.add-info-description:focus{border-color:#3b82f6;outline:none}.vendor-list-scroll::-webkit-scrollbar{width:6px}.vendor-list-scroll::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.vendor-list-scroll::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.vendor-list-scroll::-webkit-scrollbar-thumb:hover{background:#94a3b8}.vendor-actions{display:flex;gap:.5rem;margin-left:auto}.vendor-list-item:hover .vendor-actions{opacity:1}.vendor-actions button{align-items:center;border:1px solid #e2e8f0;border-radius:4px;cursor:pointer;display:flex;justify-content:center;outline:none;padding:.4rem;transition:all .2s}.vendor-actions .edit-btn{background-color:#f1f5f9;border:1px solid #e2e8f0;color:#475569}.vendor-actions .edit-btn:hover{background-color:#e2e8f0;border-color:#cbd5e1;color:#1e293b}.vendor-actions .edit-btn:active{background-color:#e2e8f0;border-color:#64748b;color:#1e293b;transform:translateY(1px)}.vendor-actions .delete-btn{background-color:#fee2e2;border:1px solid #fed7d7;color:#f87171}.vendor-actions .delete-btn:hover{background-color:#fecaca;border-color:#fca5a5;color:#ef4444}.vendor-actions .delete-btn:active{background-color:#fecaca;border-color:#ef4444;color:#dc2626;transform:translateY(1px)}.vendor-actions button:focus{outline:none}.vendor-actions .edit-btn:focus{border-color:#3b82f6;outline:none}.vendor-actions .delete-btn:focus{border-color:#ef4444;outline:none}.code-editor-container{background-color:#fff;border:2px solid #e2e8f0;border-radius:6px;font-family:monospace;margin-top:.5rem;overflow:hidden;position:relative;width:100%}.code-editor-container:focus-within{border-color:#3b82f6}.code-editor{background-color:#fff;background-image:linear-gradient(90deg,#f1f5f9 50px,#0000 0);background-repeat:no-repeat;background-size:100% 100%;border:none;color:#334155;counter-reset:line;font-family:Courier New,Courier,monospace;font-size:.9rem;line-height:1.5;min-height:180px;padding:12px 12px 12px 55px;resize:vertical;tab-size:2;width:100%}.code-editor:focus{outline:none}.code-editor:before{content:attr(data-line-numbers);padding:12px 8px;white-space:pre}.code-editor-line-numbers,.code-editor:before{background-color:#f1f5f9;color:#64748b;font-size:.9rem;left:0;line-height:1.5;overflow:hidden;position:absolute;text-align:right;top:0;-webkit-user-select:none;user-select:none;width:50px}.code-editor-line-numbers{border-right:1px solid #e2e8f0;bottom:0;padding:12px 8px 12px 0;pointer-events:none}.code-editor-line-numbers div{height:1.5rem;padding-right:8px}.html-tag{color:#d97706}.javascript-keyword{color:#8b5cf6}.string{color:#16a34a}.comment{color:#9ca3af;font-style:italic}@media (max-width:600px){.code-editor,.code-editor-container{font-size:.85rem}.code-editor{background-image:linear-gradient(90deg,#f1f5f9 40px,#0000 0);padding-left:45px}.code-editor-line-numbers{font-size:.85rem;padding-right:5px;width:40px}}.ads-add-btn{background-color:#f1f5f9;border:1px solid #cbd5e1;border-radius:6px;box-sizing:border-box;color:#475569;cursor:pointer;font-size:.875rem;font-weight:500;height:45px;padding:.5rem 1rem;transition:all .2s}.ads-add-btn:hover{background-color:#e2e8f0;border-color:#94a3b8}.ads-add-btn:active{background-color:#cbd5e1;border-color:#64748b;outline:none;transform:translateY(1px)}.ads-add-btn.ads-save{background-color:#3b82f6;border:1px solid #2563eb;color:#fff}.ads-add-btn.ads-save:hover{background-color:#2563eb;border-color:#1d4ed8}.ads-add-btn.ads-save:active{background-color:#1d4ed8;border-color:#1e40af;outline:none;transform:translateY(1px)}.ads-add-btn:focus{border-color:#94a3b8;outline:none}.ads-add-btn.ads-save:focus{border-color:#1d4ed8;outline:none}.manage-ads-actions{display:flex;gap:1rem}.ad-activity-btn{background:#4f46e5;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:background-color .2s}.ad-activity-btn:hover{background:#4338ca}.ad-locations-list{display:flex;flex-direction:column;gap:1rem;padding:1rem 0}.ad-location-item{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;display:flex;justify-content:space-between;padding:1rem}.ad-location-name{color:#1e293b;font-weight:500}.ad-location-controls{display:flex;gap:.5rem}.visibility-btn{border:none;border-radius:4px;cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:all .2s}.visibility-btn.visible{background:#22c55e;color:#fff}.visibility-btn.visible:hover{background:#16a34a}.visibility-btn.hidden{background:#ef4444;color:#fff}.visibility-btn.hidden:hover{background:#dc2626}.ad-location-info{align-items:center;display:flex;gap:1rem}.ad-location-desc{color:#64748b;font-size:.875rem;font-style:italic}.selected-location-name{color:#4b5563;font-size:.85rem;margin-bottom:8px;padding:4px 0}.selected-location-name strong{color:#3b82f6;font-weight:500}.create-vendor-container{margin:0 auto;max-width:800px;padding:2rem}.create-vendor-box{background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:2rem}.create-vendor-header{margin-bottom:2rem;text-align:center}.create-vendor-header h1{color:#1e293b;font-size:2rem;font-weight:600;margin-bottom:.5rem}.create-vendor-header p{color:#64748b;font-size:1rem}.create-vendor-form{gap:1.5rem}.create-vendor-form,.form-group{border-bottom:none;display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.form-group label{color:#475569;font-size:.875rem;font-weight:500}.form-group input,.form-group select{border:1px solid #e2e8f0;border-radius:6px;font-size:1rem;outline:none;padding:.75rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus{border-color:#3b82f6}.form-actions{border-bottom:none;border-top:none;display:flex;gap:1rem;margin-top:1rem;padding-top:0;position:relative}.form-actions:after,.form-actions:before{display:none}.cancel-btn,.submit-btn{align-items:center;border-radius:4px;box-sizing:border-box;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;height:45px;justify-content:center;line-height:1;min-width:100px;padding:.5rem 1rem;transition:all .2s}.cancel-btn{background-color:#f1f5f9;border:1px solid #cbd5e1;color:#475569}.cancel-btn:hover{background-color:#e2e8f0;border-color:#94a3b8}.cancel-btn:active,.cancel-btn:focus{border-color:#94a3b8;outline:none}.cancel-btn:active{background-color:#cbd5e1;box-shadow:none;transform:translateY(1px)}.submit-btn{background-color:#3b82f6;border:1px solid #2563eb;color:#fff}.submit-btn:hover{background-color:#2563eb;border-color:#1d4ed8}.submit-btn:focus{border-color:#1d4ed8;outline:none}.submit-btn:active{background-color:#1d4ed8;border-color:#1e40af;box-shadow:none;outline:none;transform:translateY(1px)}.submit-btn:disabled{background-color:#93c5fd;cursor:not-allowed}.error-message{background-color:#fee2e2;border-radius:6px;color:#dc2626;margin-bottom:1.5rem;padding:1rem}.loading-spinner{border:2px solid #fff;border-top-color:#0000;display:inline-block;height:20px;margin:0;width:20px}.success-message{animation:fadeIn .3s ease-in;background-color:#dcfce7;border-radius:6px;color:#166534;font-weight:500;margin-bottom:1rem;padding:1rem;text-align:center}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.create-vendor-container{padding:1rem}.create-vendor-box{padding:1.5rem}.create-vendor-header h1{font-size:1.5rem}.form-actions{flex-direction:row;justify-content:flex-end}.cancel-btn,.submit-btn{min-width:100px;width:auto}}#root{margin:0;padding:0;text-align:left;width:100%}.logo{height:6em;padding:1.5em;transition:filter .3s;will-change:filter}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin 20s linear infinite}}.card{padding:2em}.read-the-docs{color:#888}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1 1;margin-top:64px;width:100%}.loading-container{align-items:center;display:flex;justify-content:center;min-height:calc(100vh - 64px)}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#3b82f6;height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#242424;color:#ffffffde;color-scheme:light dark;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-synthesis:none;font-weight:400;line-height:1.5;text-rendering:optimizeLegibility}a{color:#646cff;font-weight:500;text-decoration:inherit}a:hover{color:#535bf2}h1{font-size:3.2em;line-height:1.1}button{background-color:#1a1a1a;border:1px solid #0000;border-radius:8px;cursor:pointer;font-family:inherit;font-size:1em;font-weight:500;padding:.6em 1.2em;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:none}@media (prefers-color-scheme:light){:root{background-color:#fff;color:#213547}a:hover{color:#747bff}button{background-color:#f9f9f9}}
/*# sourceMappingURL=main.c579ce78.css.map*/