*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}body{background-color:#f5f6f8;color:#222;line-height:1.6;-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}ul,ol{list-style:none}img{max-width:100%;display:block}.carousel-banner{width:100%;background:linear-gradient(135deg,#0b4a78 0,#0d5a91 50%,#0b4a78 100%);position:relative;overflow:hidden;min-height:320px}.carousel-track{position:relative;width:100%;min-height:320px}.carousel-slide{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:50px 80px;opacity:0;transition:opacity .6s ease;pointer-events:none}.carousel-slide.active{opacity:1;pointer-events:auto}.carousel-slide-inner{display:flex;align-items:center;gap:40px;max-width:1100px;width:100%}.carousel-thumb{width:160px;height:210px;border-radius:8px;flex-shrink:0;overflow:hidden;backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,0.2);background:rgba(255,255,255,0.15)}.carousel-thumb img{width:100%;height:100%;object-fit:cover;display:block}.carousel-thumb svg{width:48px;height:48px;color:rgba(255,255,255,0.7);margin:auto;display:block;padding-top:80px}.carousel-text{flex:1}.carousel-label{font-size:13px;text-transform:uppercase;letter-spacing:1.5px;color:#4aa3ff;margin-bottom:8px;font-weight:600}.carousel-title{font-size:28px;font-weight:700;color:#fff;margin-bottom:8px;line-height:1.3}.carousel-desc{font-size:16px;color:rgba(255,255,255,0.75);margin-bottom:20px;max-width:500px}.carousel-cta{display:inline-flex;align-items:center;gap:8px;background:#2f9bff;color:#fff;padding:10px 24px;border-radius:6px;font-size:14px;font-weight:600;border:0;cursor:pointer;transition:background .2s,transform .2s}.carousel-cta:hover{background:#1d86ea;transform:translateY(-1px)}.carousel-cta svg{width:16px;height:16px}.carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.2);border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s;z-index:10}.carousel-arrow:hover{background:rgba(255,255,255,0.3)}.carousel-arrow.prev{left:16px}.carousel-arrow.next{right:20px}.carousel-dots{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);display:flex;gap:8px}.carousel-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.35);border:0;cursor:pointer;transition:background .3s,transform .3s}.carousel-dot.active{background:#fff;transform:scale(1.3)}.page-container{display:flex;max-width:1280px;margin:32px auto;padding:0 24px;gap:32px;align-items:flex-start}.sidebar{width:260px;flex-shrink:0;position:sticky;top:24px}.sidebar-card{background:#fff;border-radius:10px;box-shadow:0 2px 12px rgba(16,24,40,0.06);overflow:hidden}.sidebar-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#8c95a3;padding:20px 20px 12px}.sidebar-nav{padding:0 8px 12px}.sidebar-item{display:flex;align-items:center;gap:12px;padding:11px 16px;border-radius:8px;cursor:pointer;transition:background .2s,color .15s;font-size:14px;font-weight:500;color:#1e232b;margin-bottom:2px}.sidebar-item svg{width:18px;height:18px;flex-shrink:0;opacity:.6;transition:opacity .2s}.sidebar-item:hover{background:#f1f5f9}.sidebar-item.active{background:#0b4a78;color:#fff}.sidebar-item.active svg{opacity:1;color:#fff}.sidebar-count{margin-left:auto;font-size:12px;font-weight:600;color:#8c95a3;background:#f1f5f9;padding:2px 8px;border-radius:10px}.sidebar-item.active .sidebar-count{background:rgba(255,255,255,0.2);color:#fff}.mobile-filter-toggle{display:none;width:100%;padding:14px 20px;background:#fff;border:1px solid #d9e0e8;border-radius:10px;font-size:14px;font-weight:600;color:#1e232b;cursor:pointer;margin-bottom:16px;align-items:center;gap:8px;box-shadow:0 2px 12px rgba(16,24,40,0.06)}.mobile-filter-toggle svg{width:18px;height:18px}.content-area{flex:1;min-width:0}.content-header{margin-bottom:24px}.content-title{font-size:26px;font-weight:700;color:#111;margin-bottom:4px}.content-subtitle{font-size:14px;color:#5f6773;margin-bottom:16px}.content-divider{height:1px;background:#d9e0e8}.search-bar{display:flex;align-items:center;gap:10px;margin-top:20px;padding:10px 16px;background:#fff;border:1px solid #d9e0e8;border-radius:10px;transition:border-color .2s,box-shadow .2s}.search-bar:focus-within{border-color:#2f9bff;box-shadow:0 0 0 3px rgba(47,155,255,0.1)}.search-bar svg{width:18px;height:18px;color:#8c95a3;flex-shrink:0}.search-bar input{flex:1;border:0;outline:0;font-size:14px;color:#222;background:transparent;font-family:inherit}.search-bar input::placeholder{color:#8c95a3}.search-clear{display:none;align-items:center;justify-content:center;width:24px;height:24px;border:0;background:#f1f5f9;border-radius:50%;font-size:16px;color:#5f6773;cursor:pointer;line-height:1;transition:background .2s}.search-clear.visible{display:flex}.search-clear:hover{background:#d9e0e8}.resources-container{position:relative;min-height:300px}.resources-list{opacity:1;transition:opacity .3s ease}.resources-list.fading{opacity:0}.resource-row{display:flex;align-items:flex-start;gap:20px;padding:24px 0;border-bottom:1px solid #d9e0e8;transition:background .2s;border-radius:4px;opacity:0;transform:translateY(12px);animation:fadeUp .4s ease forwards}@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}.resource-row:hover{background:#fafbfc}.resource-row:last-child{border-bottom:0}.resource-thumb{width:140px;height:200px;border-radius:6px;flex-shrink:0;overflow:hidden;border:1px solid #d9e0e8;background:#e8eef4}.resource-thumb img{width:100%;height:100%;object-fit:cover;display:block}.resource-thumb svg{width:48px;height:48px;color:#8c95a3;margin:auto;display:block;padding-top:76px}.resource-body{flex:1;min-width:0}.resource-category{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:#4aa3ff;font-weight:600;margin-bottom:4px}.resource-title{font-size:16px;font-weight:600;color:#111;margin-bottom:6px;line-height:1.4}.resource-desc{font-size:13px;color:#5f6773;line-height:1.5;margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.resource-download{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#2490ff;transition:color .2s,transform .15s;cursor:pointer}.resource-download:hover{color:#0f78e6;transform:translateX(2px)}.resource-download svg{width:14px;height:14px}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:none;align-items:flex-start;justify-content:center;padding-top:60px;z-index:5}.loading-overlay.visible{display:flex}.loading-spinner{width:32px;height:32px;border:3px solid #d9e0e8;border-top-color:#2f9bff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:60px 20px;color:#8c95a3}.empty-state svg{width:48px;height:48px;margin:0 auto 16px;opacity:.5}.empty-state p{font-size:15px;font-weight:500}.pagination{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:32px;padding-bottom:40px}.pagination-btn{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;border-radius:8px;border:1px solid #d9e0e8;background:#fff;color:#222;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s,border-color .2s,color .2s}.pagination-btn:hover:not(:disabled){background:#f1f5f9;border-color:#c9d3df}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-btn.active{background:#0b4a78;color:#fff;border-color:#0b4a78}.pagination-btn.nav-btn{gap:4px;font-weight:600}.pagination-btn.nav-btn svg{width:14px;height:14px}.results-info{text-align:center;margin-top:12px;font-size:13px;color:#8c95a3}@media(max-width:900px){.page-container{flex-direction:column}.sidebar{width:100%;position:static}.sidebar-card{display:none}.sidebar-card.mobile-open{display:block;margin-bottom:8px}.mobile-filter-toggle{display:flex}.carousel-slide{padding:30px 50px}.carousel-slide-inner{gap:24px}.carousel-thumb{width:80px;height:110px}.carousel-title{font-size:20px}}@media(max-width:600px){.carousel-slide{padding:24px 16px}.carousel-slide-inner{flex-direction:column;text-align:center;gap:16px}.carousel-thumb{width:70px;height:90px;margin:0 auto}.carousel-desc{max-width:100%}.carousel-arrow{width:32px;height:32px}.carousel-arrow.prev{left:8px}.carousel-arrow.next{right:8px}.resource-row{flex-direction:column;gap:12px}.resource-thumb{width:100px;height:140px}.page-container{padding:0 16px;margin:16px auto}}