.filter-panel{box-sizing:border-box;border-top:1px solid #e0e0e0;width:100%;padding-top:1.5rem;overflow-x:hidden}.filter-panel-collapsed .filter-scrollable-content,.filter-panel-collapsed .filter-apply-footer:not(.filter-apply-footer-visible){display:none}.filter-panel-collapsed{padding-top:0}.filter-panel-collapsed .filter-header{margin-bottom:0;padding:1rem 1.5rem 0}.grants-sidebar .filter-panel{box-sizing:border-box;background:#fff;border-top:none;border-radius:8px;flex-direction:column;width:100%;max-width:100%;max-height:calc(100vh - 4rem);padding:0;display:flex;position:relative;overflow-x:hidden;box-shadow:0 2px 8px #0000001a}.filter-header{box-sizing:border-box;flex-shrink:0;justify-content:space-between;align-items:center;width:100%;margin-bottom:1rem;padding:1rem 1.5rem 0;display:flex;overflow-x:hidden}.filter-toggle-btn{cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;padding:.25rem;transition:opacity .2s;display:flex}@media (min-width:769px){.filter-toggle-btn{opacity:.5;cursor:default;pointer-events:auto}.filter-toggle-btn:hover{opacity:.5}}.filter-toggle-arrow{transition:transform .2s;transform:rotate(0)}.filter-toggle-arrow.collapsed{transform:rotate(-90deg)}.filter-scrollable-content{box-sizing:border-box;flex:1;width:100%;padding:0 1.5rem 1rem;overflow:hidden auto}.filter-scrollable-content::-webkit-scrollbar{width:6px}.filter-scrollable-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.filter-scrollable-content::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.filter-scrollable-content::-webkit-scrollbar-thumb:hover{background:#999}.filter-header h3{color:#333;margin:0;font-size:1.1rem}.clear-filters-link{color:#999;cursor:pointer;background:0 0;border:none;padding:0;font-size:.8rem;text-decoration:underline;transition:color .2s}.clear-filters-link:hover{color:#333}.filter-grid{box-sizing:border-box;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;width:100%;display:grid}.grants-sidebar .filter-grid{grid-template-columns:1fr;min-width:0}.filter-group{flex-direction:column;display:flex}.filter-group label,.filter-group-label{color:#555;margin-bottom:.2rem;font-size:.9rem;font-weight:500}.filter-group-checkboxes{margin-top:0}.checkbox-group{box-sizing:border-box;flex-direction:column;gap:.1rem;width:100%;max-height:200px;padding-right:.5rem;display:flex;overflow:hidden auto}.checkbox-group-no-scroll{box-sizing:border-box;width:100%;max-height:none;padding-right:0;overflow:hidden visible}.checkbox-label{cursor:pointer;color:#333;-webkit-user-select:none;user-select:none;align-items:center;gap:.4rem;font-size:.75rem;display:flex}.checkbox-label:hover{color:#667eea}.filter-checkbox{cursor:pointer;accent-color:#667eea;flex-shrink:0;width:18px;height:18px}.checkbox-text{word-wrap:break-word;overflow-wrap:break-word;min-width:0;line-height:1.4}.checkbox-group::-webkit-scrollbar{width:6px}.checkbox-group::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.checkbox-group::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.checkbox-group::-webkit-scrollbar-thumb:hover{background:#999}.custom-dropdown{box-sizing:border-box;width:100%;min-width:0;max-width:100%;position:relative}.custom-dropdown-toggle{cursor:pointer;color:#333;text-align:left;background:#fff;border:2px solid #e0e0e0;border-radius:6px;justify-content:space-between;align-items:center;width:100%;padding:.65rem 2.5rem .65rem .75rem;font-size:.85rem;font-weight:500;transition:all .2s;display:flex;position:relative}.custom-dropdown-toggle:hover{background-color:#f8f9ff;border-color:#667eea}.custom-dropdown-toggle:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.custom-dropdown-value{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.custom-dropdown-arrow{pointer-events:none;flex-shrink:0;transition:transform .2s;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.custom-dropdown-arrow.open{transform:translateY(-50%)rotate(180deg)}.custom-dropdown-menu{z-index:1000;background:#fff;border:2px solid #e0e0e0;border-radius:6px;flex-direction:column;max-height:300px;margin-top:.25rem;display:flex;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #00000026}.custom-dropdown-item{color:#333;cursor:pointer;text-align:left;background:0 0;border:none;border-bottom:1px solid #f0f0f0;padding:.75rem;font-size:.85rem;transition:background-color .15s}.custom-dropdown-item:last-child{border-bottom:none}.custom-dropdown-item:hover{color:#667eea;background-color:#f8f9ff}.custom-dropdown-item.selected{color:#667eea;background-color:#f0f4ff;font-weight:600}.custom-dropdown-item:first-child{color:#999;font-weight:400}.custom-dropdown-item:first-child.selected{color:#667eea;font-weight:600}.custom-dropdown-menu::-webkit-scrollbar{width:6px}.custom-dropdown-menu::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.custom-dropdown-menu::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.custom-dropdown-menu::-webkit-scrollbar-thumb:hover{background:#999}.filter-apply-footer{box-sizing:border-box;background:#fff;border-top:1px solid #e0e0e0;flex-shrink:0;width:100%;margin-top:auto;padding:1rem 1.5rem;display:none;overflow-x:hidden}.filter-apply-footer-visible{animation:.3s ease-out slideUp;display:block;box-shadow:0 -2px 8px #00000026}@media (max-width:768px){.filter-apply-footer-visible{z-index:1000;border-radius:0;max-width:100vw;position:fixed;bottom:0;left:0;right:0}}@media (min-width:769px){.filter-apply-footer-visible{border-radius:0 0 8px 8px;position:relative}}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.grants-sidebar .filter-panel{padding-bottom:80px}.grants-sidebar .filter-panel:not(:has(.filter-apply-footer-visible)){padding-bottom:0}.grants-sidebar .filter-panel.filter-panel-collapsed{padding-bottom:0}}.apply-filters-btn{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:6px;width:100%;padding:.75rem 1.5rem;font-size:.825rem;font-weight:600;transition:background .2s}.apply-filters-btn:hover{background:#5568d3}.apply-filters-btn:active{transform:scale(.98)}@media (max-width:768px){.filter-panel,.grants-sidebar .filter-panel{width:100%;max-width:100vw;overflow-x:hidden}.filter-grid{grid-template-columns:1fr;width:100%;min-width:0;max-width:100%}.filter-header{box-sizing:border-box;flex-wrap:nowrap;gap:.5rem;width:100%;max-width:100%;padding:1rem 1rem 0;overflow-x:hidden}.filter-panel-collapsed .filter-header{padding:1rem}.filter-header>h3{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.filter-header>div{flex-shrink:0;align-items:center;gap:.5rem;min-width:0;display:flex}.filter-scrollable-content{box-sizing:border-box;width:100%;max-width:100%;padding:0 1rem;overflow-x:hidden}.filter-apply-footer,.filter-apply-footer-visible{box-sizing:border-box;width:100%;max-width:100vw;padding:1rem;left:0!important;right:0!important}.custom-dropdown{width:100%;min-width:0;max-width:100%}.custom-dropdown-toggle{box-sizing:border-box;width:100%;min-width:0;max-width:100%;padding:.65rem 2rem .65rem .75rem}.custom-dropdown-arrow{right:.5rem}.filter-group{width:100%;min-width:0;max-width:100%}.checkbox-group,.checkbox-group-no-scroll{width:100%;max-width:100%;padding-right:0}.checkbox-label{width:100%;min-width:0;max-width:100%}.checkbox-text{word-break:break-word;overflow-wrap:break-word;max-width:100%}.clear-filters-link{white-space:nowrap;flex-shrink:0;font-size:.75rem}}
