:root{--bg-primary:#ffffff;--bg-secondary:#f8f9fb;--bg-card:#ffffff;--bg-glass:rgba(255,255,255,0.85);--glass-border:rgba(0,0,0,0.08);--glass-shadow:0 1px 3px rgba(0,0,0,0.06),0 4px 16px rgba(0,0,0,0.04);--text-primary:#1a1a2e;--text-secondary:#555770;--text-muted:#8b8da3;--accent-indigo:#4f46e5;--accent-violet:#7c3aed;--accent-cyan:#0891b2;--accent-green:#059669;--accent-amber:#d97706;--accent-red:#dc2626;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--transition:0.2s ease;--sidebar-width:260px;--sidebar-collapsed:72px;--navbar-height:64px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-secondary);color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}.container{max-width:1200px}.container,.container-narrow{margin:0 auto;padding:0 1.5rem}.container-narrow{max-width:800px}.glass-card{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1.25rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:all var(--transition);font-family:inherit;text-decoration:none;white-space:nowrap}.btn:hover{transform:translateY(-1px)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--accent-indigo);color:#ffffff}.btn-primary:hover{background:#4338ca}.btn-outline{background:transparent;border:1px solid #d1d5db;color:var(--text-primary)}.btn-outline:hover{border-color:var(--accent-indigo);color:var(--accent-indigo);background:rgba(79,70,229,.04)}.btn-sm{padding:.375rem .75rem;font-size:.8rem;border-radius:var(--radius-sm)}.btn-lg{padding:.75rem 1.75rem;font-size:.95rem}.btn-full{width:100%}.btn-success{background:var(--accent-green);color:#ffffff}.btn-warning{background:var(--accent-amber);color:#ffffff}.btn-danger{background:#fee2e2;color:var(--accent-red);border:1px solid #fecaca}.btn-danger:hover{background:#fecaca}.navbar{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--navbar-height);background:rgba(255,255,255,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--glass-border)}.navbar-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;height:100%;justify-content:space-between}.navbar-brand,.navbar-inner{display:flex;align-items:center}.navbar-brand{gap:.5rem;font-size:1.15rem;font-weight:700}.brand-logo{border-radius:6px;object-fit:contain}.brand-text,.navbar-toggle{color:var(--text-primary)}.navbar-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem}.navbar-nav{display:flex;gap:.25rem}.nav-link{padding:.5rem .875rem;border-radius:var(--radius-md);font-size:.9rem;font-weight:500;color:var(--text-secondary);transition:all var(--transition)}.nav-link.active,.nav-link:hover{color:var(--text-primary);background:var(--bg-secondary)}.nav-link.active{color:var(--accent-indigo);font-weight:600}.main-content{margin-top:var(--navbar-height);min-height:calc(100vh - var(--navbar-height))}.hero{position:relative;padding:8rem 0 6rem;text-align:center;overflow:hidden;min-height:480px;display:flex;align-items:center;justify-content:center}.hero-bg{background-image:url(/hero.png);background-size:cover;background-position:50%;background-repeat:no-repeat;z-index:0}.hero-bg,.hero-bg:before{position:absolute;inset:0}.hero-bg:before{content:"";background:linear-gradient(180deg,rgba(255,255,255,.1),rgba(0,0,0,.5));z-index:1}.hero-content{position:relative;z-index:3}.hero-title{font-size:clamp(2.5rem,5vw,4rem);font-weight:800;line-height:1.1;margin-bottom:1.25rem;color:#ffffff;text-shadow:0 2px 20px rgba(0,0,0,.3)}.gradient-text{color:#c7d2fe}.hero-subtitle{font-size:1.15rem;color:rgba(255,255,255,.85);max-width:600px;margin:0 auto 2.5rem;line-height:1.7;text-shadow:0 1px 8px rgba(0,0,0,.2)}.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.section{padding:4rem 0}.section-alt{background:var(--bg-secondary)}.section-header{text-align:center;margin-bottom:3rem}.section-title{font-size:2rem;font-weight:700;margin-bottom:.5rem}.section-subtitle{color:var(--text-secondary);font-size:1.05rem}.section-cta{text-align:center;margin-top:2rem}.articles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));grid-gap:1.5rem;gap:1.5rem}.article-card{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition)}.article-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.08)}.article-card-image{height:200px;overflow:hidden}.article-card-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition)}.article-card:hover .article-card-image img{transform:scale(1.05)}.article-card-body{padding:1.25rem;flex:1 1;display:flex;flex-direction:column}.article-card-date{font-size:.8rem;color:var(--text-muted);margin-bottom:.5rem}.article-card-title{font-size:1.15rem;font-weight:600;margin-bottom:.5rem;line-height:1.3}.article-card-excerpt{font-size:.9rem;color:var(--text-secondary);line-height:1.5;flex:1 1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.article-card-link{margin-top:1rem;font-size:.85rem;font-weight:600;color:var(--accent-indigo)}.back-link{display:inline-flex;align-items:center;color:var(--text-secondary);font-size:.9rem;margin-bottom:2rem;transition:color var(--transition)}.back-link:hover{color:var(--accent-indigo)}.article-detail{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);overflow:hidden}.article-cover{height:350px;overflow:hidden}.article-cover img{width:100%;height:100%;object-fit:cover}.article-header{padding:2rem 2rem 1rem}.article-date{font-size:.85rem;color:var(--text-muted)}.article-title{font-size:2rem;font-weight:700;margin:.5rem 0;line-height:1.2}.article-excerpt{font-size:1.1rem;color:var(--text-secondary);margin-top:.5rem;line-height:1.6}.article-body{padding:1rem 2rem 2rem;color:var(--text-secondary);line-height:1.8;font-size:1rem}.article-body h2,.article-body h3{color:var(--text-primary);margin:1.5rem 0 .75rem}.article-body p{margin-bottom:1rem}.article-body ol,.article-body ul{margin:1rem 0;padding-left:1.5rem}.article-body a{color:var(--accent-indigo);text-decoration:underline}.charts-container{display:grid;grid-gap:2rem;gap:2rem}.chart-wrapper{padding:1.5rem}.chart-title{font-size:1.15rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary)}.chart-empty{text-align:center;padding:3rem;color:var(--text-muted)}.data-table-container{padding:1.5rem}.table-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;gap:1rem;flex-wrap:wrap}.table-search{background:var(--bg-primary);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:.625rem 1rem;color:var(--text-primary);font-size:.875rem;font-family:inherit;min-width:250px;transition:border-color var(--transition)}.table-search:focus{outline:none;border-color:var(--accent-indigo)}.table-search::placeholder{color:var(--text-muted)}.table-count{font-size:.85rem;color:var(--text-muted)}.table-scroll{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table thead{border-bottom:2px solid var(--glass-border)}.data-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:var(--text-primary);white-space:nowrap}.data-table td{padding:.625rem 1rem;color:var(--text-secondary);border-bottom:1px solid var(--glass-border)}.data-table tbody tr:hover{background:var(--bg-secondary)}.table-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--glass-border)}.pagination-info{font-size:.85rem;color:var(--text-muted)}.table-empty{padding:3rem}.empty-state,.table-empty{text-align:center;color:var(--text-muted)}.empty-state{padding:3rem 2rem;flex-direction:column;gap:1rem}.alert,.empty-state{display:flex;align-items:center}.alert{padding:.875rem 1.25rem;border-radius:var(--radius-md);font-size:.9rem;margin-bottom:1rem;gap:.5rem}.alert-error{background:#fef2f2;color:var(--accent-red);border:1px solid #fecaca}.alert-success{background:#f0fdf4;color:var(--accent-green);border:1px solid #bbf7d0}.alert-hint{font-size:.82rem;color:var(--text-muted);margin-top:.25rem}.footer{background:var(--bg-primary);border-top:1px solid var(--glass-border);padding:2rem 0}.footer-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;justify-content:space-between;flex-wrap:wrap;gap:1rem}.footer-brand,.footer-inner{display:flex;align-items:center}.footer-brand{gap:.5rem;font-weight:600}.footer-text{font-size:.85rem;color:var(--text-muted)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--bg-secondary)}.login-card{width:100%;max-width:420px;padding:2.5rem}.login-header{text-align:center;margin-bottom:2rem}.login-icon{font-size:2.5rem;display:block;margin-bottom:1rem}.login-title{font-size:1.5rem;font-weight:700}.login-subtitle{color:var(--text-secondary);font-size:.9rem;margin-top:.5rem}.login-form{gap:1rem}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:.375rem}.form-label{font-size:.85rem;font-weight:600;color:var(--text-secondary)}.form-input,.form-textarea{background:var(--bg-primary);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:.75rem 1rem;color:var(--text-primary);font-size:.9rem;font-family:inherit;transition:border-color var(--transition);width:100%}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--accent-indigo);box-shadow:0 0 0 3px rgba(79,70,229,.1)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-textarea{resize:vertical;min-height:100px}.form-textarea-lg{min-height:200px;font-family:Fira Code,Courier New,monospace;font-size:.85rem;line-height:1.6}.form-check{flex-direction:row;align-items:center}.check-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem}.form-checkbox{width:18px;height:18px;accent-color:var(--accent-indigo)}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.upload-area{margin-top:.25rem}.upload-dropzone{display:flex;align-items:center;justify-content:center;border:2px dashed var(--glass-border);border-radius:var(--radius-lg);padding:2rem;cursor:pointer;transition:all var(--transition);background:var(--bg-secondary)}.upload-dropzone:hover{border-color:var(--accent-indigo);background:rgba(99,102,241,.05)}.upload-input{display:none}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.9rem}.upload-icon{font-size:2rem}.upload-hint{font-size:.75rem;color:var(--text-muted);opacity:.7}.upload-preview{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--glass-border);max-width:400px}.upload-preview img{width:100%;height:200px;object-fit:cover;display:block}.upload-remove{position:absolute;top:.5rem;right:.5rem;background:rgba(239,68,68,.9);color:white;border:none;border-radius:var(--radius-sm);padding:.35rem .75rem;font-size:.8rem;cursor:pointer;font-family:inherit;transition:background var(--transition)}.upload-remove:hover{background:rgba(239,68,68,1)}.article-form{padding:2rem}.admin-layout{display:flex;min-height:100vh}.admin-main{flex:1 1;margin-left:var(--sidebar-width);transition:margin-left var(--transition)}.admin-content{padding:2rem;max-width:1200px}.admin-sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background:var(--bg-primary);border-right:1px solid var(--glass-border);display:flex;flex-direction:column;transition:width var(--transition);z-index:100}.admin-sidebar.collapsed{width:var(--sidebar-collapsed)}.admin-sidebar.collapsed~.admin-main{margin-left:var(--sidebar-collapsed)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem;border-bottom:1px solid var(--glass-border);min-height:65px}.sidebar-brand{font-weight:700;font-size:1.1rem;white-space:nowrap}.sidebar-toggle{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center}.sidebar-nav{flex:1 1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.25rem}.sidebar-link{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:var(--radius-md);font-size:.9rem;font-weight:500;color:var(--text-secondary);transition:all var(--transition);border:none;background:none;cursor:pointer;font-family:inherit;width:100%;text-align:left}.sidebar-link:hover{color:var(--text-primary);background:var(--bg-secondary)}.sidebar-link.active{color:var(--accent-indigo);background:rgba(79,70,229,.08)}.sidebar-footer{padding:.75rem;border-top:1px solid var(--glass-border);display:flex;flex-direction:column;gap:.25rem}.logout-link:hover{color:var(--accent-red)!important;background:#fef2f2!important}.admin-page{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.admin-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.admin-page-title{font-size:1.75rem;font-weight:700}.admin-page-subtitle{font-size:.95rem;color:var(--text-secondary);margin-top:.25rem}.admin-section-title{font-size:1.25rem;font-weight:600;margin-bottom:1rem;margin-top:2rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:1.25rem;gap:1.25rem}.stat-card{padding:1.5rem;gap:1rem}.stat-card,.stat-icon{display:flex;align-items:center}.stat-icon{width:50px;height:50px;border-radius:var(--radius-md);justify-content:center;flex-shrink:0}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:1.75rem;font-weight:700}.stat-label{font-size:.85rem;color:var(--text-secondary)}.stat-action{font-size:.85rem;color:var(--accent-indigo);font-weight:600;margin-top:.25rem}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:1rem;gap:1rem}.action-card{padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center;color:var(--text-secondary);transition:all var(--transition)}.action-card:hover{color:var(--accent-indigo);transform:translateY(-2px);border-color:rgba(99,102,241,.3)}.admin-table-container{overflow:hidden}.admin-table{width:100%;border-collapse:collapse;font-size:.875rem}.admin-table th{padding:1rem 1.25rem;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid var(--glass-border);white-space:nowrap}.admin-table td{padding:.875rem 1.25rem;color:var(--text-secondary);border-bottom:1px solid rgba(99,102,241,.08)}.admin-table tbody tr:hover{background:rgba(99,102,241,.05)}.slug-text{font-size:.8rem;color:var(--text-muted);background:rgba(99,102,241,.1);padding:.2rem .5rem;border-radius:var(--radius-sm)}.action-buttons{display:flex;gap:.5rem}.badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;white-space:nowrap}.badge-success{background:rgba(16,185,129,.15);color:var(--accent-green)}.badge-warning{background:rgba(245,158,11,.15);color:var(--accent-amber)}.upload-section{padding:2rem}.upload-dropzone{margin-bottom:1.5rem}.dropzone-label{display:flex;align-items:center;justify-content:center;min-height:200px;border:2px dashed var(--glass-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition)}.dropzone-label:hover{border-color:var(--accent-indigo);background:rgba(99,102,241,.05)}.dropzone-input{display:none}.dropzone-placeholder{display:flex;flex-direction:column;align-items:center;gap:.75rem;color:var(--text-muted)}.dropzone-text{font-size:1rem;font-weight:500}.dropzone-hint{font-size:.8rem}.dropzone-file{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--accent-indigo)}.dropzone-filename{font-weight:600}.dropzone-size{font-size:.85rem;color:var(--text-muted)}.upload-info{margin-top:2rem;padding:1.5rem;background:rgba(99,102,241,.05);border-radius:var(--radius-md);border:1px solid rgba(99,102,241,.1)}.upload-info h3{font-size:1rem;margin-bottom:.75rem}.upload-info ul{list-style:disc;padding-left:1.25rem;color:var(--text-secondary);font-size:.9rem}.upload-info li{margin-bottom:.25rem}.homepage-grid{display:grid;grid-template-columns:1fr 380px;grid-gap:2rem;gap:2rem;align-items:start}.homepage-main{min-width:0}.homepage-sidebar{position:-webkit-sticky;position:sticky;top:calc(var(--navbar-height) + 2rem)}.sidebar-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.sidebar-title{font-size:1.15rem;font-weight:700}.sidebar-more{font-size:.8rem;color:var(--accent-indigo);font-weight:600}.news-feed{flex-direction:column}.news-feed,.news-item{display:flex;gap:.75rem}.news-item{padding:.875rem;background:var(--bg-glass);border:1px solid var(--glass-border);border-radius:var(--radius-md);transition:all var(--transition)}.news-item:hover{border-color:rgba(99,102,241,.3);background:rgba(99,102,241,.05);transform:translateX(4px)}.news-thumb{width:64px;height:64px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0}.news-thumb img{width:100%;height:100%;object-fit:cover}.news-content{flex:1 1;min-width:0}.news-title{font-size:.9rem;font-weight:600;line-height:1.3;margin-bottom:.25rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.news-date{font-size:.75rem;color:var(--text-muted)}.book-list-container{max-width:900px;margin:0 auto}.book-grid{display:flex;flex-direction:column;gap:1rem}.book-card{overflow:hidden;transition:all var(--transition)}.book-card:hover{border-color:rgba(99,102,241,.3)}.book-card.expanded{border-color:rgba(99,102,241,.4);box-shadow:0 8px 30px rgba(99,102,241,.12)}.book-card-header{display:flex;align-items:center;gap:1rem;padding:1.25rem;cursor:pointer;transition:background var(--transition)}.book-card-header:hover{background:rgba(99,102,241,.05)}.book-card-icon{width:48px;height:48px;border-radius:var(--radius-md);background:rgba(99,102,241,.15);display:flex;align-items:center;justify-content:center;color:var(--accent-indigo);flex-shrink:0}.book-card-info{flex:1 1;min-width:0}.book-title{font-size:1.05rem;font-weight:600;margin-bottom:.25rem;line-height:1.3}.book-meta{display:flex;gap:1rem;flex-wrap:wrap;font-size:.8rem;color:var(--text-muted)}.book-author,.book-category,.book-year{display:flex;align-items:center;gap:.25rem}.book-toggle{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.5rem;transition:color var(--transition);flex-shrink:0}.book-toggle:hover{color:var(--accent-indigo)}.book-card-body{border-top:1px solid var(--glass-border);padding:1rem 1.25rem 1.25rem;animation:fadeIn .3s ease}.book-description{color:var(--text-secondary);font-size:.9rem;line-height:1.7;margin-bottom:1rem}.book-details{display:grid;grid-template-columns:1fr 1fr;grid-gap:.5rem 1.5rem;gap:.5rem 1.5rem}.book-detail-row{display:flex;flex-direction:column;gap:.1rem;padding:.5rem 0}.book-detail-label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.book-detail-value{font-size:.9rem;color:var(--text-secondary)}@media (max-width:1024px){.homepage-grid{grid-template-columns:1fr}.homepage-sidebar{position:static}}@media (max-width:768px){.navbar-toggle{display:flex}.navbar-nav{position:fixed;top:var(--navbar-height);left:0;right:0;background:rgba(255,255,255,.98);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);flex-direction:column;padding:1rem;border-bottom:1px solid var(--glass-border);transform:translateY(-100%);opacity:0;pointer-events:none;transition:all var(--transition)}.navbar-nav.open{transform:translateY(0);opacity:1;pointer-events:all}.hero-title{font-size:2rem}.articles-grid{grid-template-columns:1fr}.admin-sidebar{transform:translateX(-100%)}.admin-sidebar:not(.collapsed){transform:translateX(0)}.admin-main{margin-left:0}.admin-content{padding:1rem}.admin-page-header{flex-direction:column;align-items:flex-start}.stats-grid{grid-template-columns:1fr 1fr}.footer-inner{flex-direction:column;text-align:center}.table-search{min-width:100%}.book-details{grid-template-columns:1fr}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}.hero{padding:4rem 0 3rem;min-height:360px}.book-card-header{padding:1rem}.book-meta{flex-direction:column;gap:.25rem}}