/* Basic grid for playlists */
.jwplayer-playlists { max-width: 1100px; margin: 0 auto; }
.jwplayer-playlists-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 16px; }
.jwplaylist-card { background: #fff; border: 1px solid #e5e7eb; border-radius: 8px; overflow: hidden; cursor: pointer; transition: box-shadow .2s ease, transform .05s ease; }
.jwplaylist-card:hover { box-shadow: 0 8px 24px rgba(0,0,0,.08); transform: translateY(-1px); }
.jwplaylist-thumb { aspect-ratio: 16/9; background: #f3f4f6; display: flex; align-items: center; justify-content: center; }
.jwplaylist-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.jwplaylist-thumb-placeholder { width: 100%; height: 100%; background: repeating-linear-gradient(45deg,#f3f4f6,#f3f4f6 10px,#e5e7eb 10px,#e5e7eb 20px); }
.jwplaylist-info { padding: 10px 12px; }
.jwplaylist-title { font-weight: 600; line-height: 1.3; margin-bottom: 4px; }
.jwplaylist-count { color: #6b7280; font-size: 13px; }

/* Playlist view */
.jwplaylist-view { margin-top: 20px; }
.jwplaylist-view-header { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.jwplaylist-back { background: #f3f4f6; border: 1px solid #d1d5db; border-radius: 6px; padding: 6px 10px; cursor: pointer; }
.jwplaylist-view-title { font-size: 18px; font-weight: 600; }
.jwplaylist-player { width: 100%; aspect-ratio: 16/9; background: #000; border-radius: 8px; overflow: hidden; }
.jwplaylist-iframe { width: 100%; height: 100%; display: block; }

.jwplaylist-items { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; margin-top: 16px; }
.jwplaylist-item { display: flex; flex-direction: column; gap: 6px; border: 1px solid #e5e7eb; border-radius: 8px; overflow: hidden; background: #fff; cursor: pointer; transition: box-shadow .2s ease; }
.jwplaylist-item:hover { box-shadow: 0 8px 24px rgba(0,0,0,.06); }
.jwplaylist-item-thumb { aspect-ratio: 16/9; background: #f3f4f6; display:flex; align-items:center; justify-content:center; color:#6b7280; font-size:13px; }
.jwplaylist-item-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.jwplaylist-item-title { padding: 8px 10px; font-size: 14px; font-weight: 500; line-height: 1.3; }
/* Tag badges */
.jwplaylist-item-tags { padding: 0 10px 10px 10px; display:flex; flex-wrap:wrap; gap:6px; }
.jw-tag { display:inline-block; padding:3px 8px; border-radius:999px; background:#eef2ff; color:#3730a3; font-size:12px; line-height:1; border:1px solid #e5e7eb; cursor:pointer; }
.jw-tag:hover { background:#e0e7ff; color:#312e81; }

/* Utility */
.jwplayer-playlists-meta { margin-top: 12px; color: #6b7280; font-size: 13px; }
.jwplayer-playlists-empty, .jwplayer-playlists-error { padding: 16px; background: #fff7ed; border: 1px solid #fed7aa; border-radius: 8px; }

/* Search results (videos) */
.jwplaylists-results { margin-top: 16px; }
.jwplaylists-results-title { margin: 0 0 8px 0; font-size: 16px; font-weight: 600; }
.jwplaylists-video-results-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; }
.jwplaylists-video-result { display: flex; flex-direction: column; gap: 6px; border: 1px solid #e5e7eb; border-radius: 8px; overflow: hidden; background: #fff; cursor: pointer; transition: box-shadow .2s ease; }
.jwplaylists-video-result:hover { box-shadow: 0 8px 24px rgba(0,0,0,.06); }
.jwplaylist-item-tags { padding: 0 10px 8px 10px; color:#6b7280; font-size:12px; }
.jwplaylists-video-result .jwplaylist-item-title { padding: 8px 10px; font-size: 14px; font-weight: 600; line-height: 1.3; display:block; }
.jwplaylists-video-result .jwplaylist-item-title { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.jwplaylists-video-result .jwplaylist-item-tags { padding: 0 10px 8px 10px; display:flex; flex-wrap:wrap; gap:6px; }

/* Results page layout */
.jwsearch-results { max-width: 1200px; margin: 0 auto; }
.jwsearch-form { display:flex; gap:10px; margin-bottom:14px; }
.jwsearch-input { flex:1; padding:10px 12px; border:1px solid #e5e7eb; border-radius:8px; }
.jwsearch-btn { background:#f3b600; color:#111827; border:none; border-radius:8px; padding:10px 14px; font-weight:700; cursor:pointer; }
.jwsearch-meta { color:#6b7280; font-size:13px; margin-bottom:10px; }

.jwsearch-grid .jwsearch-grid-wrap { display:grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap:16px; }
.jwsearch-card { display:flex; flex-direction:column; background:#fff; border:1px solid #e5e7eb; border-radius:8px; overflow:hidden; cursor:pointer; transition: box-shadow .2s ease, transform .05s ease; }
.jwsearch-card:hover { box-shadow:0 8px 24px rgba(0,0,0,.08); transform: translateY(-1px); }
.jwsearch-card-thumb { position:relative; aspect-ratio:16/9; background:#f3f4f6; flex:0 0 auto; }
.jwsearch-card-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.jwsearch-card-title-overlay { position:absolute; left:0; right:0; bottom:0; padding:8px 10px; color:#fff; font-weight:700; font-size:13px; text-shadow:0 1px 2px rgba(0,0,0,.5); background:linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.55) 100%); display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.jwsearch-card-title { display:block !important; padding:10px 12px !important; margin:0 !important; font-weight:600 !important; line-height:1.3 !important; color:#111827 !important; background:#fff !important; flex:0 0 auto; }
.jwsearch-card-title { display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; min-height:2.6em; }

/* Modal player */
.jwsearch-modal { position:fixed; inset:0; z-index:9999; display:none; }
.jwsearch-modal-backdrop { position:absolute; inset:0; background:rgba(0,0,0,.6); }
.jwsearch-modal-dialog { position:relative; width:min(1000px, 92vw); margin:5vh auto; background:#000; border-radius:10px; overflow:hidden; box-shadow:0 20px 40px rgba(0,0,0,.3); }
.jwsearch-modal-close { position:absolute; top:8px; right:10px; z-index:2; background:#fff; border:none; border-radius:999px; width:32px; height:32px; font-size:18px; line-height:32px; text-align:center; cursor:pointer; }
.jwsearch-modal-player { width:100%; aspect-ratio:16/9; }
.jwsearch-iframe { width:100%; height:100%; display:block; }
.jwsearch-modal-open { overflow:hidden; }
