.plm-directorio-wrap { max-width: 1200px; margin: 40px auto; font-family: 'Inter', sans-serif; padding: 0 20px; }
.plm-directorio-titulo { font-size: 30px; font-weight: 800; text-align: center; color: #18181b; margin-bottom: 10px; letter-spacing: -0.02em; }
.plm-directorio-sub { text-align: center; color: #71717a; font-size: 16px; margin-bottom: 30px; }

.plm-search-container { max-width: 600px; margin: 0 auto 30px; position: relative; z-index: 9999; }
.plm-search-input { -webkit-appearance: none !important; appearance: none !important; width: 100% !important; height: 56px !important; min-height: 56px !important; padding: 0 25px 0 55px !important; font-size: 16px !important; border: 2px solid #e4e4e7 !important; border-radius: 14px !important; font-family: 'Inter', sans-serif !important; box-sizing: border-box !important; transition: all 0.2s ease !important; background: #fff !important; color: #18181b !important; outline: none !important; box-shadow: 0 4px 15px rgba(0,0,0,0.03) !important; margin: 0 !important; display: block !important; }
.plm-search-input:focus { border-color: #10b981 !important; box-shadow: 0 4px 20px rgba(16, 185, 129, 0.15) !important; }
.plm-search-icon { display: block !important; position: absolute; left: 20px; top: 50%; transform: translateY(-50%); color: #a1a1aa; pointer-events: none; z-index: 3; }

.plm-suggestions-list { position: absolute; top: calc(100% + 8px); left: 0; right: 0; background: #fff; border: 1px solid #e4e4e7; border-radius: 14px; box-shadow: 0 10px 30px rgba(0,0,0,0.08); list-style: none; padding: 8px 0; margin: 0; display: none; max-height: 250px; overflow-y: auto; z-index: 1000; text-align: left; }
.plm-suggestion-item { padding: 12px 25px; font-size: 15px; color: #3f3f46; cursor: pointer; transition: background 0.2s; border-bottom: 1px solid #f4f4f5; }
.plm-suggestion-item:last-child { border-bottom: none; }
.plm-suggestion-item:hover { background: #f0fdf4; color: #059669; font-weight: 600; }

.plm-grid-locales { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 25px; position: relative; z-index: 1; }
.plm-card-local { background: #fff; border: 1px solid #e4e4e7; border-radius: 16px; overflow: hidden; text-align: center; transition: transform 0.2s, box-shadow 0.2s; display: flex; flex-direction: column; text-decoration: none; color: inherit; }
.plm-card-local:hover { transform: translateY(-5px); box-shadow: 0 10px 25px rgba(0,0,0,0.05); }
.plm-card-cover { height: 80px; background: linear-gradient(135deg, #10b981 0%, #059669 100%); }
.plm-card-logo { width: 80px; height: 80px; border-radius: 50%; object-fit: cover; border: 4px solid #fff; margin: -40px auto 10px; background: #fff; box-shadow: 0 2px 8px rgba(0,0,0,0.1); }
.plm-card-info { padding: 0 20px 20px; flex-grow: 1; display: flex; flex-direction: column; }
.plm-card-nombre { font-size: 20px; font-weight: 800; color: #18181b; margin: 0 0 8px; }
.plm-card-desc { font-size: 14px; color: #71717a; line-height: 1.5; margin-bottom: 20px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.plm-card-btn { margin-top: auto; display: block; background: #18181b; color: #fff; padding: 12px; border-radius: 8px; font-weight: 600; font-size: 14px; text-decoration: none; transition: 0.2s; }
.plm-card-local:hover .plm-card-btn { background: #10b981; }

.plm-no-results { display: none; grid-column: 1 / -1; text-align: center; padding: 40px; background: #f4f4f5; border-radius: 16px; color: #71717a; font-weight: 600; }

@media (max-width: 768px) {
    .plm-directorio-wrap { margin: 20px auto; padding: 0 15px; }
    .plm-directorio-titulo { font-size: 22px; }
    .plm-grid-locales { grid-template-columns: 1fr; gap: 14px; }
    .plm-search-container { padding: 0 !important; }
    .plm-search-icon { left: 16px !important; width: 18px !important; }
    .plm-search-input { padding-left: 44px !important; }
}