/* Student Resource Directory Frontend Styles */

.srd-directory-container { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; }
.srd-filters-form { background: #f6f7f7; border: 1px solid #ddd; padding: 20px; margin-bottom: 30px; border-radius: 4px; }
.srd-filters-form .srd-filter-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 20px; align-items: end; }
.srd-filters-form label { font-weight: bold; display: block; margin-bottom: 5px; color: #000; }
.srd-filters-form input[type="text"], .srd-filters-form select { width: 100%; padding: 8px; border-radius: 4px; border: 1px solid #ccc; background-color: #fff; color: #000; }
.srd-filters-form .srd-filter-submit { text-align: right; }
.srd-filters-form input[type="submit"] { padding: 10px 20px; border: none; background-color: #2271b1; color: white; border-radius: 4px; cursor: pointer; font-size: 1em; font-weight: bold; }
.srd-filters-form input[type="submit"]:hover { background-color: #135e96; }
.srd-category-group-title { font-size: 1.8em; font-weight: bold; margin-top: 40px; margin-bottom: 20px; padding-bottom: 10px; border-bottom: 2px solid #eee; color: #000; }
.srd-listing-grid + .srd-category-group-title { margin-top: 60px; }
.srd-listing-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 20px; }
.srd-listing-item { border: 1px solid #e0e0e0; border-radius: 4px; background: #fff; overflow: hidden; transition: box-shadow 0.3s ease-in-out; display: flex; flex-direction: column; }
.srd-listing-item:hover { box-shadow: 0 4px 15px rgba(0,0,0,0.1); }
.srd-listing-item-content { padding: 20px; flex-grow: 1; display: flex; flex-direction: column; }
.srd-listing-header { margin-bottom: 15px; }
.srd-listing-title { margin: 0 0 10px 0; font-size: 1.4em; font-weight: bold; }
.srd-listing-title a { text-decoration: none; color: #1d2327; }
.srd-listing-title a:hover { color: #2271b1; }
.srd-listing-badges span { display: inline-block; padding: 4px 8px; font-size: 0.75em; font-weight: bold; border-radius: 3px; color: #fff; margin-right: 5px; text-transform: uppercase; }
.srd-badge-featured { background-color: #d63638; }
.srd-badge-recommended { background-color: #00a32a; }
.srd-listing-description { color: #444; line-height: 1.6; flex-grow: 1; }
.srd-listing-terms { margin-top: 15px; padding-top: 15px; border-top: 1px solid #f0f0f0; }
.srd-term-list { margin-bottom: 8px; }
.srd-term-list strong { margin-right: 5px; }
.srd-term-badge { display: inline-block; font-size: 0.8em; padding: 3px 7px; border-radius: 3px; background-color: #e9e9e9; color: #555; margin-right: 5px; margin-bottom: 5px; }
.srd-listing-footer { padding: 20px; margin-top: auto; }
.srd-listing-button { display: block; width: 100%; text-align: center; padding: 12px; background-color: #34495e; color: #fff; text-decoration: none; border-radius: 4px; font-weight: bold; transition: background-color 0.2s ease; margin-bottom: 10px; }
.srd-listing-button:hover { background-color: #2c3e50; color: #fff; }
.srd-no-results { background: #fff; border: 1px solid #e0e0e0; padding: 30px; text-align: center; }
.srd-star-rating { color: #f0ad4e; display: inline-flex; align-items: center; gap: 5px; }
.srd-star-rating .dashicons { font-size: 20px; height: 20px; width: 20px; }
.srd-rating-count { color: #555; font-size: 0.9em; margin-left: 5px; }
.srd-unrated-text { color: #999; font-size: 0.9em; font-style: italic; }
.srd-direct-rating-wrap { margin-top: 15px; text-align: center; }
.srd-user-rating-stars { display: flex; justify-content: center; align-items: center; gap: 2px; margin-top: 5px; }
.srd-user-rating-stars .dashicons { cursor: pointer; color: #ccc; transition: color 0.2s; }
.srd-user-rating-stars:hover .dashicons { color: #f0ad4e; }
.srd-user-rating-stars .dashicons:hover ~ .dashicons { color: #ccc; }
.srd-user-rating-stars.srd-rated .dashicons { cursor: default; }
.srd-user-rating-label { font-size: 0.9em; color: #777; margin-right: 10px; }
.srd-listing-actions { margin-top: 15px; display: flex; gap: 10px; align-items: center; justify-content: center; }
.srd-favorite-button { background: #f0f0f0; color: #000 !important; border: 1px solid #ddd; padding: 5px 10px; border-radius: 3px; cursor: pointer; text-decoration: none; font-size: 0.9em; font-weight: bold; transition: all 0.2s ease; }
.srd-favorite-button:hover { background: #e0e0e0; border-color: #ccc; color: #000 !important; }
.srd-favorite-button.srd-is-favorite { background: #ffd4d4; border-color: #f0ad4e; color: #c0392b !important; }
.srd-favorite-button.srd-is-favorite::before { content: "\f155"; font-family: "dashicons"; margin-right: 5px; }
.srd-favorite-button.srd-loading { cursor: wait; }
