.card{background-color:#fff;border:1px solid #e2e8f0;border-radius:.75rem;padding:1.5rem;box-shadow:0 4px 6px -1px #00000012,0 2px 4px -1px #0000000d;display:flex;flex-direction:column;justify-content:space-between;transition:box-shadow .2s ease-in-out,transform .2s ease-in-out;height:100%;box-sizing:border-box}.card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.card-content{flex-grow:1;margin-bottom:1rem}.card-title{font-size:1.25em;font-weight:600;color:#1a202c;margin-bottom:.75rem}.card-description{font-size:.95em;color:#4a5568;line-height:1.5}.card-tags{margin-top:1rem;display:flex;flex-wrap:wrap;gap:.5rem}.card-tag{background-color:#edf2f7;color:#4a5568;padding:.2rem .6rem;border-radius:.25rem;font-size:.8em}.card-title a{color:inherit;text-decoration:none}.card-title a:hover{text-decoration:underline;color:#2b6cb0}.card-tags{margin-top:1rem;display:flex;flex-wrap:wrap;gap:.5rem;max-height:5em;overflow:hidden}.card-tag{background-color:#edf2f7;color:#4a5568;padding:.2rem .6rem;border-radius:9999px;font-size:.8em;white-space:nowrap}.card-button{padding:.6rem 1rem;border:1px solid #e2e8f0;background-color:#fff;color:#4a5568;border-radius:.5rem;cursor:pointer;font-size:.9em;font-weight:500;text-align:center;width:100%;margin-top:auto;transition:background-color .2s ease,color .2s ease}.card-button:hover{background-color:#f7fafc;border-color:#cbd5e0}.tag-button{padding:.5rem 1.25rem;border:1px solid #e2e8f0;background-color:#fff;color:#4a5568;border-radius:9999px;cursor:pointer;font-size:.9em;transition:background-color .2s ease,color .2s ease,border-color .2s ease;white-space:nowrap}.tag-button:hover{background-color:#f7fafc;border-color:#cbd5e0}.tag-button.active{background-color:#2d3748;color:#fff;border-color:#2d3748;font-weight:500}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem;box-sizing:border-box}.modal-content{background-color:#fff;padding:2rem;border-radius:.5rem;box-shadow:0 5px 15px #0000004d;max-width:800px;width:90%;max-height:90vh;overflow-y:auto;position:relative;animation:-slide-down .3s ease-out}@keyframes -slide-down{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.modal-close-buttonh{position:absolute;top:.75rem;right:1rem;background:none;border:none;font-size:1.8rem;line-height:1;cursor:pointer;color:#888}.modal-close-button:hover{color:#333}.modal-title{margin-top:0;margin-bottom:1rem;color:#1a202c}.modal-link{margin-bottom:1.5rem;font-size:.9em}.modal-link a:where{color:#3182ce;text-decoration:none}.modal-link a:where:hover{text-decoration:underline}.modal-body{margin-bottom:1.5rem;line-height:1.6;color:#4a5568}.modal-body h1,.modal-body h2,.modal-body h3,.modal-body h4{margin-top:1.5em;margin-bottom:.8em;color:#2d3748;line-height:1.3}.modal-body h1{font-size:1.6em}.modal-body h2{font-size:1.4em}.modal-body h3{font-size:1.2em}.modal-body p{margin-bottom:1em}.modal-body ul,.modal-body ol{margin-left:1.5rem;margin-bottom:1em}.modal-body li{margin-bottom:.5em}.modal-body a{color:#3182ce}.modal-body a:hover{text-decoration:underline}.modal-body code{background-color:#edf2f7;padding:.2em .4em;border-radius:3px;font-size:.9em}.modal-body pre{background-color:#f7fafc;padding:1em;border-radius:4px;overflow-x:auto}.modal-body pre code{background-color:transparent;padding:0}.modal-body strong{font-weight:600}.modal-body blockquote{border-left:4px solid #e2e8f0;padding-left:1rem;margin-left:0;margin-right:0;color:#718096}.modal-tags{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e2e8f0;font-size:.9em;color:#4a5568}.modal-tags strong:where{margin-right:.5rem}.modal-tagh{display:inline-block;background-color:#e2e8f0;color:#4a5568;padding:.2rem .6rem;border-radius:4px;font-size:.9em;margin-right:.5rem;margin-bottom:.5rem}.modal-footer{margin-top:1.5rem;text-align:right;padding-top:1rem;border-top:1px solid #e2e8f0}.modal-close-text-button{padding:.6rem 1.2rem;border:1px solid #cbd5e0;background-color:#f7fafc;color:#4a5568;border-radius:.375rem;cursor:pointer;transition:background-color .2s ease}.modal-close-text-button:hover{background-color:#e2e8f0}.resource-page{max-width:1200px;margin:2rem auto;padding:0 1rem;font-family:sans-serif;color:#333}.header-banner{background-color:#f0f0f0;color:#555;padding:.5rem 1rem;border-radius:1rem;display:inline-block;margin-bottom:1.5rem;font-size:.9em}h1{font-size:2.5em;margin-bottom:.5rem;text-align:center;color:#1a202c}.subtitle{text-align:center;color:#718096;margin-bottom:2.5rem;font-size:1.1em}.filter-bar{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem;margin-bottom:3rem}.resource-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}@media (max-width: 768px){.resource-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}h1{font-size:2em}}@media (max-width: 480px){.resource-grid{grid-template-columns:1fr}}
